# TMS320C54x Chip Support Library API Reference Guide

SPRU420D May 2003







#### 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 that third party, or a license from TI under the patents or other intellectual property of TI.

Reproduction of 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.

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 any 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.

Mailing Address:

Texas Instruments Post Office Box 655303 Dallas, Texas 75265

# **Preface**

# **Read This First**

#### About This Manual

The TMS320C54x<sup>™</sup> DSP Chip Support Library (CSL) provides C-program functions to configure and control on-chip peripherals, which makes it easier for algorithms to run in a real system. The CSL provides peripheral ease of use, shortened development time, portability, and hardware abstraction, along with some level of standardization and compatibility among devices. A version of the CSL is available for all TMS320C54x<sup>™</sup> DSP devices.

The contents of the TMS320C5000™ DSP Chip Support Library (CSL) are as

#### How to Use This Manual

| foll | follows:                                                                                                                                                                                                                                                           |  |  |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|      | Chapter 1, <i>CSL Overview</i> , provides an overview of the CSL, includes tables showing CSL module support for various C5000 devices, and lists the CSL modules.                                                                                                 |  |  |
|      | Chapter 2, $How\ To\ Use\ CSL$ , provides basic examples of how to use CSL functions with or without using the DSP/BIOS <sup>TM</sup> Configuration Tool, and shows how to define Build options for the CSL in the Code Composer Studio <sup>TM</sup> environment. |  |  |
|      | Chapters 3-16 provide basic examples, functions, macros, and CSL GUI configurations for the individual CSL modules.                                                                                                                                                |  |  |
|      | Appendix A provides examples of how to use CSL C5000 Registers.                                                                                                                                                                                                    |  |  |

# **Notational Conventions**

| Ihi | s document uses the following conventions:                                                                                                                                                                                                                                                                                    |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | Program listings, program examples, and interactive displays are shown in a special typeface.                                                                                                                                                                                                                                 |
|     | In syntax descriptions, the function or macro appears in a <b>bold typeface</b> and the parameters appear in plainface within parentheses. Portions of a syntax that are in <b>bold</b> should be entered as shown; portions of a syntax that are within parentheses describe the type of information that should be entered. |
|     | Macro names are written in uppercase text; function names are written in lowercase.                                                                                                                                                                                                                                           |
|     | TMS320C54x <sup>™</sup> DSP devices are referred to throughout this reference guide as C5401, C5402, etc.                                                                                                                                                                                                                     |

#### Related Documentation From Texas Instruments

The following books describe the TMS320C54x<sup>™</sup> DSP and related support tools. To obtain a copy of any of these TI documents, call the Texas Instruments Literature Response Center at (800) 477-8924. When ordering, please identify the book by its title and literature number. Many of these documents are located on the internet at http://www.ti.com.

- TMS320C54x Assembly Language Tools User's Guide (literature number SPRU102) describes the assembly language tools (assembler, linker, and other tools used to develop assembly language code), assembler directives, macros, common object file format, and symbolic debugging directives for the C54x generation of devices.
- TMS320C54x Optimizing C Compiler User's Guide (literature number SPRU103) describes the C54x C compiler. This C compiler accepts ANSI standard C source code and produces TMS320 assembly language source code for the C54x generation of devices.
- TMS320C54x Simulator Getting Started (literature number SPRU137) describes how to install the TMS320C54x simulator and the C source debugger for the C54x. The installation for MS-DOS™, PC-DOS™, SunOS™, Solaris™, and HP-UX™ systems is covered.
- **TMS320C54x Evaluation Module Technical Reference** (literature number SPRU135) describes the C54x evaluation module, its features, design details and external interfaces.
- **TMS320C54x** Simulator Getting Started Guide (literature number SPRU137) describes how to install the TMS320C54x simulator and the C source debugger for the C54x. The installation for Windows 3.1, SunOS™, and HP-UX™ systems is covered.
- TMS320C54x Code Generation Tools Getting Started Guide (literature number SPRU147) describes how to install the TMS320C54x assembly language tools and the C compiler for the C54x devices. The installation for MS-DOS™, OS/2™, SunOS™, Solaris™, and HP-UX™ 9.0x systems is covered.
- TMS320C54x Simulator Addendum (literature number SPRU170) tells you how to define and use a memory map to simulate ports for the C54x. This addendum to the TMS320C5xx C Source Debugger User's Guide discusses standard serial ports, buffered serial ports, and time division multiplexed (TDM) serial ports.

### **Trademarks**

The Texas Instruments logo and Texas Instruments are registered trademarks of Texas Instruments. Trademarks of Texas Instruments include: TI, Code Composer, DSP/BIOS, and TMS320C5000.

All other brand or product names are trademarks or registered trademarks of their respective companies or organizations.

# **Contents**

| 1 | CSL  | Overview                                                                              | . 1-1 |
|---|------|---------------------------------------------------------------------------------------|-------|
|   | Over | view of the features and architecture of the Chip Support Library.                    |       |
|   | 1.1  | Introduction to the CSL                                                               | . 1-2 |
|   |      | 1.1.1 Benefits of the CSL                                                             |       |
|   |      | 1.1.2 CSL Architecture                                                                | . 1-2 |
|   | 1.2  | Naming Conventions                                                                    | . 1-6 |
|   | 1.3  | Data Types                                                                            |       |
|   | 1.4  | Functions                                                                             | . 1-8 |
|   |      | 1.4.1 Peripheral Initialization via Registers                                         | 1-10  |
|   | 1.5  | Macros                                                                                |       |
|   | 1.6  | Symbolic Constant Values                                                              | 1-14  |
|   | 1.7  | Resource Management and the Use of CSL Handles                                        | 1-15  |
|   |      | 1.7.1 Using CSL Handles                                                               |       |
|   | 1.8  | Support for Device-Specific Features                                                  |       |
| 2 | How  | To Use CSL                                                                            | . 2-1 |
|   | This | chapter explains the features of the CSL GUI. Instructions and examples are included. |       |
|   | 2.1  | Overview                                                                              | . 2-2 |
|   | 2.2  | Using CSL with the CSL GUI                                                            | . 2-3 |
|   |      | 2.2.1 CSL GUI: The CSL Tree                                                           |       |
|   |      | 2.2.2 Steps to configuring a peripheral using CSL GUI                                 | . 2-7 |
|   |      | 2.2.3 TIMER Configuration Example                                                     |       |
|   |      | 2.2.4 Files Generated by the CSL GUI                                                  |       |
|   |      | 2.2.5 Modifying Your Application Code (main.c)                                        |       |
|   | 2.3  | Using CSL without the CSL GUI                                                         |       |
|   |      | 2.3.1 Using the DMA_config() function                                                 |       |
|   |      | 2.3.2 Compiling and Linking With CSL using Code Composer Studio (CCStudio)            |       |
|   | 2.4  | Rebuilding CSL                                                                        |       |
| 3 | CHIP | Module                                                                                | . 3-1 |
|   | _    | eral description of the CSL CHIP module, its functions, and macros.                   |       |
|   | 3.1  | Overview                                                                              | . 3-2 |
|   | 3.2  | Functions                                                                             |       |

| 4 |                          | Modulesection include API functions for the DAA module.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 4-1                                          |
|---|--------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|
|   | 4.1<br>4.2<br>4.3<br>4.4 | Overview 4.1.1 Configuration Structures 4.1.2 Functions 4.1.3 Macros Configuration Structures Functions Macros                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 4-2<br>4-3<br>4-3<br>4-4<br>4-7              |
| 5 |                          | Module eral description of the DAT module and its functions.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                              |
|   | 5.1<br>5.2               | Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                              |
| 6 |                          | Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 6-1                                          |
|   | 6.1<br>6.2<br>6.3        | Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 6-4<br>6-7<br>6-7                            |
|   | 6.4<br>6.5               | 6.3.2 DMA Global Register Function 6.3.3 DMA Auxiliary Functions 6.3.3 DMA Auxiliary Functions 6.3.3 DMA Auxiliary Functions 6.5.1 DMA Module Using CSL GUI 6.5.1 DMA Configuration Manager 6.5.2 DMA Resource Manager 6.5.3 C Code Generation for DMA Module 6.5.3 C Code Generation for DMA Module 6.5.4 DMA Module 6.5.5 C Code Generation for DMA Module 6.5 C C C C C C C C C C C C C C C C C C C | 6-18<br>6-20<br>6-32<br>6-32<br>6-35<br>6-37 |
| 7 |                          | S Moduleures and description of the external bus interface (EBUS) module.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 7-1                                          |
|   | 7.1<br>7.2<br>7.3<br>7.4 | Overview                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 7-3<br>7-4                                   |
| 8 |                          | Moduleeral description of the GPIO module and its macros.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 8-1                                          |
|   | 8.1<br>8.2<br>8.3<br>8.4 | Overview Functions Macros Configuring the GPIO Module Using CSL GUI 8.4.1 Non-Multiplexed GPIO Configuration Manager                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 8-3<br>8-5<br>8-7<br>8-7                     |
|   |                          | 8.4.2 C Code Generation for GPIO Module                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 8-8                                          |

| 9  |                  | lodule                                                                                        | 9-1  |
|----|------------------|-----------------------------------------------------------------------------------------------|------|
|    | Desci            | riptions for macros available in the HPI module.                                              |      |
|    | 9.1              | Macros                                                                                        | 9-2  |
| 10 |                  | Module                                                                                        |      |
|    | Overv<br>interru | view of the IRQ module, including the configuration structure, functions, and examples oupts. | f    |
|    | 10.1             | Overview                                                                                      |      |
|    | 10.2             | Using Interrupts with CSL                                                                     |      |
|    | 10.3             | Configuration Structure                                                                       |      |
|    | 10.4             | Functions                                                                                     | 10-9 |
| 11 |                  | SP Module                                                                                     |      |
|    |                  | ral description of the McBSP Module, its configuration structure, functions and macros        |      |
|    | 11.1             | Overview                                                                                      |      |
|    | 11.2             | 3                                                                                             | 11-4 |
|    | 11.3             | Functions                                                                                     |      |
|    | 11.4             | Macros                                                                                        |      |
|    | 11.5             | Configuring the McBSP Module Using CSL GUI                                                    |      |
|    |                  | 11.5.1 Overview         1           11.5.2 McBSP Configuration Manager         1              |      |
|    |                  | 11.5.3 McBSP Resource Manager                                                                 |      |
|    |                  | 11.5.4 C Code Generation for McBSP Module                                                     |      |
|    | 11.6             | Examples                                                                                      |      |
| 12 | DIIN             | Module                                                                                        | 12_1 |
| 12 |                  | ribes the structure, functions, and macros of the PLL module.                                 | 12-1 |
|    | 12.1             | Overview                                                                                      | 12-2 |
|    | 12.2             | Configuration Structure                                                                       | 12-3 |
|    | 12.3             | Functions                                                                                     | 12-4 |
|    | 12.4             | Macros                                                                                        |      |
|    | 12.5             | Configuring the PLL Module Using CSL GUI                                                      |      |
|    |                  |                                                                                               | 12-8 |
|    |                  | 12.5.2 PLL Configuration Manager                                                              |      |
|    |                  | 12.5.3 PLL Resource Manager                                                                   |      |
|    |                  | 12.5.4 C Code Generation for PLL Module                                                       | 2-11 |
| 13 |                  | Module                                                                                        | 13-1 |
|    | Gene             | ral description of the PWR module and its functions.                                          |      |
|    | 13.1             | Overview                                                                                      |      |
|    | 13.2             | Functions                                                                                     | 13-3 |

| 14  | TIME  | R Module                                                                                                                  | 14-1  |
|-----|-------|---------------------------------------------------------------------------------------------------------------------------|-------|
|     | Gene  | eral description of the structure and functions for the TIMER module.                                                     |       |
|     | 14.1  | Overview                                                                                                                  | 14-2  |
|     | 14.2  | Configuration Structure                                                                                                   | 14-3  |
|     | 14.3  | Functions                                                                                                                 | 14-4  |
|     | 14.4  | Macros                                                                                                                    |       |
|     | 14.5  | Configuring the TIMER Module Using CSL GUI                                                                                |       |
|     |       | 14.5.1 Overview                                                                                                           |       |
|     |       | 14.5.2 TIMER Configuration Manager                                                                                        |       |
|     |       | 14.5.3 TIMER Resource Manager                                                                                             |       |
|     |       | 14.5.4 C Code Generation for TIMER                                                                                        |       |
| 4 5 | LIADI | Г Module                                                                                                                  |       |
| 15  |       |                                                                                                                           |       |
|     |       | chapter describes the UART module, lists the API structure, functions, macros, an<br>tions for configuring using CSL GUI. | a in- |
|     | 15.1  | Overview                                                                                                                  | 15-2  |
|     | 15.2  | Configuration Structures                                                                                                  | 15-5  |
|     | 15.3  | Functions                                                                                                                 | 15-8  |
|     |       | 15.3.1 CSL Primary Functions                                                                                              | 15-8  |
|     | 15.4  | Macros                                                                                                                    | 15-15 |
|     |       | 15.4.1 General Macros                                                                                                     | 15-15 |
|     |       | 15.4.2 UART Control Signal Macros                                                                                         | 15-16 |
|     | 15.5  | Configuring the UART Module Using CSL GUI                                                                                 | 15-21 |
|     |       | 15.5.1 UART Configuration Manager                                                                                         | 15-21 |
|     |       | 15.5.2 UART Resource Manager                                                                                              | 15-23 |
|     |       | 15.5.3 C Code Generation for UART Module                                                                                  | 15-24 |
| 16  | WDTI  | IM Module                                                                                                                 | 16-1  |
|     |       | eral description of the WDTIM module, its configuration structure, functions, and ma                                      |       |
|     | 16.1  | Overview                                                                                                                  | 16-2  |
|     | 16.2  | Configuration Structure                                                                                                   | 16-3  |
|     | 16.3  | Functions                                                                                                                 | 16-4  |
|     | 16.4  | Macros                                                                                                                    | 16-6  |
|     | 16.5  | Configuring the WATCHDOG TIMER Module Using CSL GUI                                                                       | 16-8  |
|     |       | 16.5.1 Overview                                                                                                           | 16-8  |
|     |       | 16.5.2 WATCHDOG TIMER Configuration Manager                                                                               | 16-8  |
|     |       | 16.5.3 WATCHDOG TIMER Resource Manager                                                                                    | 16-10 |
|     |       | 16.5.4 C Code Generation for WATCHDOG TIMER                                                                               |       |

| 4 | Perip | heral Re | egisters                                                            | A-1  |
|---|-------|----------|---------------------------------------------------------------------|------|
|   | Provi | des sym  | bolic constants for the peripheral registers.                       |      |
|   | A.1   | DMA R    | legisters                                                           | A-2  |
|   |       | A.1.1    | DMA Channel Priority and Enable Control Register (DMPREC)           | A-2  |
|   |       | A.1.2    | DMA Channel n Sync Select and Frame Count Register (DMSFCn) .       | A-3  |
|   |       | A.1.3    | DMA Channel n Transfer Mode Control Register (DMMCRn)               | A-6  |
|   |       | A.1.4    | DMA Channel n Source Address Register (DMSRCn)                      | A-9  |
|   |       | A.1.5    | DMA Global Source Address Reload Register (DMGSA)                   | A-9  |
|   |       | A.1.6    | DMA Source Program Page Address Register (DMSRCP)                   | A-9  |
|   |       | A.1.7    | DMA Channel n Destination Address Register (DMDSTn)                 | A-10 |
|   |       | A.1.8    | DMA Global Destination Address Reload Register (DMGDA)              | A-10 |
|   |       | A.1.9    | DMA Destination Program Page Address Register (DMDSTP)              | A-11 |
|   |       | A.1.10   | DMA Channel n Element Count Register (DMCTRn)                       | A-11 |
|   |       | A.1.11   | DMA Global Element Count Reload Register (DMGCR)                    | A-12 |
|   |       | A.1.12   | DMA Global Frame Count Reload Register (DMGFR)                      | A-12 |
|   |       | A.1.13   | DMA Element Address Index Register 0 (DMIDX0)                       | A-13 |
|   |       | A.1.14   | DMA Element Address Index Register 1 (DMIDX1)                       | A-13 |
|   |       | A.1.15   | DMA Frame Address Index Register 0 (DMFRI0)                         | A-14 |
|   |       | A.1.16   | DMA Frame Address Index Register 1 (DMFRI1)                         | A-14 |
|   |       |          | DMA Global Extended Source Data Page Register (DMSRCDP)             |      |
|   |       | A.1.18   | DMA Global Extended Destination Data Page Register (DMDSTDP)        | A-15 |
|   | A.2   | EBUS I   | Registers                                                           |      |
|   |       | A.2.1    | Software Wait-State Register (SWWSR)                                | A-16 |
|   |       | A.2.2    | Software Wait-State Control Register (SWCR)                         | A-17 |
|   |       | A.2.3    | Bank-Switching Control Register (BSCR)                              | A-17 |
|   | A.3   | GPIO F   | Registers (C5440 and C5441)                                         |      |
|   |       | A.3.1    | General Purpose I/O Register (GPIO)                                 | A-22 |
|   | A.4   | HPI Re   | gisters                                                             | A-24 |
|   |       | A.4.1    | General Purpose I/O Control Register (GPIOCR)                       | A-24 |
|   |       | A.4.2    | General Purpose I/O Status Register (GPIOSR)                        | A-25 |
|   |       | A.4.3    | HPI Control Register (HPIC) (for 5401, 5402, 5409, and 5410 only) . | A-25 |
|   | A.5   | Multich  | annel BSP (McBSP) Registers                                         | A-26 |
|   |       | A.5.1    | McBSP Serial Port Control Register (SPCR1)                          |      |
|   |       | A.5.2    | McBSP Serial Port Control Register 2 (SPCR2)                        | A-28 |
|   |       | A.5.3    | McBSP Pin Control Register (PCR)                                    | A-30 |
|   |       | A.5.4    | Receive Control Register 1 (RCR1)                                   | A-33 |
|   |       | A.5.5    | Receive Control Register 2 (RCR2)                                   | A-34 |
|   |       | A.5.6    | Transmit Control Register 1 (XCR1)                                  | A-35 |
|   |       | A.5.7    | Transmit Control Register 2 (XCR2)                                  |      |
|   |       | A.5.8    | Sample Rate Generator Register 1 (SRGR1)                            | A-38 |
|   |       | A.5.9    | Sample Rate Generator Register 2 (SRGR2)                            | A-38 |
|   |       | A.5.10   | Multichannel Control Register 1 (MCR1)                              | A-40 |
|   |       | A.5.11   | Multichannel Control Register 2 (MCR2)                              | A-41 |

|     | A.5.12 | Receive Channel Enable Register (RCERn) A-43       |
|-----|--------|----------------------------------------------------|
|     | A.5.13 | Transmit Channel Enable Register (XCERn) A-45      |
| A.6 | PLL R  | egisters (CLKMD) A-47                              |
| A.7 | Timer  | Registers A-49                                     |
|     | A.7.1  | Timer Control Register (TCR) A-49                  |
|     | A.7.2  | Timer Secondary Control Register (TSCR) A-51       |
|     | A.7.3  | Timer Period Register (PRD)                        |
| A.8 | Watch  | dog Timer Registers (C5441) A-52                   |
|     | A.8.1  | Watchdog Timer Control Register (WDTCR) A-52       |
|     | A.8.2  | Watchdog Timer Secondary Control Register (WDTSCR) |
|     | A.8.3  | Watchdog Timer Period Register (WDPRD) A-55        |

# **Figures**

| 1–1  | API Modules                                                          | 1-3   |
|------|----------------------------------------------------------------------|-------|
| 2–1  | CSL Tree (for 5402)                                                  | 2-3   |
| 2–2  | Expanded CSL Tree (for C5402)                                        | 2-4   |
| 2–3  | Insert Configuration Object                                          |       |
| 2–4  | Delete/Rename Options                                                |       |
| 2–5  | Show Dependency Option                                               | 2-6   |
| 2–6  | Code Composer Studio IDE Project Window                              |       |
| 2–7  | Code Composer Studio IDE Project Window with .cdb Project File Added |       |
| 2–8  | CCStudio IDE Project View                                            |       |
| 2–9  | Configuring the TIMER1 Device                                        | 2-10  |
| 2–10 | Header File mytimercfg.h                                             |       |
| 2–11 | Resource Manager Properties Page                                     | 2-14  |
| 2–12 | Source File mytimercfg_c.c                                           | 2-15  |
| 2–13 | Example of main.c File Using Data Generated by the CSL GUI           | 2-16  |
| 2–14 | Defining the Target Device in the Build Options Dialog               | 2-21  |
| 2–15 | Defining Far Mode                                                    | 2-22  |
| 2–16 | Defining Large Memory Model                                          | 2-23  |
| 2–17 | Defining Library Paths                                               | 2-24  |
| 6–1  | DMA Sections Menu                                                    | 6-32  |
| 6–2  | DMA Properties Page                                                  | 6-34  |
| 6–3  | DMA Resource Manager Menu                                            |       |
| 6–4  | DMA Properties Page With Handle Object Accessible                    | 6-36  |
| 6–5  | DMA Channel Initialization Using DMA_config()                        | 6-41  |
| 8–1  | GPIO Sections Menu                                                   | 8-7   |
| 8–2  | GPIO Properties Page                                                 | 8-7   |
| 11–1 | McBSP Sections Menu                                                  | 11-42 |
| 11–2 | McBSP Properties Page                                                | 11-45 |
| 11–3 | McBSP Resource Manager Menu                                          | 11-46 |
| 11–4 | McBSP Properties Page With Handle Object Accessible                  | 11-47 |
| 12–1 | PLL Sections Menu                                                    | 12-8  |
| 12–2 | PLL Properties Page                                                  | 12-9  |
| 12–3 | PLL Resource Manager Menu                                            | 12-10 |
| 12–4 | PLL Properties Page                                                  | 12-11 |
| 14–1 | Timer Sections Menu                                                  | 14-12 |
| 14–2 | TIMER Properties Page                                                | 14-14 |
| 14–3 | Timer Resource Manager Menu                                          |       |
| 14–4 | Timer Properties Page With Handle Object Accessible                  | 14-15 |

| 15–1 | UART Sections Menu                                                             | 15-21 |
|------|--------------------------------------------------------------------------------|-------|
| 15–2 | UART Properties Page                                                           |       |
| 15–3 | UART Resource Manager Menu                                                     |       |
| 15–4 | UART Resource Manager Properties Page                                          |       |
| 16–1 | WATCHDOG TIMER Sections Menu                                                   |       |
| 16–2 | WATCHDOG TIMER Properties Page                                                 |       |
| 16–3 | WATCHDOG TIMER Resource Manager Menu                                           |       |
| 16–4 | WATCHDOG TIMER Properties Page                                                 |       |
| A–1  | DMA Channel Priority and Enable Control Register (DMPREC)                      |       |
| A–2  | DMA Channel n Sync Select and Frame Count Register (DMSFCn)                    |       |
| A-3  | DMA Channel n Transfer Mode Control Register (DMMCRn)                          |       |
| A–4  | DMA Channel n Source Address Register (DMSRCn)                                 |       |
| A–5  | DMA Global Source Address Reload Register (DMGSA)                              |       |
| A–6  | DMA Source Program Page Address Register (DMSRCP)                              |       |
| A–7  | DMA Channel n Destination Address Register (DMDSTn)                            |       |
| A–8  | DMA Global Destination Address Reload Register (DMGDA)                         |       |
| A-9  | DMA Destination Program Page Address Register (DMDSTP)                         |       |
| A-10 | DMA Channel n Element Count Register (DMCTRn)                                  |       |
| A-11 | DMA Global Element Count Reload Register (DMGCR)                               |       |
| A-12 | DMA Global Frame Count Reload Register (DMGFR)                                 |       |
| A-13 | DMA Element Address Index Register 0 (DMIDX0)                                  |       |
| A-14 | DMA Element Address Index Register 1 (DMIDX1)                                  | A-13  |
| A-15 | DMA Frame Address Index Register 0 (DMFRI0)                                    | A-14  |
| A-16 | DMA Frame Address Index Register 1 (DMFRI1)                                    | A-14  |
| A-17 | DMA Global Extended Source Data Page Register (DMSRCDP)                        | A-15  |
| A–18 | DMA Global Extended Destination Data Page Register (DMDSTDP)                   | A-15  |
| A-19 | Software Wait-State Register(SWWSR)-All devices except C5440 and C5441         | A-16  |
| A-20 | Software Wait-State Control Register (SWCR)-All devices except C5440 and C5441 | Δ-17  |
| A-21 | Bank-Switching Control Register (BSCR) — C5401, C5402, C5409, C5420,           | /\ 1/ |
|      | C5421, and 5471                                                                | A-17  |
| A-22 | Bank-Switching Control Register (BSCR) — C5410, C5410A, and C5416              | A-19  |
| A-23 | Bank-Switching Control Register (BSCR) — C5440 and C5441                       | A-21  |
| A-24 | General Purpose I/O Register (GPIO)                                            | A-22  |
| A-25 | General Purpose I/O Control Register (GPIOCR)                                  | A-24  |
| A-26 | General Purpose Status Register (GPIOSR)                                       | A-25  |
| A-27 | HPI Control Register (HPIC) (for 5410)                                         |       |
| A-28 | McBSP Serial Port Control Register 1 (SPCR1)                                   |       |
| A-29 | McBSP Serial Port Control Register 2 (SPCR2)                                   |       |
| A-30 | McBSP Pin Control Register (PCR)                                               |       |
| A-31 | Receive Control Register 1 (RCR1)                                              |       |
| A-32 | Receive Control Register 2 (RCR2)                                              |       |
| A–33 | Transmit Control Register 1 (XCR1)                                             |       |
| A-34 | Transmit Control Register 2 (XCR2)                                             | A-36  |

| A-35 | Sample Rate Generator Register 1 (SRGR1)                          | A-38 |
|------|-------------------------------------------------------------------|------|
| A-36 | Sample Rate Generator Register 2 (SRGR2)                          | A-38 |
| A-37 | Multichannel Control Register 1 (MCR1)                            | A-40 |
| A-38 | Multichannel Control Register 2 (MCR2)                            | A-41 |
| A-39 | Receive Channel Enable Register (RCERn)                           | A-43 |
| A-40 | Transmit Channel Enable Register (XCERn)                          | A-45 |
| A-41 | Clock Mode Register (CLKMD)                                       | A-47 |
| A-42 | Timer Control Register (TCR)                                      | A-49 |
| A-43 | Timer Secondary Control Register (TSCR) — C5440, C5441, and C5471 | A-51 |
| A-44 | Timer Period Register (PRD)                                       | A-51 |
| A-45 | Watchdog Timer Control Register (WDTCR)                           | A-52 |
| A-46 | Watchdog Timer Secondary Control Register (WDTSCR)                | A-54 |
| Δ_47 | Watchdog Timer Period Register (WDPRD)                            | Δ-55 |

# **Tables**

| 1–1  | CSL Modules and Include Files              |
|------|--------------------------------------------|
| 1–2  | CSL Device Support                         |
| 1–3  | CSL Naming Conventions                     |
| 1–4  | CSL Data Types 1-7                         |
| 1–5  | Generic CSL Functions 1-9                  |
| 1–6  | Generic CSL Macros 1-12                    |
| 1–7  | Generic CSL Macros (Handle-based)          |
| 1–8  | Generic CSL Symbolic Constants 1-14        |
| 1–9  | Device-Specific Features Support           |
| 2–1  | CSL Directory Structure 2-20               |
| 3–1  | CHIP Functions                             |
| 4–1  | DAA Configuration Structures               |
| 4–2  | DAA Functions 4-3                          |
| 4–3  | DAA Macros                                 |
| 5–1  | DAT Functions                              |
| 6–1  | DMA Configuration Structure 6-2            |
| 6–2  | DMA Functions                              |
| 6–3  | DMA CSL Macros (using channel number) 6-20 |
| 6–4  | DMA CSL Macros (using handles) 6-21        |
| 7–1  | EBUS Configuration Structure 7-2           |
| 7–2  | EBUS Functions                             |
| 7–3  | EBUS Macros                                |
| 8–1  | GPIO Functions                             |
| 8–2  | GPIO Macros (C544x devices only) 8-5       |
| 9–1  | HPI Macros                                 |
| 10–1 | IRQ Configuration Structure 10-3           |
| 10–2 | IRQ Functions                              |
| 10–3 | IRQ_EVT_NNNN Event List 10-4               |
| 11–1 | McBSP Configuration Structure              |
| 11–2 | McBSP Functions                            |
| 11–3 | MCBSP CSL Macros (using port number)       |
| 11–4 | MCBSP CSL Macros (using handle)            |
| 12–1 | PLL Configuration Structure 12-2           |
| 12–2 | PLL Functions                              |
| 12–3 | PLL CSL Macros                             |
| 13–1 | PWR Functions                              |
|      |                                            |

| 14–1 | TIMER Configuration Structure                                                                        | 14-2  |
|------|------------------------------------------------------------------------------------------------------|-------|
| 14–2 | TIMER Functions                                                                                      |       |
| 14–3 | TIMER CSL Macros Using Timer Port Number                                                             | 14-10 |
| 14–4 | TIMER CSL Macros Using Handle                                                                        | 14-11 |
| 15–1 | UART APIs                                                                                            | 15-2  |
| 15–2 | UART CSL Macros                                                                                      | 15-15 |
| 16–1 | WDTIM Configuration Structure                                                                        | 16-2  |
| 16–2 | WDTIM Functions                                                                                      |       |
| 16–3 | WDTIM CSL Macros Using Timer Port Number                                                             | 16-7  |
| A–1  | DMA Channel Priority and Enable Control Register (DMPREC) Field Values (DMA_DMPREC_field_symval)     | A-2   |
| A-2  | DMA Channel n Sync Select and Frame Count Register (DMSFCn) Field Values (DMA_DMSFC_field_symval)    | A-3   |
| A-3  | DMA Channel n Transfer Mode Control Register (DMMCRn) Field Values (DMA_DMMCR_field_symval)          |       |
| A-4  | DMA Channel n Source Address Register (DMSRCn) Field Values (DMA_DMSRC_field_symval)                 | A-9   |
| A-5  | DMA Global Source Address Reload Register (DMGSA) Field Values (DMA_DMGSA_field_symval)              |       |
| A–6  | DMA Source Program Page Address Register (DMSRCP) Field Values (DMA_DMSRCP_field_symval)             | A-10  |
| A–7  | DMA Channel n Destination Address Register (DMDSTn) Field Values (DMA_DMDST_field_symval)            | A-10  |
| A–8  | DMA Global Destination Address Reload Register (DMGDA) Field Values (DMA_DMGDA_field_symval)         | A-10  |
| A-9  | DMA Destination Program Page Address Register (DMDSTP) Field Values (DMA_DMDSTP_field_symval)        | A-11  |
| A-10 |                                                                                                      | A-11  |
| A–11 | DMA Global Element Count Reload Register (DMGCR) Field Values (DMA_DMGCR_field_symval)               | A-12  |
| A-12 | DMA Global Frame Count Reload Register (DMGFR) Field Values (DMA_DMGFR_field_symval)                 | A-12  |
| A–13 | DMA Element Address Index Register 0 (DMIDX0) Field Values (DMA_DMIDX0_field_symval)                 | A-13  |
| A-14 | DMA Element Address Index Register 1 (DMIDX1) Field Values (DMA_DMIDX1_field_symval)                 | A-13  |
| A–15 | DMA Frame Address Index Register 0 (DMFRI0) Field Values (DMA_DMFRI0_field_symval)                   | A-14  |
| A–16 | DMA Frame Address Index Register 1 (DMFRI1) Field Values (DMA_DMFRI1_field_symval)                   | A-14  |
| A–17 | DMA Global Extended Source Data Page Register (DMSRCDP) Field Values (DMA_DMSRCDP_field_symval)      | A-15  |
| A–18 | DMA Global Extended Destination Data Page Register (DMDSTDP) Field Values (DMA_DMDSTDP_field_symval) | A-15  |
| A–19 | Software Wait-State Register (SWWSR) Field Values (EBUS_SWWSR_field_symval)                          | A-16  |
| A-20 | Software Wait-State Control Register (SWCR) Field Values (EBUS_SWCR_field_symval)                    | A-17  |

| A–21 | Bank-Switching Control Register (BSCR) Field Values — C5401, C5402, C5409, and C5420, and C5471 (EBUS_BSCR_field_symval) | . A-18 |
|------|--------------------------------------------------------------------------------------------------------------------------|--------|
| A-22 | Bank-Switching Control Register (BSCR) Field Values — C5410, and C5416 (EBUS_BSCR_field_symval)                          | . A-20 |
| A-23 | Bank-Switching Control Register (BSCR) Field Values — C5440 and C5441 (EBUS_BSCR_field_symval)                           | . A-21 |
| A-24 | General Purpose I/O Register (GPIO) Field Values (GPIO_GPIO_field_symval)                                                | . A-22 |
| A-25 | General Purpose I/O Control Register (GPIOCR) Field Values (HPI_GPIOCR_field_symval)                                     | . A-24 |
| A-26 | General Purpose I/O Status Register (GPIOSR) Field Values (HPI_GPIOSR_field_symval)                                      | . A-25 |
| A–27 | McBSP Serial Port Control Register 1 (SPCR1) Field Values (MCBSP_SPCR1_field_symval)                                     | . A-26 |
| A–28 | McBSP Serial Port Control Register 2 (SPCR2) Field Values (MCBSP_SPCR2_field_symval)                                     |        |
| A-29 | McBSP Pin Control Register (PCR) Field Values (MCBSP_PCR_field_symval)                                                   | . A-30 |
| A-30 | Receive Control Register 1 (RCR1) Field Values (MCBSP_RCR1_field_symval)                                                 | . A-33 |
| A-31 | Receive Control Register 2 (RCR2) Field Values (MCBSP_RCR2_field_symval)                                                 | . A-34 |
| A-32 | Transmit Control Register 1 (XCR1) Field Values (MCBSP_XCR1_field_symval)                                                | . A-35 |
| A-33 | Transmit Control Register 2 (XCR2) Field Values (MCBSP_XCR2_field_symval)                                                | . A-36 |
| A-34 | Sample Rate Generator Register 1 (SRGR1) Field Values (MCBSP_SRGR1_field_symval)                                         | . A-38 |
| A-35 | Sample Rate Generator Register 2 (SRGR2) Field Values (MCBSP_SRGR2_field_symval)                                         | . A-38 |
| A-36 | Multichannel Control Register 1 (MCR1) Field Values (MCBSP_MCR1_field_symval)                                            | . A-40 |
| A-37 | Multichannel Control Register 2 (MCR2) Field Values (MCBSP_MCR2_field_symval)                                            | . A-42 |
| A–38 | Receive Channel Enable Register (RCERn) Field Values (MCBSP_RCERn_field_symval)                                          | . A-43 |
| A-39 | Transmit Channel Enable Register (XCERn) Field Values (MCBSP_XCERn_field_symval)                                         | . A-45 |
| A-40 | Clock Mode Register (CLKMD) Field Values (PLL_CLKMD_field_symval)                                                        | . A-47 |
| A–41 | Timer Control Register (TCR) Field Values (TIMER_TCR_field_symval)                                                       | . A-49 |
| A–42 | Timer Secondary Control Register (TSCR) Field Values (TIMER_TSCR_field_symval)                                           | . A-51 |
| A-43 | Timer Period Register (PRD)                                                                                              |        |
| A–44 | Watchdog Timer Control Register (WDTCR) Field Values (WDTIM_WDTCR_field_symval)                                          |        |
| A–45 | Watchdog Timer Secondary Control Register (WDTSCR) Field Values (WDTIM_WDTSCR_field_symval)                              | . A-54 |
| A-46 | Watchdog Timer Period Register (WDPRD)                                                                                   | . A-55 |

# **Examples**

| 1_1  | Using PER_config or PER_configArgs               |
|------|--------------------------------------------------|
| 2–1  | Using a Linker Command File                      |
| 6–1  | DMA Header File                                  |
| 6–2  | DMA Source File (Declaration Section) 6-38       |
| 6–3  | DMA Source File (Body Section) 6-39              |
| 8–1  | GPIO Source File (Body Section) 8-8              |
| 10–1 | Manual Setting Outside DSPBIOS HWIs              |
| 11–1 | McBSP Header File                                |
| 11–2 | McBSP Source File (Declaration Section)          |
| 11–3 | McBSP Source File (Body Section)                 |
| 11–4 | McBSP Port Initialization using MCBSP_config     |
| 12–1 | PLL Header File                                  |
| 12–2 | PLL Source File (Declaration Section)            |
| 12–3 | PLL Source File (Body Section)                   |
| 14–1 | Timer Header File                                |
| 14–2 | Timer Source File (Declaration Section)          |
| 14–3 | Timer Source File (Body Section)                 |
| 15–1 | UART Header File                                 |
| 15–2 | UART Source File (Declaration Section)           |
| 15–3 | UART Source File (Body Section)                  |
| 16–1 | WATCHDOG TIMER Header File                       |
| 16–2 | WATCHDOG TIMER Source File (Declaration Section) |
| 16-3 | WATCHDOG TIMER Source File (Body Section)        |

# Chapter 1

# **CSL Overview**

This chapter introduces the Chip Support Library(CSL), briefly describes its architecture, and provides a generic overview of the collection of functions, macros, and constants that are needed to program DSP peripherals.

| Topi | С                                              | Page   |
|------|------------------------------------------------|--------|
| 1.1  | Introduction to the CSL                        | 1-2    |
| 1.2  | Naming Conventions                             | 1-6    |
| 1.3  | Data Types                                     | 1-7    |
| 1.4  | Functions                                      | 1-8    |
| 1.5  | Macros                                         | . 1-11 |
| 1.6  | Symbolic Constant Values                       | . 1-14 |
| 1.7  | Resource Management and the Use of CSL Handles | . 1-15 |
| 1.8  | Support for Device-Specific Features           | . 1-17 |
|      |                                                |        |

#### 1.1 Introduction to the CSL

The Chip Support Library(CSL) is a collection of functions, macros, and symbols used to configure and control on-chip peripherals. The goal is peripheral ease of use, shortened development time, portability, hardware abstraction, and some level of standardization and compatibility among TI devices.

The CSL is a fully scalable component of DSP/BIOS™, however, it does not require the use of other DSP/BIOS components to operate.

#### 1.1.1 Benefits of the CSL

### Standard Protocol to Program Peripherals

The CSL provides you with a standard protocol to use each time you program on-chip peripherals. This protocol includes specific data types and macros to define peripheral configurations, and standard functions to implement the various operations of each peripheral.

## Automated Peripheral Pre-initialization via the CSL GUI

The CSL integrates a graphical user interface (GUI) into the DSP/BIOS configuration tool. The CSL GUI pre-initializes peripherals by generating correct peripheral register values and C files. The C files initialize peripherals by using functions provided in the CSL.

Section 2.2, *Using CSL with the CSL GUI*, details the available CSL modules found in the CSL DSP/BIOS Configuration Tool.

### ☐ Basic Resource Management

Basic resource management is provided through the use of open and close functions for many of the peripherals. This is especially helpful for peripherals that support multiple channels.

# Symbol Peripheral Descriptions

As a side benefit to the creation of CSL, a complete symbolic description of all peripheral registers and register fields has been created. It is suggested that you use the higher level protocols described in the first two benefits, as these are less device specific, thus making it easier to migrate your code to newer versions of DSPs.

#### 1.1.2 CSL Architecture

The CSL consists of modules that are built and archived into a library file. Each peripheral is covered by a single module while additional modules provide general programming support.

Figure 1–1 illustrates the individual CSL modules. This architecture allows for future expansion because new modules can be added as new peripherals emerge.

Figure 1–1. API Modules



Although each CSL module provides a unique set of functions, some interdependency exists between the modules. For example, the DMA module depends on the IRQ module because of DMA interrupts; as a result, when you link code that uses the DMA module, a portion of the IRQ module is linked automatically.

Each module has a compile-time support symbol that denotes whether or not the module is supported for a given device. For example, the symbol \_DMA\_SUPPORT has a value of 1 if the current device supports it and a value of 0 otherwise. The available symbols are located in Table 1–1. You can use these support symbols in your application code to make decisions.

Table 1–1 lists general and peripheral modules with their associated include file, the module support symbol, and a column that specifies which modules are/are not supported by the CSL GUI. These components must be included in your application.

Table 1-1. CSL Modules and Include Files

| Peripheral<br>Module (PER) | Description                                    | Include File | Module Support Symbol | CSL GUI<br>Support |
|----------------------------|------------------------------------------------|--------------|-----------------------|--------------------|
| CHIP                       | General device module                          | csl_chip.h   | _CHIP_SUPPORT         | NO                 |
| DAA                        | Digital Access Arrangement                     | csl_daa.h    | _DAA_SUPPORT          | NO                 |
| DAT                        | A data copy/fill module based on the DMA       | csl_dat.h    | _DAT_SUPPORT          | NO                 |
| DMA                        | DMA Peripheral                                 | csl_dma.h    | _DMA_SUPPORT          | YES                |
| EBUS                       | External bus interface                         | csl_ebus.h   | _EBUS_SUPPORT         | YES                |
| GPIO                       | Non-multiplexed general purpose I/O            | csl_gpio.h   | _GPIO_SUPPORT         | YES                |
| HPI                        | HPI peripheral                                 | csl_hpi.h    | _HPI_SUPPORT          | NO                 |
| IRQ                        | Interrupt controller                           | csl_irq.h    | _IRQ_SUPPORT          | NO                 |
| MCBSP                      | Multi-channel buffered serial port             | csl_mcbsp.h  | _MCBSP_SUPPORT        | YES                |
| PLL                        | PLL                                            | csl_pll.h    | _PLL_SUPPORT          | YES                |
| PWR                        | Power savings control                          | csl_pwr.h    | _PWR_SUPPORT          | NO                 |
| TIMER                      | Timer peripheral                               | csl_timer.h  | _TIMER_SUPPORT        | YES                |
| UART                       | Universal Asynchronous<br>Receiver/Transmitter | csl_uart.h   | _UART_SUPPORT         | YES                |
| WDTIM                      | Watchdog Timer                                 | csl_wdtim.h  | _WDT_SUPPORT          | YES                |

Table 1–2 lists the C54x devices that the CSL supports and the far and near-mode libraries included in the CSL. The device support symbol must be used with the compiler (–d option), for the correct peripheral configuration to be used in your code.

### Note:

Devices C541 to C549 are NOT supported by CSL.

Table 1–2. CSL Device Support

| Device | Near-Mode Library | Far-Mode Library | Device Support Symbol |
|--------|-------------------|------------------|-----------------------|
| C5401  | csl5401.lib       | csl5401x.lib     | CHIP_5401             |
| C5402  | csl5402.lib       | csl5402x.lib     | CHIP_5402             |
| C5404  | csl5404.lib       | csl5404x.lib     | CHIP_5404             |
| C5407  | csl5407.lib       | csl5407x.lib     | CHIP_5407             |
| C5409  | csl5409.lib       | csl5409x.lib     | CHIP_5409             |
| C5409A | csl5409A.lib      | csl5409Ax.lib    | CHIP_5409A            |
| C5410  | csl5410.lib       | csl5410x.lib     | CHIP_5410             |
| C5410A | csl5410A.lib      | csl5410Ax.lib    | CHIP_5410A            |
| C5416  | csl5416.lib       | csl5416x.lib     | CHIP_5416             |
| C5420  | csl5420.lib       | csl5420x.lib     | CHIP_5420             |
| C5421  | csl5421.lib       | csl5421x.lib     | CHIP_5421             |
| C5440  | csl5440.lib       | csl5440x.lib     | CHIP_55440            |
| C5441  | csl5441.lib       | csl5441x.lib     | CHIP_5441             |
| C5471  | csl5471.lib       | csl5471x.lib     | CHIP_5471             |
| C54cst | cslcst.lib        | cslcstx.lib      | CHIP_54CST            |

# 1.2 Naming Conventions

The following conventions are used when naming CSL functions, macros and data types.

Table 1–3. CSL Naming Conventions

| Object Type       | Naming Convention           |
|-------------------|-----------------------------|
| Function          | PER_funcName() <sup>†</sup> |
| Variable          | PER_varName() <sup>†</sup>  |
| Macro             | PER_MACRO_NAME†             |
| Typedef           | PER_Typename <sup>†</sup>   |
| Function Argument | funcArg                     |
| Structure Member  | memberName                  |

<sup>†</sup> PER is the placeholder for the module name.

- ☐ All functions, macros and data types start with PER\_ (where PER—all in capital letters—is the Peripheral module name listed in Table 1–1).
- ☐ Function names use all small letters. Capital letters are used only if the function name consists of two separate words (e.g., PER\_getConfig()).
- ☐ Macro names use all capital letters (e.g., DMA\_DMPREC\_RMK).
- ☐ Data types begin with a capital letter, followed by small letters (e.g., DMA\_Handle).

# 1.3 Data Types

The CSL provides its own set of data types. Table 1–4 lists the CSL data types as defined in the *stdinc*.h file.

Table 1-4. CSL Data Types

| Data Type  | Description                                     |
|------------|-------------------------------------------------|
| CSLBool    | unsigned short                                  |
| PER_Handle | void *                                          |
| Int16      | short                                           |
| Int32      | long                                            |
| Uchar      | unsigned char                                   |
| Uint16     | unsigned short                                  |
| Uint32     | unsigned long                                   |
| DMA_AdrPtr | void (*DMA_AdrPtr)() pointer to a void function |

#### 1.4 Functions

Table 1–5 provides a generic description of the most common CSL functions where *PER* indicates a peripheral module as listed in Table 1–1.

#### Note:

Not all of the peripheral functions are available for all the modules. See the specific module chapter for specific module information. Also, each peripheral module may offer additional peripheral specific functions.

The following conventions are used in Table 1–5:

- Italics indicate variable names.
- □ Brackets [...] indicate optional parameters.
  - [handle] is required only for the handle-based peripherals: DAT, DMA, MCBSP, and TIMER. See section 1.7.1.
  - [priority] is required only for the DAT peripheral module.

CSL functions provide a way to program peripherals by *direct register initialization* using the PER\_config() or PER\_configArgs() functions (see section 1.4.1). This method is used by the CSL GUI.

Table 1-5. Generic CSL Functions

| Function                                                          | Description                                                                                                                                                                                                                                                                                                               |
|-------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| handle = PER_open(<br>channelNumber,<br>[priority,]               | Opens a peripheral channel and then performs the operation indicated by <i>flags</i> ; must be called before using a channel. The return value is a unique device handle that is used in subsequent API calls.                                                                                                            |
| flags<br>)                                                        | The <i>priority</i> parameter applies only to the DAT module.                                                                                                                                                                                                                                                             |
| PER_config(<br>[handle,]<br>*configStructure<br>)                 | Writes the values of the configuration structure to the peripheral registers. You can initialize the configuration structure with:  Integer constants  Integer variables  CSL symbolic constants, PER_REG_DEFAULT (see section 1.6, CSL Symbolic Constant Values)  Merged field values created with the PER_REG_RMK macro |
| PER_configArgs(    [handle,]    regval_1,    .    .    regval_n ) | Writes the individual values (regval_n) to the peripheral registers. These values can be any of the following:  Integer constants Integer variables CSL symbolic constants, PER_REG_DEFAULT Merged field values created with the PER_REG_RMK macro                                                                        |
| PER_start(<br>[handle,])<br>[txrx,]<br>[delay]<br>)               | Starts the peripheral after using PER_config() or PER_configArgs(). [txrx] and [delay] apply only to MCBSP.                                                                                                                                                                                                               |
| PER_reset(<br>[handle]<br>)                                       | Resets the peripheral to its power-on default values.                                                                                                                                                                                                                                                                     |
| PER_close( handle )                                               | Closes a peripheral channel previously opened with PER_open(). The registers for the channel are set to their power-on defaults, and any pending interrupt is cleared.                                                                                                                                                    |

## 1.4.1 Peripheral Initialization via Registers

The CSL provides two generic functions for initializing the registers of a peripheral: *PER*\_config and *PER*\_configArgs (where *PER* is the peripheral as listed in Table 1–1).

- → PER\_config allows you to initialize a configuration structure with the appropriate register values and pass the address of that structure to the function, which then writes the values to the register. The CSL GUI uses this function to initialize peripherals. Example 1–1 shows an example of this method.
- → PER\_configArgs allows you to pass the individual register values as arguments to the function, which then writes those individual values to the register. Example 1–1 shows an example of this method.

You can use these two initialization functions interchangeably, but you still need to generate the register values. To simplify the process of defining the values to write to the peripheral registers, the CSL offers you a GUI that produces these register values. CSL also provides the PER\_REG\_RMK (make) macros, which form merged values from a list of field arguments. Macros are covered in section 1.5, *CSL Macros*.

# Example 1-1. Using PER config or PER configArgs

```
PER_Config MyConfig = {
  reg0,
  reg1,
  ...
};
main() {
  ...
PER_config(&MyConfig);
  ...
;or...
;PER_configArgs (reg0, reg1, ...);
}
```

#### 1.5 Macros

| The | e following naming conventions are used:                                                                                                                                                |
|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | PER indicates a peripheral module as listed in Table 1–1.                                                                                                                               |
|     | REG indicates a register name (without the channel number).                                                                                                                             |
|     | REG# indicates, if applicable, a register with the channel number. (e.g., DMPREC, DMSRC1,)                                                                                              |
|     | FIELD indicates a field in a register.                                                                                                                                                  |
|     | regval indicates an integer constant, an integer variable, a symbolic constant (PER_REG_DEFAULT), or a merged field value created with the PER_REG_RMK() macro.                         |
|     | fieldval indicates an integer constant, integer variable, macro, or symbolic constant ( <i>PER_REG_FIELD_SYMVAL</i> ) as explained in section 1.6; al field values are right justified. |

Table 1–6 provides a generic description of the most common CSL macros.

CSL also offers equivalent macros to those listed in Table 1–6, but instead of using REG# to identify which channel the register belongs to, it uses the Handle value. The Handle value is returned by the PER\_open() function. The equivalent macros are shown in Table 1–7. Please note that REG is the register name without the channel number.

Table 1-6. Generic CSL Macros

| Macro                                              | Description                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PER_REG_RMK(<br>fieldval_15,                       | Creates a value to store in the peripheral register; _RMK macros make it easier to construct register values based on field values.                                                                                                                                                                                                                                                                                       |
| fieldval_0<br>)                                    | The following rules apply to the _RMK macros:  Define only when more than one field exists in a register  Include only fields that are writable.  Specify field arguments as most-significant bit first.  Whether or not they are used, all writable field values must be included.  If you pass a field value exceeding the number of bits allowed for that particular field, the _RMK macro truncates that field value. |
| PER_RGET(REG#<br>)                                 | Returns the value in the peripheral register.                                                                                                                                                                                                                                                                                                                                                                             |
| PER_RSET(REG#, regval )                            | Writes the value to the peripheral register.                                                                                                                                                                                                                                                                                                                                                                              |
| PER_FMK (REG,<br>FIELD,<br>fieldval<br>)           | Creates a shifted version of <i>fieldval</i> that you could OR with the result of other _FMK macros to initialize register REG. This allows you to initialize few fields in REG as an alternative to the _RMK macro that requires that ALL the fields in the register be initialized.                                                                                                                                     |
| PER_ <b>FGET</b> (REG#,<br>FIELD<br>)              | Returns the value of the specified FIELD in the peripheral register.                                                                                                                                                                                                                                                                                                                                                      |
| PER_ <b>FSET</b> (REG#,<br>FIELD,<br>fieldval<br>) | Writes fieldval to the specified FIELD in the peripheral register.                                                                                                                                                                                                                                                                                                                                                        |
| PER_ <b>ADDR</b> (REG#<br>)                        | If applicable, retrieves the memory address (or sub-address) of the peripheral register REG#.                                                                                                                                                                                                                                                                                                                             |

Table 1–7. Generic CSL Macros (Handle-based)

| Macro                                           | Description                                                                                                         |
|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------|
| PER_RGETH(handle,<br>REG<br>)                   | Returns the value of the peripheral register REG associated with Handle.                                            |
| PER_RSETH(handle,<br>REG,<br>regval<br>)        | Writes the value to the peripheral register REG associated with Handle.                                             |
| PER_ADDRH(handle,<br>REG<br>)                   | If applicable, retrieves the memory address (or sub-address) of the peripheral register REG associated with Handle. |
| PER_FGETH(handle,<br>REG,<br>FIELD              | Returns the value of the specified <i>FIELD</i> in the peripheral register REG associated with Handle.              |
| PER_FSETH(handle,<br>REG,<br>FIELD,<br>fieldval | Sets the value of the specified FIELD in the peripheral register REG to fieldval.                                   |

# 1.6 Symbolic Constant Values

To initialize values in your application code, the CSL provides symbolic constants for registers and writable field values as described in Table 1–8. The following naming conventions are used:

PER indicates a peripheral module as listed in Table 1–1.

REG indicates a peripheral register.

FIELD indicates a field in the register.

SYMVAL indicates the symbolic value of a register field as listed in

Table 1–8. Generic CSL Symbolic Constants

Appendix A.

### (a) Constant Values for Registers

| Constant                       | Description                                                                                                                             |
|--------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|
| PER_REG_DEFAULT                | Default value for a register; corresponds to the register value after a reset or to 0 if a reset has no effect.                         |
| (b) Constant Values for Fields |                                                                                                                                         |
| PER_REG_FIELD_SYMVAL           | Symbolic constant to specify values for individual fields in the indicated peripheral register. See Appendix A for the symbolic values. |
| PER_REG_FIELD_DEFAULT          | Default value for a field; corresponds to the field value after a reset or to 0 if a reset has no effect.                               |

## 1.7 Resource Management and the Use of CSL Handles

The CSL provides limited support for resource management in applications that involve multiple threads, reusing the same multichannel peripheral device.

Resource management in the CSL is achieved through calls to the PER\_open and PER\_close functions. The PER\_open function normally takes a channel/port number as the primary argument. It then returns a pointer to a Handle structure that contains information about which channel (DMA) or port (MCBSP) was opened.

When given a specific channel/port number, the open function checks a global flag to determine its availability. If the port/channel is available, it returns a pointer to a predefined Handle structure for this device.

If the device has already been opened by another process, an invalid Handle is returned with a value equal to the CSL symbolic constant, INV.

Calling PER\_close frees a port/channel for use by other processes. PER\_close clears the in\_use flag and resets the port/channel.

#### Note:

All CSL modules that support multiple ports or channels, such as MCBSP, TIMER, DAT, and DMA, require a device Handle as primary argument to most functions. For these functions, the definition of a PER\_Handle object is required.

# 1.7.1 Using CSL Handles

CSL Handle objects are used to uniquely identify an opened peripheral channel/port or device. Handle objects must be declared in the C source, and initialized by a call to a PER\_open function before calling any other API functions that require a handle object as argument.

For example:

```
DMA Handle myDma; /* Defines a DMA Handle object, myDma */
```

Once defined, the CSL Handle object is initialized by a call to PER open:

The call to DMA\_open initializes the handle, myDma. This handle can then be used in calls to other API functions:

# 1.8 Support for Device-Specific Features

Not all C54x peripherals offer the same type of features across the C54x devices. Table 1–9 lists specific features that are not common across the C54x family and the devices that support these features. References to Table 1–9 will be found across the CSL documentation.

Table 1–9. Device-Specific Features Support

#### (a) DMA Module-Channel Reload

| Individual Channel Register<br>Reload Support      |                                        | Global Channel Register Reload<br>Support |
|----------------------------------------------------|----------------------------------------|-------------------------------------------|
| 5416, 5421, 5409a, 5410a, 5440, 5441               |                                        | All other C54x supported devices          |
| (b) DMA Module-Extended Data F                     | Reach                                  |                                           |
| Individual Channel Extended<br>Data Memory Support | Global Extended Data Memory<br>Support | No Extended Data Memory<br>Support        |
| 5440, 5441                                         | 5409, 5416, 5421, 5409a, 5410a         | 5402, 5404, 5407, 5410, 5420,<br>5455     |
| (c) MCBSP Module-Channel Supp                      | ort                                    |                                           |
| MCBSP 128-Channel Support                          |                                        | MCBSP 32-Channel Support                  |
| 5416, 5421, 5440, 5409a, 5410a, 5441               |                                        | All other C54x supported devices          |
| (d) Watchdog Module                                |                                        |                                           |
| Watchdog Timer Support                             |                                        | No Watchdog Timer Support                 |
| 5440, 5441                                         |                                        | All other C54x supported devices          |
| (e) Timer Module                                   |                                        |                                           |
| Timer Extended Pre-Scaler Support                  |                                        | No Timer Extended Pre-Scaler Support      |
| 5471, 5441                                         |                                        | All other C54x supported devices          |
| (f) Chip Module                                    |                                        |                                           |
| Device ID Support                                  |                                        | No Device ID Support                      |
| 5416, 5409A, 5410A, 5441, 5421                     |                                        | All other C54x supported devices          |

# Chapter 2

# How To Use CSL

This chapter provides instructions on how to:

- ☐ Use the TMS320C54x CSL Graphic User Interface (GUI) integrated into the DSP/BIOS Configuration Tool. It describes a detailed work-flow for setting and accessing the CSL GUI data via the generation of C code files. The examples shown in this chapter include a complete procedure for creating configuration objects and generating peripheral pre-initialization.

# Topic Page

| 2.1 | Overview                      |
|-----|-------------------------------|
| 2.2 | Using CSL with the CSL GUI    |
| 2.3 | Using CSL without the CSL GUI |
| 2.4 | Rebuilding CSL 2-26           |

### 2.1 Overview

There are two methods to configure peripherals when using CSL:

- Manually configure the peripherals by declaring/initializing objects and invoking the CSL functions inside your C source code.
- Configure peripherals by using the CSL GUI.

The CSL GUI, integrated under the DSP/BIOS configuration tool, provides the benefit of a visual tool that allows you to view the chosen register settings, and determine which flags/options have been set by a particular mode selection. With CSL GUI, code for the configuration settings is automatically created and stored in a C source file that is integrated directly into your application.

It is not possible to configure all peripherals via the CSL GUI. Only peripherals requiring initial static configurations are supported. Please refer to Table 1–1, on page 1-4, for the list of peripherals supported by the CSL GUI.

# 2.2 Using CSL with the CSL GUI

### 2.2.1 CSL GUI: The CSL Tree

The CSL GUI, integrated under the DSP/BIOS Configuration tool tree, allows you to configure some, but not all, of the on-chip peripherals. Each peripheral is represented as a subdirectory of the CSL Tree as shown in Figure 2–1.

Figure 2–1. CSL Tree (for 5402)



Figure 2–2 shows an example of the expanded CSL Tree.





Each peripheral is organized into two sections (see Figure 2–2):

- □ PERIPHERAL Configuration Manager allows you to build and configure peripheral objects using the CSL PER\_Config structure (see Table 1–5 on page 1-9). You can set the peripheral register values by selecting the options through the Properties pages. Several configuration objects can be created by selecting the Insert PERCfg option from the right-click menu (see Figure 2–3). The menu options allow you to rename and delete the configuration object (see Figure 2–4), and to display the Dependency Dialog box that allows you to determine which peripheral is using the configuration (see Figure 2–5).
- □ PERIPHERAL Resource Manager allows you to bind a peripheral configuration to a specific on-chip device, i.e., a DMA channel, a MCBSP port, or a TIMER device. The devices are displayed as pre-defined objects and cannot be deleted or renamed. However, the Handles to these objects can be renamed.

Figure 2–3. Insert Configuration Object



The Insert option allows the user to create the configuration objects. Once the object is created, you can access the Properties Page of this configuration, which allows you to set the register values.

Figure 2-4. Delete/Rename Options



The Delete option allows you to delete a configuration object. The Delete option is not accessible if the configuration is used by a physical peripheral of the associated Resource manager.

Figure 2-5. Show Dependency Option





The Show Dependency menu option shows which device/channel is using what specific configuration. Once a configuration has been bound to a peripheral, the Show Dependency option can be used to indicate which peripheral is using what particular configuration. In Figure 2–5, the "timerCfg0" configuration is bound to the physical timer device "Timer1" at design time (in the configuration tool).

### Note:

A configuration object cannot be deleted if there is a dependency present.

## 2.2.2 Steps to configuring a peripheral using CSL GUI

This section provides an example using the 5402 device that demonstrates how to create, open and define a configuration for a TIMER device using the CSL GUI.

When configuring a peripheral using the CSL GUI, the steps below must be followed:

- Step 1: Create the DSP/BIOS configuration file (.cdb file). In Code Composer Studio, select File → New → DSP/BIOS Configuration (select template.cdb). Default name, Config1.cdb.
- **Step 2:** Configure the on-chip peripherals using the CSL hierarchy tree. (see section 2.2.3)
- Step 3: Save the configuration file (.cdb file). Select File → Save as: enter the .cdb name; for example, mytimer.cdb. This automatically generates several files requested to build your project. (see section 2.2.4)
- Step 4: Add the .cdb file to your project:Click on Project → Add Files to Project. Select the mytimer.cdb file.
- Step 5: Add the linker command file associated with the .cdb file:
  Click on Project → Add Files to Project. Select the mytimer.cmd file.
  Figure 2–6 shows the project layout before and Figure 2–7 shows the project layout after a .cdb file is created and the mytimer.cmd, mytimer.s54, and mytimer\_c.c files have been added to the project.
- **Step 6:** Modify your application code (main.c) (see section 2.2.5)

Figure 2–6. Code Composer Studio IDE Project Window



Figure 2-7. Code Composer Studio IDE Project Window with .cdb Project File Added



## 2.2.3 TIMER Configuration Example

Because the default values (device power-on reset) are different from one chip to another, it is recommended that you delete any existing config objects before changing the chip type under the Global Setting (system). This ensures that you get the right reset value when you want to use the default setting of the registers.

The configuration file *mytimer*.cdb is assumed to be created previously and opened (see section 2.2.2).

In the CCStudio Project View window (see Figure 2–8) open *mytimer*.cdb, and go to the sub-folder TIMER module (CSL Folder).





Using Figure 2–9 follow these steps:

- **Step 1:** Right-click on the TIMER Configuration Manager, insert a new configuration object.
- **Step 2:** Right-click on timerCfg0 and select Properties to open the timerCfg0 Properties window (as shown in Figure 2–9). Set the configuration by clicking on any of the tabs.
- **Step 3:** Under the Timer Resource Manager, right-click on Timer1 and select Properties to open the Timer1 Properties window (see Figure 2–9).
  - Check the Open Handle to Timer and Enable pre-initialization

From the pre-initialize drop-down list, select the configuration, timerCfg0.

Figure 2-9. Configuring the TIMER1 Device



### 2.2.4 Files Generated by the CSL GUI

erated by the configuration tool: mytimer.cdb - An updated configuration database containing all inserted objects and all current property settings. mytimercfq.h - An extern declaration of all created objects, definition of CHIP\_XXXX, plus #include of CSL module headers. mytimercfg\_c.c - Definition and initialization of created objects. Contains function calls to TIMER open and TIMER config pre-opened/pre-initialized objects. mytimercfg.sXX - Defines which DSP/BIOS elements are present and provides initialization for those elements. mytimercfg.cmd - A Linker command file. Includes the CSL library and .csldata placements. Two of these files are dedicated to the CSL and use the CSL API: ☐ Header file: mytimercfg.h ☐ Source file: mytimercfg\_c.c In this example, mytimer is your .cdb file name. The bold characters are attached automatically. 2.2.4.1 Header File: mytimercfg.h This header file must be added to one of the user's source files in order to access the CSL functions and/or objects predefined in the DSP/BIOS configuration tool. This header file contains several elements: The definition of the chip: #define CHIP\_5402 1 ☐ The csl header files used by the CSL tree The declaration list of the CSL handle objects and configuration names defined in the *mytimer\_c.c* These are declared external, and can be applied in the user's code: extern TIMER Config timerCfg1;

After saving the configuration file mytimer.cdb, there are a number of files gen-

Figure 2–10 illustrates the setup of *mytimercfg\_c.c* 

extern TIMER\_Handle hTimer1;
#include cprojectcfq.h>

Figure 2-10. Header File mytimercfg.h

```
/* Do *not* directly modify this file.
                                                        * /
/*
     generated by the Configuration Tool; any */
     changes risk being overwritten.
                                                        * /
/* INPUT mytimer.cdb */
#define CHIP_5402 1
/* Include Header Files */
#include <std.h>
#include <hst.h>
                            csl header files of the peripherals
#include <swi.h>
                            implemented under the CSL tree
#include <tsk.h>
#include <log.h>
#include <sts.h>
#include <csl timer.h>
#ifdef __cplusplus
                            The Handle and Configuration objects are
extern "C" {
                            defined and can be used by other C files
#endif
                            (user's files).
extern far HST_Obj RTA_fromHost;
extern far HST_Obj RTA_toHost;
extern far SWI_Obj KNL_swi;
extern far TSK_Obj TSK_idle;
extern far LOG_Obj LOG_system;
extern far STS_Obj IDL_busyObj;
extern far TIMER_Config timerCfg0;
extern far TIMER Handle htimer1;
extern far void CSL_cfgInit();
#ifdef __cplusplus
#endif /* extern "C" */
```

### 2.2.4.2 Source File: mytimercfg\_c.c

This source file consists of the Include section, the Declaration section, and the Code section:

### ☐ Include section

This section defines the project header file. This allows *mytimercfg\_c.c* access to the data declared in the header file.

```
#include <mytimercfq.h>
```

### Note:

This line is added before the other CSL header files (csl\_emif.h, csl\_timer.h, ...). This is done so that you are not required to specify the device number under the Project option (that –dCHIP\_54xx is not required).

### Declaration section

This section defines the peripheral registration configuration structures and the Handle objects previously defined in the CSL GUI.

### Code section

The code section is composed of a unique function, **CSL\_cfgInit()**, as shown in Figure 2–11, which is automatically called by the DSP/BIOS boot routine if the project.cdb is added to your project. Otherwise, you can call it later in your main.c file.

CSL\_cfglnit() prompts the tool to implement the open and configuration options you specify in the CSL GUI, via calls to the TIMER\_open and TIMER\_config functions.

Calls to TIMER\_open() and TIMER\_config() are generated when the *Open Handle to Peripheral and Enable pre-initialization* options are checked in the Properties page of the related Resource Manager (see the timer example illustrated in Figure 2–11).

#### Note:

A device can be allocated/opened without being configured.

In the example shown in Figure 2–11,

- If Enable pre-initialization is checked, a call to the *TIMER\_config()* function is generated.
- If Enable Pre-initialization is unchecked, a call to the TIMER\_config() is not generated, but the configuration structure timerCfg1 is created and available for you to use at a later time.

Figure 2-11. Resource Manager Properties Page



Figure 2–12 illustrates the mytimercfg\_c.c file.

Figure 2-12. Source File mytimercfg\_c.c

```
generated by the Configuration Tool; any */
     changes risk being overwritten.
/* INPUT mytimer.cdb */
   Include Header File */
                                  TIMER Configuration structure timerCfg0
#include <mytimercfq.h>
                                  with full TIMER peripheral register values
/* Config Structures */
TIMER Config timerCfq = {
                   /* Timer Control Register
    0 \times 0020,
    0 \times 0300
                   /* Timer Period Register
};
                                  Handle hTimer1 declaration
/* Handles */
TIMER Handle hTimer1;
                                   The TIMER_open() function returns the
/* ====== CSL cfqInit() ===
                                   handle value in the handle variable
void CSL cfqInit()
                                   hTimer1 previously declared.
    CSL_init();
    hTimer1 = TIMER_open(TIMER_DEV1, TIMER_OPEN_RESET);
    TIMER_config(hTimer1, &timerCfg0);
                                     TIMER_config() function sets the register
                                     values defined by the configuration object
                                     timerCfq0.
```

# 2.2.5 Modifying Your Application Code (main.c)

The following line of code is required to access the CSL objects you predefined with the CSL GUI:

```
#include "mytimercfq.h"
```

This includes CSL handle and configuration declarations to your code.

mytimercfg.h automatically includes the required csl.h and csl\_timer.h files.

This header file must be included before other CSL files are added.

Figure 2–13 illustrates how to access the files generated by the CSL GUI in your application code (main.c)

Figure 2–13. Example of main.c File Using Data Generated by the CSL GUI

```
#include <mytimercfg.h>
                                           This line allows the objects created with the
                                           CSL GUI tool to be referenced here.
static Uint32 TIMEREventId1;
                                           The header file must be included before
                                           any other CSL header files; otherwise,
void main() {
                                           the -dCHIP_XXXX option must be set in
                                           the compiler option window.
  /* Obtain the event IDs for the TIMER devices */
  TIMEREventId1 = TIMER getEventId(hTimer1);
  /* Enable the TIMER events */
  IRQ_enable(TIMEREventId1);
                                             Handle object "hTimer1" is used directly by
  /* Start the TIMERs - */
                                             the TIMER CSL APIs.
   TIMER_start(hTimer1);
  /* Waiting for TIMER Interrupt: */
    while( !IRQ_test(TIMEREventId1));
  /* Close TIMER */
  TIMER_close(hTimer1);
```

## 2.3 Using CSL without the CSL GUI

You may choose to manually declare and initialize the peripheral configuration objects within the C source. This means that you are not required to use the CSL GUI when working with the CSL library. However, it is highly recommended that you use the CSL GUI, particularly if your application involves interrupt management, and there are other components of DSP/BIOS present.

This section provides an example of using CSL without the CSL GUI and without a .cdb file. The CSL GUI merely assists in generation of the CSL configuration structures and provides the option to open and configure peripherals. This can equally be done using the CSL macros and functions directly.

There are two ways to program peripherals using CSL:

| Register-based configuration (PER_config()): Configures periphe           |  |  |
|---------------------------------------------------------------------------|--|--|
| by setting the full values of memory-map registers. Compared to function- |  |  |
| al parameter-based configurations, register-based configurations require  |  |  |
| less cycles and code size, but are not abstracted.                        |  |  |

☐ Functional parameter-based configuration (PER\_setup()): Configures peripherals via a set of parameters. Compared to register-based configurations, functional parameter-based configurations require more cycles and code size, but are more abstracted.

The following example illustrates the use of CSL to initialize DMA channel 0 and to copy a table from address 0x3000 to address 0x2000 using the register based configuration (DMA\_config())

Source address: 2000h in data space Destination address: 3000h in data space

Transfer size: Sixteen 16-bit single words

## 2.3.1 Using the DMA\_config() function

The steps below use the DMA\_config() function to initialize the registers:

**Step 1:** Include the csl.h and the header file of the module/peripheral you will use <csl\_dma.h>. The different header files are shown in Table 1–1.

```
#include <csl.h>
#include <csl_dma.h>
// Example-specific initialization
#define N 16
                   // block size to transfer
#pragma DATA_SECTION(src,"table1")
/* scr data table address */
Uint16 src[N] = {
      OxBEEFu, OxBEEFu, OxBEEFu, OxBEEFu,
      OxBEEFu, OxBEEFu, OxBEEFu, OxBEEFu,
      OxBEEFu, OxBEEFu, OxBEEFu, OxBEEFu,
      OxBEEFu, OxBEEFu, OxBEEFu, OxBEEFu
};
#pragma DATA_SECTION(dst, "table2")
/* dst data table address */
Uint16 dst[N];
```

**Step 2:** Define and initialize the DMA channel configuration structure.

```
DMA_Config myconfig = {
   DMA_DMACSDP_RMK(0 , 0 ,0 ,0 ,0 ,1), /* DMACSDP */
   DMA_DMACCR_RMK(1, 1, 0, 0, 0, 0, 0, 0, 0), /* DMACCR */
   DMA_DMACICR_RMK(1, 1,1 , 1, 1, 1),
                                            /* DMACICR */
   (DMA_AdrPtr) &src,
                                            /* DMACSSAL */
   0,
                                             /* DMACSSAU */
   (DMA_AdrPtr)&dst,
                                             /* DMACDSAL */
                                             /* DMACDSAU */
                                             /* DMACEN */
   Ν,
   1,
                                             /* DMACFN */
                                             /* DMACFI */
   0,
   0};
                                             /* DMACEI */
```

**Step 3:** Define a DMA\_Handle pointer. DMA\_open will initialize this handle when a DMA channel is opened.

```
DMA_Handle myhDma;
void main(void) {
// .....
```

**Step 4:** Initialize the CSL Library. A one-time only initialization of the CSL library must be done before calling any CSL module API:

```
CSL_init(); /* Init CSL */
```

**Step 5:** For multi-resource peripherals such as McBSP and DMA, call PER\_open to reserve resources (MCBSP\_open(), DMA\_open()...):

```
myhDma = DMA_open(DMA_CHA0, 0);/* Open DMA Channel 0 */
```

By default, the TMS320C54xx compiler assigns all data symbols word addresses. The DMA however, expects all addresses to be byte addresses. Therefore, you must shift the address by 2 in order to change the word address to a byte address for the DMA transfer.

**Step 6:** Configure the DMA channel by calling DMA\_config() function:

```
myconfig.dmacssal =
(DMA_AdrPtr)(((Uint16)(myconfig.dmacssal)<<1)&0xFFFF);
myconfig.dmacdsal =
( DMA_AdrPtr)(((Uint16)(myconfig.dmacdsal)<<1)&0xFFFF);
DMA_config(myhDma, &myConfig); /* Configure Channel */</pre>
```

**Step 7:** Call DMA\_start() to begin DMA transfers:

```
DMA_start(myhDma); /* Begin Transfer */
```

Step 8: Close DMA channel

```
DMA_close(myhDma);    /* Close channel (Optional) */
}
```

# 2.3.2 Compiling and Linking With CSL using Code Composer Studio (CCStudio)

To compile and link with CSL, you must configure the CCStudio project environment. To complete this process, follow these steps:

- **Step 1:** Specify the target device. (Refer to section 2.3.2.1)
- **Step 2:** Determine whether or not you are using small or large memory model and specify the CSL and RTS libraries you require. (Refer to section 2.3.2.3)
- **Step 3:** Create the linker command file (with a special .csldata section) and add the file to the project. (Refer to section 2.3.2.4)
- **Step 4:** Determine if you must enable inlining. (Refer to section 2.3.2.5)

The remaining sections in this chapter will provide more details and explanations for the steps above.

### Note:

CCStudio will automatically define the search paths for include files and libraries as defined in Table 2–1. You are not required to set the –i option.

Table 2–1. CSL Directory Structure

| This CSL component | Is located in this directory          |
|--------------------|---------------------------------------|
| Libraries          | c:\ti\c5400\bios\lib                  |
| Source Library     | c:\ti\c5400\bios\lib                  |
| Include files      | c:\ti\c5400\bios\include              |
| Examples           | c:\ti\examples\ <target>\csl</target> |
| Documentation      | c:\ti\docs                            |

# 2.3.2.1 Specifying Your Target Device

Use the following steps to specify the target device you are configuring:

- **Step 1:** In Code Composer Studio, select Project → Options.
- **Step 2:** In the Build Options dialog box, select the Compiler tab (see Figure 2–14).
- **Step 3:** In the Category list box, highlight Preprocessor.
- **Step 4:** In the Define Symbols field, enter one of the device support symbols in Table 1–2, on page 1-5.

For example, if you are using the 5402PG1.2 device, enter CHIP\_5402PG1\_2.

Step 5: Click OK.



Figure 2–14. Defining the Target Device in the Build Options Dialog

### 2.3.2.2 Selecting Far/Near Mode

If you use an far-mode libraries, define far-mode for the compiler, and link with the far-mode library (rts\_ext.lib), use the following steps. Use Figure 2–15 to complete these steps.

- **Step 1:** In Code Composer Studio, select Project  $\rightarrow$  Options
- **Step 2:** In the Build Options dialog box, select the Compiler Tab.
- **Step 3:** In the Category list box, highlight advanced.
- **Step 4:** Select Use Far Calls.
- **Step 5:** In the Processor Version (-v) field, type 548.
- Step 6: Click OK.

Figure 2-15. Defining Far Mode



- Step 7: If you use any far-mode libraries, define far mode for the compiler and link with the far mode runtime library (rts\_ext.lib). Then, you must specify which CSL and RTS libraries will be linked in your project.
- **Step 8:** In Code Composer Studio, select Project → Options
- **Step 9:** In the Build Options dialog box, Select the Linker Tab (see Figure 2–17).
- **Step 10:** In the Category list, highlight Basic.

The Library search Path field (-I), should show: c:\ti\c5400\bios\lib (automatically configured by CCS)

**Step 11:** In the Include Libraries (-I) field, enter the correct library from Table 1–2, on page 1-5.

For example, if you are using the 5402 device, enter csl5402.lib for near mode or csl5402x.lib for far mode. In addition, you must include the corresponding rts.lib or rts\_ext.lib compiler runtime support libraries.

Step 12: Click OK.

### 2.3.2.3 Large/Small Memory Model Selection

If you use any large memory model libraries, define the -ml option for the compiler and link with the large memory model runtime library (rts54x.lib) using the following steps:

- **Step 1:** In Code Composer Studio, select Project  $\rightarrow$  Options.
- **Step 2:** In the Build Options dialog box, select the Compiler Tab (Figure 2–16).
- **Step 3:** In the Category list box, highlight advanced.
- Step 4: Select Use Large memory model (-ml).
- Step 5: Click OK.

Figure 2–16. Defining Large Memory Model



Then, you must specify which CSL and RTS libraries will be linked in your project.

- ☐ In Code Composer Studio, select Project → Options
- ☐ In the Build Options dialog box, Select the Linker Tab (see Figure 2–17).
- In the Category list, highlight Basic.
- ☐ The Library search Path field (-I), should show: c:\ti\c5400\bios\lib (automatically configured by CCStudio)
- ☐ In the Include Libraries (-I) field, enter the correct library from Table 1–2, on page 1-5.
- ☐ For example, if you are using the 5402 device, enter csl5402.lib for near mode or csl5402x.lib for far mode. In addition, you must include the corresponding rts54.lib or rts54x.lib compiler runtime support libraries.
- ☐ Click OK.

Figure 2–17. Defining Library Paths



### 2.3.2.4 Creating a Linker Command File

The CSL has two requirements for the linker command file:

### You must allocate the .csldata section.

CSL creates a .csl data section to maintain global data that CSL uses to implement functions with configurable data. You must allocate this section within the base 64K address space of the data space.

## ☐ You must reserve address 0x7b in scratch pad memory

The CSL uses address 0x7b in the data space as a pointer to the .csldata section, which is initialized during the execution of *CSL\_init()*. For this reason, you must call *CSL\_init()* before calling any other CSL functions. Overwriting memory location 0x7b can cause the CSL functions to fail.

Example 2–1 illustrates these requirements which must be included in the linker command file.

Example 2-1. Using a Linker Command File

```
MEMORY
      PROG0: origin = 8000h, length = 0D000h
      PROG1: origin = 18000h, length = 08000h
      DATA: origin = 1000h, length = 04000h
SECTIONS
          > PROG0
   .text
   .cinit > PROG0
   .switch > PROG0
   .data
           > DATA
   .bss
          > DATA
   .const > DATA
   .sysmem > DATA
   .stack
           > DATA
   .csldata > DATA
   table1 : load = 6000h
   table2 : load = 4000h
```

### 2.3.2.5 Using Function Inlining

Because some CSL functions are short (they may set only a single bit field), incurring the overhead of a C function call is not always necessary. If you enable inline, the CSL declares these functions as *static inline*. Using this technique helps you improve code performance.

# 2.4 Rebuilding CSL

All CSL source code is archived in the file csl54xx.src located in the \C5400\bios\lib\ folder. For example, to rebuild csl5402x.lib, type the following on the command line:

mk500 csl54xx.src -dCHIP\_5402 -v548 -mf

# **Chapter 3**

# **CHIP Module**

The CSL CHIP module offers general CPU functions and macros for C54x register accesses. The CHIP module is not handle-based.

| Top | c Page    |
|-----|-----------|
| 3.1 | Overview  |
| 3.2 | Functions |

# 3.1 Overview

The CSL CHIP module offers general CPU functions. The CHIP module is not handle-based.

Table 3–1 lists the functions available as part of the CHIP module.

Table 3-1. CHIP Functions

| Function         | Purpose                                                  | See page |
|------------------|----------------------------------------------------------|----------|
| CHIP_getCpuld    | Returns the CPU ID field of the CSIDR register.          | 3-3      |
| CHIP_getMapMode  | Returns the current MAP mode of the device.              | 3-3      |
| CHIP_getRevId    | Returns the CPU revision ID.                             | 3-4      |
| CHIP_getSubsysId | Returns sub-system ID (or core) for a multi-core device. | 3-4      |

### 3.2 Functions

This section lists the functions in the CHIP module.

# CHIP\_getCpuld Get CPU ID (C5416, C5421, C5440, C5441 only)

**Function** Uint32 CHIP\_getCpuld();

**Arguments** None

Return Value CPU ID Returns the CPU (CHIP) ID Field

**Description** This function returns the CPU (CHIP) ID field of the CSIDR register.

Example Uint32 CpuId;

CpuId = CHIP\_getCpuId();

# CHIP\_getMapMode Reads the map mode bits

**Function** Uint16 CHIP\_getMapMode();

**Arguments** None

Return Value map mode Returns current device MAP mode, which will be one of the

following:

☐ CHIP\_MAP\_0: MP/MC DROM and OVLY bits are OFF

☐ CHIP\_MAP\_1: DROM bit is on ☐ CHIP MAP 2: OVLY bit is on

☐ CHIP\_MAP\_3: Both DROM and OVLY Bits are on

☐ CHIP\_MAP\_4: MP/MC bit is on

☐ CHIP\_MAP\_5: MP/MC and DROM are on☐ CHIP MAP 6: MP/MC and OVLY bits are on

☐ CHIP\_MAP\_7: MP/MC, DROM, and OVLY bits are on

**Description** Reads the map mode bits (OVLY, DROM, MPMC) from the device. In devices

not supported by a specific map-mode bit, the value returned is invalid. See the specific device data sheet for the availability of map mode bits. This

function is useful for debugging purposes.

**Example** Uint16 MapMode;

..

```
MapMode = CHIP_getMapMode();
if (MapMode == CHIP_MAP_0) {
   /* do map 0 tasks /
} else {
   /* do map 1 tasks */
}
```

# CHIP\_getRevId

CHIP\_getRevId Get revision ID (C5416, C5421 only)

**Function** Uint32 CHIP\_getRevId();

**Arguments** None

Return Value Revision ID Returns CPU revision ID

**Description** This function returns the CPU revision ID as determined by the Revision ID

field of the CSIDR register.

**Example** Uint32 RevId;

RevId = CHIP\_getRevId();

CHIP getSubsysld Get subsystem ID (C5421, C5440, C5441 only)

**Function** Uint32 CHIP\_getSubsysId();

**Arguments** None

Return Value Subsytem ID

**Description** Get the sub-system ID (or core) from a multi-core device from the CSIDR

register.

Example Uint32 RevId;

RevId = CHIP\_getSubsysId();

# Chapter 4

# **DAA Module**

This chapter contains general descriptions for the DAA (Data Access Arrangement) configuration structures, functions, and macros.

| C                        | Page     |
|--------------------------|----------|
| Overview                 | 4-2      |
| Configuration Structures | 4-4      |
| Functions                | 4-7      |
| Macros                   | 4-11     |
|                          | Overview |

### 4.1 Overview

The on-chip DAA (Data Access Arrangement) is the system (digital) side of a two-chip integrated DAA solution that provides a programmable line interface to meet global telephone line requirements. The DAA has built in A/D and D/A converters for telephone line data and these converters interface to the DSP core through a dedicated DSP serial port (McBSP #2).

Programming of the DAA registers is implemented through the same serial port. This eliminates the need for an isolation transformer, relays, opto—isolators, and a 2 to 4-wire hybrid, and reduces the cost of discrete components required to achieve compliance with global regulatory requirements.

### Note:

This DAA chip requires the line (analog) side DAA (Silicon Labs Si3016) for operation.

## 4.1.1Configuration Structures

Table 4-1. DAA Configuration Structures

| Configuration Structure              | Purpose                           | See page |
|--------------------------------------|-----------------------------------|----------|
| DAA_CircBufCtrl                      | Circular buffer control structure | 4-4      |
| DAA_Params                           | Parameters structure              | 4-4      |
| DAA_PrivateObject/DAA/<br>DAA_Handle | Private object/Handle structure   | 4-5      |
| DAA_DevSetup                         | Device setup structure            | 4-6      |
| DAA_Setup                            | DAA setup structure               | 4-6      |

# 4.1.2 Functions

Table 4-2. DAA Functions

| Functions               | Purpose                                             | See page |
|-------------------------|-----------------------------------------------------|----------|
| DAA_setup               | Sets up DAA devices                                 | 4-7      |
| DAA_close               | Stops a DAA function                                | 4-8      |
| DAA_reset               | Hardware reset function for the on-chip DAA         | 4-8      |
| DAA_readWrite           | DAA read/write function                             | 4-9      |
| DAA_availability        | Returns available words in the circular buffer      | 4-9      |
| DAA_resetInternalBuffer | Resets the pointers of the internal circular buffer | 4-9      |
| DAA_delay               | Implements a delay count of McBSP frame syncs       | 4-10     |
| DAA_isr                 | DAA interrupt service routine                       | 4-10     |

# 4.1.3 Macros

Table 4-3. DAA Macros

| Macros    | Purpose                                                                            | See page |
|-----------|------------------------------------------------------------------------------------|----------|
| DAA_RGETH | Macro to read DAA register                                                         | 4-11     |
| DAA_RSETH | Macro to write a value to a DAA register                                           | 4-11     |
| DAA_ADDR  | Returns a DAA register address                                                     | 4-12     |
| DAA_FMK   | Returns a 16-bit register value for <b>REG</b> with <b>FIELD</b> set to <b>VAL</b> | 4-12     |

# 4.2 Configuration Structures

(Example of structures are included in the Functions section)

### DAA CircBufCtrl

DAA Circular Buffer Control Structure

### **Members**

### **Description**

The user must create this circular buffer control structure, and include it in the DAA private object structure (DAA\_PrivateObject). The structure is initialized by the DAA\_setup(...) function. One circular buffer control structure must be created for each DAA device.

### DAA Params

### DAA Parameters Structure

### **Members**

```
Uint16 txAttenuation
                           /* analog transmit attenuation, valid attenuation
                           /* values are: */
DAA_GCR_ATX_ATT_0db
DAA_GCR_ATX_ATT_3db
DAA_GCR_ATX_ATT_6db
DAA GCR ATX ATT 9db
DAA_GCR_ATX_ATT_12db
                           /* cid receive attenuation/analog receive gain,
Uint16 rxGain
                           /* valid */
                           /* attenuation/gain values are: */
DAA_GCR_ARX_ATT_0db
DAA_GCR_ARX_ATT_1db
DAA_GCR_ARX_ATT_2.2db
DAA_GCR_ARX_ATT_3.5db
DAA GCR ARX ATT 5db
DAA GCR ARX GAIN 0db
DAA GCR ARX GAIN 3db
DAA GCR ARX GAIN 6db
DAA_GCR_ARX_GAIN_9db
DAA_GCR_ARX_GAIN_12db
Uint16 sampleRateReg7
                           /* sample rate control - register 7,
                           /* valid values are: */
DAA_SRCTRL_SRC_7200
```

```
DAA_SRCTRL_SRC_8000
DAA SRCTRL SRC 8229
DAA_SRCTRL_SRC_8400
DAA_SRCTRL_SRC_9000
DAA_SRCTRL_SRC_9600
DAA_SRCTRL_SRC_10286
Uint16 sampleRateReg8
                           /* sample rate control - register 8 */
                           /* sample rate control - register 9 */
Uint16 sampleRateReg9
                           /* sample rate control - register 10*/
Uint16 sampleRateReg10
                           /* international control register 1 value */
Uint16 ictrl1
Uint16 ictrl2
                           /* international control register 2 value */
                           /* international control register 3 value */
Uint16 ictrl3
                           /* pre-defined country-specific macros for the three */
                           /* international control registers are: */
DAA_AUSTRALIA
DAA_BULGARIA
DAA_CHINA
DAA_CTR21 (Europe)
DAA_ CZECH_REPUBLIC
DAA_FCC (same as DAA_USA)
DAA_ HUNGARY
DAA JAPAN
DAA_ MALAYSIA
DAA_ NEW_ZEALAND
DAA PHILIPPINES
DAA_ POLAND
DAA_ SINGAPORE
DAA_ SLOVAKIA
DAA_SLOVENIA
DAA_SOUTH_AFRICA
DAA_SOUTH_KOREA
DAA_USA
```

### **Description**

The user must create this DAA parameters structure, initialize all members, and include it in the DAA single device setup structure (DAA\_DevSetup). One parameter structure may be used for multiple DAA devices.

# DAA\_PrivateObject/DAA\_Handle Private Object/Handle Structure

#### Members

```
MCBSP_Handle mcbspHandle
                                 /* McBSP 2 Handle */
Int16 state
                                 /* current control and read/write state */
                                 /* DAA register request - read or write */
Uint16 regRequest
                                 /* Flag to indicate register IO complete */
CSLBool
             isIOReqReady
                                 /* Value of DAA register value just read or to
Uint16 regValue
                                 /* be written */
Uint16 regIndex
                                 /* Index of DAA register value just read or to
                                 /* be written */
Uint16 buffLength
                                 /* buffer length for DAA read/write function */
```

### Description

The user must create this private object/handle structure, initialize all members, and include it in the DAA single device setup structure (DAA\_DevSetup). One private object structure must be created for each DAA device. This private object/handle serves as the state machine for the DAA device.

### DAA DevSetup

DAA Single Device Setup Structure

### **Members**

```
DAA_Params
             *params
                          /* DAA parameters (initial register values) */
DAA Handle
             daaHandle
                          /* pointer to DAA private object created by user */
Uint16
             mcbspPort
                          /* MCBSP port the DAA is connected to */
                          /* MCBSP_PORT2 (for internal DAA) */
             *pCircBuf
                          /* pointer to the user-allocated circular buffer */
Int.16
Uint16
             circBufSize /* circular buffer size */
             circBufOffset/* Initial circular buffer offset */
Uint16
Uint16
             dataLength
                          /* Length of data buffer (callback size) */
                          /* void pointer to device ID */
Void
             *pID
DAA_CallBack dataCallBack /* pointer to user-defined data callback function */
DAA_CallBack ctrlCallBack /* pointer to user-defined control callback function */
DAA RstFxn reset
                          /* pointer to DAA hardware reset control function */
                          /* for internal DAA, use &DAA_reset */
```

### Description

The user must create this single device setup structure, initialize all members, and include it in the DAA setup structure (DAA\_Setup). One device structure must be created for each DAA device. The DAA setup structure is passed to the function DAA\_setup(..).

### DAA\_Setup

# DAA Setup Structure

### **Members**

```
Uint16 numDevs /* number of devices to be set up, must be greater /* that 0 */
DAA_DevSetup **dev /* pointer to array of device setup structure /* pointers */
```

### Description

The user must create DAA setup structure, initialize all members, and pass it to the DAA setup function, DAA\_setup(..).

#### 4.3 Functions

## void DAA\_setup

Pointer to DAA setup structure

**Arguments** 

DAA Setup \*

**Return Value** 

None

Description

This function sets up a number of DAA devices according to the value of numDevs in the setup structure and initializes the state machines. The function enables the IMR fields for the DAA interrupts. However, it is the responsibility of the user to plug the corresponding DAA ISRs into the vector table. Each of these user ISRs must call the function DAA\_isr(...). Note that this function takes a pointer to a DAA private object as it's argument. This function makes calls to the CSL MCBSP module.

Important: The DAA\_DevSetup structure passed through the DAA\_Setup structure to this function defines a data callback length. As soon as interrupts are globally enabled, following a call to this function, the state machine starts invoking data callbacks whenever it has the specified number of words in the circular buffer.

#### **Example**

```
DAA DevSetup setupStruct ={
&daaParams,
&daaPrivateObject,
MCBSP_PORT2,
circBuff,
40,
5,
10,
(void *)0,
(DAA_CallBack)&dataCB,
(DAA_CallBack)&ctrlCB,
&DAA reset
};
DAA_DevSetup *devArray[] = {&devSetup};
DAA Setup setup = {
1,
devArray
```

```
};
    DAA_setup(&setup);
void dataCB(void* pID, Arg task, Uns result)
{
/* submit next readwrite request */
DAA_readWrite(handle, dataBuff, 10);
/* Post buffer processing function */
}
```

### DAA close

## Handle to DAA device

**Arguments** DAA\_Handle

Return Value None

**Description** This function stops the DAA device operation. The function also closes the

corresponding McBSP port.

**Example** DAA\_Handle handle;

DAA close(handle);

#### DAA\_reset

# DAA flag to select hardware

Arguments Uint16 Flag to select hardware reset (1) /unreset (0).

Return Value None

**Description** Flag to select hardware **reset** (1) /unreset (0). It is used during the setup

operation (DAA\_setup(...)). This address of this function should be passed to

the setup function for the on-chip DAA.

**Example** See example in 2.0.

DAA\_readWrite Copies size words from the data read/write buffer

**Arguments** DAA Handle Handle to DAA device

Int16 \* Pointer to data read/write buffer Uint16 Size of data read/write buffer

**Return Value** Int16 Number of received words in buffer. Zero is returned if there is an error

in dataBuff or size arguments.

**Description** This function copies *size* words from the data read/write buffer into the internal

circular buffer for transmission and fills the buffer with **size** received data from the circular buffer. Note: This function does not check for how much data is in the circular buffer. Therefore, the user must call DAA\_availability to determine how much data is available in the circular buffer before calling the function.

**Example** DAA\_Handle handle;

Int16 buff[20];
Uint16 size = 20;

DAA\_readWrite(handle, buff, size);

DAA\_availabilty Returns available words in the circular buffer

**Arguments** DAA\_Handle Handle to DAA device

**Return Value** Int16 Number of available words in circular buffer.

**Description**This function returns the number of available (received) words in the circular

buffer.

**Example** DAA Handle handle;

Int16 bufCount;

BufCount = DAA\_availability(handle);

DAA resetInternalBuffer Resets the pointers of the internal circular buffer

**Arguments** DAA\_Handle Handle to DAA device

Return Value None.

**Description** This function resets the pointers of the internal circular buffer. This action is

equivalent to clearing out the buffer.

**Example** DAA\_Handle handle;

DAA\_resetInternalBuffer(handle);

#### DAA delay

## Implements a delay of count McBSP frame syncs

**Arguments** 

DAA\_Handle Handle to DAA device

Uint16

Number of McBSP frame-syncs to delay for

**Return Value** 

CSLBool

TRUE Indicates "Accepted" and FALSE "rejected".

Description

This function requests a delay of length count McBSP frame syncs. The function returns immediately with an indication of whether the request was accepted (TRUE) or rejected (FALSE). If accepted, the user defined control callback will be invoked when the delay is done with a flag of "\_DAA\_DELAY". If not, the user must keep invoking the function until it is accepted.

#### **Example**

```
Void main(void)
{
         DAA_Handle handle;
        Uint16 delay;
While(!DAA_delay(handle, delay));
...
...
}
        void ctrlCB(void* pID, Uint16 task, Uint16 arg)
{
         if (task & _DAA_DELAY)
        {
             printf("delay is done!\n");
        }
        }
}
```

## DAA isr

#### DAA interrupt service routine

Arguments

DAA Handle Handle to DAA device

**Return Value** 

None.

Description

This is the DAA state machine and must be invoked on every DAA receive interrupt.

**Example** 

```
DAA_Handle handle;
   Interrupt void myDAAIsr(void)
   {
        DAA_isr(handle);
   }
```

#### 4.4 Macros

#### DAA RGETH

## Macros used to read a DAA register

**Arguments** 

DAA\_Handle Handle to DAA device Reg DAA register name

**Return Type** 

CSLBool TRUE Indicates "Accepted" and FALSE "rejected".

**Description** 

This macro reads a DAA register. The macro returns immediately with an indication of whether the request was accepted (TRUE) or rejected (FALSE). If accepted, the user defined control callback will be invoked when the register read is done with a flag of "\_DAA\_REG\_READ". If not, the user must keep invoking the macro until it is accepted.

**Example** 

```
Void main(void)
{
    DAA_Handle handle;
While(!DAA_RGETH(handle, DAACTRL1));
...
...
}
    void ctrlCB(void* pID, Uint16 task, Uint16 arg)
{
        if (task & _DAA_REG_READ)
         {
            printf("DAA control 1 register has a value of %d\n", &arg);
        }
    }
}
```

# DAA RSETH

# Macro used to write a value to a DAA register

**Arguments** 

DAA\_Handle Handle to DAA device REG DAA register name

VAL Register value to be written

**Return Type** 

CSLBool TRUE Indicates "Accepted" and FALSE "rejected".

**Description** 

This macro writes a value to a DAA register. The macro returns immediately with an indication of whether the request was accepted (TRUE) or rejected (FALSE). If accepted, the user defined control callback will be invoked when the register write is done with a flag of "\_DAA\_REG\_WRITE". If not, the user must keep invoking the macro until it is accepted.

Example

```
Void main(void)
{
    DAA_Handle handle;
    Uint16 val = DAA_DAACTRL1_OH_OFFHOOK;
/* Take DAA off-hook */
While(!DAA_RSETH(handle, DAACTRL1, val));
...
...
}
    void ctrlCB(void* pID, Uint16 task, Uint16 arg)
{
        if (task & _DAA_REG_WRITE)
        {
            printf("DAA control 1 register write complete!\n");
        }
    }
}
```

## DAA\_ADDR

# Macro used to return the address of a DAA register

**Arguments** REG DAA register name e.g SRCTRL

Return Type REGADDR Register address

**Description** This macro returns the address of a DAA register.

**Example** reg5Addr = DAA\_ADDR(DAACTRL1);

## DAA FMK

# Macro used to return 16-bit register values

**Arguments** REG DAA register name

FIELD Field name VAL Field value

**Return Type** REGADDR Register address

**Description** This macro returns a 16-bit register value for **REG** with **FIELD** set to **VAL**.

**Example** offhook = DAA\_FMK(DAACTRL1, OH, 1);

# Chapter 5

# **DAT Module**

The handle-based DAT (data) module allows you to use DMA hardware to move data.

| Торіс |     | Page          |
|-------|-----|---------------|
|       | 5.1 | Overview 5-2  |
|       | 5.2 | Functions 5-4 |

#### 5.1 Overview

The handle-based DAT (data) module allows you to use DMA hardware to move data. This module works the same for all devices that support DMA regardless of the type of DMA controller; therefore, any application code using the DAT module is compatible across all devices as long as the DMA supports the specific address reach and memory space.

The DAT copy operations occur on dedicated DMA hardware independent of the CPU. Because of this asynchronous nature, you can submit an operation to be performed in the background while the CPU performs other tasks in the foreground. Then you can use the DAT\_wait() function to block completion of the operation before moving to the next task.

Since the DAT module uses the DMA peripheral, it cannot use a DMA channel that is already allocated by the application. To ensure this does not happen, you must call the DAT\_open() function to allocate a DMA channel for exclusive use. When the module is no longer needed, you can free the DMA resource by calling DAT\_close().

Table 5–1 lists the functions for use with the DAT modules. The functions are presented in the order that they will typically be used in an application.

#### Note:

# 1) Multiplexing Across Different Devices:

To simplify the Interrupt multiplexing across different devices, the C54x DAT module uses only DMA channels 2 and 3.

# 2) Memory Spaces:

The DAT module contains functions to copy data from one location to another and to fill a region of memory in program, data, or I/O space valid for the specific device (Refer to the C54x data sheets). CSL does not perform any searches for invalid memory addresses.

# Table 5–1. DAT Functions

| Function Purpose |                                                                                           | See page |
|------------------|-------------------------------------------------------------------------------------------|----------|
| DAT_close()      | e() Closes a DAT channel                                                                  |          |
| DAT_copy()       | Copies a linear block of data from src to dst using DMA hardware                          | 5-4      |
| DAT_copy2D()     | Copies 2D data from src to dst using DMA hardware                                         | 5-6      |
| DAT_fill()       | AT_fill() Fills a linear block of memory with the specified fill value using DMA hardware |          |
| DAT_open()       | Opens a DAT channel                                                                       | 5-9      |
| DAT_wait()       | Waits for a previous transfer to complete                                                 | 5-10     |

# 5.2 Functions

This section describes, in alphabetical order, the functions in the DAT module.

| DAT_close    | Closes the DAT module                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Function     | void DAT_close(     DAT_Handle hDat );                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Arguments    | hDat Handle to a DAT channel (obtained via DAT_open)                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Return Value | None                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Description  | Closes a DAT channel previously opened with DAT_open(). Any pending requests are first allowed to complete.                                                                                                                                                                                                                                                                                                                                                                                 |
| Example      | <pre>DAT_close(hDat);</pre>                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| DAT_copy     | Copies linear block of data from src to dst                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Function     | Uint16 DAT_copy( DAT_Handle hDat, Uint32 src, Uint32 dst, Uint16 ElemCnt );                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Arguments    | hDat Handle to a DAT channel (obtained via DAT_open) src Source address ORed with any of the following memory space symbols:  DAT_PROGRAM_SPACE (Not valid for devices 5402, 5471, and 5472)  DAT_DATA_SPACE  DAT_IO_SPACE (Not valid for devices 5402, 5471, and 5472)  For example:  0x10000   DAT_PROGRAM_SPACE indicates address 0x10000 in program space  0x10000   DAT_DATA_SPACE indicates address 0x10000 in data space  0x100   DAT_IO_SPACE indicates address 0x100 in I/O space; |

dst Destination address ORed with a memory space symbol

ElemCnt Number of 16-bit words to copy

**Return Value** 

DMA status Returns status of data transfer at the moment of exiting the

routine:

0: transfer complete1: on-going transfer

**Description** 

Copies a linear block of data from src to dst using DMA hardware.

You must open the DAT channel with DAT\_open() before calling this function. You can use the DAT\_wait() function to poll for the completed transfer of data.

**Example** 

```
#define DATA_SIZE 256 // number of 16-bit elements to transfer
Uint16 BuffA[DATA_SIZE];
Uint16 BuffB[DATA_SIZE];
DAT_Handle hDat;
main() {
...
   hDat = DAT_open(DAT_CHA_ANY,DAT_PRI_LOW,0);
DAT_copy(
     hDat,
     (Uint32) (&BuffA) | DAT_DATA_SPACE,
     (Uint32) (&BuffB) | DAT_DATA_SPACE,
     DATA_SIZE
   );
...
}
```

# Copies data from src to dst DAT copy2D **Function** Uint16 DAT copy2D( DAT Handle hDat, Uint16 Type, Uint32 src. Uint32 dst. Uint16 LineLen, Uint16 LineCnt, Uint16 LinePitch ); Arguments hDat Handle to a DAT channel (obtained via DAT open) Type Type of 2D DMA transfer, must be one of the following: ☐ DAT\_1D2D : 1D to 2D transfer ☐ DAT 2D1D : 2D to 1D transfer ☐ DAT\_2D2D : 2D to 2D transfer Pointer to source ORed with any of the following memory src space symbols: ☐ DAT\_PROGRAM\_SPACE (Not valid for devices 5402, 5471, and 5472) □ DAT DATA SPACE ☐ DAT\_IO\_SPACE (Not valid for devices 5402, 5471, and 5472) For example: □ 0x10000 | DAT\_PROGRAM\_SPACE indicates address 0x10000 in program space; □ 0x10000 | DAT\_DATA\_SPACE indicates address 0x10000 in data space; □ 0x100 | DAT\_IO\_SPACE indicates address 0x100 in I/Ospace; dst Pointer to destination address ORed with a memory space symbol LineLen Number of 16-bit words to copy for each line LineCnt Number of lines to copy LinePitch Pitch of each line, number of 16-bit words **Return Value** DMA status Returns status of data transfer at the moment of exiting the

routine:

0: transfer complete1: on-going transfer

# Description

This function copies 2D data from src to dst using DMA hardware.

You must open the DAT channel with DAT\_open() before calling this function. You can use the DAT\_wait() function to poll for the completed transfer of data.

# **Example**

```
#define DATA_SIZE 256
Uint16 BuffA[DATA_SIZE];
Uint16 BuffB[DATA_SIZE];
DAT_Handle hDat;
main(){
...
    hDat = DAT_open(DAT_CHA_ANY,DAT_PRI_LOW,0);
    DAT_copy2D(
        hDat,
        DAT_2D2D,
        (Uint32) (&BuffA) | DAT_DATA_SPACE,
        (Uint32) (&BuffB) | DAT_DATA_SPACE,
        10,20,10
    );
...
}
```

# Fills linear block of memory with specified fill value DAT fill **Function** Uint16 DAT fill( DAT Handle hDat: Uint32 dst. Uint16 ElemCnt. Uint32 Value ); **Arguments** hDat Handle to a DAT channel dst Destination address ORed with any of the following memory space symbols: □ DAT\_PROGRAM\_SPACE □ DAT DATA SPACE □ DAT\_IO\_SPACE For example: □ 0x10000 | DAT PROGRAM SPACE indicates address 0x1000 in program space; □ 0x10000 | DAT\_DATA\_SPACE indicates address 0x10000 in data space; □ 0x100 | DAT IO SPACE indicates address 0x100 in I/Ospace; ElemCnt Number of bytes to fill (must be power of 2) Value fill value **Return Value** DMA status Returns status of data transfer at the moment of exiting the routine: 0: transfer complete 1: on-going transfer Description Fills a linear block of memory with the specified fill value using DMA hardware. You must open the DAT channel with DAT\_open() before calling this function. You can use the DAT\_wait() function to poll for the completed transfer of data. Example #define BUFF\_SIZE 256; Uint16 Buff[BUFF\_SIZE]; Uint32 FillValue = 0xA5A5; DAT\_Handle hDat; hDat = DAT\_open(DAT\_CHA\_ANY,DAT\_PRI\_LOW,0); DAT\_fill( hDat, (Uint32)(&Buff) | DAT\_DATA\_SPACE, BUFF\_SIZE, FillValue

);

# Opens a DAT module DAT open **Function** DAT\_Handle DAT\_open( int ChaNum, int Priority, Uint32 Flags ); ChaNum Specifies which DMA channel to allocate; must be one of the **Arguments** following: ☐ DAT CHA ANY (allocates Channel 2 or 3) ☐ DAT CHA2 ☐ DAT CHA3 **Priority** Specifies the priority of the DMA channel, must be one of the following: □ DAT\_PRI\_LOW sets the DMA channel for low priority level ☐ DAT PRI HIGH sets the DMA channel for high priority level Miscellaneous open flags (currently None available). Flags **Return Value** Handle for DAT channel. If the requested DMA channel is currently being used, an INV(-1) value is returned. Description Opens the DAT module. You must call this function before using any of the other DAT API functions. The ChaNum argument specifies which DMA channel to open for exclusive use by the DAT module. Currently, no flags are defined and the argument should be set to zero. **Example 1** To open a DAT channel using any available DMA channel (2 or 3 only) in low priority mode: DAT\_Handle hdat; hdat = DAT\_open(DAT\_CHA\_ANY,DAT\_PRI\_LOW,0); **Example 2** To open the DAT channel using DMA channel 2 in high priority mode: DAT Handle hdat; hdat = DAT\_open(DAT\_CHA2,DAT\_PRI\_HIGH,0);

#### DAT wait

## Waits for previous transfer to complete

**Function** 

```
void DAT_wait(
    DAT_Handle hDat
);
```

**Arguments** 

hDat Handle to a DAT channel

**Return Value** 

None

**Description** 

This function polls the IFR flag to see if the DMA channel has completed a transfer. If the transfer is already completed, the function returns immediately. If the transfer is not complete, the function waits for completion of the transfer as identified by the handle; interrupts are not disabled during the wait.

Example

```
Uint16 TransferStat;
DAT_Handle hDat;
main(){
...
   hDat = DAT_open(DAT_CHA_ANY, DAT_PRI_LOW, 0);
   ...
   TransferStat = DAT_copy(hDat, src,dst,len);
   /* custom DAT configuration */
   if (TransferStat)
   DAT_wait(hDat);
...
}
```

# Chapter 6

# **DMA Module**

This chapter describes the structure, functions, and macros of the DMA module.

| Topi | C Pag                                         |
|------|-----------------------------------------------|
| 6.1  | Overview 6-2                                  |
| 6.2  | Configuration Structure 6-4                   |
| 6.3  | Functions 6-7                                 |
| 6.4  | Macros 6-20                                   |
| 6.5  | Configuring the DMA Module Using CSL GUI 6-32 |
| 6.6  | Examples 6-40                                 |

#### 6.1 Overview

The DMA module is a handle-based module that requires a call to DMA\_open() to obtain a handle before any other functions are called.

The CSL module is not the same for all C54x devices. The differences mainly relate to:

Individual channel register reload support

Extended Data Memory Support

For more information regarding the DMA support in the C54x family, refer to Table 1–9 on page 1-17.

Table 6–1 lists the configuration structure for use with the DMA functions. Table 6–2 lists the functions available in the CSL DMA module.

Table 6-1. DMA Configuration Structure

| Structure     | Purpose                                                                                               | See page |
|---------------|-------------------------------------------------------------------------------------------------------|----------|
| DMA_Config    | DMA structure that contains all local registers required to set up a specific DMA channel.            | 6-4      |
| DMA_GblConfig | Global DMA structure that contains all global registers that you may need to initialize a DMA channel | 6-5      |

Table 6-2. DMA Functions

#### (a) DMA Primary Functions

| Function                             | Purpose                                                                  | See page |
|--------------------------------------|--------------------------------------------------------------------------|----------|
| DMA_close() Closes a DMA channel     |                                                                          | 6-7      |
| DMA_config()                         | Sets up the DMA channel using the configuration structure 6-7            |          |
| DMA_configArgs()                     | () Sets up the DMA channel using the register values passed in 6-8       |          |
| DMA_open()                           | Opens a DMA channel                                                      | 6-10     |
| DMA_pause()                          | Pauses a DMA channel. Identical to DMA_stop().                           | 6-11     |
| DMA_reset()                          | A_reset() Resets DMA channel register to their power-on reset value 6-11 |          |
| DMA_start()                          | Starts a DMA channel                                                     | 6-11     |
| DMA_stop() Disables a DMA channel 6- |                                                                          | 6-12     |

# Table 6–2. DMA Functions (Continued)

# (b) DMA Global Register Function

| Function               | Purpose                                                     | See page |
|------------------------|-------------------------------------------------------------|----------|
| DMA_globalAlloc()      | Allocates a global DMA register                             | 6-12     |
| DMA_globalConfig()     | Sets up the DMA channel using the configuration structure   | 6-14     |
| DMA_globalConfigArgs() | Sets up the DMA channel using the register values passed in | 6-15     |
| DMA_globalFree()       | Frees a global DMA register that was previously allocated   | 6-16     |
| DMA_globalGetConfig()  | Gets DMA global register configuration                      | 6-17     |
| DMA_resetGbl()         | Resets the DMA global registers                             | 6-17     |

# (c) DMA Auxiliary Functions

| Function Purpose |                                                           | See page |
|------------------|-----------------------------------------------------------|----------|
| DMA_autostart()  | Enables a DMA channel                                     | 6-18     |
| DMA_getConfig()  | Get DMA channel configuration                             | 6-18     |
| DMA_getEventId() | Returns the IRQ Event ID for the DMA completion interrupt | 6-19     |

# 6.2 Configuration Structure

Because the DMA has both local and global registers to each channel, the CSL DMA Module has two configuration structures:

■ DMA\_Config (channel configuration structure) contains all the local registers required to set up a specific DMA channel.

□ DMA\_GblConfig (global configuration structure) contains all the global registers that you may need to initialize a DMA channel. These global registers are resources shared across the different DMA channels and include element/frame indexes, reload registers, as well as src/dst page registers.

You can use literal values or the \_RMK macros to create the structure member values.

# DMA\_Config

# DMA channel configuration structure

# Structure

**Members** 

21VII T OHAHITOI OOTIII GATALIOTT OLI AO

Uint16 priority DMA channel priority

For devices supporting individual channel reload registers (see note) add:
Uint16 autoix Provided for compatibility with older versions of DMA

For all devices add:

DMA Config

Uint16 dmmcr DMA transfer mode control register

Uint16 dmsfc DMA sync select and frame count register

DMA\_AdrPtr dmsrc DMA source address register
DMA\_AdrPtr dmdst DMA destination address register
Uint16 dmctr DMA element count register

For devices supporting individual channel reload registers (see note) add:

DMA\_AdrPtr dmgsa
DMA source address reload
DMA\_AdrPtr dmgda
DMA destination address reload
Uint16 dmgcr
DMA element count reload
DMA frame count reload

For devices supporting individual channel extended data memory addressing (see note), add:

Uint16 dmsrcdp data page for src Uint16 dmdstdp data page for dst

#### Note:

For more information concerning these devices, see section 1.8 *Device-Specific Features Support*.

#### **Description**

This DMA configuration structure is used to set up a DMA channel. You create and initialize this structure then pass its address to the DMA\_config() function. You can use literal values or the DMA\_REG\_RMK macros to create the structure member values.

#### **Example**

```
DMA_Config MyConfig = {
                    /* priority */
0 \times 00000,
                    /* xfrctrl
                                    * /
0x0000,
                     /* syncframe */
(DMA_AdrPtr) 0x0300, /* src
(DMA_AdrPtr) 0x0400, /* dst
                                    * /
0 \times 00 FF
                     /* xfrcnt
                                   * /
};
```

# DMA GblConfig

## DMA global configuration structure

#### Structure

DMA\_GblConfig

#### **Members**

Uint16 free

run free under emulation control

For devices supporting individual channel reload registers (see note) add: Uint16 autoix For compatibility with older versions of DMA

For all devices add:

Uint16 gbldmsrcp global program page for src Uint16 gbldmdstp global program page for dst Uint16 gbldmidx0 global element index 0 Uint16 gbldmfri0 global frame index 0 Uint16 gbldmidx1 global element index 1 Uint16 gbldmfri1 global frame index 1

For devices not offering global channel reload registers (see note), add:

DMA\_AdrPtr gbldmgsa global src address reload DMA AdrPtr gbldmgda global dst address reload Uint16 gbldmgcr global element count reload Uint16 gbldmgfr global frame count reload

For devices supporting global extended data memory addressing (see note), add:

Uint16 gbldmsrcdp;

global data page for src Uint16 gbldmdstdp; global data page for dst

#### Note:

For more information concerning these devices, see section 1.8, *Device-Specific Features Support*.

# Description

You can use literal values or the DMA\_REG\_RMK macros to create the structure member values.

#### Example 1

```
DMA_GblConfig MyGblConfig = {
                      0, /* stop under emulation control */
                      10, /* src program page
                                                             * /
                      20, /* dst program page
                                                            * /
                      0x1, /* index 0
                                                             * /
                                                            * /
                      0x4 /* frame index 0
                      0,
                          /* index 1
                                                             */
                      0, /* frame index 1
                                                            * /
                      0, /* src data page
                                                            * /
                          /* dst data page
                                                            * /
}
```

In this example, source and destination pages are hard-coded.

For a complete example, see Example 2 in section 6.6.

#### Example 2

# 6.3 Functions

This section describes the functions in the DMA CSL module.

# **6.3.1 DMA Primary Functions**

| DMA_close    | Closes DMA channel                                                                                                                                                                                                                                                       |  |  |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Function     | void DMA_close(     DMA_Handle hDma );                                                                                                                                                                                                                                   |  |  |
| Arguments    | hDma Handle to DMA channel; see DMA_open()                                                                                                                                                                                                                               |  |  |
| Return Value | None                                                                                                                                                                                                                                                                     |  |  |
| Description  | Closes a DMA channel previously opened with DMA_open(). The registers for the DMA channel are set to their power-on reset defaults, then the completion interrupt is disabled and cleared.                                                                               |  |  |
| Example      | <pre>DMA_close(hDma);</pre>                                                                                                                                                                                                                                              |  |  |
| DMA_config   | Sets up DMA channel using configuration structure                                                                                                                                                                                                                        |  |  |
| Function     | void DMA_config(     DMA_handle hDma,     DMA_Config *Config );                                                                                                                                                                                                          |  |  |
| Arguments    | hDma Handle to DMA channel; see DMA_open(). Config Pointer to an initialized configuration structure (See DMA_Config)                                                                                                                                                    |  |  |
| Return Value | None                                                                                                                                                                                                                                                                     |  |  |
| Description  | Sets up the DMA channel using the configuration structure. The values of the structure are written to the DMA registers. To start the DMA channel, call the DMA_start() function. DMA_Config() initializes the DMA channel register, but does not start the DMA channel. |  |  |

#### Example

```
DMA_Config MyConfig = {
  0x0,
                       /*priority */
                       /* mcr
  0x0000,
                                    * /
  0x0000,
                        /* sfc
                                    * /
  (DMA_AdrPtr) 0x0300, /* src
                                    * /
  (DMA_AdrPtr) 0x0400, /* dst
                                   * /
  0x00FF
                        /* ctr
                                    * /
};
   DMA_config(hDma,&MyConfig);
```

For complete examples, please refer to section 6.6, Examples.

# DMA\_configArgs

Sets up DMA channel with register values

#### **Function**

```
void DMA_configArgs(
DMA_Handle hDma,
```

Uint16 priority,

For devices supporting individual channel reload registers (see note) add:

Uint16 autoix (Provided for compatibility with older versions of DMA)

For all devices add:

Uint16 dmmcr,

Uint16 dmsfc,

Uint16 dmsrc.

Uint16 dmdst,

Uint16 dmctr,

For devices supporting individual channel reload registers (see note), add:

Uint16 dmgsa,

Uint16 dmgda,

Uint16 dmgcr,

Uint16 dmgfr,

For devices supporting individual channel extended data memory addressing (see note), add:

```
Uint16 dmsrcdp,
Uint16 dmdstdp
);
```

#### Note:

For more information concerning these devices, see section 1.8, *Device-Specific Features Support*.

#### **Arguments**

hDma Handle to DMA channel; see DMA\_open()

priority DMA channel priority

For devices supporting individual channel reload registers (see note) add: Uint16 autoix (Provided for compatibility with older versions of DMA)

dmmcr DMA transfer mode control register value

dmsfc DMA sync select and frame count register value

dmsrc DMA source address register value
dmdst DMA destination address register value
dmctr DMA element count register value

For devices supporting individual channel reload registers (see note):

dmgsa Pointer to DMA source address reload value dmgda Pointer to DMA destination address reload value

dmgcr DMA element count reload value dmgfr DMA frame count reload value

For devices supporting individual channel extended data memory addressing (see note), add:

Uint16 dmsrcdp data page for src Uint16 dmdstdp data page for dst

#### **Return Value**

#### None

#### Description

Sets up the DMA channel with the register values passed to the function. The register values are written to the DMA registers. To start the DMA channel, you must call the DMA\_start() function. DMA\_Config() initializes the DMA channel register, but **does not** start the DMA channel.

You may use literal values for the arguments; or for readability, you may use the *MK macros* to create the register values based on field values.

# **Example**

```
DMA_configArgs(hDma,
    0x0000, /* channel priority */
    0x0000, /* mcr */
    0x0000, /* sfc */
    0x0300, /* src */
    0x0400, /* dst */
    0x00FF /* ctr */
);
```

For a complete example, see Section 5.4, Example 1B.

| DMA_open     | Opens DMA o                                                                                                                                                                                                                                                                                           | channel                                                                                                                                                                                                 |  |
|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Function     | int ChaNum                                                                                                                                                                                                                                                                                            | DMA_Handle DMA_open( int ChaNum, Uint32 Flags );                                                                                                                                                        |  |
| Arguments    | ChaNum                                                                                                                                                                                                                                                                                                | DMA channel to open: DMA_CHA_ANY DMA_CHA0 DMA_CHA1 DMA_CHA2 DMA_CHA3 DMA_CHA4 DMA_CHA5                                                                                                                  |  |
|              | Flags                                                                                                                                                                                                                                                                                                 | Open flags (logical OR of any of the following):<br>DMA_OPEN_RESET                                                                                                                                      |  |
| Return Value | Device handle                                                                                                                                                                                                                                                                                         | Handle to newly opened device                                                                                                                                                                           |  |
| Description  | Opens a DMA channel. Before a DMA channel can be used, you must first call this function to open the channel. Once opened, it cannot be opened again before you call DMA_close(). The return value is a unique device handle for use in subsequent DMA API calls. If the open fails, INV is returned. |                                                                                                                                                                                                         |  |
|              | You can use th                                                                                                                                                                                                                                                                                        | is function in either of the following ways:                                                                                                                                                            |  |
|              |                                                                                                                                                                                                                                                                                                       | actly which physical channel to open. CHA_ANY to allow the library pick an unused channel.                                                                                                              |  |
|              | to the power-o                                                                                                                                                                                                                                                                                        | e DMA_OPEN_RESET flag, the DMA channel registers are set on reset defaults and the channel interrupt is disabled and is flag when the DMA channel has been running to clean presus and interrupt flags. |  |
| Example      | DMA_Handle hDma;                                                                                                                                                                                                                                                                                      |                                                                                                                                                                                                         |  |

hDma = DMA\_open(DMA\_CHA\_ANY,DMA\_OPEN\_RESET);

DMA\_pause Pauses DMA channel

**Function** void DMA\_pause(

DMA Handle hDma

);

**Arguments** hDma Handle to DMA channel; see DMA\_open().

Return Value None

**Description** Identical to DMA\_stop(). This is provided for compatibility with other TMS320

devices only.

**Example** DMA\_pause(hDma);

DMA\_reset Resets DMA channel

**Function** void DMA\_reset(

DMA Handle hDma

);

Arguments hDma Handle to DMA channel; see DMA open()...

or INV (If you want to reset all DMA channel registers)

Return Value None

**Description** Resets the DMA channel by setting its registers to the power-on defaults and

disables and clears the channel interrupt. You can use INV as the device

handle to reset all channels.

**Example** /\* reset an open DMA channel /

DMA reset(hDma);

/\* reset all DMA channels \*/

DMA\_reset(INV);

DMA start Starts DMA channel

**Function** void DMA start(

DMA Handle hDma

);

**Arguments** hDma Handle to DMA channel; see DMA\_open().

Return Value None

**Description** Starts a DMA channel by setting the enable channel bits in the DMA priority

and enable control register (DMPREC) accordingly to 1. See DMA\_stop().

**Example** DMA\_start(hDma);

DMA stop Disables DMA channel

**Function** void DMA\_stop(

DMA Handle hDma

);

**Arguments** hDma Handle to DMA channel; see DMA\_open().

Return Value None

**Description** Disables the DMA channel by resetting the enable channel bits in the DMA

priority and enable control (DMPREC) register accordingly. See DMA start().

**Example** DMA\_stop(hDma);

## 6.3.2 DMA Global Register Function

# DMA globalAlloc Performs global register allocation

**Function** Uint16 DMA\_globalAlloc (

Uint16 RegMask

);

**Arguments** RegMask Mask that indicates which global registers you want to use;

must be one of the following:

DMA\_GBL\_DMIDXANY (any global index register)

DMA\_GBL\_DMIDX0 (global index 0)
DMA\_GBL\_DMIDX1 (global index 1)
DMA\_GBL\_DMFRI0 (global frame index 0)

DMA\_GBL\_DMFRI1 (global frame index 1)
DMA\_GBL\_RLDR (global reload registers)
DMA\_GBL\_SRCP (global program page for src)
DMA\_GBL\_DSTP (global program page for dst)

DMA\_GBL\_SRCDP (global data page for src)
DMA\_GBL\_DSTDP (global data page for dst)

DMA GBL ALL (all global registers)

#### Note:

In the C54x, the DMA\_GBL\_DMFRIx and DMA\_GBL\_DMIDXx masks should used in pairs. For example, when you use DMA\_GBL\_DMFRI0, you should also use DMA\_GBL\_DMIDX0. Similarly both DMA\_GBL\_DMFRI1 and DMA\_GBL\_DMIDX1 should be used. If you do not follow this guideline, the function allocates all registers (DMA\_GBL\_DMFRI0, DMA\_GBL\_DMFRI1, DMA\_GBL\_DMIDX0, DMA\_GBL\_DMIDX1). If you use DMA\_GBL\_DMIDXANY, the function allocates any of the available DMA\_GBL\_DMFRIx/DMA\_GBL\_DMIDXx pairs.

#### **Return Value**

RegMaskalloc Mask that indicates the global registers that are being allocated as a response to the current RegMask requests. This mask does NOT include registers requested via previous calls to DMA globalAlloc().

> If ANY of the RegMask requests cannot be fulfilled, then RegMaskAlloc equals zero.

### **Description**

Performs Global register allocation. This function returns a mask that indicates to the DMA global Config/ConfigArgs functions which global registers are being allocated for the DMA channel. If you request via RegMask a global register that has been previously allocated the function returns a zero.

The use of this function is considered optional. It can be used to prevent double allocation of registers to DMA channels. If not used, you can pass off the DMA\_GBL\_ALL (0xffff value) as the RegMaskAlloc parameter for the DMA global Config/Args functions.

#### **Example**

#define NOTUSED 0

```
DMA_GblConfig MyGblConfig = {
     0,
                    /* free emulator control */
                    /* src program page
     10,
                                               * /
     20,
                     /* dst program page
                                               * /
                     /* index 0
                                               * /
     0x1,
     0 \times 4
                     /* frame index 0
                                              * /
                    /* index 1
                                               * /
     NOTUSED,
     NOTUSED
                     /* frame index 1
                                               * /
      };
. . . . .
     mask = DMA qlobalAlloc (DMA GBL DMIDX1 DMA GBL DMFRI1);
     DMA_globalConfig (mask, &MyGblConfig);
```

For a complete example, see Section 6.6, Example 2.

# DMA globalConfig

# Sets up DMA global registers using configuration structure

#### **Function**

```
void DMA globalConfig (
   Uint16 RegMaskAlloc,
   DMA_GblConfig *Config
   );
```

#### Arguments

RegMaskAlloc Mask to indicate global registers to initialize. This argument is produced by the DMA GlobalAlloc function. A value of DMA\_GBL\_ALL(0xffff value) allocates all the global registers

specified in Config.

Config Pointer to an initialized global configuration structure

#### Return Value

None

# Description

Sets up the DMA global registers using the global configuration structure. The values of the structure are written to the DMA global registers. Since the DMA global registers are shared, this function will ONLY initialize the registers that have been allocated via a DMA global Alloc routine and passed to this function via the RegMaskAlloc value. See DMA globalAlloc.

This function is optional. It may not be necessary to use this function if no global resource register initialization (element/frame indexes, reload registers, and src/dst page registers) is required for the DMA transfer.

#### **Example**

#define NOTUSED 0

```
DMA_GblConfig MyGblConfig = {
  0,
                             /* free emulator control */
                             /* src program page */
 10,
                             /* dst program page */
  20,
                             /* index 0 */
  0x1,
 0x4
                             /* frame index 0 */
                             /* index 1 */
 NOTUSED,
                            /* frame index 1 */
 NOTUSED,
  (DMA_AdrPtr) 100,
                            /* src data page */
  (DMA AdrPtr) 101,
                         /* dst data page */
  }
 mask = DMA globalAlloc (DMA GBL DMIDX1 DMA GBL DMFRI1);
 DMA_globalConfig (mask, &MyGblConfig);
```

For a complete example, see Section 6.6, Example 2.

# DMA\_globalConfigArgs Sets up DMA global registers using arguments

#### **Function**

void DMA\_globalConfigArgs(

Uint16 RegMask, Uint16 free,

For devices supporting individual channel reload registers (see note) add: Uint16 autoix, (Provided for compatibility with older versions of DMA)

For all devices add:

Uint16 intosel, Uint16 dmidx0, Uint16 dmfri0, Uint16 dmidx1, Uint16 dmfri1,

For devices not supporting global channel reload registers, (see section 1.8) add:

Uint16 dmgsa, Uint16 dmgda, Uint16 dmgc, Uint16 dmgcr, Uint16 dmgfr,

For all devices, add:

Uint16 dmsrcp, Uint16 dmdstp,

For devices supporting extended DMA data support, (see section 1.8) add:

Uint16 dmsrcdp, Uint16 dmdstdp

#### **Arguments**

RegMask

Mask to indicate global registers to initialize. This argument is produced by the DMA\_GlobalAlloc function. A value of 0xffff (DMA\_GBL\_ALL) allocates all the global registers specified in Config.

For devices supporting individual channel reload registers (see note) add: autoix (Provided for compatibility with older versions of DMA)

free; Response to emulation control dmidx0; Global element index 0

dmfri0; Global frame index 0 dmidx1; Global element index 1 dmfri1; Global frame index 1 For devices supporting global channel reload registers, (see section 1.8):

dmgsa; Pointer to global src address reload dmgda; Pointer to global dst address reload

dmgcr; Global element count reload dmgfr; Global frame count reload

For all devices:

dmsrcp; Global program page for src dmdstp; Global program page for dst

For devices supporting extended data addressing (see section 1.8):

dmsrcdp; Global data page for src dmdstdp; Global data page for dst

Return Value None

Description Sets up the DMA global registers with the register values passed to the

function. The register values are written to the DMA global registers. Since the DMA global registers are shared, this function will ONLY initialize the registers that have been allocated via a DMA\_globalAlloc routine and passed to this

function via the RegMaskAlloc value. See DMA\_globalAlloc().

**Example** None

#### DMA globalFree

#### Frees global DMA register that was previously allocated

**Function** void DMA\_globalFree( Uint16 regMask

);

**Arguments** regMask Global register mask that can be obtained from

DMA\_globalAlloc(). A value of 0xffff (DMA\_GBL\_ALL) frees all

of the global DMA registers.

Return Value None

**Description** Frees global DMA registers that were previously allocated by calling

DMA\_globalAlloc(). Once freed, the register is again available for allocation.

**Example** Uint16 RegMask;

...
 RegMask = DMA\_globalAlloc(DMA\_GBL\_DMIDX0, DMA\_GBL\_DMIDX0);
...
/\* some time later on when you're done with it \*/
DMA\_globalFree(RegMask);

# DMA\_globalGetConfig Gets a DMA global configuration register

Function void DMA\_globalGetConfig (

Uint16 RegMaskAlloc, DMA\_GblConfig \*Config

);

Arguments RegMaskAlloc Mask that indicates which global register to get. Refer to

DMA\_globalAlloc for valid values. DMA\_GBL\_ALL will get all

global registers

Config Pointer to an un-initialized global configuration structure

Return Value None

**Description** Specifies the current configuration for the DMA global registers specified by

RegMask. This is accomplished by reading the actual DMA global registers

and fields and storing them back in the config structure.

**Example** DMA\_GblConfig ConfigRead;

. . .

DMA\_globalGetConfig (DMA\_GBL\_ALL, &ConfigRead);

# DMA resetGbl Resets a DMA global register

Function void DMA\_resetGbl(

DMA Handle hDma

);

Arguments hDma Handle to DMA channel; see DMA\_open(),

Or INV (-1) if you want to reset all DMA channel registers.

Return Value None

**Description** Resets the DMA global register by setting all global registers to the power-on

defaults. You must use INV (-1) as the device handle to reset all the global

registers.

**Example** DMA\_resetGbl(hDma);

/\* or \*/

DMA\_resetGbl(INV);

# 6.3.3 DMA Auxiliary Functions

DMA\_autostart Enables the specified DMA channel and sets the AUTOINIT bit

**Function** void DMA\_autostart(

DMA\_Handle hDma

);

Arguments hDma Handle to DMA channel; see DMA\_open().

Return Value None

**Description** Enables the specified DMA channel and sets the AUTOINIT bit.

**Example** DMA\_autostart(hDma);

# DMA\_getConfig

## Gets a DMA channel configuration

**Function** void DMA\_getConfig(

DMA\_Handle hDma
DMA\_Config \*Config

);

**Arguments** hDma Handle to DMA channel; see DMA\_open().

Config Pointer to an un-initialized configuration structure (see

DMA\_Config)

Return Value None

**Description** Gets the current configuration for the DMA channel used by handle. This is

accomplished by reading the actual DMA channel registers and fields and

storing them back in the Config structure.

**Example** DMA\_Config ConfigRead;

. . .

myHdma = DMA\_open (DMA\_CHA0, 0);
DMA\_getConfig (myHdma, &ConfigRead);

DMA getEventId Returns IRQ Event ID for DMA completion interrupt

Function Uint16 DMA\_getEventId(

DMA\_Handle hDma

);

**Arguments** hDma Handle to DMA channel; see DMA\_open().

Return Value Event ID IRQ Event ID for DMA Channel

**Description** Returns the IRQ Event ID for the DMA completion interrupt. Use this ID to

manage the event using the IRQ module.

**Example** EventId = DMA\_getEventId(hDma);

IRQ\_enable(EventId);

For a complete example, see Section 6.6, Example 2.

DMA\_getStatus Gets DMA channel status

Function Uint16 DMA\_getStatus (

DMA\_Handle hDma

);

**Arguments** hDma

Return Value 1: if DMA channel is still running

0: if DMA channel has stopped (transfer completed)

**Description** Returns the status of the DMA channel used by handle. Use as a indication

of transfer complete.

**Example** while (DMA\_getStatus(myHdma)); /\*wait for transfer to complete \*/

For a complete example of DMA\_getStatus, see Section 5.4 (Example 1a)

#### 6.4 Macros

As covered in section 1.5, the CSL offers a collection of macros that allow individual access to the peripheral registers and fields. To use the DMA macros include "csl\_dma.h" in your project.

Because the DMA has several channels, the macros identify the channel used by either the channel number or the handle used. Table 6–3 lists the macros available for a DMA channel, using the channel number as part of the register name. Table 6–4 lists the macros available for a DMA channel using its corresponding handle.

Table 6–3. DMA CSL Macros (using channel number)

| (a) Macros to read/write DMA register values                                                                             |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------|--|--|--|
| DMA_RGET()                                                                                                               |  |  |  |
| DMA_RSET()                                                                                                               |  |  |  |
| (b) Macros to read/write DMA register field values(Applicable only to registers with more than one field)                |  |  |  |
| DMA_FGET()                                                                                                               |  |  |  |
| DMA_FSET()                                                                                                               |  |  |  |
| (c) Macros to create value to write to a DMA register and fields (Applicable only to registers with more than one field) |  |  |  |
| DMA_REG_RMK()                                                                                                            |  |  |  |
| DMA_FMK()                                                                                                                |  |  |  |
| (d) Macros to read a register address                                                                                    |  |  |  |
| DMA_ADDR()                                                                                                               |  |  |  |

# Table 6-4. DMA CSL Macros (using handles)

(a) Macros to read/write DMA register values

DMA\_RGETH()

DMA\_RSETH()

(b) Macros to read/write DMA register field values(Applicable only to registers with more than 1-field)

DMA\_FGETH()

DMA\_FSETH()

(c) Macros to read a register address

DMA\_ADDRH()

# DMA\_RGET

# Get value of DMA register

#### Macro

Uint16 DMA\_RGET (REG)

# **Arguments**

REG LOCALREG# or GLOBALREG, where:

☐ LOCALREG# Local register name with channel number (#),

where # = 0, 1, 2, 3, 4, 5,

DMSRC#

DMDST#

DMCTR#

DMSFC#

DMMCR#

For devices supporting individual channel reload registers, add:

DMGSA#

DMGDA#

DMGCR#

DMGFR#

For devices supporting individual channel extended data

memory space support, add:

DMSRCDP#

DMDSTDP#

☐ GLOBALREG Global register name

**DMPREC** 

**DMSRCP** 

**DMDSTP** 

For devices not supporting individual channel extended data

memory space support, add:

**DMSRCDP** 

**DMDSTDP** 

For devices supporting global channel reload registers, add:

**DMGSA** 

**DMGDA** 

**DMGCR** 

**DMGFR** 

For devices supporting global extended data memory space support, add:

DMSRCDP#

DMDSTDP#

Return Value value of register

**Description** Returns the DMA register value

**Example 1** For local registers:

```
Uint16 myvar;
```

myVar = DMA\_RGET(DMSRC1); /\* read DMSRC for channel 1 \*/

**Example 2** For global registers:

```
Uint16 myVar;
...
myVar = DMA_RGET(DMPREC);
```

# DMA\_RSET

# Set value of DMA register

Macro Void DMA\_RSET (REG, Uint16 regval)

Arguments REG LOCALREG# or GLOBALREG, as listed in DMA\_RGET()

macro

regval register value that wants to write to register REG

Return Value value of register

**Description** Set the DMA register REG value to regval

**Example 1** For local registers:

DMA\_RSET(DMSRC1, 0x8000); /\*DMSRC for channel 1 = 0x8000 \*/

**Example 2** For global registers:

DMA\_RSET(DMSRCP, 3); /\* DMSRCP = 3 \*/

#### DMA REG RMK

# Creates register value based on individual field values

#### Macro

Uint16 DMA\_REG\_RMK (fieldval\_n,...,fieldval\_0)

#### **Arguments**

REG

Only writable registers containing more than one field are supported by this macro. Also notice that the channel number is not used as part of the register name.

For example: DMSFC DMMCR DMPREC

#### fieldval

Field values to be assigned to the writable register fields.

Rules to follow:

- Only writable fields are allowedStart from Most-significant field first
- □ Value should be a right-justified contant. If fieldval\_n value exceeds the number of bits allowed for that field, fieldval\_n is truncated accordingly.

#### **Return Value**

Value of register that corresponds to the concatenation of values passed for the fields.

#### Description

Returns the DMA register value given specific field values. You can use constants or the CSL symbolic constants covered in Section 1.6.

#### Example

```
Uint16 myregval;
myregval = DMA_DMSFC_RMK (0,0,3); /* dsyn,dblw,framecount fiel
ds */
```

or you can use the PER\_REG\_FIELD\_SYMVAL symbolic constants provided in CSL (see section 1.6).

```
myregval=DMA_DMSFC_RMK
(DMA_DMSFC_DSYN_NONE, DMA_DMSFC_DBLW_OFF, 3);
```

DMA\_REG\_RMK are typically used to initialize a DMA configuration structure used for the DMA\_config() function (see section 6.6).

#### DMA FMK

# Creates register value based on individual field values

#### Macro

Uint16 DMA\_FMK (REG, FIELD, fieldval)

#### **Arguments**

REG Only writable registers containing more than one field are supported by this macro. Also notice that for local registers, the channel number is not used as part of the register name.

For example: DMPREC DMSFC DMMCR

FIELD Symbolic name for field of register REG Possible values: Field names as listed in the C54x Register Reference Guide. (see Appendix A) Only writable fields are allowed.

fieldval

Field values to be assigned to the writable register fields.

Rules to follow:

- Only writable fields are allowedStart from Most-significant field first
- ☐ Value should be a right-justified contri
- □ Value should be a right-justified contant. If fieldval\_n value exceeds the number of bits allowed for that field, fieldval\_n is truncated accordingly.

#### **Return Value**

Shifted version of fieldval. fieldval is shifted to the bit numbering appropriate for FIELD.

#### **Description**

Returns the shifted version of fieldval. Fieldval is shifted to the bit numbering appropriate for FIELD within register REG. This macro allows the user to initialize few fields in REG as an alternative to the DMA\_REG\_RMK() macro that requires ALL the fields in the register to be initialized. The returned value could be ORed with the result of other \_FMK macros, as show below.

```
Uint16 myregval;
myregval = DMA_FMK (DMSFC, DBLW, 1) | DMA_FMK (DMSFC, DSYN,
2);
```

# DMA\_FGET

# Get value of register field

Macro

Uint16 DMA\_FGET (REG, FIELD)

**Arguments** 

REG Only writable registers containing more than one field are

supported by this macro. Also notice that for local registers, the

channel number is used as part of the register name.

For example: DMPREC DMSFC# DMMCR#

FIELD Symbolic name for field of register REG. Possible values: Field names

as listed in the C54x Register Reference Guide (see Appendix A).

Only writable fields are allowed.

**Return Value** Value of register field

**Description** Gets the DMA register field value

Example 1

For local registers:

Uint16 myvar;
...
myregval = DMA\_FGET (DMMCR1, CTMOD);

Example 2

For global registers:

Uint16 myvar;
...
myregval = DMA\_FGET (DMPREC, INTOSEL);

#### DMA FSET

# Set value of register field

Macro

Void DMA\_FSET (REG, FIELD, fieldval)

**Arguments** 

REG Only writable registers containing more than one field are supported by this macro. Also notice that for local registers, the channel number is used as part of the register name.

For example: DMPREC DMSFC# DMMCR#

FIELD Symbolic name for field of register REG Possible values: Field names as listed in the C54x Register Reference Guide. (see Appendix A). Only writable fields are allowed.

fieldval Field values to be assigned to the writable register fields.

Rules to follow:

Only writable fields are allowed

☐ If fieldval value exceeds the number of bits allowed for field, fieldval is truncated accordingly.

Return Value None

**Description** Set the DMA register value to regval

**Example 1** For Local Registers:

DMA\_FSET (DMMCR1, CTMOD, 1);

**Example 2** For global registers:

DMA\_FSET (DMPREC, INTOSEL, 1);

DMA ADDR

Get address of given register

Macro

Uint16 DMA\_ADDR (REG)

**Arguments** 

REG LOCALREG# or GLOBALREG as listed in DMA\_RGET() macro

**Return Value** 

Address of register LOCALREG and GLOBALREG

Description

Get the address of a DMA register. In the case of LOCALREG (sub-addressed

registers), the function returns the sub-address. For example:

DMA\_ADDR (DMSRC1) returns a value of 5.

Example 1

For local registers:

myvar = DMA\_ADDR (DMMCR1);

Example 2

For global registers:

myvar = DMA\_ADDR (DMPREC);

DMA\_RGETH

Get value of DMA register used in handle

Macro

Uint16 DMA\_RGETH (DMA\_Handle hDma, LOCALREG)

**Arguments** 

hDma Handle to DMA channel that identifies the specific DMA

channel used.

LOCALREG

Same register as in DMA\_RGET(), but without channel

number (#). Example: DMSRC (instead of DMSRC#)

**Return Value** 

Value of register

Description

Returns the DMA value for register LOCALREG for the channel associated

with handle.

**Example** 

DMA\_Handle myHandle;

Uint16 myVar;

. . .

myHandle = DMA\_open (DMA\_CHA0, DMA\_OPEN\_RESET);

. . .

myVar = DMA\_RGETH (myHandle, DMMCR);

# DMA RSETH

# Set value of DMA register

#### Macro

void DMA\_RSETH (DMA\_Handle hDma, LOCALREG, Uint16 regval)

#### **Arguments**

hDma Handle to DMA channel that identifies the specific DMA

channel used.

**LOCALREG** 

Same register as in DMA\_RSET(), but without channel

number (#). Example: DMSRC (instead of DMSRC#)

regval

value to write to register LOCALREG for the channel

associated with handle.

#### **Return Value**

None

Description

Set the DMA register LOCALREG for the channel associated with handle to

the value regval.

#### **Example**

DMA\_Handle myHandle;

. . .

myHandle = DMA\_open (DMA\_CHA0, DMA\_OPEN\_RESET);

. .

DMA\_RSETH (myHandle, DMMCR, 0x123);

#### DMA FGETH

# Get value of register field

#### Macro

Uint16 DMA\_FGETH (DMA\_Handle hDma, LOCALREG, FIELD)

#### **Arguments**

hDma Handle to DMA channel that identifies the specific DMA

channel used.

LOCALREG

Same register as in DMA\_RSET(), but without channel number (#). Example: DMSRC (instead of DMSRC#) Only registers containing more than one field are

supported by this macro.

**FIELD** 

Symbolic name for field of register REG. Possible values: Field names as listed in the C54x Register Reference Guide

(see Appendix A). Only readable references are allowed.

#### **Return Value**

Value of register field given by FIELD, of LOCALREG use by handle.

#### Description

Gets the DMA register field value

#### **Example**

DMA\_Handle myHandle;

. . .

myHandle = DMA\_open (DMA\_CHA0, DMA\_OPEN\_RESET);

. . .

myVar = DMA\_FGETH (myHandle, DMMCR, CTMOD);

| DMA_FSETH    | Set value of register field                                                                                             |                                                                                                                                                                                                                                                                                                            |
|--------------|-------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Macro        | void DMA_FSETH (DMA_Handle hDma, LOCALREG, FIELD, fieldval)                                                             |                                                                                                                                                                                                                                                                                                            |
| Arguments    | hDma                                                                                                                    | Handle to DMA channel that identifies the specific DMA channel used.                                                                                                                                                                                                                                       |
|              | LOCALREG                                                                                                                | Same register as in DMA_RSET(), but without channel number (#). Example: DMSRC (instead of DMSRC#) Only registers containing more than one field are supported by this macro.                                                                                                                              |
|              | FIELD                                                                                                                   | Symbolic name for field of register REG. Possible values: Field names as listed in the C54x Register Reference Guide (see Appendix A). Only readable references are allowed.                                                                                                                               |
|              | fieldval                                                                                                                | Field values to be assigned to the writable register fields. Rules to follow:  Only writable fields are allowed Start from Most-significant field first Value should be a right-justified contant. If fieldval value exceeds the number of bits allowed for that field, fieldval is truncated accordingly. |
| Return Value | None                                                                                                                    |                                                                                                                                                                                                                                                                                                            |
| Description  | Set the DMA register field FIELD of the LOCALREG register for the channel associated with handle to the value fieldval. |                                                                                                                                                                                                                                                                                                            |
| Example      | <pre>DMA_Handle myHandle; Uint16 myVar;</pre>                                                                           |                                                                                                                                                                                                                                                                                                            |

myHandle = DMA\_open (DMA\_CHA0, DMA\_OPEN\_RESET);

DMA\_FSETH (myHandle, DMMCR, CTMOD, 1);

DMA\_ADDRH Get address of given register

Macro Uint16 DMA\_ADDR\_H (DMA\_Handle hDma, LOCALREG,)

Arguments hDma Handle to DMA channel that identifies the specific DMA

channel used.

LOCALREG Same register as in DMA\_RSET(), but without channel

number (#). Example: DMSRC (instead of DMSRC#)

Return Value Address of register LOCALREG

**Description** Get the address of a DMA local register (sub-address) for channel used in

hDma

**Example** DMA\_Handle myHandle;

Uint16 myVar;

. . .

myVar = DMA\_ADDRH (myHandle, DMMCR);

# 6.5 Configuring the DMA Module Using CSL GUI

The DMA module facilitates configuration of the Direct Memory Access (DMA) controller. The DMA module consists of a configuration manager and a resource manager.

The configuration manager allows creation of an object that contains the complete set of register values needed to configure a DMA channel. The resource manager associates a configuration object with a specific DMA channel.

Figure 6–1 illustrates the DMA sections menu on the CSL graphical user interface (GUI).

Figure 6–1. DMA Sections Menu



The DMA includes the following sections:

- **DMA Configuration Manager** allows you to create configuration objects by setting the peripheral registers related to the DMA.
- DMA Resource Manager allows you to select a DMA channel and to associate a configuration object to this channel. The six channel handle objects are predefined.

# **6.5.1 DMA Configuration Manager**

The DMA Configuration Manager allows you to create DMA Channel configurations through the Properties page and to generate the configuration objects.

# 6.5.1.1 Creating/Inserting a Configuration

There is no predefined configuration object available.

- **Step 1:** To configure a DMA channel through the Peripheral Registers, you must insert a new configuration object.
- Step 2: To insert a new configuration object, right-click on the DMA Configuration Manager and select insert dmaCfg from the drop-down menu. The configuration objects can be renamed. Their use depends on the on-chip device resources. Because six channels are available, a maximum of six configurations can be used simultaneously.

#### Note:

A maximum of six configurations may be inserted. This is due to the association that each configuration has with a pre-defined global configuration. The global configuration is dynamically updated with changes made to the associated DMA configuration. One DMA configuration (and its associated global configuration) can be used by more than one DMA channel.

# 6.5.1.2 Deleting/Renaming an Object

To delete or rename an object, right-click on the configuration object you want to delete or rename. Select Delete to delete a configuration object. Select Rename to rename the object.

If a configuration object is used by one of the predefined handle objects of the DMA Resource Manager, the Delete and Rename options are grayed-out and non-usable. The Show Dependency option is accessible and shows which device is using the configuration object (see Figure 2–1, *The CSL Tree*, on page 2-3).

# 6.5.1.3 Configuring the Object Properties

You can configure object properties through the Properties dialog box. (See Figure 6–2). To access the Properties dialog box, right-click on a configuration object and select Properties. By default, the General page of the Properties dialog box is displayed.

The Properties pages allow you to set the Peripheral registers related to the DMA. You can set the configuration options through the following Tab pages:

| <br>                                                                                                                                                                                                                    |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| General: Breakpoint emulation behavior.                                                                                                                                                                                 |
| Transfer Modes: Allows you to configure the Priority, Sync Events, ABU/Multi-frame                                                                                                                                      |
| Source/Destination: Allows you to configure the Address, Index, Element/Frame Count                                                                                                                                     |
| Autoinit: Allows you to configure the Reload Registers                                                                                                                                                                  |
| Advanced A and B Pages: These pages contains the full hexadecimal register values and reflects the option setting of the previous pages. Also, the full register values can be entered directly and the new options are |

mirrored in the related pages automatically.

Figure 6-2. DMA Properties Page



Each page is composed of several options that are set to a default value (at device reset).

# 6.5.1.4 Specifying Address Formats

The source, destination, and addresses can be specified in either a numeric format (hard coded address) or a symbolic format. Before setting any addresses, ensure that the right format is selected in the Source Address Format and Destination Address Format pull-down menus located on the Source and Destination tabs of the Properties page.

# 6.5.2 DMA Resource Manager

The DMA Resource Manager allows you to generate the DMA\_open() and DMA\_config() CSL functions.

Figure 6–3 illustrates the DMA Resource Manager menu on the CSL graphical user interface (GUI).

Figure 6-3. DMA Resource Manager Menu



# 6.5.2.1 Predefined Objects

The six channel handle objects are predefined and each is associated with a supported on-chip DMA channel as follows:

DMA0 – Default handle name: hDma0
 DMA1 – Default handle name: hDma1
 DMA2 – Default handle name: hDma2
 DMA3 Default handle name: hDma3
 DMA4 Default handle name: hDma4
 DMA5 Default handle name: hDma5

# 6.5.2.2 Properties Page

You can generate the DMA\_open() and DMA\_config() CSL functions through the Properties page.

To access the Properties page, right-click on a predefined DMA channel and select Properties from the drop-down menu (see Figure 6–4).

The first time the Properties page appears, only the Open Handle to DMA check-box can be selected. Select this to open the DMA channel, allowing pre-initialization.

DMA\_NOTHING is used to indicate that there is no configuration object selected for this DMA.

To pre-initialize the DMA channel, check the Enable pre-initialization checkbox. You can then select one of the available configuration objects (see section 6.5.1, *DMA Configuration Manager*) for this channel through the pre-initialize drop-down list.

If DMA\_NOTHING is selected, no configuration object is generated for the related DMA handle (see section 6.5.3, *C Code Generation for DMA Module*).

In the example shown in Figure 6–4, the Open DMA Channel option is checked and the handle object hDma1 is now accessible (The handle object can be renamed by typing the new name in the box provided). The DMA\_open() function is now generated with hDma1 containing the returned handle address.

Figure 6–4. DMA Properties Page With Handle Object Accessible



# 6.5.3 C Code Generation for DMA Module

Two C files are generated from the configuration tool:

☐ Header file

Source file

#### 6.5.3.1 Header File

The header file includes all the CSL header files of the modules and contains the DMA handles, and configuration objects generated by the configuration tool (see Example 6–1).

# Example 6-1. DMA Header File

```
extern DMA_Config dmaCfg0;
extern DMA_GblConfig gDMAConfig0;;
extern DMA_Handle hDma1;
```

#### 6.5.3.2 Source File

The source file includes the declaration of the channel handle objects and the configuration structures (see Example 6–2).

# Example 6–2. DMA Source File (Declaration Section)

```
Config Structures */
DMA_Config dmaCfg0 = {
   0x0000,
                  /* Channel Priority (0x0000 or 0x0001 */
    0 \times 00000,
                  /* Global Reload Register Usage in Autoinit Mode (AUTO
                   IX : 0x0000 \text{ or } 0x0001) */
                  /* Transfer Mode Control Register (DMMCR) */
   0 \times 00000,
   0x0000,
                  /* Sync Event and Frame Count Register (DMSFC) */
                /* Source Address Register (DMSRC) - Symbolic */
   NULL,
   NULL,
                /* Destination Address Register (DMDST) - Symbolic */
   0x0000
                 /* Element Count Register (DMCTR) */
};
DMA_GblConfig gDMAConfig0 = {
    0x0,
               /* Breakpoint Emulation Behavior (FREE) */
   0x0000,
                   /* Global Reload Register Usage in Autoinit Mode (AUTO
                    IX : 0x0000 \text{ or } 0x0001) */
   NULL, /* Source Program Page Address Register (DMSRCP) - Symbolic */
   NULL, /* Destination Program Page Address Register (DMDSTP) - Symbolic
* /
                  /* Element Address Index Register 0 (DMIDX0) */
   0 \times 00000,
    0x0000,
                  /* Frame Address Index Register 0 (DMFRI0) */
   0x0000,
                  /* Element Address Index Register 1 (DMIDX1)
   0 \times 00000,
                   /* Frame Address Index Register 1 (DMFRI1)
   NULL, /* Global Source Address Reload Register (DMGSA) - Symbolic */
   NULL, /* Global Destination Address Reload Register (DMGDA) - Symbolic
* /
   0x0000,
                  /* Global Element Count Reload Register (DMGCR) */
   0x0000
                 /* Global Frame Count Reload Register B (DMGFR) */
};
  Handles */
DMA Handle hDma1;
```

The source file contains the Handle and Configuration Pre-Initialization using the CSL DMA API functions, DMA\_open() and DMA\_config() (see Example 6–3).

These two functions are encapsulated in a unique function, CSL\_cfgInit(), which is called from your main C file. DMA\_open() and DMA\_config() are generated only if Open Handle to DMA and Enable pre-initialization (with a selected configuration other than DMA\_NOTHING) are checked under the DMA Resource Manager Properties page.

# Example 6-3. DMA Source File (Body Section)

```
void CSL_cfgInit()
{
   hDma1 = DMA_open(DMA_CHA1, DMA_OPEN_RESET);
   DMA_config(hDma1, &dmaCfg0);
   DMA_globalConfig(0x0FFFF, &gDMAConfig0);
}
```

# 6.6 Examples

The following CSL DMA initialization examples are provided under the directories:

c:\ti\examples\<target>\csl\manual\_config\dma1a, dma1b, dma2, dma3, dma4

| Example 1A | DMA channel initialization | using DMA_config() |
|------------|----------------------------|--------------------|
|            |                            |                    |

Example 1B DMA channel initialization using DMA\_configArgs()

Example 2 DMA channel auto-initialization with interrupt on

transfer completion using DMA\_config(). This example also illustrates the usage of globalConfig() to con-

figure DMA global registers.

Example 3 DMA channel data transfer from/to MCBSP.

Example 4 DMA channel data transfer from/to MCBSP in ABU

and digital loopback mode.

For illustration purposes, Example 1A is covered in detail below, and is illustrated in Figure 6–5.

Example 1A explains how DMA Channel 0 is initialized to transfer the data table at 0x3000@data space to 0x2000@data space. This example does not use any DMA global registers resources. Basic initialization values are as follows:

| Source address: 2000h in data space      |
|------------------------------------------|
| Destination address: 3000h in data space |
| Transfer size: 10h words single words    |

The following two macros are used to create the initialization values for DMMCR and DMSFC respectively:

DMA\_DMMCR\_RMK(autoinit, dinm, imod, ctmod, sind, dms, dind, dmd)
0 0 0 1 1 1 1

DMA\_DMSFC\_RMK(dsyn, dblw, framecount)

0 0 0 (single-frame, Nframes-1)

The settings needed for the DMMCR are:

DMMCR0 = 0x0145u#0000000100000101b

```
;0~~~~~ (AUTOINIT)
                        Autoinitialization disabled
;~0~~~~~ (DINM)
                        Interrupts masked
;~~0~~~~~ (IMOD)
                        N/A
;~~~0~~~~~~ (CTMOD)
                        Multi-frame mode
;~~~0~~~~~~~
                        Reserved
;~~~~001~~~~~ (SIND)
                        Post increment source
                        address
;~~~~~(DMS)
                        Source in data space
;~~~~~~~0~~~~
                        Reserved
;~~~~~~001~~ (DIND)
                        Post increment destination
                        address
;~~~~~01 (DMD) Destination in data space
```

#### The settings needed for the DMSFC are:

# Figure 6-5. DMA Channel Initialization Using DMA\_config()

```
#include <csl_dma.h>
/*----*/
/* create a data from DMA transfer */
#define N
            16
/* Place data in separate section to ensure placement */
/* within the DMA memory space defined for the device.*/
/* The address ranges chosen for this example in the */
/* linker command file place src and dst within the */
/* DMA memory map for the TMS320C5402. When modifying */
/* this example to run on a different C54x target, */
/* please check the datasheet for your specific
/* device to make sure that the src and dst addresses */
/* for your transfer are assigned to a valid DMA
                                                * /
/* memory space.
                                                * /
```

# Figure 6-5. DMA Channel Initialization Using DMA\_config() (Continued)

```
#pragma DATA_SECTION(src, "dmaMem")
Uint16 src[N];
#pragma DATA_SECTION(dst, "dmaMem")
Uint16 dst[N];
/* In this example, we will be effecting a DMA
/* transfer from DATA to DATA space in internal
/* memory. The DMA will operate in multi-frame
                                                * /
/* mode and we will poll for DMA operation
                                                * /
                                                * /
/* complete.
/* These are the settings we need for the DMA
                                                * /
/* mode control register, DMMCR, in order to
                                                * /
/* perform the transfer
                                                * /
   DMMCR0 = 0x0145u
                                                         * /
                                                         * /
/* #000000101000101b
   ;0~~~~~~ (AUTOINIT) No Autoinit
                                                         * /
   ;~0~~~~~ (DINM)
                                                         * /
                                 No Interrupts
/*
   ;~~0~~~~~~ (IMOD)
                                 N/A
                                                         * /
   ;~~~0~~~~~~ (CTMOD)
                                Multi-frame on
                                                         * /
/*
   ;~~~~0~~~~~~~ (SLAXS)
                                Src not in extended mem */
   ;~~~~001~~~~~ (SIND)
                                 Src addr Post-incr
                                                         * /
   ;~~~~~~1~~~~~ (DMS)
/*
                                 Src in data space
                                                         * /
   ;~~~~~(DLAXS)
/*
                                Dst not in extended mem */
/*
   ;~~~~~~~001~~ (DIND)
                                 Dst addr Post-incr
                                                         * /
   ;~~~~~~~~~01 (DMD)
                                 Dst in data space
                                                         * /
                                                         * /
/* These are the settings required for DMA sync and
/* frame count register, DMSFC
                                                         * /
/*
     DMSFC0 = 0x0000u
                                                         * /
/*
     #000000000000000b
                                                         * /
     ;0000~~~~~ (DSYN)
                                 No sync event
                                                         * /
     ;~~~~0~~~~~~~ (DBLW)
/*
                                 Single-word mode
                                                         * /
      ;~~~~000~~~~~~
                                 N/A
                                                         * /
      i \sim \sim \sim \sim \sim 00000000 (Frame Count) = 0 (one frame)
/*
                                                         * /
/* Create a DMA configuration structure for the transfer
                                                         * /
/* using predefined CSL macros and symbolic constants
                                                         * /
```

# Figure 6-5. DMA Channel Initialization Using DMA\_config() (Continued)

```
DMA_Config myconfig = {
                                 /* Set Priority */
 1,
 0,
                                 /* Autoix off */
 DMA DMMCR RMK (
   DMA_DMMCR_AUTOINIT_OFF,
   DMA_DMMCR_DINM_OFF,
   DMA_DMMCR_IMOD_FULL_ONLY,
   DMA_DMMCR_CTMOD_MULTIFRAME,
   DMA_DMMCR_SLAXS_OFF,
   DMA_DMMCR_SIND_POSTINC,
   DMA_DMMCR_DMS_DATA,
   DMA_DMMCR_DLAXS_OFF,
   DMA_DMMCR_DIND_POSTINC,
   DMA DMMCR DMD DATA
                                      /* DMMCR */
 ),
 DMA_DMSFC_RMK(
   DMA_DMSFC_DSYN_NONE,
   DMA_DMSFC_DBLW_OFF,
   DMA_DMSFC_FRAMECNT_OF(0)
                                      /* DMSFC */
 ),
                                      /* DMSRC */
 (DMA_AdrPtr) &src[0],
                                      /* DMDST */
 (DMA_AdrPtr) &dst[0],
 (Uint16)(N-1),
                                      /* DMCTR */
 0,
                                      /* DMGSA */
 0,
                                      /* DMGDA */
 0,
                                      /* DMGCR */
 0,
                                      /* DMGFR */
/*----*/
void main() {
 Uint16 i;
 /* Initialize CSL library, this step is required */
 CSL_init();
 /* Set Src values and Clear destination */
 for (i=0; i \le N-1; i++) {
   src[i] = 0xBEEF;
   dst[i] = 0;
/*-----*/
void taskFunc() {
```

# Figure 6-5. DMA Channel Initialization Using DMA\_config() (Continued)

```
DMA_Handle myhDma;
 /* Create a DMA handle pointer */
Uint16 err = 0;
Uint16 i;
LOG_printf(&LogMain,"<DMA1A>");
/* Open DMA channel 0, to use for this transfer */
myhDma = DMA_open(DMA_CHA0, 0);
/* Call DMA_config function to write your configuration */
/* values to DMA channel control registers
DMA_config(myhDma, &myconfig);
/* Call DMA_start to begin the data transfer */
DMA_start(myhDma);
/* Poll DMA status too see if its done
                                             * /
while(DMA_getStatus(myhDma));
/* Check the values to make sure DMA transfer is */
/* correct.
for (i = 0; i \le N-1; i++)
 if (dst[i] != 0xBEEFu) {
    ++err;
}
/* We are done, so close DMA channel */
DMA_close(myhDma);
LOG_printf(&LogMain,"%s",err?"DMA Example 1A FAILED":"DMA Example 1A PASSED");
LOG_printf(&LogMain,"<DONE>");
```

# Chapter 7

# **EBUS Module**

This chapter describes the configuration structure, functions, and macros used in the external bus interface (EBUS) module.

| Topic |                         | Page |
|-------|-------------------------|------|
| 7.1   | Overview                | 7-2  |
| 7.2   | Configuration Structure | 7-3  |
| 7.3   | Functions               | 7-4  |
| 7.4   | Macros                  | 7-6  |
|       |                         |      |

#### 7.1 Overview

The EBUS module provides a configuration structure, functions, macros, and constants that allow you to control the external bus interface through the CSL.

Table 7–1 summarizes the configuration structure. Table 7–2 lists the EBUS functions.

Use the following guidelines for the EBUS functions:

- You can perform configuration by calling either EBUS\_config(), EBUS\_configArgs(), or any of the SET register macros.
- Because EBUS\_config() and EBUS\_configArgs() initialize all three external bus control registers, macros are provided to enable efficient access to individual registers when you need to set only one or two.
- ☐ The recommended approach is to initialize the external bus by using EBUS\_config() with the EBUS\_Config structure.

Table 7-1. EBUS Configuration Structure

| Structure   | Purpose                                                       | See page |
|-------------|---------------------------------------------------------------|----------|
| EBUS_Config | EBUS configuration structure used to setup the EBUS interface | 7-3      |

#### Table 7-2. EBUS Functions

| Function Purpose  |                                                           | See page |
|-------------------|-----------------------------------------------------------|----------|
| EBUS_config()     | Sets up EBUS using configuration structure (EBUS_Config)  | 7-4      |
| EBUS_configArgs() | Sets up EBUS using register values passed to the function | 7-5      |

# 7.2 Configuration Structure

This section describes the configuration structure that you can use to set up the EBUS interface.

# EBUS\_Config

EBUS configuration structure used to set up EBUS interface

**Structure** 

EBUS\_Config

**Members** 

For 544x devices:

Uint16 bscr

Bank-switching control register

For other C54x devices:

Uint16 swwsr Software wait-state register
Uint16 bscr Bank-switching control register
Uint16 swcr Sofware wait-state control register

Description

The EBUS configuration structure is used to set up the EBUS Interface. You create and initialize this structure and then pass its address to the EBUS\_config() function. You can use literal values or the EBUS\_REG\_RMK macros to create the structure member values.

```
EBUS_Config Config1 = {
    0x7FFF, /* swwsr */
    0xF800, /* bscr */
    0x0000 /* swcr */
};
```

# 7.3 Functions

This section describes the EBUS API functions.

# EBUS\_config

Writes value to set up EBUS using configuration structure

**Function** void EBUS\_config(

EBUS\_Config \*Config

);

Arguments

Config

Pointer to an initialized configuration structure

Return Value

None

Description

Writes a value to set up the EBUS using the configuration structure. The values of the structure are written to the port registers (see also EBUS\_configArgs() and EBUS\_Config).

```
EBUS_Config MyConfig = {
    0x7FFF, /* swwsr */
    0xF800, /* bscr */
    0x0000 /* swcr */
};
...
EBUS_config(&MyConfig);
```

# EBUS\_configArgs Writes to EBUS using register values passed to the function

#### **Function** For C544x devices:

EBUS\_configArgs (Uint16 bscr);

#### For other C54x devices:

```
void EBUS_configArgs(
   Uint16 swwsr,
   Uint16 bscr,
   Uint16 swcr
);
```

#### **Arguments**

Software wait-state register swwsr Bank-switching control register bscr

swcr Software wait-state control register

#### **Return Value**

None

#### Description

Writes to the EBUS using the register values passed to the function. The

register values are written to the EBUS registers.

You may use literal values for the arguments; or for readability, you may use the EBUS\_REG\_RMK macros to create the register values based on field values.

```
EBUS_configArgs (
 0x7FFF, /* swwsr */
 0xF800, /* bscr */
 0x0000 /* swcr */
);
```

# 7.4 Macros

As covered in section 1.3, CSL offers a collection of macros to gain individual access to the EBUS peripheral registers and fields.

Table 7–3 contains a list of macros available for the EBUS module. To use them, include "csl\_ebus.h."

Table 7–3. EBUS Macros

# (a) Macros to read/write EBUS register values

| (a) Macros to rough Mice 2000 register values |                                                                                                                                             |  |
|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|--|
| Macro                                         | Syntax                                                                                                                                      |  |
| EBUS_RGET()                                   | Uint16 EBUS_RGET(REG)                                                                                                                       |  |
| EBUS_RSET()                                   | void EBUS_RSET(REG, Uint16 regval)                                                                                                          |  |
| (b) Macros to read/write EBUS register fie    | eld values (Applicable only to registers with more than one field)                                                                          |  |
| Macro                                         | Syntax                                                                                                                                      |  |
| EBUS_FGET()                                   | Uint16 EBUS_FGET(REG, FIELD)                                                                                                                |  |
| EBUS_FSET()                                   | Void EBUS_FSET(REG,FIELD, Uint16 fieldval)                                                                                                  |  |
| (c) Macros to read/write EBUS register fie    | eld values (Applicable only to registers with more than one field)                                                                          |  |
| Macro                                         | Syntax                                                                                                                                      |  |
| EBUS_REG_RMK()                                | Uint16 EBUS_REG_RMK(fieldval_n,fieldval_0)                                                                                                  |  |
|                                               | Note: *Start with field values with most significant field positions: field_n: MSB field field_0: LSB field * only writeable fields allowed |  |
| EBUS_FMK()                                    | Uint16 EBUS_FMK(REG, FIELD, fieldval)                                                                                                       |  |
| (d) Macros to read a register address         |                                                                                                                                             |  |
| Macro                                         | Syntax                                                                                                                                      |  |
| EBUS_ADDR()                                   | Uint16 EBUS_ADDR(REG)                                                                                                                       |  |
|                                               |                                                                                                                                             |  |

| Where:    |                                                                                                                                                           |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| REG:      | SWWSR (except in C544x), SWCR (except in C544x), BSCR                                                                                                     |
| FIELD:    | register field name as specified in Appendix A.                                                                                                           |
|           | ☐ For _FSET and _FMK, field should be a writable field.                                                                                                   |
|           |                                                                                                                                                           |
| regVal:   | value to write in register REG                                                                                                                            |
| fieldVal: | value to write in field FIELD of register REG. Rules to follow:                                                                                           |
|           | Only writable fields are allowed.                                                                                                                         |
|           | ☐ Value should be a right-justified constant. If fieldval_n value exceeds the number of bits allowed for that field, fieldval_n is truncated accordingly. |

For examples on how to use macros, refer to macro sections 6.4 (DMA) and 11.4 (McBSP).

# **Chapter 8**

# **GPIO Module**

The GPIO module is designed to allow central control of non-multiplexed GPIO pins available in the C54x devices. (C544x devices only)

| Topic   | Page                                       |
|---------|--------------------------------------------|
| 8.1 Ove | erview 8-2                                 |
| 8.2 Fun | ctions 8-3                                 |
| 8.3 Mad | eros                                       |
| 8.4 Cor | figuring the GPIO Module Using CSL GUI 8-7 |

# 8.1 Overview

The GPIO module is designed to allow central control of the four non-multiplexed GPIO pins (GPIO 0 to GPIO 3) available in each of the C54x core devices (C544x devices only).

Functions that allow you to manipulate the C54x GPIO pins are listed in Table 8–1.

Macros that allows access to registers have been provided on page 8-5 (see Table 8–2).

Table 8-1. GPIO Functions

| Function Description |                                                     | See page |
|----------------------|-----------------------------------------------------|----------|
| GPIO _pinDirection   | Sets the GPIO pins as either an input or output pin | 8-3      |
| GPIO_pinRead         | Reads the GPIO pin value 8-                         |          |
| GPIO_pinWrite        | Writes a value to a GPIO pin 8-4                    |          |

#### 8.2 Functions

The following are functions available for use with the GPIO module.

GPIO\_pinDirection Sets the GPIO pin as input or output

**Function** int GPIO\_pinDirection (Uint32 pinId, Uint16 direction);

**Arguments** IDs of the GPIO pins to enable. It will have one pinld

one of the following values:

**GPIO PIN0** 

GPIO\_PIN3

Direction pin direction

> GPIO INPUT //input GPIO\_OUTPUT //output

**Return Value** None

Description Sets the direction for a general-purpose I/O pin (input or output)

**Example** /\* sets the pin gpiol as an input \*/

GPIO\_pinDirection (GPIO\_PIN1, GPIO\_INPUT);

# **GPIO\_pinRead**

#### Reads the GPIO pin value

Function int GPIO\_pinRead (Uint32 pinId);

**Arguments** pinld IDs of the GPIO pins to enable. It will have one of the following values:

GPIO\_PIN0

GPIO\_PIN3

**Return Value** Value Value read in GPIO pin (1 or 0)

Description Reads the value in a general purpose input pin.

**Example** int val;

val = GPIO\_pinRead (GPIO\_PIN3);

GPIO\_pinWrite Writes a value to a GPIO pin

**Function** int GPIO\_pinWrite (Uint32 pinId, Unit16 val);

**Arguments** pinId IDs of the GPIO pins to enable. It will have one of the following values:

GPIO\_PIN0

...

GPIO\_PIN3

val Value to write to the pinID.

Return Value None

**Description** Writes a value to a general purpose output pin.

**Example** GPIO\_pinWrite (GPIO\_PIN1, 1); /\* sets iopin1 to "1" \*/

# 8.3 Macros

As covered in section 1.3, CSL offers a collection of macros to gain individual access to a GPIO specific register (GPIO) in C544x devices.

Table 8–2 contains a list of macros available for the GPIO module. To use them, include "csl\_gpio.h."

Table 8–2. GPIO Macros (C544x devices only)

# (a) Macros to read/write GPIO register values

| Macro                                                                                                       | Syntax                                                                                                                                     |  |
|-------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|
| GPIO_RGET()                                                                                                 | Uint16 GPIO_RGET(REG)                                                                                                                      |  |
| GPIO_RSET()                                                                                                 | void GPIO_RSET(REG, Uint16 regval)                                                                                                         |  |
| (b) Macros to read/write GPIO register fie                                                                  | eld values (Applicable only to registers with more than one field)                                                                         |  |
| Macro                                                                                                       | Syntax                                                                                                                                     |  |
| GPIO_FGET()                                                                                                 | Uint16 GPIO_FGET(REG, FIELD)                                                                                                               |  |
| GPIO_FSET()                                                                                                 | Void GPIO_FSET(REG,FIELD, Uint16 fieldval)                                                                                                 |  |
| (c) Macros to read/write GPIO register field values (Applicable only to registers with more than one field) |                                                                                                                                            |  |
| Macro                                                                                                       | Syntax                                                                                                                                     |  |
| GPIO_REG_RMK()                                                                                              | Uint16 GPIO_REG_RMK(fieldval_n,fieldval_0)                                                                                                 |  |
|                                                                                                             | Note: *Start with field values with most significant field positions: field_n: MSB field field_0: LSB field * only writable fields allowed |  |
| GPIO_FMK()                                                                                                  | Uint16 GPIO_FMK(REG, FIELD, fieldval)                                                                                                      |  |
| (d) Macros to read a register address                                                                       |                                                                                                                                            |  |
| Macro                                                                                                       | Syntax                                                                                                                                     |  |
| GPIO_ADDR()                                                                                                 | Uint16 GPIO_ADDR(REG)                                                                                                                      |  |
|                                                                                                             |                                                                                                                                            |  |

| Where:    |                                                                                                                                                           |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| REG:      | GPIO                                                                                                                                                      |
| FIELD:    | register field name as specified in Appendix A.                                                                                                           |
|           | ☐ For _FSET and _FMK, field should be a writable field.                                                                                                   |
|           |                                                                                                                                                           |
| regVal:   | value to write in register REG                                                                                                                            |
| fieldVal: | value to write in field FIELD of register REG. Rules to follow:                                                                                           |
|           | <ul> <li>Only writable fields are allowed.</li> </ul>                                                                                                     |
|           | □ Value should be a right-justified constant. If fieldval_n value exceeds the number of bits allowed for that field, fieldval_n is truncated accordingly. |

For examples on how to use macros, refer to the macro sections 6.4 (DMA) and 11.4 (McBSP).

### 8.4 Configuring the GPIO Module Using CSL GUI

The GPIO module facilitates configuration/control of the General-Purpose I/O on the C54x. The module consists of a configuration manager. The configuration manager allows you to configure the directions to either the input or output of the GPIO pins.

Figure 8–1 illustrates the GPIO sections menu on the CSL graphical user interface (GUI)

Figure 8-1. GPIO Sections Menu



The Non-Multiplexed GPIO includes the following section:

**Non-Multiplexed GPIO Configuration Manager** allows you to configure the GPIO Pin directions.

### 8.4.1 Non-Multiplexed GPIO Configuration Manager

The Non-Multiplexed GPIO Configuration Manager allows you to configure the GPIO pin directions.

### 8.4.1.1 Properties Pages of the Non-Multiplexed GPIO Configuration

The Properties pages allow you to set the Peripheral registers related to the GPIO. The configuration options are divided into the following Tab page:

**Settings** allows you to configure the Input/Output settings of GPIO Pins.

Figure 8–2 depicts the Properties Page dialog box.

Figure 8-2. GPIO Properties Page



The Settings Tab is composed of several options that are set to a default value (at device reset).

The options represent the fields of the GPIO register direction. For further details of the fields and registers, refer to the GPIO section of the *TMS320C54x DSP Enhanced Peripherals Reference Set* (literature number SPRU302).

### 8.4.2 C Code Generation for GPIO Module

Two C files are generated from the configuration tool:

- ☐ Header file
- ☐ Source file

### 8.4.2.1 Header File

The header file includes all the csl header files of the modules.

### 8.4.2.2 Source File

The source file contains the GPIO Register set macro invocation. This macro invocation is encapsulated in a unique function, CSL\_cfgInit(), which is called from your main C file.

GPIO\_RSET() will be generated only if Configure Non-Multiplexed GPIO is checked under the Non-multiplexed GPIO Configuration Properties page. See Figure 8–2.

### Example 8–1. GPIO Source File (Body Section)

```
void CSL_cfgInit()
{
    GPIO_RSET(GPIO, 3840);
}
```

# Chapter 9

## **HPI Module**

This chapter contains descriptions for macros available in the HPI module.

| Topic | С      | Page |
|-------|--------|------|
| 9.1   | Macros | 9-2  |

### 9.1 Macros

As covered in section 1.3, the CSL offers a collection of macros to gain individual access to the peripheral registers and fields.

Table 9–1 contains a list of macros available for the HPI module. To use them, include "csl\_hpi.h."

Table 9-1. HPI Macros

### (a) Macros to read/write HPI register values

| Macro                                         | Syntax                                                                                                     |
|-----------------------------------------------|------------------------------------------------------------------------------------------------------------|
| HPI_RGET()                                    | Uint16 HPI_RGET(REG)                                                                                       |
| HPI_RSET()                                    | void HPI_RSET(REG, Uint16 regval)                                                                          |
| (b) Macros to read/write HPI register field v | alues (Applicable only to registers with more than one field)                                              |
| Macro                                         | Syntax                                                                                                     |
| HPI_FGET()                                    | Uint16 HPI_FGET(REG, FIELD)                                                                                |
| HPI_FSET()                                    | Void HPI_FSET(REG,FIELD, Uint16 fieldval)                                                                  |
| (c) Macros to read/write HPI register field v | alues (Applicable only to registers with more than one field)                                              |
| Macro Syntax                                  |                                                                                                            |
| HPI_REG_RMK()                                 | Uint16 HPI_REG_RMK(fieldval_n,fieldval_0)                                                                  |
|                                               | Note:                                                                                                      |
|                                               | Start with field values with most significant field positions:<br>field_n: MSB field<br>field_0: LSB field |
|                                               | <ul> <li>only writable fields allowed</li> </ul>                                                           |
| HPI_FMK()                                     | Uint16 HPI_FMK(REG, FIELD, fieldval)                                                                       |
| (d) Macros to read a register address         |                                                                                                            |
| (a) madrod to road a register address         |                                                                                                            |
| Macro                                         | Syntax                                                                                                     |

| Where:    |                                                                                                                                                           |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| REG:      | include HPIC, GPIOCR, GPIOSR                                                                                                                              |
| FIELD:    | register field name as specified in Appendix A.                                                                                                           |
|           | ☐ For _FSET and _FMK, field should be a writable field.                                                                                                   |
|           | ☐ For _FGET, this field should, at least, be readable.                                                                                                    |
| regVal:   | value to write in register REG                                                                                                                            |
| fieldVal: | value to write in field FIELD of register REG. Rules to follow:                                                                                           |
|           | <ul> <li>Only writable fields are allowed</li> </ul>                                                                                                      |
|           | □ Value should be a right-justified constant. If fieldval_n value exceeds the number of bits allowed for that field, fieldval_n is truncated accordingly. |

For examples on how to use macros, refer to macro sections 6.4 (DMA) and 11.4 (McBSP).

# Chapter 10

## **IRQ Module**

The IRQ module provides an easy to use interface for enabling/disabling and managing interrupts.

| Topic |                           | Page   |
|-------|---------------------------|--------|
| 10.1  | Overview                  | . 10-2 |
| 10.2  | Using Interrupts with CSL | . 10-7 |
| 10.3  | Configuration Structure   | . 10-8 |
| 10.4  | Functions                 | . 10-9 |

### 10.1 Overview

The IRQ module provides an interface for managing peripheral interrupts to the CPU. This module provides the following functionality:
 Masking an interrupt in the IMR<sub>x</sub> register.
 Polling for the interrupt status from the IFR<sub>x</sub> register.
 Setting the interrupt vector table address and placing the necessary code in the interrupt vector table to branch to a user-defined interrupt service routine (ISR).
 Enabling/Disabling Global Interrupts in the ST1 (INTM) bit.
 Reading and writing to parameters in the DSP/BIOS dispatch table. (When the DPS BIOS dispatcher option is enabled in DSP BIOS.)
 The DSP BIOS dispatcher is responsible for dynamically handling interrupts and maintains a table of ISRs to be executed for specific interrupts. The IRQ module has a set of APIs that update the dispatch table.

Table 10–1 lists the IRQ configuration structure.

Table 10–2 lists the functions available in the IRQ module.

Table 10–2(a) and (b) list the primary and auxiliary IRQ functions.

Table 10–2(c) lists the API functions that enable DSP/BIOS dispatcher communication.

The IRQ functions in Table 10–2(a) can be used with or without DSP/BIOS; however, if DSP/BIOS is present, do not disable interrupts for long periods of time, as this could disrupt the DSP/BIOS environment.

Table 10–2(b) lists the only API functions that cannot be used when DSP/BIOS dispatcher is present or DSP/BIOS HWI module is used to configure the interrupt vectors. This function, IRQ\_plug(), dynamically places code at the interrupt vector location to branch to a user-defined ISR for a specified event. If you call IRQ\_plug() when DSP/BIOS dispatcher is present or HWI module has been used to configure interrupt vectors, this could disrupt the DSP/BIOS operating environment.

Table 10–2(c) lists the API functions that enable DSP/BIOS dispatcher communications. These functions should be used only when DSP/BIOS is present **and** the DSP/BIOS dispatcher is enabled.

Table 10–3 lists all IRQ logical interrupt events for this module.

Table 10-1. IRQ Configuration Structure

| Structure  | Purpose                                                                                    | See page |
|------------|--------------------------------------------------------------------------------------------|----------|
| IRQ_Config | IRQ structure that contains all local registers required to set up a specific IRQ channel. | 10-8     |

### Table 10-2. IRQ Functions

### (a) Primary Functions

| Function            | Purpose                                                                | See page |
|---------------------|------------------------------------------------------------------------|----------|
| IRQ_clear()         | Clears the interrupt flag in the IFR register for the specified event. | 10-9     |
| IRQ_disable()       | Disables the specified event in the IMR register.                      | 10-10    |
| IRQ_enable()        | Enables the specified event in the IMR register flag.                  | 10-11    |
| IRQ_globalDisable() | Globally disables all maskable interrupts. (INTM = 1)                  | 10-12    |
| IRQ_globalEnable()  | Globally enables all maskable interrupts. (INTM = 0)                   | 10-13    |
| IRQ_globalRestore() | Restores the status of global interrupt enable/disable (INTM).         | 10-13    |
| IRQ_restore()       | Restores the status of the specified event.                            | 10-15    |
| IRQ_setVecs()       | Sets the base address of the interrupt vector table.                   | 10-16    |
| IRQ_test()          | Polls the interrupt flag in IFR register the specified event.          | 10-16    |

### (b) Auxiliary Functions

| Function   | Purpose                                                                                                                        | See page |
|------------|--------------------------------------------------------------------------------------------------------------------------------|----------|
| IRQ_plug() | Writes the necessary code in the interrupt vector location to branch to the interrupt service routine for the specified event. | 10-14    |
|            | <b>Caution:</b> Do not use this function when DSP/BIOS is present and the dispatcher is enabled.                               |          |

Table 10–2. IRQ Functions (Continued)

### (c) DSP/BIOS Dispatcher Communication Functions

| Function         | Purpose                                                                                                                       | See page |
|------------------|-------------------------------------------------------------------------------------------------------------------------------|----------|
| IRQ_config()     | Updates the DSP/BIOS dispatch table with a new configuration for the specified event.                                         | 10-9     |
| IRQ_configArgs() | Updates the DSP/BIOS dispatch table with a new configuration for the specified event.                                         | 10-10    |
| IRQ_getArg()     | Returns value of the argument to the interrupt service routine that the DSP/BIOS dispatcher passes when the interrupt occurs. | 10-11    |
| IRQ_getConfig()  | Returns current DSP/BIOS dispatch table entries for the specified event.                                                      | 10-12    |
| IRQ_map()        | Maps a logical event to its physical interrupt.                                                                               | 10-14    |
| IRQ_setArg()     | Sets the value of the argument for DSP/BIOS dispatch to pass to the interrupt service routine for the specified event.        | 10-15    |

### 10.1.1 The Event ID Concept

The IRQ module assigns an event ID to each of the possible physical interrupts. Because there are more events possible than can be masked in the IMR register, many of the events share a common physical interrupt. Therefore, it is necessary in some cases to map the logical events to the corresponding physical interrupt. The IRQ module defines a set of constants IRQ\_EVT\_NNNN that uniquely identify each of the possible logical interrupts. A list of these event IDs is listed in Table 10–3. All of the IRQ APIs operate on logical events.

Table 10-3. IRQ\_EVT\_NNNN Event List

| Constant       | Purpose                      |
|----------------|------------------------------|
| IRQ_EVT_RS     | Reset                        |
| IRQ_EVT_SINTR  | Software Interrupt           |
| IRQ_EVT_NMI    | Non-Maskable Interrupt (NMI) |
| IRQ_EVT_SINT16 | Software Interrupt #16       |
| IRQ_EVT_SINT17 | Software Interrupt #17       |
| IRQ_EVT_SINT18 | Software Interrupt #18       |

Table 10–3. IRQ\_EVT\_NNNN Event List (Continued)

| Constant       | Purpose                |
|----------------|------------------------|
| IRQ_EVT_SINT19 | Software Interrupt #19 |
| IRQ_EVT_SINT20 | Software Interrupt #20 |
| IRQ_EVT_SINT21 | Software Interrupt #21 |
| IRQ_EVT_SINT22 | Software Interrupt #22 |
| IRQ_EVT_SINT23 | Software Interrupt #23 |
| IRQ_EVT_SINT24 | Software Interrupt #24 |
| IRQ_EVT_SINT25 | Software Interrupt #25 |
| IRQ_EVT_SINT26 | Software Interrupt #26 |
| IRQ_EVT_SINT27 | Software Interrupt #27 |
| IRQ_EVT_SINT28 | Software Interrupt #28 |
| IRQ_EVT_SINT29 | Software Interrupt #29 |
| IRQ_EVT_SINT30 | Software Interrupt #30 |
| IRQ_EVT_SINT0  | Software Interrupt #0  |
| IRQ_EVT_SINT1  | Software Interrupt #1  |
| IRQ_EVT_SINT2  | Software Interrupt #2  |
| IRQ_EVT_SINT3  | Software Interrupt #3  |
| IRQ_EVT_SINT4  | Software Interrupt #4  |
| IRQ_EVT_SINT5  | Software Interrupt #5  |
| IRQ_EVT_SINT6  | Software Interrupt #6  |
| IRQ_EVT_SINT7  | Software Interrupt #7  |
| IRQ_EVT_SINT8  | Software Interrupt #8  |
| IRQ_EVT_SINT9  | Software Interrupt #9  |
| IRQ_EVT_SINT10 | Software Interrupt #10 |
| IRQ_EVT_SINT11 | Software Interrupt #11 |
| IRQ_EVT_SINT12 | Software Interrupt #12 |
| IRQ_EVT_SINT13 | Software Interrupt #13 |

Table 10–3. IRQ\_EVT\_NNNN Event List (Continued)

| Constant       | Purpose                          |
|----------------|----------------------------------|
| IRQ_EVT_INT0   | External User Interrupt #0       |
| IRQ_EVT_INT1   | External User Interrupt #1       |
| IRQ_EVT_INT2   | External User Interrupt #2       |
| IRQ_EVT_INT3   | External User Interrupt #3       |
| IRQ_EVT_TINT0  | Timer 0 Interrupt                |
| IRQ_EVT_HINT   | Host Interrupt (HPI)             |
| IRQ_EVT_DMA0   | DMA Channel 0 Interrupt          |
| IRQ_EVT_DMA1   | DMA Channel 1 Interrupt          |
| IRQ_EVT_DMA2   | DMA Channel 2 Interrupt          |
| IRQ_EVT_DMA3   | DMA Channel 3 Interrupt          |
| IRQ_EVT_DMA4   | DMA Channel 4 Interrupt          |
| IRQ_EVT_DMA5   | DMA Channel 5 Interrupt          |
| IRQ_EVT_RINT0  | MCBSP Port #0 Receive Interrupt  |
| IRQ_EVT_XINT0  | MCBSP Port #0 Transmit Interrupt |
| IRQ_EVT_RINT2  | MCBSP Port #2 Receive Interrupt  |
| IRQ_EVT_XINT2  | MCBSP Port #2 Transmit Interrupt |
| IRQ_EVT_TINT1  | Timer #1 Interrupt               |
| IRQ_EVT_HPINT  | Host Interrupt (HPI)             |
| IRQ_EVT_RINT1  | MCBSP Port #1 Receive Interrupt  |
| IRQ_EVT_XINT1  | MCBSP Port #1 Transmit Interrupt |
| IRQ_EVT_IPINT  | FIFO Full Interrupt              |
| IRQ_EVT_SINT14 | Software Interrupt #14           |
| IRQ_EVT_WDTINT | Watchdog Timer Interrupt         |
| IRQ_EVT_UART   | UART Interrupt                   |
| IRQ_EVT_DAARCV | DAA Receive Interrupt            |
| IRQ_EVT_DAAXMT | DAA Transmit Interrupt           |

### 10.2 Using Interrupts with CSL

Interrupts within CSL can be managed in the following methods:

- ☐ Manual setting outside DSPBIOS HWIs
- ☐ Using DSPBIOS HWIs
- Using DSPBIOS Dispatcher

Example 10–1. Manual Setting Outside DSPBIOS HWIs

```
#define NVECTORS
                        256
#pragma DATA_SECTION
                       (myIvtTable, "myvec")
int myIvtTable[NVECTORS];
interrupt void myIsr();
main (){
; Option 1: use Event IDs directly
IRQ_setVecs ((Uint16)myIvtTable);
IRQ_plug (IRQ_EVT_TINT0,&myIsr);
IRQ_enable(IRQ_EVT_TINT0);
IRQ_globalEnable();
; Option 2: Use the PER_getEventId() function (TIMER as an example)
for a better abstraction
IRQ_setVecs ((Uint16)myIvtTable);
eventId = TIMER_getEventId (hTimer);
IRQ_plug (eventId,&myIsr);
IRQ enable (eventId);
IRQ_globalEnable();
; ...
interrupt void myISR()
//...;
```

## 10.3 Configuration Structure

};

| IRQ_Config  | IRQ configuration structure                                                                                                                                                 |                                                                                                                                          |  |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|--|
| Structure   | IRQ_Config                                                                                                                                                                  |                                                                                                                                          |  |
| Members     | IRQ_IsrPtr FuncAddr<br>Uint16 funcArg<br>Uint32 ierMask                                                                                                                     | Function to be called Argument to pass to ISR when invoked Mask for the interrupts to be disabled when the current interrupt is handled. |  |
| Description | This is the IRQ configuration structure used to update a DSP/BIOS table entry. You create and initialize this structure then pass its address to the IRQ_config() function. |                                                                                                                                          |  |
| Example     | <pre>IRQ_Config MyConfig 0x0000, /* funcAd 0x0000, /* funcAr 0x0300 /* ierMask</pre>                                                                                        | dr */<br>g */                                                                                                                            |  |

### 10.4 Functions

This section describes the primary, auxiliary, and DSP/BIOS Dispatcher Communications IRQ functions.

## IRQ\_clear Clears event flag from IFR register

Function void IRQ\_clear(

Uint16 EventId

);

Arguments EventID, see IRQ\_EVT\_NNNN (Table 10–3) for a complete list

of events. Or, use the PER\_getEventId() function to get the

EventID.

Return Value None

**Description** Clears the event flag from the IFR register

### IRQ\_config

### Updates Entry in DSPBIOS dispatch table

```
Function void IRQ_config(
```

Uint16 EventId, IRQ\_Config \*Config

);

**Arguments** EventID Event ID, see IRQ\_EVT\_NNNN for a complete list of events.

Config Pointer to an initialized configuration structure

Return Value None

**Description** Updates the entry in the DSPBIOS dispatch table for the specified event.

**Example** IRQ\_Config MyConfig = {

```
0x0000, /* funcAddr */
0x0000, /* funcArg */
0x0300 /* ierMask */
};
```

IRQ\_config(IRQ\_EVT\_TINT0,&MyConfig);

## IRQ\_configArgs

### Updates entry in DSPBIOS dispatch table

**Function** void IRQ configArgs(

Uint16 EventId, IRQ\_IsrPtr funcAddr,

Uint16 funcArg, Uint32 ierMask

);

**Arguments** EventID, see IRQ\_EVT\_NNNN for a complete list of events.

funcArg Argument to pass to interrupt service routine when it is invoked

by DSPBIOS dispatcher

ierMask Interrupts to disable while processing the ISR for this event

(Mask for IER0, IER1)

Return Value None

**Description** Updates DSPBIOS dispatch table entry for the specified event.

**Example** IRQ\_configArgs(EventID, funcAddr, funcArg, ierMask);

### IRQ disable

### Disables specified event

Function int IRQ disable(

Uint16 EventId

);

Arguments EventID, see IRQ\_EVT\_NNNN (Table 10-3) for a complete list

of events. Or, use the PER getEventId() function to get the

EventID.

**Return Value** intm Old value of the specified mask bit in the IMR register.

**Description** Disables the specified event, by modifying the IMR register.

**Example** int intm;

intm = IRQ\_disable(IRQ\_EVT\_TINT0);

IRQ enable Enables specified event

**Function** int IRQ\_enable(

Uint16 EventId

);

Arguments EventID, see IRQ\_EVT\_NNNN (Table 10-3) for a complete list

of events. Or, use the PER\_getEventId() function to get the

EventID.

**Return Value** intm Old value of the specified mask bit in the IMR register.

**Description** Enables the specified event.

**Example** int intm;

intm = IRQ\_enable(IRQ\_EVT\_TINT0);

IRQ\_getArg Gets value for specified event

Function Uint32 IRQ\_getArg(

Uint16 EventId

);

Arguments EventID, see IRQ\_EVT\_NNNN (Table 10-3) for a complete list

of events. Or, use the PER\_getEventId() function to get the

EventID.

Return Value Value of argument

**Description** Gets the value for specified event.

Example Uint32 arg;

arg = IRQ\_getArg(IRQ\_EVT\_TINT0);

IRQ\_getConfig

Gets DSP/BIOS dispatch table entry

**Function** 

void IRQ\_getConfig( Uint16 EventId, IRQ\_Config \*Config

);

**Arguments** 

EventID, see IRQ\_EVT\_NNNN (Table 10-3) for a complete list

of events. Or, use the PER\_getEventId() function to get the

EventID.

Config

Pointer to configuration structure

**Return Value** 

None

Description

Reads the current configuration for the IRQ event.

Example

IRQ\_Config ConfigRead;

. . .

IRQ\_getConfig(IRQ\_EVT\_TINT0, &ConfigRead);

IRQ\_globalDisable

Globally Disables Interrupts

**Function** 

int IRQ\_globalDisable(

);

Arguments

None

**Return Value** 

intm Returns the old INTM value

Description

This function globally disables interrupts by setting the INTM of the ST1 register. The old value of INTM is returned. This is useful for temporarily

disabling global interrupts, then enabling them again.

**Example** 

int oldgie;

oldgie = IRQ\_globalDisable();

### IRQ globalEnable Globally enables all events

**Function** int IRQ\_globalEnable(

);

**Arguments** None

**Return Value** Returns the old INTM value intm

**Description** This function globally enables all interrupts by setting the INTM of the ST1

register. The old value of INTM is returned. This is useful for temporarily

enabling global interrupts, then disabling them again.

Example Uint32 intm;

intm = IRQ\_globalEnable();

IRQ\_globalRestore (intm);

### IRQ\_globalRestore

### Restores The Global Interrupt Mask State

**Function** void IRQ\_globalRestore(

int intm

);

**Arguments** intm Value to restore the INTM value to (0 = enable, 1 = disable)

**Return Value** Previously saved value gie

**Description** This function restores the INTM state to the value passed in by writing to the

INTM bit of the ST1 register. This is useful for temporarily disabling/enabling

global interrupts, then restoring them back to its previous state.

**Example** int intm;

intm = IRQ\_globalDisable();

IRQ globalRestore (intm);

| IRQ_map      | Maps Event To Physical Interrupt Number                                                                                                                                                                |                                                                                                                                                                                                     |  |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Function     | void IRQ_map(<br>Uint16 EventId<br>);                                                                                                                                                                  |                                                                                                                                                                                                     |  |
| Arguments    | EventId                                                                                                                                                                                                | Event ID, see IRQ_EVT_NNNN (Table 10–3) for a complete list                                                                                                                                         |  |
|              |                                                                                                                                                                                                        | of events. Or, use the PER_getEventId() function to get the EventID.                                                                                                                                |  |
| Return Value | None                                                                                                                                                                                                   |                                                                                                                                                                                                     |  |
| Description  | This function maps a logical event to a physical interrupt number for use by DSPBIOS dispatch.                                                                                                         |                                                                                                                                                                                                     |  |
| Example      | IRQ_map(]                                                                                                                                                                                              | RQ_EVT_TINTO);                                                                                                                                                                                      |  |
|              |                                                                                                                                                                                                        |                                                                                                                                                                                                     |  |
| IRQ_plug     | Initializes An Interrupt Vector Table Vector                                                                                                                                                           |                                                                                                                                                                                                     |  |
| Function     | void IRQ_plug(     Uint16 EventId,     IRQ_IsrPtr funcAddr, );                                                                                                                                         |                                                                                                                                                                                                     |  |
| Arguments    | EventId                                                                                                                                                                                                | Event ID, see IRQ_EVT_NNNN (Table 10–3) for a complete list                                                                                                                                         |  |
|              |                                                                                                                                                                                                        | of events. Or, use the PER_getEventId() function to get the EventID.                                                                                                                                |  |
|              | funcAddr                                                                                                                                                                                               | Address of the interrupt service routine to be called when the interrupt happens. This function must be C-callable and if implemented in C, it must be declared using the <i>interrupt</i> keyword. |  |
| Return Value | None                                                                                                                                                                                                   |                                                                                                                                                                                                     |  |
| Description  | Initializes an interrupt vector table vector with the necessary code to branch to the specified ISR. <b>Caution</b> : Do not use this function when DSP/BIOS is present and the dispatcher is enabled. |                                                                                                                                                                                                     |  |
| Example      | <pre>IRQ_IsrPtr funcAddr; .</pre>                                                                                                                                                                      |                                                                                                                                                                                                     |  |

IRQ\_plug (IRQ\_EVT\_TINT0, funcAddr);

IRQ restore Restores the status of the specified event

**Function** void IRQ\_restore(

Uint16 Eventld, Uint16 Val

);

Arguments EventID, see IRQ\_EVT\_NNNN (Table 10–3 on page 10-4)

for a complete list of events.

Val Value to restore the specified event to

Return Value None

**Description** Restores the status of the specified event.

**Example** Uint16 intm = IRQ\_disable(IRQ\_EVT\_TINT0);

. . . .

IRQ\_restore(IRQ\_EVT\_TINT0,intm);

IRQ\_setArg Sets value of argument for DSPBIOS dispatch entry

**Function** void IRQ\_setArg(

Uint16 EventId, Uint32 val

);

Arguments Event ID, see IRQ\_EVT\_NNNN (Table 10–3) for a complete list

of events. Or, use the PER\_getEventId() function to get the

EventID.

Return Value None

**Description** Sets the argument that DSP/BIOS dispatcher will pass to the interrupt service

routine for the specified event.

Example Uint32 val;

IRQ\_setArg(IRQ\_EVT\_TINT0, val);

IRQ setVecs

Sets the base address of the interrupt vectors

**Function** 

int IRQ\_setVecs( Uint32 iptr

);

Arguments

iptr IVPD pointer to the DSP interrupt vector table

**Return Value** 

oldVecs

Returns the old IVPD Pointer to the DSP interrupt Vector table

Description

Use this function to set the base address of the interrupt vector table in the

IVPD register.

**Caution:** Changing the interrupt vector table base can have adverse effects on your system because you will be effectively eliminating all previous interrupt settings. There is a strong chance that the DSP/BIOS kernel and RTDX will fail

if this function is not used with care.

Example

IRQ\_setVecs (0x8000);

IRQ\_test

Tests event to see if its flag is set in IFR register

**Function** 

CSLBool IRQ\_test( Uint16 EventId

);

Arguments

EventId Event ID, see IRQ EVT NNNN (Table 10-3) for a complete list

of events. Or, use the PER\_getEventId() function to get the

EventID.

**Return Value** 

Event flag, 0 or 1

Description

Tests an event to see if its flag is set in the IFR register.

Example

while (!IRQ\_test(IRQ\_EVT\_TINT0);

## **Chapter 11**

## McBSP Module

The chapter describes the structure, functions, and macros of the McBSP module.

# Topic Page 11.1 Overview 11-2 11.2 Configuration Structure 11-4 11.3 Functions 11-6 11.4 Macros 11-24 11.5 Configuring the MCBSP Module Using CSL GUI 11-42 11.6 Examples 11-50

### 11.1 Overview

THE McBSP is a handle-based module that requires you to call MCBSP\_open() to obtain a handle before calling any other functions. Table 11–1 lists the structure for use with the McBSP modules. Table 11–2 lists the functions for use with the McBSP modules.

Table 11-1. McBSP Configuration Structure

| Structure    | Purpose                                                  | See page |
|--------------|----------------------------------------------------------|----------|
| MCBSP_Config | McBSP configuration structure used to setup a McBSP port | 11-4     |

### Table 11–2. McBSP Functions

### (a) Primary Functions

| Function           | Purpose                                                                 | See page |
|--------------------|-------------------------------------------------------------------------|----------|
| MCBSP_close()      | Closes a McBSP port                                                     | 11-10    |
| MCBSP_config()     | Sets up the McBSP port using the configuration structure (MCBSP_Config) | 11-10    |
| MCBSP_configArgs() | Sets up the McBSP port using the register values passed to the function | 11-12    |
| MCBSP_open()       | Opens a McBSP port                                                      | 11-17    |
| MCBSP_start()      | Start a transmit and/or receive for a MCBSP port                        | 11-20    |

## Table 11–2. McBSP Functions (Continued)

### (b) Auxiliary Functions

| Function          | Purpose                                                                                                          | See page |
|-------------------|------------------------------------------------------------------------------------------------------------------|----------|
| MCBSP_getConfig() | Get MCBSP channel configuration                                                                                  | 11-15    |
| MCBSP_getPort()   | Get MCBSP Port number used in given handle                                                                       | 11-15    |
| MCBSP_read16()    | Performs a direct 16-bit read from the data receive register DRR1                                                | 11-17    |
| MCBSP_read32()    | Performs two direct 16-bit reads: data receive register 2 DRR2 (MSB) and data receive register 1 DRR1 (LSB)      | 11-18    |
| MCBSP_reset()     | Resets the given serial port                                                                                     | 11-18    |
| MCBSP_rfull()     | Reads the RFULL bit SPCR1 register                                                                               | 11-18    |
| MCBSP_rrdy()      | Reads the RRDY status bit of the SPCR1 register                                                                  | 11-19    |
| MCBSP_write16()   | Writes a 16-bit value to the serial port data transmit register, DXR1                                            | 11-22    |
| MCBSP_write32()   | Writes two 16-bit values to the two serial port data transmit registers, DXR2 (16-bit MSB) and DXR1 (16-bit LSB) | 11-22    |
| MCBSP_xempty()    | Reads the XEMPTY bit from the SPCR2 register                                                                     | 11-23    |
| MCBSP_xrdy()      | Reads the XRDY status bit of the SPCR2 register                                                                  | 11-23    |

### (c) Interrupt Control Functions

| Function              | Purpose                                            | See page |
|-----------------------|----------------------------------------------------|----------|
| MCBSP_getRcvEventId() | Retrieves the receive event ID for the given port  | 11-16    |
| MCBSP_getXmtEventId() | Retrieves the transmit event ID for the given port | 11-16    |

### (d) Multichannel Control Functions

| Function               | Purpose                                                        | See page |
|------------------------|----------------------------------------------------------------|----------|
| MCBSP_channelDisable() | Disables one or several McBSP channels                         | 11-6     |
| MCBSP_channelEnable()  | Enables one or several McBSP channels of the selected register | 11-7     |
| MCBSP_channelStatus()  | Returns the channel status                                     | 11-9     |

## 11.2 Configuration Structure

This section lists the configuration structure for the McBSP module.

### MCBSP\_Config

McBSP configuration structure used to setup McBSP port

**Structure** 

MCBSP\_Config

**Members** 

| Uint16 spcr1 | Serial port control register 1 value   |
|--------------|----------------------------------------|
| Uint16 spcr2 | Serial port control register 2 value   |
| Uint16 rcr1  | Receive control register 1 value       |
| Uint16 rcr2  | Receive control register 2 value       |
| Uint16 xcr1  | Transmit control register 1 value      |
| Uint16 xcr2  | Transmit control register 2 value      |
| Uint16 srgr1 | Sample rate generator register 1 value |
| Uint16 srgr2 | Sample rate generator register 2 value |
| Uint16 mcr1  | Multi-channel control register 1 value |
| Uint16 mcr2  | Multi-channel control register 2 value |
| Uint16 pcr   | Pin control register value             |
|              |                                        |

For devices supporting 128 channels:

| Uint16 rcera | Receive channel enable register partition A value  |
|--------------|----------------------------------------------------|
| Uint16 rcerb | Receive channel enable register partition B value  |
| Uint16 rcerc | Receive channel enable register partition C value  |
| Uint16 rcerd | Receive channel enable register partition D value  |
| Uint16 rcere | Receive channel enable register partition E value  |
| Uint16 rcerf | Receive channel enable register partition F value  |
| Uint16 rcerg | Receive channel enable register partition G value  |
| Uint16 rcerh | Receive channel enable register partition H value  |
| Uint16 xcera | Transmit channel enable register partition A value |
| Uint16 xcerb | Transmit channel enable register partition B value |
| Uint16 xcerc | Transmit channel enable register partition C value |
| Uint16 xcerd | Transmit channel enable register partition D value |
| Uint16 xcere | Transmit channel enable register partition E value |
| Uint16 xcerf | Transmit channel enable register partition F value |
| Uint16 xcerg | Transmit channel enable register partition G value |
| Uint16 xcerh | Transmit channel enable register partition H value |
|              |                                                    |

For devices that do not support 128 channels:

Uint16 rcera Uint16 rcerb Uint16 xcera Uint16 xcerb

### Description

McBSP configuration structure used to setup a McBSP port. You create and initialize this structure then pass its address to the MCBSP\_config ( ) function. You can use literal values or the MCBSP\_RMK macros to create the structure member values.

### **Example**

```
MCBSP_Config MyConfig = {
  0x8001, /* spcr1 */
  0x0001, /* spcr2 */
  0x0000, /* rcrl */
  0x0000, /* rcr2 */
  0x0000, /* xcr1 */
  0x0000, /* xcr2 */
  0x0001, /* srgr1 */
  0x2000, /* srgr2 */
  0x0000, /* mcr1 */
  0x0000, /* mcr2 */
  0x0000, /* pcr */
  0x0000, /* rcera */
  0x0000, /* rcerb */
 0x0000, /* xcera */
  0x0000, /* xcerb */
};
hMcbsp = MCBSP_open(MCBSP_PORTO, MCBSP_OPEN_RESET)
MCBSP_config(hMcbsp,&MyConfig);
```

### 11.3 Functions

This section lists the primary, auxiliary, interrupt control, and multi-channel functions available for use in the McBSP module.

### MCBSP\_channelDisable Disables one or several McBSP channels

**Function** void MCBSP\_channelDisable( MCBSP\_Handle hMcbsp, Uint16 RegName,

Uint16 RegName, Uint16 Channels

);

Arguments hMcbsp Handle to McBSP port obtained by MCBSP\_open()

RegName Receive and Transmit Channel Enable Registers:

RCERA RCERB XCERA XCERB

For devices supporting 128 channels (see section 1.8) add:

RCERC RCERD RCERE RCERF RCERG RCERH XCERC XCERD XCERE

XCERF XCERG XCERH

Channels Available values for the specific RegName are:

MCBSP\_CHAN0 MCBSP\_CHAN1 MCBSP\_CHAN2 MCBSP\_CHAN3 MCBSP\_CHAN4 MCBSP CHAN5 MCBSP CHAN6 MCBSP\_CHAN7 MCBSP CHAN8 MCBSP CHAN9 MCBSP\_CHAN10 MCBSP\_CHAN11 MCBSP CHAN12 MCBSP CHAN13 MCBSP CHAN14 MCBSP CHAN15

**Return Value** 

None

Description

Disables one or several McBSP channels of the selected register. To disable several channels at the same time, the sign "|" OR has to be added in between.

To see if there is pending data in the receive or transmit buffers before disabling a channel, use MCBSP\_rrdy() or MCBSP\_xrdy().

Example

```
/* Disables Channel 0 of the partition A */
MCBSP_channelDisable(hMcbsp,RCERA, MCBSP_CHAN0);
/* Disables Channels 1, 2 and 8 of the partition B with "|"*/
MCBSP_channelDisable(hMcbsp,RCERB,(MCBSP_CHAN1 | MCBSP_CHAN2 |
MCBSP_CHAN8));
```

MCBSP\_channelEnable Enables one or several McBSP channels of selected register

**Function** 

void MCBSP channelEnable( MCBSP Handle hMcbsp, Uint16 RegName, Uint16 Channels );

**Arguments** 

hMcbsp Handle to McBSP port obtained by MCBSP open()

RegName Receive and Transmit Channel Enable Registers:

**RCERA RCERB XCERA XCERB** 

```
For devices supporting 128 channels (see section 1.8) add:
          RCERC
          RCERD
          RCERE
          RCERF
          RCERG
          RCERH
         XCERC
         XCERD
         XCERE
         XCERF
         XCERG
         XCERH
Channels
         Available values for the specificReg Addr are:
         MCBSP_CHAN0
         MCBSP_CHAN1
          MCBSP_CHAN2
         MCBSP CHAN3
         MCBSP_CHAN4
         MCBSP_CHAN5
         MCBSP CHAN6
          MCBSP CHAN7
          MCBSP_CHAN8
          MCBSP CHAN9
         MCBSP CHAN10
         MCBSP_CHAN11
         MCBSP_CHAN12
          MCBSP_CHAN13
         MCBSP CHAN14
          MCBSP_CHAN15
None
Enables one or several McBSP channels of the selected register.
To enabling several channels at the same time, the sign "|" OR has to be added
in between.
/* Enables Channel 0 of the partition A */
MCBSP_channelEnable(hMcbsp,RCERA, MCBSP_CHAN0);
/* Enables Channel 1, 4 and 6 of the partition B with "|" */
MCBSP_channelEnable(hMcbsp,RCERB,(MCBSP_CHAN1 | MCBSP_CHAN4 |
MCBSP_CHAN6));
```

**Return Value** 

Description

**Example** 

### MCBSP channelStatus Returns channel status

```
Function
                   Uint16 MCBSP channelStatus(
                         MCBSP Handle hMcbsp.
                         Uint16 RegName,
                         Uint16 Channel
                       );
Arguments
                             Handle to McBSP port obtained by MCBSP_open()
                   hMcbsp
                   RegName Receive and Transmit Channel Enable Registers:
                             RCERA
                             RCERB
                             XCERA
                             XCERB
                             For devices supporting 128 channels (see section 1.8) add:
                             RCERC
                             RCERD
                             RCERE
                             RCERF
                             RCERG
                             RCERH
                             XCERC
                             XCERD
                             XCERE
                             XCERF
                             XCERG
                             XCERH
                   Channel
                             Selectable Channels for the specific RegName are:
                             MCBSP CHAN0
                             MCBSP_CHAN1
                             MCBSP_CHAN2
                             MCBSP CHAN3
                             MCBSP CHAN4
                             MCBSP_CHAN5
                             MCBSP_CHAN6
                             MCBSP CHAN7
                             MCBSP_CHAN8
                             MCBSP_CHAN9
                             MCBSP_CHAN10
```

MCBSP CHAN11

CHAN12 CHAN13 CHAN14 CHAN15

Return Value Channel status 0 - Disabled

1 - Enabled

**Description** Returns the channel status by reading the associated bit into the selected

register (RegName). Only one channel can be observed.

Example Uint16 C1, C4;

/\* Returns Channel Status of the channel 1 of the partition B
\*/
C1=MCBSP\_channelStatus(hMcbsp,RCERB,MCBSP\_CHAN1);
/\* Returns Channel Status of the channel 4 of the partition A
\*/

C4=MCBSP\_channelStatus(hMcbsp,RCERA,MCBSP\_CHAN4);

### MCBSP close

### Closes McBSP port

Function void MCBSP close(

MCBSP Handle hMcbsp

);

Arguments hMcbsp Handle to McBSP port obtained by MCBSP\_open()

Return Value None

**Description** Closes a McBSP port previously opened via MCBSP\_open(). The registers for

the McBSP port are set to their power-on defaults and any associated

interrupts are disabled and cleared.

**Example** MCBSP\_close(hMcbsp);

### MCBSP\_config

### Sets up McBSP port using configuration structure

Function void MCBSP\_config(

MCBSP\_Handle hMcbsp, MCBSP\_Config \*Config

);

### **Arguments**

hMcbsp Handle to McBSP port obtained by MCBSP\_open()

Config

Pointer to an initialized configuration structure

### **Return Value**

None

### Description

Sets up the McBSP port identified by hMcbsp handle using the configuration structure. The values of the structure are written to the MCBSP port registers.

### Note:

If you want to configure all MCBSP registers without starting the MCBSP port, use MCBSP\_config() without setting the SPCR2 (XRST, RRST, GRST, and FRST) fields. Then,

- Step 1: Start Transmit and receive
- Step 2: Write the first data valid to the DXR registers
- ☐ Step 3: Start Sample rate generator and framesynce.

This guarantees that the correct value is transmitted/received.

### **Example**

```
MCBSP_Config MyConfig = {
  0x8001, /* spcr1 */
  0x0001, /* spcr2 */
  0x0000, /* rcr1 */
  0x0000, /* rcr2 */
  0x0000, /* xcrl */
  0x0000, /* xcr2 */
  0x0001, /* srgr1 */
  0x2000, /* srgr2 */
  0x0000, /* mcr1 */
  0x0000, /* mcr2 */
  0x0000, /* pcr
  0x0000, /* rcera */
  0x0000, /* rcerb */
  0x0000, /* xcera */
  0x0000 /* xcerb */
};
MCBSP_config(hMcbsp,&MyConfig);
```

For complete examples, refer to section 11.4.

### MCBSP\_configArgs

Sets up McBSP port using register values passed in

```
Function
                        void MCBSP_configArgs(
                           MCBSP_Handle hMcbsp,
                           Uint16 spcr1,
                           Uint16 spcr2,
                           Uint16 rcr1,
                           Uint16 rcr2,
                           Uint16 xcr1,
                           Uint16 xcr2.
                           Uint16 srgr1,
                           Uint16 srgr2,
                           Uint16 mcr1,
                           Uint16 mcr2,
                           Uint16 pcr,
                        For devices that support 128 channels:
                           Uint16 rcera,
                           Uint16 rcerb.
                           Uint16 rcerc,
                           Uint16 rcerd,
                           Uint16 rcere,
                           Uint16 rcerf,
                           Uint16 rcerg.
                           Uint16 rcerh,
                           Uint16 xcera.
                           Uint16 xcerb.
                           Uint16 xcerc.
                           Uint16 xcerd,
                           Uint16 xcere,
                           Uint16 xcerf,
                           Uint16 xcerg,
                           Uint16 xcerh,
                        For devices that do not support 128 channels:
                           Uint16 rcera.
                           Uint16 rcerb,
                           Uint16 xcera,
                           Uint16 xcerb
                           );
```

| Arguments    | hMcbsp     | Handle to McBSP port obtained by MCBSP_open()      |
|--------------|------------|----------------------------------------------------|
|              | spcr1      | Serial port control register 1 value               |
|              | spcr2      | Serial port control register 2 value               |
|              | rcr1       | Receive control register 1 value                   |
|              | rcr2       | Receive control register 2 value                   |
|              | xcr1       | Transmit control register 1 value                  |
|              | xcr2       | Transmit control register 2 value                  |
|              | srgr1      | Sample rate generator register 1 value             |
|              | srgr2      | Sample rate generator register 2 value             |
|              | mcr1       | Multi-channel control register 1 value             |
|              | mcr2       | Multi-channel control register 2 value             |
|              | pcr        | Pin control register value                         |
|              | rcerx      | Receive channel enable register partition x value  |
|              | xcerx      | Transmit channel enable register partition x value |
| Return Value | Where x= A | A, B, C, D, E, F, G, H                             |

### Description

Sets up the McBSP port using the register values that are passed. The register values are written to the port registers.

### Note:

If you want to configure all MCBSP registers without starting the MCBSP port, use MCBSP\_config() without setting the SPCR2 (XRST, RRST, GRST, and FRST) fields. Then,

- ☐ Step 1: Start Transmit and receive
- Step 2: Write the first data valid to the DXR registers
- Step 3: Start Sample rate generator and framesync

This guarantees that the correct value is transmitted/received.

You may use literal values for the arguments or for readability, you may use the MCBSP\_RMK macros to create the register values based on field values.

### **Example**

```
MCBSP_configArgs(hMcbsp,
  0x8001, /* spcr1 */
  0x0001, /* spcr2 */
  0x0000, /* rcr1 */
  0x0000, /* rcr2 */
  0x0000, /* xcr1 */
  0x0000, /* xcr2 */
  0x0001, /* srgr1 */
  0x2000, /* srgr2 */
  0x0000, /* mcr1 */
  0x0000, /* mcr2 */
  0x0000 /* pcr */
  0x0000, /* rcera*/
  0x0000, /* rcerb*/
  0x0000, /* xcera*/
  0x0000 /* xcerb*/
);
```

# MCBSP\_getConfig

# Get MCBSP channel configuration

Function void MCBSP\_getConfig (

MCBSP\_Handle hMcbsp, MCBSP\_Config \*Config

);

Arguments hMcbsp Handle to McBSP port; (see MCBSP open())

Config Pointer to an initialized configuration structure (see

MCBSP\_Config)

Return Value None

**Description** Get the current configuration for the McBSP port used by handle. This is

accomplished by reading the actual McBSP port registers and fields and

storing them back in the Config structure.

**Example** MCBSP\_Config ConfigRead;

. . .

myHandle = MCBSP\_open (MCBSP\_PORT0, 0);
MCBSP\_getConfig (myHandle, &ConfigRead);

# MCBSP\_getPort

# Get McBSP port number used in given handle

**Function** Uint16 MCBSP\_getPort (MCBSP\_Handle hMcbsp);

Arguments hMcbsp Handle to McBSP port given by MCBSP\_open()

Return Value Port number

**Description** Get Port number used by specific handle

**Example** Uint16 PortNum;

. . .

PortNum = MCBSP\_getPort (hMcbsp);

# MCBSP\_getRcvEventId Retrieves receive event ID for given port

Function Uint16 MCBSP\_getRcvEventId(

MCBSP\_Handle hMcbsp

);

Arguments hMcbsp Handle to McBSP port obtained by MCBSP\_open()

Return Value Receiver event ID

**Description** Retrieves the IRQ receive event ID for the given port. Use this ID to manage

the event using the IRQ module.

**Example** Uint16 RecvEventId;

. . .

RecvEventId = MCBSP\_getRcvEventId(hMcbsp);

IRQ\_enable(RecvEventId);

# MCBSP\_getXmt EventID Retrieves transmit event ID for given port

**Function** Uint16 MCBSP\_getXmtEventId(

MCBSP\_Handle hMcbsp

);

Arguments hMcbsp Handle to McBSP port obtained by MCBSP\_open()

Return Value Transmitter event ID

**Description** Simple replace receive for transmit. Use this ID to manage the event using the

IRQ module.

**Example** Uint16 XmtEventId;

. .

XmtEventId = MCBSP\_getXmtEventId(hMcbsp);

IRO enable(XmtEventId);

# Opens McBSP port MCBSP open **Function** MCBSP\_Handle MCBSP\_open( int devNum, Uint32 flags ); **Arguments** devNum McBSP device (port) number: ☐ MCBSP\_PORT0 ☐ MCBSP\_PORT1 ☐ MCBSP PORT2 (if available in the device) ☐ MCBSP PORT ANY Open flags, may be logical OR of any of the following: flags ☐ MCBSP\_OPEN\_RESET **Return Value** Device Handle **Description** Before a McBSP port can be used, it must first be opened by this function. Once opened, it cannot be opened again until closed, see MCBSP\_close(). The return value is a unique device handle that you use in subsequent MCBSP API calls. If the open fails, INV (-1) is returned. If the MCBSP OPEN RESET is specified, the McBSP port registers are set to their power-on defaults and any associated interrupts are disabled and cleared. Example MCBSP\_Handle hMcbsp; hMcbsp = MCBSP\_open(MCBSP\_PORTO,MCBSP\_OPEN\_RESET); MCBSP read16 Performs16-bit data read **Function** Uint16 MCBSP\_read16( MCBSP\_Handle hMcbsp ); **Arguments** hMcbsp Handle to McBSP port obtained by MCBSP open() **Return Value** Data read for MCBSP receive port. Directly reads a 16-bit value from the McBSP data receive register DRR1. Description Depending on the receive word data length you have selected in the RCR1/RCR2 registers, the actual data could be 8, 12, or 16 bits long. This function does not verify if new valid data as been received. Use MCBSP\_rrdy() prior to calling MCBSP\_read32() for this purpose. **Example** Uint16 Data; Data = MCBSP\_read16(hMcbsp);

# MCBSP read32

### Performs 32-bit data read

**Function** 

Uint32 MCBSP\_read32( MCBSP\_Handle hMcbsp ):

**Arguments** 

hMcbsp Handle to McBSP port obtained by MCBSP\_open()

**Return Value** 

Data (MSW-LSW ordering)

Description

A 32-bit read. First, the 16-bit MSW (Most significant word) is read from register DRR2. Then, the 16-bit LSW (least significant word) is read from register DRR1. Depending on the receive word data length you have selected in the RCR1/RCR2 register, the actual data could be 20, 24, or 32 bits. This function does not verify that new valid data has been received. Use MCBSP\_rrdy() prior to calling MCBSP\_read32() for this purpose.

**Example** 

```
Uint32 Data;
...
Data = MCBSP_read32(hMcbsp);
```

# MCBSP\_reset

## Resets given serial port

**Function** 

void MCBSP\_reset( MCBSP\_Handle hMcbsp );

Arguments

hMcbsp Handle to McBSP port obtained by MCBSP\_open()

Return Value

None

Description

Resets the given serial port. If you use INV (-1) for hMcbsp, all serial ports are

reset. Actions Taken:

☐ All serial port registers are set to their power-on defaults.

All associated interrupts are disabled and cleared.

**Example** 

MCBSP\_reset(hMcbsp);
MCBSP\_reset(INV);

### MCBSP rfull

### Reads RFULL bit of serial port control register 1

Function CSLBool MCBSP\_rfull(

MCBSP\_Handle hMcbsp

);

Arguments hMcbsp Handle to McBSP port obtained by MCBSP open()

Return Value Returns RFULL status bit of SPCR1 register, 0 (receive buffer

empty) or 1(receive buffer full)

**Description** Reads the RFULL bit of the serial port control register 1. (Both RBR and RSR

are full. A receive overrun error could have occured.)

**Example** if (MCBSP\_rfull(hMcbsp)) {

}

# MCBSP\_rrdy

## Reads RRDY status bit of SPCR1 register

**Function** CSLBool MCBSP\_rrdy(

MCBSP\_Handle hMcbsp

);

Arguments hMcbsp Handle to McBSP port obtained by MCBSP\_open()

Return Value RRDY Returns RRDY status bit of SPCR1, 0 (no new data to be

received) or 1 (new data has been received)

**Description** Reads the RRDY status bit of the SPCR1 register. A 1 indicates the receiver

is ready with data to be read.

**Example** if (MCBSP\_rrdy(hMcbsp)) {

val = MCBSP\_read16(hMcbsp);
}

### MCBSP start

### Starts transmit and/or receive operation for a McBSP port

**Function** 

void MCBSP\_start(

MCBSP\_Handle hMcbsp,

Uint16 startMask,

Uint16 SampleRateGenDelay

);

**Arguments** 

hMcbsp

Handle to McBSP port obtained by MCBSP\_open()

startMask

Start mask. It could be any of the following values (or

their logical OR):

MCBSP\_XMIT\_START: start transmit (XRST field)
MCBSP\_RCV\_START: start receive (RRST field)
MCBSP\_SRGR\_START: start sample rate generator

(GRST field)

MCBSP\_SRGR\_FRAMESYNC: start framesync

generation (FRST field)

SampleRateGenDelay Sample rate generates delay. MCBSP logic requires

two sample\_rate generator clock\_periods after enabling the sample rate generator for its logic to stabilize. Use this parameter to provide the appropriate delay before starting the MCBSP. A

conservative value should be equal to:

SampleRateGenDelay =

2 x Sample\_Rate\_Generator\_Clock\_period 4 x C54x\_Instruction\_Cycle

A default value of:

MCBSP SAMPLE RATE DELAY DEFAULT (0xFFFF value)

can be used (maximum value).

**Return Value** 

None

### Description

Starts a transmit and/or a receive operation for a MCBSP port.

#### Note:

If you want to configure all MCBSP registers without starting the MCBSP port, use MCBSP\_config() without setting the SPCR2 (XRST, RRST, GRST, and FRST) fields. Then,

- ☐ Step 1: Start Transmit and receive
- ☐ Step 2: Write the first data valid to the DXR registers
- ☐ Step 3: Start Sample rate generator and framesynce

This guarantees that the correct value is transmitted/received (see example 2).

### Example 1

### **Example 2**

MCBSP write16

Writes a 16-bit data value

Function

void MCBSP\_write16(

MCBSP Handle hMcbsp,

Uint16 Val

);

Arguments

hMcbsp

Handle to McBSP port obtained by MCBSP\_open()

Val

16-bit data value to be written to MCBSP transmit register.

**Return Value** 

None

Description

Directly writes a 16-bit value to the serial port data transmit register; DXR1. Depending on the receive word data length you have selected in the RCR1/RCR2 registers, the actual data could be 8, 12, or 16 bits long. **This function does not check if the transmitter is ready.** Use MCBSP\_xrdy() prior to calling MCBSP write16() for this purpose.

Example

MCBSP\_write16(hMcbsp,0x1234);

### MCBSP write32

Writes a 32-bit data value

**Function** 

Void MCBSP write32(

MCBSP Handle hMcbsp,

Uint32 Val

);

**Arguments** 

hMcbsp

Handle to McBSP port obtained by MCBSP open()

Val

32-bit data value

Return Value

None

Description

Depending on the transmit word data length you have selected in the XCR1|XCR2 registers, the actual data could be 20, 24, or 32 bits long. This function does not verify that all valid data has been transmitted. Use

MCBSP\_xrdy(), prior to calling MCBSP\_write32(), for this purpose.

Example

MCBSP\_write32(hMcbsp,0x12345678);

# MCBSP\_xempty

### Reads XEMPTY bit from SPCR2 register

**Function** 

CSLBool MCBSP\_xempty( MCBSP\_Handle hMcbsp

);

**Arguments** 

hMcbsp Handle to McBSP port obtained by MCBSP open()

**Return Value** 

XEMPTY

Returns XEMPTY bit of SPCR2 register, O(transmit buffer empty)

or 1(transmit buffer full)

**Description** 

Reads the XEMPTY bit from the SPCR2 register. A 0 indicates the transmit shift (XSR) is empty.

**Example** 

```
if (MCBSP_xempty(hMcbsp)) {
```

### MCBSP\_xrdy

## Reads XRDY status bit of SPCR2 register

**Function** 

CSLBool MCBSP\_xrdy( MCBSP\_Handle hMcbsp );

**Arguments** 

hMcbsp Handle to McBSP port obtained by MCBSP\_open()

**Return Value** 

XRDY Returns XRDY status bit of SPCR2, 0 (not ready to transmit)

and 1 (ready to transmit).

**Description** 

Reads the XRDY status bit of the SPCR2 register. A "1" indicates that the transmitter is ready to transmit a new word. A "0" indicates that the transmitter

is not ready to transmit a new word.

**Example** 

```
if (MCBSP_xrdy(hMcbsp)) {
  MCBSP_write16 (hMcbsp, 0x1234);
```

### 11.4 Macros

As covered in section 1.5, the CSL offers a collection of macros to get individual access to the peripheral registers and fields.

The following are the list of macros available for the MCBSP. To use these macros, include "csl\_mcbsp.h".

Because the MCBSP has several channels, macros identify the channel by either the channel number or the handle used.

Table 11–3 lists the macros available for a MCBSP channel using the channel number as part of the register name.

Table 11–4 lists the macros available for a MCBSP channel using its corresponding handle.

## Table 11-3. MCBSP CSL Macros (using port number)

(a) Macros to read/write MCBSP register values

#### Macro

MCBSP\_RGET()

MCBSP\_RSET()

(b) Macros to read/write MCBSP register field values (Applicable only to registers with more than one field)

#### Macro

MCBSP\_FGET()

MCBSP\_FSET()

(c) Macros to read/write MCBSP register field values (Applicable only to registers with more than one field)

#### Macro

MCBSP\_REG\_RMK()

MCBSP\_FMK()

(d) Macros to read a register address

#### Macro

MCBSP\_ADDR()

# Table 11-4. MCBSP CSL Macros (using handle)

# (a) Macros to read/write MCBSP register values

| Масго                                                                                                  | See page |  |  |
|--------------------------------------------------------------------------------------------------------|----------|--|--|
| MCBSP_RGETH()                                                                                          | 11-34    |  |  |
| MCBSP_RSETH()                                                                                          | 11-36    |  |  |
| (b) Macros to read/write register field values (Applicable only to registers with more than one field) |          |  |  |
| Масто                                                                                                  | See page |  |  |
| MCBSP_FGETH()                                                                                          | 11-37    |  |  |
| MCBSP_FSETH()                                                                                          | 11-38    |  |  |
| (c) Macros to read a register address                                                                  |          |  |  |
| Macro                                                                                                  | See page |  |  |
| MCBSP_ADDRH()                                                                                          | 11-40    |  |  |

# MCBSP\_RGET

# Get the value of a MCBSP register

Macro Uint16 MCBSP\_RGET (REG#)

Arguments REG# Register name with channel number (#) where

# = 0,1, (2: depending on the device)

DRR1# DRR2# DXR1# DXR2# SPCR1# SPCR2# RCR1# RCR2# XCR1# XCR2# SRGR1# SRGR2# MCR1# MCR2# PCR# RCERA# RCERB#

XCERA# XCERB#

For devices supporting 128-channels, add:

RCERC#
XCERD#
XCERD#
RCERE#
XCERE#
XCERF#
XCERF#
XCERG#
XCERG#
RCERH#

XCERH#

Return Value value of register

Description Returns the MCBSP register value

**Example** Uint16 myVar;

REG#

myVar = MCBSP\_RGET(RCR10); /\*get register RCR1 of channel 0 \*/

# MCBSP\_RSET

### Set the value of a MCBSP register

Macro

Void MCBSP\_REG\_SET (MCBSP\_Handle hMcbsp, Uint16 RegVal)

**Arguments** 

Register name with channel number (#) where

# = 0,1, (2: depending on the device)

DRR1#

DRR2# DXR1#

DXR2#

SPCR1#

SPCR2#

RCR1#

RCR2#

XCR1#

XCR2#

SRGR1#

SRGR2#

MCR1#

MCR2#

PCR#

RCERA#

RCERB#

XCERA#

XCERB#

For devices supporting 128-channels, add:

RCERC#

XCERC#

RCERD#

XCERD#

RCERE#

XCERE#

RCERF#

XCERF#

RCERG#

XCERG# RCERH# XCERH#

regval Register value needed to write to register REG

Return Value None

**Description** Set the MCBSP register REG value to regval

**Example** MCBSP\_RSET(RCR10, 0x4); /\* RCR1C for channel 0 = 0x4 \*/

# MCBSP\_REG\_RMK Creates a register value based on individual field values

Macro Uint16 MCBSP\_REG\_RMK (fieldval\_n,...,fieldval\_0)

Arguments REG Only writable registers containing more than one field are

supported by this macro. Please note that the channel

number is not used as part of the register name. SPCR1

SPCR2

01 0112

RCR1

RCR2

XCR1

XCR2

SRGR1

SRGR2

MCR1

MCR2

PCR

RCERA

**RCERB** 

**XCERA** 

**XCERB** 

For devices supporting 128-channels, add:

RCERC

**XCERC** 

**RCERD** 

**XCERD** 

RCERE

**XCERE** 

**RCERF** 

**XCERF** 

**RCERG XCERG RCERH XCERH** fieldval\_n field values to be assigned to the register fields rules to follow: Only writable fields are allowed ☐ Start from Most-significat field first Value should be a right-justified constant. If fieldval in value exceeds the number of bits allowed for that field, then fieldval n is truncated accordingly. **Return Value** value of register that corresponds to the concatenation of values passed for the fields. (writable fields only) Description Returns the MCBSP register value given to specific field values. You can use constants or the CSL symbolic constants covered in section 1.6. Example /\* frame length, word length \*/ myVal = MCBSP\_RCR1\_RMK Uint16 myVal (4,3); or you can use the PER\_REG\_FIELD\_SYMVAL symbolic constants provided in CSL (See section 1.6) MCBSP\_REG\_RMK macros are typically used to initialize a MCBSP configuration structure used for the MCBSP\_config() function. For more examples see section 11.6. Creates a register value based on individual field values MCBSP FMK Macro Uint16 MCBSP FMK (REG, FIELD, fieldval) **Arguments** REG Only writable registers containing more than one field are supported by this macro. Please note that the channel number is not used as part of the register name. SPCR1 SPCR2 RCR1 RCR2 XCR1

> XCR2 SRGR1

SRGR2 MCR1 MCR2 PCR RCERA **RCERB XCERA XCERB** For devices supporting 128-channels, add: RCERC XCERC RCERD **XCERD RCERE XCERE RCERF XCERF RCERG** XCERG RCERH **XCERH** FIELD Symbolic name for field of register REG. Possible values are the field names as listed in the C54x Register Reference Guide. Only writable fields are allowed. fieldval field values to be assigned to the register fields rules to follow: Only writable fields are allowed ☐ Start from Most-significat field first ☐ Value should be a right-justified constant. If fieldval in value exceeds the number of bits allowed for that field, then fieldval n is truncated accordingly. Shifted version of fieldval. fieldval is shifted to the bit numbering appropriate for FIELD. Returns the shifted version of fieldval. fieldval is shifted to the bit numbering appropriate for FIELD within register REG. This macro allows the user to initialize few fields in REG as an alternative to the MCBSP REG RMK() macro that requires ALL the fields in the register to be initialized. The returned value could be ORed with the result of other \_FMK macros, as shown in the example below.

**Return Value** 

Description

### **Example**

```
Uint16 myreqval;
```

Myregval = MCBSP\_FMK (RCR1, RFRLEN1, 1) | MCBSP\_FMK (RCR1,

RWDLEN1,2);

# MCBSP\_FGET

# Gets the value of a register field

#### Macro

# Uint16 MCBSP\_FGET (REG#, FIELD)

### **Arguments**

REG# Register name with channel number (#) where

# = 0,1, (2: depending on the device)

DRR1#

DRR2#

DXR1#

DXR2#

SPCR1#

SPCR2#

RCR1#

RCR2#

XCR1#

XCR2#

SRGR1#

SRGR2#

MCR1#

MCR2#

PCR#

RCERA#

RCERB#

XCERA#

XCERB#

### For devices supporting 128-channels, add:

RCERC#

XCERC#

RCERD#

XCERD#

RCERE#

XCERE#

RCERF#

XCERF#

RCERG#

XCERG#

RCERH#

XCERH#

FIELD symbolic name for field of register REG. Possible values are

the field names listed in the C54x Register Reference Guide

(Appendix x) Only readable fields are allowed.

Return Value Value of register field

**Description** Gets the MCBSP register FIELD value

Example Uint16 myVar;

. . .

myVar = MCBSP\_FGET(RCR20,RPHASE);

### MCBSP FSET

# Sets the value of a register field

# Macro Arguments

Void MCBSP\_FSET (REG#, FIELD, fieldval)

REG# Register name with channel number (#) where

# = 0,1, (2: depending on the device)

DRR1#

DRR2#

DXR1#

DXR2#

SPCR1#

OF CIVIT

SPCR2#

RCR1#

RCR2#

XCR1#

XCR2#

SRGR1#

SRGR2#

MCR1#

MCR2#

PCR#

RCERA#

I COLITY (II

RCERB#

XCERA#

XCERB#

For devices supporting 128-channels, add:

RCERC#

XCERC#

RCERD#

XCERD#

RCERE#
XCERF#
RCERF#
XCERF#
RCERG#
XCERG#
RCERH#
XCERH#

Symbolic name for field of register REG. Possible values:
Field names as listed in the C54x Register Reference Guide.
Only writable fields are allowed.

field values to be assigned to the register fields rules to follow:

Only writable fields are allowed
Start from Most-significat field first
Value should be a right-justified constant. If fieldval\_n value

exceeds the number of bits allowed for that field, then

fieldval n is truncated accordingly.

Return Value None

**Description** Set the MCBSP register value to regval

**FIELD** 

fieldval

**Example** For Registers:

MCBSP\_FSET(RCR20,RPHASE,2);

### MCBSP ADDR

Get the address of a given register

Macro Uint16 MCBSP\_ADDR (REG#)

**Arguments** REG# Register name with channel number (#) where

# = 0,1, (2: depending on the device)

DRR1#
DRR2#
DXR1#
DXR2#
SPCR1#
SPCR2#
RCR1#
RCR2#
XCR1#

XCR2# SRGR1# SRGR2# MCR1# MCR2# PCR# RCERA# RCERB# XCERA#

For devices supporting 128-channels, add:

RCERC#
XCERD#
XCERD#
RCERE#
XCERE#
XCERF#
XCERF#
XCERG#
XCERG#
XCERH#
XCERH#

Return Value Address of register REG

**Description** Get the address of a given MCBSP register.

**Example** For Registers:

myVar = MCBSP\_ADDR(RCR10); /\*get register RCR1 of channel 0 \*/

MCBSP\_RGETH Get the value of a MCBSP register used in a handle

Macro Uint16 MCBSP\_RGETH (MCBSP\_Handle hMcbsp, REG)

Arguments hMcbsp Handle to MCBSP channel that identifies the MCBSP

channel used.

REG Similar to register in MCBSP\_RGET(), but without channel

number (#).

DRR1

```
DRR2
          DXR1
          DXR2
          SPCR1
          SPCR2
          RCR1
          RCR2
          XCR1
          XCR2
          SRGR1
          SRGR2
          MCR1
          MCR2
          PCR
          RCERA
          RCERB
          XCERA
          XCERB
          For devices supporting 128-channels, add:
          RCERC
          XCERC
          RCERD
          XCERD
          RCERE
          XCERE
          RCERF
          XCERF
          RCERG
          XCERG
          RCERH
          XCERH
value of register
Returns the MCBSP register value for register REG for the channel associated
with handle.
MCBSP_Handle myHandle;
Uint16
         myVar;
myHandle = MCBSP_open (MCBSP_PORT0, MCBSP_OPEN_RESET);
```

myVar = MCBSP\_RGETH(myHandle, RCR1);

**Return Value** 

Description

**Example** 

# MCBSP\_RSETH

# Set the value of a MCBSP register

Macro Void MCBSP\_RSETH (MCBSP\_Handle hMcbsp, REG, Uint16 RegVal)

**Arguments** hMcbsp Handle to McBSP port that identifies specific McBSP port

being used.

REG# Similar to register in MCBSP\_RGET(), but without channel

number (#).

DRR1

DRR2

DXR1

DXR2

SPCR1

SPCR2

RCR1

RCR2

XCR1

XCR2

ACINZ

SRGR1

SRGR2

MCR1

IVICITI

MCR2

**PCR** 

**RCERA** 

**RCERB** 

**XCERA** 

**XCERB** 

For devices supporting 128-channels, add:

**RCERC** 

**XCERC** 

**RCERD** 

**XCERD** 

**RCERE** 

XCERE

RCERF

....

XCERF RCERG

...

**XCERG** 

**RCERH** 

**XCERH** 

regval value to write to register REG for the channel associated with

handle.

**Return Value** None

Description Set the MCBSP register REG for the channel associated with handle to the

value regval.

**Example** MCBSP\_Handle myHandle;

myHandle = MCBSP\_open (MCBSP\_PORTO, MCBSP\_OPEN\_RESET);

MCBSP\_RSETH(myHandle, RCR1, 0x4);

# MCBSP\_FGETH

### Get the value of a register field

Macro Uint16 MCBSP\_FGETH (MCBSP\_Handle Hmcbsp, REG, FIELD)

**Arguments** Handle to McBSP port that identifies specific McBSP port hMcbsp

being used.

REG Similar to register in MCBSP\_RGET(), but without channel

number (#).

DRR1 DRR2 DXR1 DXR2 SPCR1 SPCR2 RCR1 RCR2

XCR1 XCR2 SRGR1

SRGR2 MCR1 MCR2

PCR **RCERA** 

**RCERB XCERA** 

#### **XCERB**

For devices supporting 128-channels, add:

RCERC XCERC RCERD XCERD RCERE XCERE RCERF XCERF RCERG XCERG RCERH

**XCERH** 

FIELD symbolic name for field of register REG Possible values:

Field names listed in the C54x Register Reference Guide

Only readable fields are allowed.

**Return Value** Value of register field given by FIELD and of REG used by handle.

**Description** Gets the MCBSP register FIELD value

**Example** MCBSP\_Handle myHandle;

Uint16 myVar;

. . .

myHandle = MCBSP\_open (MCBSP\_PORTO, MCBSP\_OPEN\_RESET);

. . .

myVar = MCBSP\_FGETH(myHandle, RCR2, RPHASE);

# MCBSP FSETH

### Set the value of a register field

Macro Void MCBSP\_FSETH (MCBSP\_Handle hMcbsp, REG, FIELD, fieldval)

Arguments hMcbsp Handle to McBSP port that identifies specific McBSP port

being used.

REG# Similar to register in MCBSP RGET(), but without channel

number (#).

DRR1 DRR2 DXR1

|          | DXR2 SPCR1 SPCR2 RCR1 RCR2 XCR1 XCR2 SRGR1 SRGR2 MCR1 MCR2 PCR RCERA RCERB XCERB XCERB For devices supporting 128-channels, add: RCERC                                                                                                                            |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|          | XCERC RCERD XCERD XCERD RCERE XCERE XCERE RCERF XCERF XCERF RCERG XCERG RCERH XCERH                                                                                                                                                                               |
| FIELD    | Symbolic name for field of register REG. Possible values are the field names as listed the C54x Register Reference Guide.  Only writable fields are allowed.                                                                                                      |
| fieldval | field values to be assigned to the register fields rules to follow:  Only writable fields are allowed  Value should be a right-justified constant. If fieldval_n value exceeds the number of bits allowed for that field, then fieldval is truncated accordingly. |
| None     |                                                                                                                                                                                                                                                                   |

Return Value None

**Description** Set the MCBSP register field FIELD of the REG register for the channel

associated with handle to the value fieldval.

**Example** MCBSP\_Handle myHandle;

. . .

myHandle = MCBSP\_open (MCBSP\_PORTO, MCBSP\_OPEN\_RESET);

. .

MCBSP\_FSETH(myHandle, RCR2, RPHASE,1);

## MCBSP\_ADDRH

### Get the address of a given register

Macro Uint16 MCBSP\_ADDR (REG#)

Arguments hMcbsp Handle to MCBSP channel that identifies the MCBSP channel

used. Use only for MCBSP channel registers. Registers are listed

as part of the MCBSP\_RGETH macro description.

REG Similar to register in MCBSP\_RGET(), but without channel

number (#).

DRR1

DRR2

DXR1

ואועם

DXR2

SPCR1

SPCR2

RCR1

RCR2

XCR1

XCR2

7,01,2

SRGR1

SRGR2

MCR1

MCR2

PCR

**RCERA** 

**RCERB** 

**XCERA** 

**XCERB** 

For devices supporting 128-channels, add:

**RCERC** 

XCERC RCERD XCERD RCERE XCERE RCERF XCERF RCERG XCERG RCERH XCERH

Return Value Address of register REG

**Description** Gets the address of the MCBSP register associated with handle hMCBSP

**Example 1** MCBSP\_Handle myHandle;

Uint16 myVar;

. . .

myVar = MCBSP\_ADDRH(myHandle, RCR1);

# 11.5 Configuring the McBSP Module Using CSL GUI

#### 11.5.1 Overview

The McBSP module facilitates configuration/control of the Multichannel Buffered Serial Port (McBSP). The module consists of a configuration manager and a resource manager. The configuration manager allows creation of one or more configuration objects. The configuration objects contain all of the data necessary to set the McBSP Control Registers. The resource manager associates a configuration object with a specified port.

Figure 11–1 illustrates the GPIO sections menu on the CSL graphical user interface (GUI).

Figure 11–1.McBSP Sections Menu



The McBSP includes the following two sections:

- ☐ McBSP Resource Manager allows you to select a device and to associate a configuration object to that device. Three handle objects are predefined.

# 11.5.2 McBSP Configuration Manager

The McBSP Configuration Manager allows you to create device configurations through the Properties page and to generate the configuration objects.

# 11.5.2.1 Creating/Inserting a Configuration Object

There is no predefined configuration object available.

To configure a McBSP port through the peripheral registers, you must insert a new configuration object.

To insert a new configuration object, right-click on the McBSP Configuration Manager and select insert mcbspCfg from the drop-down menu. The configuration objects can be renamed. Their use depends upon the on-chip device resources.

#### Note:

The number of configuration objects is unlimited. Several configurations can be created and the user can select the right one for a specific port and can change the configuration later just by selecting a new one under the McBSP Resource Manager. The goal is to provide more flexibility and to reduce the time required to modify register values.

### 11.5.2.2 Deleting/Renaming an Object

To delete or to rename an object, right-click on the configuration object you want to delete or rename. Select Delete to delete a configuration object. Select Rename to rename the object.

If a configuration object is used by one of the predefined handle objects of the McBSP Resource Manager, the Delete and Rename options are grayed out and non-usable. The Show Dependency option is accessible and shows which device is using the configuration object (see Figure 2–1, *The CSL Tree*, on page 2-3).

### 11.5.2.3 Configuring the Object Properties

The Properties pages allow you to set the Peripheral registers related to the McBSP Port (see Figure 11–2). To access the Properties dialog box, right-click on a configuration object and select Properties. By default, the General page of the Properties dialog box is displayed.

The Properties pages allow you to set the Peripheral registers related to the McBSP. You can set the configuration options through the following pages:

| General: Allows you to configure the Digital Loopback, ABIS Mode, Breakpoint Emulation.              |
|------------------------------------------------------------------------------------------------------|
| Transmit Modes: Allows you to configure the Transmit Interrupt mode, Frame Sync, Clock control.      |
| Transmit Lengths: Allows you to configure the Transmit Phase, elements-per-word, elements per frame. |
| Receive Modes: Allows you to configure the Receive Interrupt mode, Frame Sync, Clock control.        |
| Receive Lengths: Allows you to configure the Receive Phase, elements-per-word, elements per frame.   |
| Sample-Rate Generator: Allows you to configure the Sample-Rate                                       |

Generator (Frame Setup).

| Receive Multichannel: Allows you to configure the Receive Element and Block partitioning.                                                                                        |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Transmit Multichannel: Allows you to configure the Transmit Element and Block partitioning.                                                                                      |
| GPIO: General Purpose I/O pin configuration.                                                                                                                                     |
| ABIS: Allows you to configure the McBSP ABIS mode.                                                                                                                               |
| Some fields are activated according to the setup of the Transmitter, Receiver, and Sample-rate generator options.                                                                |
| Advanced A and B: Summary of the previous pages. These pages contain the full hexadecimal register values and reflects the setting of the options done under the previous pages. |
| The full register values can be entered directly and the new options will be mirrored on the corresponding pages automatically.                                                  |

Figure 11–2 depicts the Properties Page.



Figure 11-2. McBSP Properties Page

Each Tab page is composed of several options that are set to a default value (at device reset).

Cancel

Help

### 11.5.3 McBSP Resource Manager

The McBSP Resource Manager allows you to generate the MCBSP\_open() and the MCBSP\_config() CSL functions.

Figure 11–3 illustrates the McBSP Resource Manager menu on the CSL graphical user interface (GUI).

Figure 11–3. McBSP Resource Manager Menu



### 11.5.3.1 Predefined Objects

Three handle objects are predefined and each of them is associated with a supported on-chip McBSP port.

|  | McBSP0 - | Default | handle | name: | hMcbsp0 |
|--|----------|---------|--------|-------|---------|
|--|----------|---------|--------|-------|---------|

McBSP1 – Default handle name: hMcbsp1

☐ McBSP2 – Default handle name: hMcbsp2

#### Note:

The above objects cannot be deleted. They can be renamed only.

A configuration can be enabled if at least one configuration object was defined previously. See section 11.5.2, *McBSP Configuration Manager*.

### 11.5.3.2 Properties Page

You can generate the MCBSP\_open() and MCBSP\_config() CSL functions through the Properties page.

To access the Properties page, right-click on a predefined McBSP channel and select Properties from the drop-down menu (see Figure 11–4).

The first time the Properties page appears, only the Open Handle to McBSP check-box can be selected. Select this to open the McBSP channel, allowing pre-initialization.

MCBSP\_NOTHING is used to indicate that there is no configuration object selected for this serial port.

To pre-initialize a McBSP port, check the Enable Pre-Initialization box. You can then select one of the available configuration objects (see section 11.5.2, *McBSP Configuration Manager*) for this channel through the pre-initialize drop-down list.

If MCBSP\_NOTHING is selected, no configuration object is generated for the related McBSP handle. (see section 11.5.4, *C Code Generation for McBSP Module*).

In the example shown in Figure 11–4, the Open Handle to McBSP option is checked and the handle object hMcbsp1 is now accessible (The handle object can be renamed by typing the new name in the box provided). The MCBSP\_open() function is now generated with hMcbsp0 containing the returned handle address.

Figure 11-4. McBSP Properties Page With Handle Object Accessible



### 11.5.4 C Code Generation for McBSP Module

Two C files are generated from the configuration tool:

- ☐ Header file
- Source file.

#### 11.5.4.1 Header File

The header file includes all the csl header files of the modules and contains the McBSP handle and configuration objects defined from the configuration tool (see Example 11–1).

### Example 11–1. McBSP Header File

```
extern MCBSP_Config mcbsCfg0;
extern MCBSP_Handle hMcbsp1;
```

#### 11.5.4.2 Source File

The source file includes the declaration of the handle object and the configuration structures (see Example 11–2).

### Example 11–2. McBSP Source File (Declaration Section)

```
/* Config Structures */
MCBSP_Config mcbspCfg0 = {
   0x0000, /* Serial Port Control Register 1
                                                              * /
   0x0000, /* Serial Port Control Register 2
                                                              * /
             /* Receive Control Register 1
   0x0000,
                                                              * /
   0x0000,
             /* Receive Control Register 2
             /* Transmit Control Register 1
   0x0000,
   0x0000,
             /* Transmit Control Register 2
   0x0000,
             /* Sample Rate Generator Register 1
   0x0000,
             /* Sample Rate Generator Register 2
                                                              * /
   0x0000,
             /* Multi-channel Control Register 1
                                                              * /
             /* Multi-channel Control Register 2
   0 \times 00000,
                                                              * /
   0x0000,
             /* Pin Control Register
   0x0000,
             /* Receive Channel Enable Register Partition A
                                                              * /
             /* Receive Channel Enable Register Partition B */
   0x0000,
   0x0000,
             /* Transmit Channel Enable Register Partition A */
   0x0000
             /* Transmit Channel Enable Register Partition B */
};
   Handles */
MCBSP_Handle hMcbsp1;
```

The source file contains the Handle and Configuration Pre-Initialization using the CSL McBSP functions, MCBSP\_open() and MCBSP\_config() (see Example 11–3).

These two functions are encapsulated in a unique function, CSL\_cfgInit(), which is called from your main C file. MCBSP\_open() and MCBSP\_config() are generated only if Open Handle to McBSP and Enable pre-initialization (with a selected configuration other than MCBSP\_NOTHING) are, respectively, checked under the McBSP Resource Manager Properties page.

You must use MCBSP\_start() in your code to start the McBSP. The MCBSP\_Config structure generated by the CSL GUI does not start the McBSP port transmit or receive operations (unless you force this behavior through the McBSP GUI Advance Tab settings). In the case of a write, this is typically done after you write your first data to the DXR register(s) to guarantee a valid data transfer (see note in MCBSP\_start() description on page 11-20).

# Example 11–3. McBSP Source File (Body Section)

```
void CSL_cfgInit()
{
    hMcbsp1 = MCBSP_open(MCBSP_PORT1, MCBSP_OPEN_RESET);
    MCBSP_config(hMcbsp1, &mcbspCfg0);
}
```

# 11.6 Examples

Examples for the McBSP module are found in the CCS examples\<target>\csl directory.

Example 11–4 illustrates the McBSP port initialization using MCBSP\_config(). The example also explains how to set the McBSP into digital loopback mode and perform 32-bit reads/writes from/to the serial port.

Example 11-4. McBSP Port Initialization using MCBSP\_config

```
#include <csl.h>
#include <csl_mcbsp.h>
/* Step 0: This is your MCBSP register configuration */
static MCBSP_Config ConfigLoopBack32= {
};
void main(void) {
 MCBSP Handle mhMcbsp;
 Uint32 xmt[n], rcv[n];
/* Step 1: Initialize CSL */
  CSL_init();
/* Step 2: Open and configure the MCBSP port */
   mhMcbsp = MCBSP_open(MCBSP_PORT0, MCBSP_OPEN_RESET);
   MCBSP_config(mhMcbsp, &ConfigLoopBack32);
/* Step 3: Write the first data value and start */
/* the sample rate genterator in the MCBSP
   MCBSP_write32(mhMcbsp, xmt[0];
  MCBSP_start(mhMcbsp,MCBSP_SRGR_START | MCBSP_SRGR_FRAMESYNC,0x300u);
. . . . . .
  while (!MCBSP_rrdy((mhMcbsp));
  rcv[0] = MCBSP_read32(mhMcbsp);
```

# Example 11–4. McBSP Port Initialization using MCBSP\_config (Continued)

```
/* Begin the data transfer loop of the remaining (N-1) values. */
for (i=1; i<N-1;i++)
    {

    /* Wait for XRDY signal before writing data to DXR */
        while (!MCBSP_xrdy(mhMcbsp));

    /* Write 32 bit data value to DXR */
        MCBSP_write32(mhMcbsp,xmt[i]);

    /* Wait for RRDY signal to read data from DRR */
        while (!MCBSP_rrdy(mhMcbsp));

    /* Read 32 bit value from DRR */
        rcv[i] = MCBSP_read32(mhMcbsp);
}

    MCBSP_close(mhMcbsp);
} /* main */</pre>
```

# Chapter 12

# **PLL Module**

This chapter describes the structure, functions, and macros of the PLL module.

| Topic                                         | Page |
|-----------------------------------------------|------|
| 12.1 Overview                                 | 12-2 |
| 12.2 Configuration Structure                  | 12-3 |
| 12.3 Functions                                | 12-4 |
| 12.4 Macros                                   | 12-6 |
| 12.5 Configuring the PLL Module Using CSL GUI | 12-8 |
|                                               |      |

# 12.1 Overview

The CSL PLL module offers functions and macros to control the Phase Locked Loop fo the C54xx clock.

The PLL module is not handle-based.

Table 12–1 lists the configuration structure to use with the PLL functions.

Table 12–2 lists the functions available as part of the PLL module.

Section 12.4 includes a description of available PLL macros.

Table 12-1. PLL Configuration Structure

| Structure  | Purpose                                                             | See page |
|------------|---------------------------------------------------------------------|----------|
| PLL_Config | PLL structure that contains the register required to setup the PLL. | 12-3     |

# Table 12-2. PLL Functions

| Function         | Purpose                                                                  | See page |
|------------------|--------------------------------------------------------------------------|----------|
| PLL_config()     | Configure the PLL with the values provided in a configuration structure. | 12-4     |
| PLL_configArgs() | Configures the PLL with values provided as function arguments.           | 12-4     |
| PLL_setFreq()    | Initializes the PLL to produce the desired CPU output frequency (clkout) | 12-5     |

# 12.2 Configuration Structure

This section describes the structure in the PLL module.

# PLL\_Config

PLL configuration structure used to set up PLL interface

Structure

PLL Config

Members

Uint16 pllmode available values

PLL\_MODE\_DIV = 1 (divide mode)

PLL\_MODE\_MUL = 2 (pll multiplier mode)

This value combines the effect of the PLLNDIV and

PLLDIV fields.

Uint16 pllcount

internal lockup counter (number of PLL clock input cycles

that the PLL logic should wait before "locking" in the new

frequency.)

Uint16 pllmul

PLL multiplier register field value.

# For CHIP\_5410 and CHIP\_5416 add:

Uint16 divfct

divide down factor

#### **Description**

PLL configuration structure used to set up the PLL Interface. You create and initialize this structure and then pass its address to the PLL\_config() function.

#### **Example**

```
/* clock_out freq = clock_in freq * final multiplier */
PLL_Config myconfig = {
   PLL_MODE_DIV,
   20,
   1   /* final multiplier = 0.5 */
}
```

#### 12.3 Functions

This section describes the functions in the PLL module.

# PLL\_config

Writes a value to set up PLL using configuration structure

**Function** void PLL\_config (PLL\_Config \*config);

**Arguments** Config Pointer to an initialized configuration structure

Return Value none

**Description** Writes a value to up the PLL using the configuration structure. The values of

the structure are written to the port registers. See also PLL configArgs() and

PLL Config.

Example

# PLL\_configArgs

Writes to PLL using register values passed to function

Function

void PLL\_configArgs (Uint16 pllmode, Uint16 pllmul, Uint16 pllcount);

For 5410 and 5416 add: Uint16 divfct);

Arguments

Uint16 pllmode available values:

PLL\_MODE\_DIV = 1 (divide mode)

PLL\_MODE\_MUL = 2 (pll multiplier mode)
This value combines the effect of the PLLNDIV

and PLLDIV fields.

Uint16 pllcount Internal lockup counter (number of PLL clock input

cycles that the PLL logic should wait before "locking"

in the new frequency.)

Uint16 pllmul PLL multiplier register field value.

Uint16 divfct Divide down factor

Return Value none

**Description** Writes to the PLL using the register values passed to the function. The register

values are written to the PLL registers. You may use literal values for the

arguments.

Clock out frequency is determined as follows:

**Example** PLL\_configArgs (PLL\_MODE\_DIV, 1, 20);

# PLL\_setFreq

## Initializes the PLL to produce the desired CPU output frequency

**Function** void PLL\_setFreq (Uint16 mul, Uint16 div);

**Arguments** mul integer multiplier

div integer divisor

Where mul should not be further divisible by div. The table below

shows valid ranges for mul and div:

Range

mul [1,15] div {1,2,4}

This function does not verify that arguments passed are within valid ranges.

Return Value None

**Description** Initializes the PLL to produce the desired CPU output frequency (clkout)

**Example** PLL\_setFreq (1, 2); // set clkout = 1/2 clkin

#### 12.4 Macros

As covered in section 1.5, CSL offers a collection of macros to get individual access to the peripheral registers (CLKMD) and fields.

The following is a list of macros available for the PLL module. To use them, include "csl\_pll.h".

Table 12–3. PLL CSL Macros

#### (a) Macros to read/write PLL register values

| Macro      | Syntax                            |
|------------|-----------------------------------|
| PLL_RGET() | Uint16 PLL_RGET(REG)              |
| PLL_RSET() | Void PLL_RSET(REG, Uint16 regval) |

#### (b) Macros to read/write PLL register field values (Applicable only to registers with more than one field)

| Macro      | Syntax                                     |
|------------|--------------------------------------------|
| PLL_FGET() | Uint16 PLL_FGET(REG, FIELD)                |
| PLL_FSET() | Void PLL_FSET(REG, FIELD, Uint16 fieldval) |

## (c) Macros to create value to PLL registers and fields (Applies only to registers with more than one field)

| Macro         | Syntax                                                                                                                                    |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| PLL_REG_RMK() | Uint16 PLL_ <i>REG</i> _RMK( <i>fieldval_n,fieldval_0</i> )                                                                               |
|               | Note: *Start with field values with most significant field positions: field_n: MSB field field_0: LSB field *only writable fields allowed |
| PLL_FMK()     | Uint16 PLL_FMK(REG, FIELD, fieldval)                                                                                                      |

#### (d) Macros to read a register address

| Macro      | Syntax               |
|------------|----------------------|
| PLL_ADDR() | Uint16 PLL_ADDR(REG) |

#### Where:

**REG**: CLKMD

**FIELD**: register field name as specified in Appendix A.

- For REG\_FSET and REG\_FMK, FIELD should be a writable field.
- REG\_FGET, the field must be a readable field.

regVal: value to write in register (REG)

fieldVal: value to write in field (FIELD)

For examples on how to use macros, refer macro sections 6.4 (DMA) and 11.4 (McBSP).

# 12.5 Configuring the PLL Module Using CSL GUI

#### 12.5.1 Overview

The PLL module facilitates programming of the Phase Locked Loop controlling C54xx clock. The PLL module consists of a configuration manager and a resource manager. The configuration manager allows creation of one or more configuration objects. A configuration object consists of the necessary register settings to control the PLL. The resource manager associates a selected configuration with the PLL.

Figure 12–1 illustrates the PLL sections menu on the CSL graphical user interface (GUI).

Figure 12-1. PLL Sections Menu



The PLL includes the following two sections:

- □ PLL Configuration Manager allows you to create configuration objects by setting the Peripheral registers related to the PLL.
- □ PLL Resource Manager allows you to associate a configuration object to the PLL.

# 12.5.2 PLL Configuration Manager

The PLL Configuration Manager allows you to create PLL configurations through the Properties page and to generate the configuration objects.

# 12.5.2.1 Creating/Inserting a configuration

There is no predefined configuration object.

To configure a PLL setting through the Peripheral Registers, you must insert a new configuration object.

To insert a new configuration object, right-click on the PLL Configuration Manager and select Insert pllCfg. The configuration objects can be renamed.

#### Note:

The number of configuration objects is unlimited. Several configurations can be created. You user can select one for the PLL and can change the configuration later just by selecting another configuration under the PLL Resource Manager. This feature allows you more flexibility and reduces the time required to modify register values.

#### 12.5.2.2 Deleting/Renaming and Object

To delete or rename an object, right-click on the configuration object you want to delete or rename. Select Delete to delete a configuration object. Select Rename to rename the object.

If a configuration object is used by the predefined object of the PLL Resource Manager, the Delete and Rename options are grayed out and non-usable. The Show Dependency option is accessible and shows which device is using the configuration object (see Figure 2–1, *The CSL Tree*, on page 2-3).

# 12.5.2.3 Configuring the Object Properties

You can configure object properties through the Properties dialog box (see Figure 12–2). To access the Properties dialog box, right-click on a configuration object and select Properties. By default, the General page of the Properties dialog box is displayed.

The Properties pages allow you to set the Peripheral registers related to the PLL. You can set the configuration options through the following tab page:

 Settings: Allows you to configure the Counter Value, Multiplier, Divide Factor

Figure 12–2 depicts the Properties Page dialog box.

Figure 12–2. PLL Properties Page



Each Tab page is composed of several options that are set to a default value (at device reset).

The options represent the fields of the PLL registers; the associated field name is shown in parenthesis. For further details concerning the fields and registers for 5416, refer to the *Expansion Bus* chapter of the *TMS320C54x DSP CPU* and *Peripherals References Set* (SPRU131F).

# 12.5.3 PLL Resource Manager

The PLL Resource Manager allows you to generate the PLL\_config() CSL function.

Because only one PLL is supported, only one resource is available and used as the default.

Figure 12–3 illustrates the PLL Resource Manager menu on the CSL graphical user interface (GUI).

Figure 12-3. PLL Resource Manager Menu



## 12.5.3.1 Properties Page

You can generate the PLL\_config() CSL function through the Properties page.

To access the Properties page, right-click on a predefined PLL channel and select Properties from the drop-down menu (see Figure 12–4).

The first time the properties page appears, only the Enable Configuration of PLL check box can be selected. Select this to enable the PLL configuration.

PLL\_NOTHING is used to indicate that there is no configuration object selected for this peripheral.

To pre-initialize the PLL channel, check the Enable Configuration of PLL box. One of the available configuration objects (see section 6.5.1, *PLL Configuration Manager*) can then be selected for this channel through the Pre-Initialize drop-down list.

If PLL\_NOTHING remains selected, The PLL\_config() function will not be generated for the PLL.

In Figure 12–4, the Enable Configuration of PLL option is checked and the PLL\_config function will be generated (See section 12.5.4, *C Code Generation for PLL Module*).

Figure 12–4. PLL Properties Page



#### 12.5.4 C Code Generation for PLL Module

Two C files are generated from the configuration tool:

- ☐ Header file
- ☐ Source file.

#### 12.5.4.1 Header File

The header file includes all the csl header files of the modules and contains the PLL configuration objects defined from the configuration tool (see Example 12–1).

# Example 12-1. PLL Header File

```
extern PLL_Config pllCfg0;
```

#### 12.5.4.2 Source File

The source file includes the declaration of the configuration structures (values of the peripheral registers) (see Example 12–2).

# Example 12–2. PLL Source File (Declaration Section)

```
/* Config Structures */
PLL_Config pllCfg0 = {
      0x2,    /* PLL Multiplier/Divider Mode */
      0x0,    /* PLL Counter Value (PLLCOUNT) */
      0x0,    /* PLL Multiplier Value (PLLMUL) */
};
```

The source file contains the Pre-Initialization PLL API function, PLL\_config(). This function is encapsulated into a unique function, CSL\_cfgInit(), which is called from your main C file (see Example 12–3).

PLL\_config() is generated only if Enable Configuration of PLL is checked under the PLL Resource Manager Properties page (with a selected configuration other than PLL\_NOTHING) (see Figure 12–4).

# Example 12–3. PLL Source File (Body Section)

```
void CSL_cfgInit()
{
    PLL_config(&pllCfg0);
}
```

# Chapter 13

# **PWR Module**

The CSL PWR module offers functions to control the power consumption of different sections in the C54x device.

| Topic | c Pa      | ge  |
|-------|-----------|-----|
| 13.1  | Overview  | 3-2 |
| 13.2  | Functions | 3-3 |

# 13.1 Overview

The CSL PWR module offers functions to control the power consumption of different sections in the C54x device. The PWR module is not handle-based.

Currently, there are no macros available for the power-down module.

Table 13–1 lists the functions for use with the PWR modules that order specific parts of the C54x to power down.

Table 13–1. PWR Functions

| Function      | Purpose                                          | See page |
|---------------|--------------------------------------------------|----------|
| PWR_powerDown | Forces the DSP to enter a power-down(IDLE) state | 13-3     |

# 13.2 Functions

This section lists the functions in the PWR module.

| PWR_powerDown      | Forces the DSP to enter a power-down state                                                                                                                                                                                                                                                                                          |
|--------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Function Arguments | void PWR_powerDown (Uint16 pwrMode, Uint16 wakeMode);  mode pwrMode:  PWR_CPU_DOWN: CPU goes idle, but peripherals keep running. This corresponds to the IDLE #1 instruction.  PWR_CPU_PER_DOWN: Both CPU and peripherals power-down. This corresponds to the IDLE #2 instruction.  PWR_CPU_PER_PLL_DOWN: CPU, peripherals, and PLL |
|                    | power-down. This corresponds to the IDLE #3 instruction.  wakeMode (Valid for all pwrdModes above)  PWR_WAKEUP_MI: Wakes up with an unmasked interrupt and jumps to execute the ISRs executed.  PWR_WAKEUP_NMI: Wakes up with an unmasked interrupt and executes the next instruction (interrupt is not taken).                     |
| Return Value       | None                                                                                                                                                                                                                                                                                                                                |
| Description        | Power-down the device in different power-down and wake-up modes. In the C54x, power-down is achieved by executing an IDLE K instruction.                                                                                                                                                                                            |
| Example            | PWR_powerDown (PWR_CPU_DOWN, PWR_WAKEUP_MI);                                                                                                                                                                                                                                                                                        |

# Chapter 14

# **TIMER Module**

This chapter describes the structure and functions for the TIMER Module.

| Topic |                                            | Page   |
|-------|--------------------------------------------|--------|
| 14.1  | Overview                                   | . 14-2 |
| 14.2  | Configuration Structure                    | . 14-3 |
| 14.3  | Functions                                  | . 14-4 |
| 14.4  | Macros                                     | . 14-9 |
| 14.5  | Configuring the TIMER Module Using CSL GUI | 14-12  |
|       |                                            |        |

# 14.1 Overview

Table 14–1 lists the configuration structure for the TIMER module.

Table 14–2 lists, in the order in which they are typically called, the functions available for use with the TIMER modules.

Section 14.4 includes descriptions for available TIMER macros.

Table 14-1. TIMER Configuration Structure

| Structure    | Purpose                                                    | See page |
|--------------|------------------------------------------------------------|----------|
| TIMER_Config | TIMER configuration structure used to setup a timer device | 14-3     |

Table 14-2. TIMER Functions

| Function           | Purpose                                                      | See page |
|--------------------|--------------------------------------------------------------|----------|
| TIMER_close()      | Closes a previously opened TIMER device                      | 14-4     |
| TIMER_config()     | Sets up the TIMER register using the configuration structure | 14-4     |
| TIMER_configArgs() | Sets up the TIMER using the register values passed in        | 14-5     |
| TIMER_getConfig()  | Gets the TIMER configuration                                 | 14-5     |
| TIMER_getEventId() | Obtains IRQ event ID for the timer device                    | 14-6     |
| TIMER_open()       | Opens a TIMER device                                         | 14-6     |
| TIMER_reload()     | Reloads the TIMER                                            | 14-7     |
| TIMER_reset()      | Resets the TIMER device                                      | 14-7     |
| TIMER_start()      | Starts the TIMER device running                              | 14-7     |
| TIMER_stop()       | Stops the TIMER device running                               | 14-8     |

# 14.2 Configuration Structure

This section lists the structure in the TIMER module.

# TIMER\_Config

# TIMER configuration structure used to setup Timer device

Structure

TIMER\_Config

**Members** 

Uint16 tcr

Control register value

Uint16 prd

Period register value

For C5440, C5441, and C5471 devices only:

Uint16 tscr Ti

Timer scaler register

**Description** 

The TIMER configuration structure is used to setup a timer device. You create and initialize this structure then pass its address to the TIMER\_config() function. You can use literal values or the TIMER\_RMK macros to create the structure member values.

**Example** 

```
TIMER_Config MyConfig = {
    0x0000, /* tcr */
    0x1000 /* prd */
    };
...
TIMER_config(hTimer,&MyConfig);
```

#### 14.3 Functions

This section lists the functions in the TIMER module.

# TIMER close Closes previously opened TIMER device **Function** void TIMER\_close( TIMER Handle hTimer ); **Arguments** hTimer Device handle (see TIMER\_open()). **Return Value** None Closes a previously opened timer device (see TIMER\_open()). Description The following tasks are performed: The timer IRQ event is disabled and cleared The timer registers are set to their default values Example TIMER\_close(hTimer); TIMER config Sets up TIMER register using configuration structure **Function** void TIMER\_config( TIMER Handle hTimer, TIMER\_Config \*Config ); **Arguments** hTimer Device handle, (see TIMER\_open()). Pointer to an initialized configuration structure config **Return Value** None Sets up the TIMER register using the configuration structure. The values of the Description structure are written to the registers TCR, PRD, TIM, (see also TIMER\_configArgs() and TIMER\_Config.) **Example** TIMER\_Config MyConfig = { }; TIMER\_config(hTimer,&MyConfig);

# TIMER\_configArgs Sets up TIMER using register values passed in

**Function** void TIMER\_configArgs(

TIMER\_Handle hTimer,

Uint16 tcr,

For 5440, 5441, and 5471:

Uint16 tscr, For all devices: Uint16 prd);

**Arguments** hTimer Device handle (see TIMER\_open()).

tcr Control register value

tscr Secondary control register

prd Period register value

Return Value None

**Description** Sets up the timer using the register values passed in. The register values are

written to the timer registers. The timer control register (tcr) is written last (see

also TIMER\_config()).

You may use literal values for the arguments or for readability, you may use the TIMER RMK macros to create the register values based on field values.

**Example** TIMER\_configArgs (hTimer,

0x0010, /\* tcr \*/ 0x1000 /\* prd \*/ );

# TIMER\_getConfig

# Gets the TIMER configuration structure for the specified device

**Function** void TIMER\_getConfig(

TIMER\_Handle hTimer, TIMER Config \*Config

);

**Arguments** hTimer Device handle, see TIMER\_open()

Config Pointer to a TIMER configuration structure

Return Value None

**Description** Gets the Timer configuration structure for the specified device.

**Example** TIMER\_Config MyConfig;

TIMER\_getConfig(hTimer, &MyConfig);

# TIMER getEventId

#### Obtains IRQ event ID for TIMER device

Function Uint16 TIMER getEventId(

TIMER Handle hTimer

);

**Arguments** hTimer Device handle (see TIMER open()).

Return Value Event ID IRQ Event ID for the timer device

**Description** Obtains the IRQ event ID for the timer device (see IRQ Module, Chapter 9).

**Example** Uint16 TimerEventId;

TimerEventId = TIMER\_getEventId(hTimer);

IRQ\_enable(TimerEventId);

# TIMER\_open

#### Opens TIMER device

**Function** TIMER\_Handle TIMER\_open(

int DevNum, Uint16 Flags

);

**Arguments** DevNum Device Number:

TIMER\_DEV\_ANY TIMER\_DEV0 TIMER\_DEV1

Flags Open flags, logical OR of any of the following:

TIMER\_OPEN\_RESET

**Return Value** Device Handle Device handle

**Description** Before a TIMER device can be used, it must first be opened by this function.

Once opened, it cannot be opened again until closed (see TIMER\_close()). The return value is a unique device handle that is used in

subsequent TIMER API calls. If the open fails, INV (-1) is returned.

If the TIMER\_OPEN\_RESET is specified, the timer device registers are set to their power-on defaults and any associated interrupts are disabled and

cleared.

**Example** TIMER\_Handle hTimer;

...

hTimer = TIMER\_open(TIMER\_DEV0,0);

TIMER reload Reloads TIMER

**Function** void TIMER\_reload(

TIMER Handle hTimer

);

**Arguments** hTimer Device handle (see TIMER\_open()).

Return Value None

**Description** Reloads the timer, TIM loaded with PRD and PSC loaded with TDDR value.

**Example** TIMER\_reload(hTimer);

TIMER\_reset Resets TIMER device

**Function** void TIMER\_reset(

TIMER\_Handle hTimer

);

**Arguments** hTimer Device handle (see TIMER\_open()).

Return Value None

**Description** Resets the timer device. Disables and clears the interrupt event and sets the

timer registers to default values. If INV (-1) is specified, all timer devices are

reset.

TIMER\_reset(INV);

TIMER\_start Starts TIMER device running

**Function** void TIMER\_start(

TIMER Handle hTimer

);

**Arguments** hTimer Device handle (see TIMER\_open()).

Return Value None

**Description** Starts the timer device running. TSS field =0.

**Example** TIMER\_start(hTimer);

# TIMER\_stop

# TIMER\_stop Stops TIMER device running

**Function** void TIMER\_stop(

TIMER\_Handle hTimer

);

**Arguments** hTimer Device handle (see TIMER\_open()).

Return Value None

**Description** Stops the timer device running. TSS field =1.

**Example** TIMER\_stop(hTimer);

#### 14.4 Macros

CSL offers a collection of macros to access CPU control registers and fields. For additional details, see section 1.5.

Because the TIMER peripheral typically has two independent timers in some, but not all C54x devices, the macros identify the correct timer through either the device number or the handle.

Table 14–3 lists the TIMER macros available that use the device number as part of the register name.

Table 14–4 lists the TIMER macros available that use a handle.

Both Table 14–3 and Table 14–4 use the following conventions:

To use the TIMER macros, include csl\_timer.h and follow these restrictions:

Only writable fields are allowed

For examples that are similar to the TIMER macros, see section 6.4 in the DMA chapter or section 11.4 in the McBSP chapter.

☐ If *fieldval\_n* value exceeds the number of bits allowed for that field,

☐ Values should be a right-justified constants.

fieldval n is truncated accordingly

# Table 14-3. TIMER CSL Macros Using Timer Port Number

## (a) Macros to read/write TIMER register values

| Macro        | Syntax                               |
|--------------|--------------------------------------|
| TIMER_RGET() | Uint16 TIMER_RGET( <i>REG#</i> )     |
| TIMER_RSET() | void TIMER_RSET(REG#, Uint16 regval) |

#### (b) Macros to read/write TIMER register field values (Applicable only to registers with more than one field)

| Macro        | Syntax                                        |
|--------------|-----------------------------------------------|
| TIMER_FGET() | Uint16 TIMER_FGET(REG#, FIELD)                |
| TIMER_FSET() | Void TIMER_FSET(REG#, FIELD, Uint16 fieldval) |

(c) Macros to create value to write to TIMER registers and fields (Applies only to registers with more than one field)

| Macro           | Syntax                                                                                                                                     |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| TIMER_REG_RMK() | Uint16 TIMER_REG_RMK(fieldval_n,fieldval_0)                                                                                                |
|                 | Note: *Start with field values with most significant field positions: field_n: MSB field field_0: LSB field * only writable fields allowed |
| TIMER_FMK()     | Uint16 TIMER_FMK(REG, FIELD, fieldval)                                                                                                     |

## (d) Macros to read a register address

| Macro        | Syntax                  |
|--------------|-------------------------|
| TIMER_ADDR() | Uint16 TIMER_ADDR(REG#) |

Notes:

- 1) REG indicates the register, TCR, PRD, TSCR (C5440, C5441, C5471 only), or TIM.
- 2) REG# indicates, if applicable, a register name with the channel number (example: TCR0)
- 3) FIELD indicates the register field name as specified in Appendix A.
  - For REG\_FSET and REG\_FMK, FIELD must be a writable field.
  - ☐ For REG\_FGET, the field must be a readable field.
- 4) regval indicates the value to write in the register (REG)
- 5) fieldval indicates the value to write in the field (FIELD)

# Table 14-4. TIMER CSL Macros Using Handle

#### (a) Macros to read/write TIMER register values

| Macro         | Syntax                                                                                 |
|---------------|----------------------------------------------------------------------------------------|
| TIMER_RGETH() | Uint16 TIMER_RGETH(TIMER_Handle hTimer, REG)                                           |
| TIMER_RSETH() | void TIMER_RSETH(<br>TIMER_Handle hTimer,<br><i>REG</i> ,<br>Uint16 <i>regval</i><br>) |

(b) Macros to read/write TIMER register field values (Applicable only to registers with more than one field)

| Macro         | Syntax                                                       |
|---------------|--------------------------------------------------------------|
| TIMER_FGETH() | Uint16 TIMER_FGETH(TIMER_Handle hTimer, REG, FIELD)          |
| TIMER_FSETH() | Void TIMER_FSETH( TIMER_Handle hTimer, REG, FIELD, fieldval) |

#### (c) Macros to read a register address

| Macro         | Syntax                                       |
|---------------|----------------------------------------------|
| TIMER ADDRH() | Uint16 TIMER ADDRH(TIMER Handle hTimer, REG) |

Notes:

- 1) REG indicates the register, TCR, PRD, TSCR (C5440, C5441, C5471 only), or TIM.
- 2) FIELD indicates the register field name as specified in Appendix A.
  - ☐ For REG\_FSET and REG\_FMK, FIELD must be a writable field.
  - ☐ For REG\_FGET, the field must be a readable field.
- 3) regVal indicates the value to write in the register (REG)
- 4) fieldVal indicates the value to write in the field (FIELD)

# 14.5 Configuring the TIMER Module Using CSL GUI

#### 14.5.1 Overview

The Timer module facilitates configuration/control of the on-chip Timer. The timer module consists of a configuration manager and a resource manager. The configuration manager allows the creation of one or more configuration objects. The configuration object consists of the necessary data to set the Timer control registers. The resource manager associates a selected configuration with a timer.

Figure 14–1 illustrates the Timer sections menu on the CSL graphical user interface (GUI).

Figure 14-1. Timer Sections Menu



The TIMER includes the following two sections:

- ☐ **TIMER Configuration Manager** allows you to create configuration objects. There are no predefined configuration objects.
- ☐ TIMER Resource Manager allows you to select a device that will be used and to associate a configuration object with that device. Two handle objects are predefined for some devices and just one for other devices.

# 14.5.2 TIMER Configuration Manager

The TIMER Configuration Manager allows you to create device configurations through the Properties page and generate the configuration objects.

# 14.5.2.1 Creating/Inserting a configuration

There are no predefined configuration objects available.

To configure a TIMER device through the peripheral, you must insert a new configuration object.

To insert a new configuration object, right-click on the TIMER Configuration Manager and select Insert timerCfg from the drop-down menu. The configuration objects can be renamed. Their use depends on the on-chip device resources.

#### Note:

The number of configuration objects is unlimited. Several configurations can be created and you can select the right one for a specific device and change the configuration later just by selecting a new one under the TIMER Resource Manager. This feature provides you with more flexibility and reduces the time required to modify register values.

## 14.5.2.2 Deleting/Renaming an Object

To delete or to rename an object, right-click on the configuration object you want to delete or rename. Select Delete to delete a configuration object. Select Rename to rename the object.

If a configuration object is used by one of the predefined handle objects of the TIMER Resource Manager (see section 14.5.3, *Timer Resource Manager*), the Delete and Rename options are grayed out and non-usable. The Show Dependency option is accessible and shows which device is using the configuration object (see Figure 2–1, *The CSL Tree*, on page 2-3).

## 14.5.2.3 Configuring the Object Properties

You can configure object properties through the Properties dialog box (see Figure 14–2). To access the Properties dialog box, right-click on a configuration object and select Properties. By default, the General page of the Properties dialog box is displayed.

The Properties pages allow you to set the Peripheral registers related to the TIMER. You can set the configuration options through the following tab pages:

| General: Allows you to configure the Breakpoint Emulation                                              |
|--------------------------------------------------------------------------------------------------------|
| Counter Control: Allows you to configure the Counter configuration                                     |
| GPIO: General Purpose I/O pin configuration                                                            |
| Advanced Page: Allows you to configure the Summary of the previous pages                               |
| This page contains the full hexadecimal register values and reflects the setting of the previous pages |
| The full register values can be entered directly and the new options will be                           |

Figure 14–2 depicts the Properties Page dialog box.

mirrored on the previous three pages automatically

Figure 14-2. TIMER Properties Page



Each Tab page is composed of several options that are set to a default value (at device reset).

The options represent the fields of the TIMER registers; the associated field name is shown in parenthesis.

# 14.5.3 TIMER Resource Manager

The TIMER Resource Manager allows you to generate the TIMER\_open() and the TIMER\_config() CSL functions.

Figure 14–3 illustrates the DMA Resource Manager menu.

Figure 14-3. Timer Resource Manager Menu



# 14.5.3.1 Predefined Objects

Two handle objects are predefined and each of them is associated with a supported on-chip TIMER device.

- → TIMER0 Default handle name: hTimer0
- TIMER1 Default handle name: hTimer1

#### Note:

The above objects can neither be deleted nor renamed.

A configuration is enabled if at least one configuration object is defined previously in section 14.5.2.

#### 14.5.3.2 Properties Page

You can generate the TIMER\_config and TIMER\_open CSL functions through the Properties page.

To access the Properties page, right-click on a predefined TIMER handle object and select Properties from the drop-down menu (see Figure 14–4).

The first time the properties page appears, only the Open Handle to Timer check-box can be selected. Select this to open the TIMER configuration, allowing pre-initialization.

TIMER\_NOTHING is used to indicate that there is no configuration object selected for this device.

To pre-initialize the TIMER channel, check the Enable Pre-Initialization box. One of the available configuration objects (see section 14.5.2, *TIMER Configuration Manager*) can then be selected for this channel through the Pre-initialize drop-down list.

If TIMER\_NOTHING is selected, no configuration object will be generated for the related TIMER handle (see section 14.5.4, *C Code Generation for TIM-ER*.)

In Figure 14–4, the Open Handle to TIMER option is checked and the handle object hTimer1 is now accessible (renaming allowed). The TIMER\_open() function will be generated with hTimer1 containing the return handle address.

Figure 14-4. Timer Properties Page With Handle Object Accessible



#### 14.5.4 C Code Generation for TIMER

Two C files are generated from the configuration tool:

- ☐ Header file
- ☐ Source file.

#### 14.5.4.1 Header File

The header file includes all the csl header files of the modules and contains the TIMER handle and configuration objects defined from the configuration tool (see Example 14–1).

#### Example 14-1. Timer Header File

```
extern TIMER_Config timerCfg0;
extern TIMER_Handle hTimer1;
```

#### 14.5.4.2 Source File

The source file includes the declaration of the handle object and the configuration structures (see Example 14–2).

# Example 14–2. Timer Source File (Declaration Section)

The source file contains the Handle and Configuration Pre-Initialization using CSL TIMER API functions TIMER\_open() and TIMER\_config() (see Example 14–3). These two functions are encapsulated into a unique function, CSL\_cfgInit(), which is called from your main C file.

TIMER\_open() and TIMER\_config() will be generated only if Open Handle to TIMER and Enable-Pre-Initialization (with timerCfg0) are, respectively, checked on the TIMER Resource Manager Properties page.

#### Note:

You must use TIMER\_start() in your code to start the TIMER. The TIMER\_Config structure generated by the CSL GUI does not start the TIMER port.

# Example 14–3. Timer Source File (Body Section)

```
void CSL_cfgInit()
{
   hTimer1 = TIMER_open(TIMER_DEV1, TIMER_OPEN_RESET);
   TIMER_config(hTimer1, &timerCfg1);
}
```

# **Chapter 15**

# **UART Module**

This chapter describes the UART module, lists the API structure, functions, and macros within the module, and provides a UART API reference section.

# Topic Page 15.1 Overview 15-2 15.2 Configuration Structures 15-5 15.3 Functions 15-8 15.4 Macros 15-15 15.5 Configuring the UART Module Using CSL GUI 15-21

#### 15.1 Overview

The Universal Asynchronous Receiver/Transmitter (UART) controller is the key component of the serial communications subsystem of a computer. Asynchronous transmission allows data to be transmitted without a clock signal to the receiver. Instead, the sender and receiver must agree on timing parameters in advance. Special bits are added to each word that is used to synchronize the sending and receiving units.

The configuration of UART can be performed by using one of the following methods:

# 1) Register-based configuration

A register-based configuration can be performed by calling either UART\_config(), UART\_configArgs(), or any of the SET register field macros.

# 2) Parameter-based configuration (Recommended)

A parameter-based configuration can be performed by calling UART\_setup(). Compared to the register-based approach, this method provides a higher level of abstraction.

Table 15–1 lists the configuration structures and functions used with the UART module.

Table 15-1. UART APIS

| Structure         | Туре | Purpose                                             | See page |
|-------------------|------|-----------------------------------------------------|----------|
| UART_Config       | S    | UART configuration structure used to setup the UART | 15-5     |
| UART_config       | F    | Sets up the UART using the configuration structure  | 15-8     |
| UART_configArgs   | F    | Sets up the UART using regsiter values              | 15-8     |
| UART_eventDisable | F    | Disable UART interrupts                             | 15-9     |
| UART_eventEnable  | F    | Enable UART interrupts                              | 15-9     |
| UART_fgetc        | F    | Read a character from UART by polling               | 15-11    |
| UART_fgets        | F    | This routine reads a string from the uart           | 15-12    |
| UART_fputc        | F    | Write a character from UART by polling              | 15-12    |
| UART_fputs        | F    | This routine writes a string from the uart          | 15-12    |
| UART_getConfig    | F    | Reads the UART configuration                        | 15-12    |

**Note:** F = Function; S = Structure

Table 15–1. UART APIs (Continued)

| Structure        | Туре | Purpose                                                         | See page |
|------------------|------|-----------------------------------------------------------------|----------|
| UART_read        | F    | Read a buffer of data from UART by polling                      | 15-13    |
| UART_setCallback | F    | Plugs UART interrupt routines into UART dispatcher table        | 15-13    |
| UART_Setup       | S    | UART configuration structure used to setup the UART             | 15-5     |
| UART_setup       | F    | Sets up the UART using the register values passed into the code | 15-14    |
| UART_write       | F    | Write a buffer of data to UART by polling                       | 15-14    |

**Note:** F = Function; S = Structure

# 15.2 Configuration Structures

# UART\_Config

#### Configuration Structure for UART

#### **Members**

| Uint16 | dll | Divisor Latch Register (low 8 bits)  |
|--------|-----|--------------------------------------|
| Uint16 | dlm | Divisor Latch Register (high 8 bits) |
| Uint16 | Icr | Line Control Register                |
| Uint16 | fcr | FIFO Control Register                |
| Uint16 | mcr | Modem Control Register               |

#### **Description**

UART configuration structure. This structure is created and initialized, and then passed to the UART\_Config() function.

# UART\_Setup

# Structure used to initialize the UART

#### **Members**

symbolic values are:

UART\_CLK\_INPUT\_58 // Input clock =

58.9824MHz

UART\_CLK\_INPUT\_117 // Input clock =

117.9684MHz

Uint16 baud Baud Rate (Range: 150 – 115200). Valid

symbolic values are:

UART\_BAUD\_150 UART\_BAUD\_300

UART\_BAUD\_600

UART\_BAUD\_1200

UART\_BAUD\_1800

UART\_BAUD\_2000 UART\_BAUD\_2400

UART\_BAUD\_3600

UART\_BAUD\_4800

UART\_BAUD\_7200

UART\_BAUD\_9600

UART\_BAUD\_19200

UART\_BAUD\_38400

UART\_BAUD\_57600

UART\_BAUD\_115200

Uint16 wordLength bits per word (Range: 5,6,7,8).

Valid symbolic values are:

UART\_WORD5 5 bits per word

UART\_WORD6 6 bits per word

UART\_WORD7 7 bits per word

UART\_WORD8 8 bits per word

Uint16 stopBits stop bits in a word (1, 1.5, and 2)

Valid symbolic values are:

UART\_STOP1 1 stop bit

UART\_STOP1\_PLUS\_HALF

1 and 1/2 stop bits

UART\_STOP2 2 stop bits

Uint16 parity parity setups

Valid symbolic values are:

UART\_DISABLE\_PARITY

UART\_ODD\_PARITY odd parity

UART\_EVEN\_PARITY even parity

UART\_MARK\_PARITY mark parity

(the parity bit is always '1')

UART\_SPACE\_PARITY space parity

(the parity bit is always '0')

Uint16 fifoControl FIFO Control

Valid symbolic values are:

UART\_FIFO\_DISABLE

UART\_FIFO\_DMA0\_TRIG01

UART\_FIFO\_DMA0\_TRIG04

UART\_FIFO\_DMA0\_TRIG08

UART\_FIFO\_DMA0\_TRIG14

DMA mode0: always be 0

RCVR FIFO trigger level: There are four

trigger levels for the RCVR FIFO

interrupt.

TRIG01 - 1 byte

TRIG04 - 4 bytes

TRIG08 - 8 byte

TRIG14 – 14 bytes

Uint16 loopbackEnable loopback Enable Valid Symbolic values are:

UART\_NO\_LOOPBACK UART\_LOOPBACK

Description

Structure used to init the UART. After created and initialized, it is passed to the UART\_init() function.

#### 15.3 Functions

# 15.3.1 CSL Primary Functions

#### UART\_config

Initializes the UART using the configuration structure

**Function** 

void UART\_config (UART\_Config \*Config);

**Arguments** 

Configure pointer to an initialized configuration structure (containing values for all registers that are visible to the user)

Description

Writes a value to initialize the UART using the configuration structure.

**Example** 

```
UART_Config Config = {
      0x00, /* DLL */
      0x06, /* DLM - baud rate 150 */
      0x18, /* LCR - even parity, 1 stop bit, 5
            bits word length */
      0x00, /* Disable FIFO */
      0x00 /* No Loop Back */
};
UART_config(&Config);
```

# UART\_configArgs

# Setups up the UART using register values

**Function** 

void UART\_configArgs(Uint16 dll, Uint16 dlm, Uint16 lcr, Uint16 Fcr, Uint16 mcr);

**Arguments** 

dll value to setup DLL register

dlm value to setup DLM register

lcr value to setup LCR register

fcr value to setup FCR register

mcr value to setup MCR register

Description

Sets up the UART using the register values passed.

#### 

# UART eventDisable Disables UART interrupts

```
Function void UART_eventDisable(Uint16 ierMask);
```

#### **Arguments** ierMask can be one or a combination of the following:

```
UART RINT
              0 \times 01
                         // Enable rx data available
                            interrupt
                         // Enable tx hold register
UART_TINT
              0 \times 02
                            empty interrupt
UART LSINT
                         // Enable rx line status
              0 \times 04
                            interrupt
                         // Enable modem status
UART_MSINT
              0 \times 0 8
                            interrupt
UART_ALLINT 0x0f
                        // Enable all interrupts
```

# **Description** It disables the interrupt specified by the ierMask.

**Example** UART\_eventDisable(UART\_TINT);

# **UART\_eventEnable** Enables a UART interrupt

**Function** void UART\_eventEnable (Uint16 isrMask);

# **Arguments** isrMask can be one or a combination of the following:

```
UART_RINT 0x01 // Enable rx data available interrupt
UART_TINT 0x02 // Enable tx hold register
empty interrupt

UART_LSINT 0x04 // Enable rx line status interrupt

UART_MSINT 0x08 // Enable modem status interrupt

UART_ALLINT 0x0f // Enable all interrupts
```

# UART\_eventEnable

**Description** It enables the UART interrupt specified by the isrMask.

**Example** UART\_eventEnable(UART\_RINT|UART\_TINT);

UART\_fgetc Reads UART characters

**Function** CSLBool UART\_fgetc(int \*c, Uint32 timeout);

**Arguments** c Character read from UART

timeout Time out for data ready.

If it is setup as 0, means there will be no time out count.

The function will block forever until DR bit is set.

**Description** Read a character from UART by polling.

**Example** Int retChar;

CSLBool returnFlag

returnFlag = UART\_fgetc(&retChar,0);

# UART\_fgets Reads UART strings

**Function** CSLBool UART fgets(char\* pBuf, int bufSize, Uint32 timeout);

**Arguments** pBuf Pointer to a buffer

bufSize Length of the buffer timeout Time out for data ready.

If it is setup as 0, means there will be no time out count.

The function will block forever until DR bit is set.

**Description** This routine reads a string from the uart. The string will be read upto a newline

or until the buffer is filled. The string is always NULL terminated and does not

have any newline character removed.

**Example** char readBuf[10];

CSLBool returnFlag

returnFlag = UART\_fgets(&readBuf[0], 10, 0);

**UART** fputc

Writes characters to the UART

**Function** 

CSLBool UART\_fputc(const int c, Uint32 timeout);

**Arguments** 

The character, as an int, to be sent to the uart.

timeout

Time out for data ready.

If it is setup as 0, means there will be no time out count. The function will block forever if THRE bit is not set.

Description

This routine writes a character out through UART.

**Example** 

Example const int putchar = 'A';

CSLBool returnFlag;

ReturnFlag = UART\_fputc(putchar, 0);

UART\_fputs

Writes strings to the UART

**Function** 

CSLBool UART\_fputs(const char\* pBuf, Uint32 timeout);

**Arguments** 

pBuf Pointer to a buffer

timeout

Time out for data ready.

If it is setup as 0, means there will be no time out count. The function will block forever if THRE bit is not set.

**Description** 

This routine writes a string to the uart. The NULL terminator is not written and

a newline is not added to the output.

**Example** 

UART\_fputs("\n\rthis is a test!\n\r");

UART\_getConfig

Reads the UART Configuration Structure

**Function** 

void UART\_getConfig (UART\_Config \*Config);

**Arguments** 

Config Pointer to an initialized configuration structure (including all registers

that are visible to the user)

Description

Reads the UART configuration structure.

Example

UART\_Config Config;

UART getConfig(&Config);

#### **UART** read

#### Reads received data

**Function** CSLBool UART\_read(char \*pBuf, Uint16 length, Uint32 timeout);

**Arguments** pbuf Pointer to a buffer

length Length of data to be received timeout Time out for data ready.

If it is setup as 0, means there will be no time out count.

The function will block forever until DR bit is set.

**Description** Receive and put the received data to the buffer pointed by pbuf.

**Example** Uint16 length = 10;

char pbuf[length];
CSLBool returnFlag;

ReturnFlag = UART\_read(&pbuf[0],length, 0);

#### UART setCallback

# Associates a function to the UART dispatch table

**Function** void UART\_setCallback(UART\_IsrAddr \*isrAddr);

**Arguments** is rAddr is a structure containing pointers to the 5 functions that will be executed

when the corresponding events is enabled.

**Description** It associates each function specified in the isrAddr structure to the UART dis-

patch table.

**Example** UART\_IsrAddr MyIsrAddr= {

};

```
NULL, // Receiver line status

UartRxIsr, // received data available

UartTxIsr, // transmiter holding register empty

NULL // character time-out indication
```

UART\_setCallback(&MyIsrAddr);

#### UART\_setup

# Sets the UART based on the UART\_Setup configuration structure

## **Function**

void UART\_setup (UART\_Setup \*Params);

#### **Arguments**

Params Pointer to an initialized configuration structure that contains values for UART setup.

#### **Description**

Sets UART based on UART\_Setup structure.

#### **Example**

```
UART_Setup Params = {
   UART_CLK_INPUT_58,
                         /* input clock freq
                                                      * /
                         /* baud rate
                                                      * /
   UART BAUD 115200,
                         /* word length
                                                       * /
   UART_WORD8,
                         /* stop bits
   UART_STOP1,
                                                       * /
   UART DISABLE PARITY,
                         /* parity
                                                       * /
   UART FIFO DISABLE,
                         /* FIFO enable/disable
                                                       * /
                                                       * /
   UART FIFO DMA MODEO,
                        /* DMA mode
                         /* FIFO trigger level
                                                       * /
   UART_FIFO_TRIG01,
   UART_NO_LOOPBACK,
                         /* Loop Back enable/disable */
};
UART_setup(&Params);
```

# **UART** write

# Transmits buffers of data by polling

#### **Function**

CSLBool UART write(char \*pBuf, Uint16 length, Uint32 timeout);

#### **Arguments**

pbuf Pointer to a data buffer Length Length of the data buffer timeout Time out for data ready.

If it is setup as 0, means there will be no time out count. The function will block forever if THRE bit is not set.

#### Description

Transmit a buffer of data by polling.

#### Example

```
Uint16 length = 4;
char pbuf[4] = \{0x74, 0x65, 0x73, 0x74\};
```

CSLBool returnFlag;

ReturnFlag = UART\_write(&pbuf[0],length,0);

#### 15.4 Macros

#### 15.4.1 General Macros

Table 15-2. UART CSL Macros

Macro Syntax

(a) Macros to read/write UART register values

UART\_RGET() Uint16 UART\_RGET(*REG*)

UART\_RSET() void UART\_RSET(*REG*, Uint16 regval)

(b) Macros to read/write UART register field values (Applicable only to registers with more than one field)

UART\_FGET() Uint16 UART\_FGET(REG, FIELD)

UART\_FSET() void UART\_FSET(*REG*, *FIELD*, Uint16 *fieldval*)

(c) Macros to create value to write to UART registers and fields (Applicable only to registers with more than one field)

UART\_REG\_RMK() Uint16 UART\_REG\_RMK(fieldval\_n,...fieldval\_0)

Note: \*Start with field values with most significant field

positions:

field\_n: MSB field field\_0: LSB field

\* only writable fields allowed

UART\_FMK() Uint16 UART\_FMK(*REG*, *FIELD*, *fieldva*l)

Notes:

- 1) REG indicates the registers: URIER, URIIR, URBRB, URTHR, URFCR, URLCR, URMCR, URLSR, URMSR, URDLL or URDLM.
- 2) FIELD indicates the register field name.
- 3) or REG\_FSET and REG\_\_FMK, FIELD must be a writable field.
- 4) For REG\_FGET, the field must be a readable field.
- 5) regval indicates the value to write in the register (REG)
- 6) fieldval indicates the value to write in the field (FIELD)

Table 15–2. UART CSL Macros (Continued)

Macro Syntax

#### (d) Macros to read a register address

UART\_ADDR()

Uint16 UART\_ADDR(REG)

Notes:

- 1) *REG* indicates the registers: URIER, URIIR, URBRB, URTHR, URFCR, URLCR, URMCR, URLSR, URMSR, URDLL or URDLM.
- 2) FIELD indicates the register field name.
- 3) or REG\_FSET and REG\_\_FMK, FIELD must be a writable field.
- 4) For REG\_FGET, the field must be a readable field.
- 5) regval indicates the value to write in the register (REG)
- 6) fieldval indicates the value to write in the field (FIELD)

# 15.4.2 UART Control Signal Macros

All the UART control signals are mapped through HPIGPIO pins. They are configurable through GPIOCR and GPIOSR registers. Since C54x DSP are commonly used as DCE (Data Communication Equipment), these signals are configured as following:

HD0 - DTR - Input

HD1 - RTS - Input

HD2 - CTS - Output

HD3 - DSR - Output

HD4 - DCD - Output

HD5 – RI – Output

UART\_ctsOff Sets a CTS signal to OFF

Macro UART\_ctsOff

**Arguments** None

**Description** Set CTS signal off.

**Example** UART\_ctsOff;

UART\_ctsOn Sets a CTS signal to ON

Macro UART\_ctsOn

**Arguments** None

**Description** Set CTS signal on.

**Example** UART\_ctsOn;

Macro UART\_flowCtrlInit

**Arguments** None

**Description** Initialize HPIGPIO registers for flow control.

**Example** UART\_flowCtrlInit;

UART\_isRts Verifies that RTS is ON

Macro UART\_isRts

**Arguments** None

**Description** Check if RTS is on. Return RTS value.

**Example** CSLBool rtsSignal;

rtsSignal = UART\_isRts;

UART\_dtcOff Sets a DTC signal to OFF

Macro UART\_dtcOff

**Arguments** None

**Description** Set DTC signal off.

**Example** UART\_dtcOff;

# UART\_dtcOn

UART\_dtcOn Sets a DTC signal to ON

Macro UART\_dtcOn

**Arguments** None

**Description** Set DTC signal on.

**Example** UART\_dtcOn;

UART\_riOff Sets an RI signal to OFF

Macro UART\_riOff

**Arguments** None

**Description** Set RI signal off.

**Example** UART\_riOff;

UART\_riOn Sets an RI signal to ON

Macro UART\_riOn

**Arguments** None

**Description** Set RI signal on.

**Example** UART\_riOn;

UART\_dsrOff Sets a DSR signal to OFF

Macro UART\_dsrOff

**Arguments** None

**Description** Set DSR signal off.

**Example** UART\_dsrOff;

UART\_dsrOn Sets a DSR signal to ON

Macro UART\_dsrOn

**Arguments** None

**Description** Set DSR signal on.

**Example** UART\_dsrOn;

UART\_isDtr Verifies that DTR is ON

Macro UART\_isDtr

Arguments Nobe

**Description** Check if DTR is on. Return DTR value.

**Example** CSLBool dtrSignal;

dtrSignal = UART\_isDtr;

# 15.5 Configuring the UART Module Using CSL GUI

The Universal Asynchronous Receiver/Transmitter (UART) controller is the key component of the serial communications subsystem of a computer. Asynchronous transmission allows data to be transmitted without a clock signal to the receiver.

The configuration manager allows creation of one or more configuration objects. The configuration objects contain all of the data necessary to set the UART Control Registers.

The resource manager allows the user to choose a configuration object to to use in configuring the UART.

Figure 15–1 illustrates the UART sections menu on the CSL graphical user interface (GUI)

Figure 15-1. UART Sections Menu



The UART includes the following two sections:

- ☐ UART Configuration Manager allows you to create configuration objects. No predefined configuration objects.
- UART Resource Manager allows you to select a configuration and enable that configuration within the object.

# 15.5.1 UART Configuration Manager

The UART Configuration Manager allows you to create UART configurations through the Properties page and to generate the configuration objects.

# 15.5.1.1 Inserting a Configuration Object

There is no predefined configuration object available.

To configure the UART registers, you must insert a new configuration object.

To insert a new configuration object, right-click on the UART Configuration Manager and select insert uartCfg from the drop-down menu. The configuration objects can be renamed. Their use depends upon the on-chip device resources.

#### Note:

The number of configuration objects is unlimited. Several configurations can be created and the user can select the right one for this application and can change the configuration later just by selecting a new one under the UART Resource Manager. The goal is to provide more flexibility and to reduce the time required to modify register values.

#### 15.5.1.2 Deleting/Renaming a Configuration Object

To delete or to rename an object, right-click on the configuration object you want to delete or rename. Select Delete to delete a configuration object. Select Rename to rename the object.

If the Delete and Rename options are grayed out and non-usable, use the UART Resource Manager to configure the UART. The Show Dependency option is accessible and shows which device is using the configuration object (see Figure 2–1, *The CSL Tree*, on page 2-3).

#### 15.5.1.3 Configuring the Object Properties

The Properties pages allow you to set the UART registers (see Figure 15–2). To access the Properties dialog box, right-click on a configuration object and select Properties. By default, the General page of the Properties dialog box is displayed.

The Properties pages allow you to set the time, date, and alarm registers of the UART. You can set the configuration options through the following pages:

- ☐ Setup: Allows you to configure the UART based on a set of parameters.
- Advanced: Allows you to configure the values of the previous pages by directly setting the UART registers.

This page contains the full 8-bit register values; the full register values can be entered directly and the new options will be mirrored on the previous page automatically.

Figure 15–2 depicts the properties page.

Figure 15–2. UART Properties Page



Each Tab page is composed of several options that are set to a default value (at device reset).

# 15.5.2 UART Resource Manager

The UART Resource Manager allows you to generate the UART\_config() CSL function.

Figure 15–3 illustrates the UART Resource Manager menu on the CSL graphical user interface (GUI).

Figure 15–3. UART Resource Manager Menu



#### 15.5.2.1 Properties Page

You can generate the UART\_Config() CSL function through the Properties page.

To access the Properties page, right-click on the predefined UART peripheral and select Properties from the drop-down menu (see Figure 15–4).

The first time the Properties page appears, only the Enable UART Configuration check-box can be selected. Select this to enable the UART configuration.

UART\_NOTHING is used to indicate that there is no configuration object selected for this serial port.

To pre-initialize the UART peripheral, check the Enable UART Configuration box. You can then select one of the available configuration objects (see section 15.5.1) for this peripheral through the pre-initialize drop-down list.

If UART\_NOTHING remains selected, the UART\_config() function will not be generated for the UART. (see section 15.5.3).

In the example shown in Figure 15–4, the uartCfg0 is selected, UART and the UART\_config() function will be generated, thereby setting the UART to UARTfg0 configuration settings.

Figure 15-4. UART Resource Manager Properties Page



#### 15.5.3 C Code Generation for UART Module

The two C files generated from the configuration tool are a header file and a source file.

#### 15.5.3.1 Header File

The header file includes all the csl header files of the modules and contains the configuration objects defined from the configuration tool (see Example 15–1).

#### Example 15-1. UART Header File

extern UART\_Config uartCfg0;

#### 15.5.3.2 Source File

The source file includes the declaration of the handle object and the configuration structures (see Example 15–2).

## Example 15–2. UART Source File (Declaration Section)

The source file contains the Configuration Pre-Initialization using the CSL UART API function UART config() (see Example 15–3).

This function is encapsulated into a unique function, CSL\_cfgInit(), which is called from your main C file. UART\_config() is generated only if Enable UART configuration (with a selected configuration other than UART\_NOTHING) is checked under the UART Resource Manager Properties page.

# Example 15–3. UART Source File (Body Section)

```
void CSL_cfgInit()
{
    UART_config(&uartCfg0);
}
```

# **Chapter 16**

# **WDTIM Module**

This chapter lists the configuration structure, functions, and macros available for use with the WDTIM modules.

# Topic Page 16.1 Overview 16-2 16.2 Configuration Structure 16-3 16.3 Functions 16-4 16.4 Macros 16-6 16.5 Configuring the WATCHDOG TIMER Module Using CSL GUI 16-8

# 16.1 Overview

Table 16–1 and Table 16–2 list the configuration structures and functions used with the WDTIM module.

Table 16-1. WDTIM Configuration Structure

| Structure    | Purpose                                                             | See page |
|--------------|---------------------------------------------------------------------|----------|
| WDTIM_Config | WDTIM configuration structure used to setup a watchdog timer device | 16-3     |

# Table 16–2. WDTIM Functions

| Function         | Purpose                                                                                                      | See page |
|------------------|--------------------------------------------------------------------------------------------------------------|----------|
| WDTIM_config     | Sets up the WDTIM register using the configuration structure                                                 | 16-4     |
| WDTIM_configArgs | Sets up the WDTIM using the register values passed in                                                        | 16-4     |
| WDTIM_getConfig  | Reads the current register values of the watchdog timer and stores the result in the configuration structure | 16-5     |
| WDTIM_service    | Writes to the watchdog key of the timer                                                                      | 16-5     |
| WDTIM_start      | Starts the WDTIM device running                                                                              | 16-5     |

# 16.2 Configuration Structure

This section lists the structure in the WDTIM module.

# WDTIM\_Config

#### WDTIM configuration structure used to setup timer device

Structure WDTIM\_Config

Members Uint16 wdtcr control

Uint16 wdtscr secondary control

Uint16 wdprd period

Description

The WDTIM configuration structure is used to setup a watchdog timer device. You create and initialize this structure then pass its address to the WDTIM\_config() function. You can use literal values or the WDTIM\_RMK macros to create the structure member values.

**Example** 

#### 16.3 Functions

This section lists the functions in the WDTIM module.

## WDTIM\_config

Sets up WDTIM register using configuration structure

**Function** 

```
void WDTIM_config(
    WDTIM_Config *Config
);
```

**Arguments** 

config Pointer to an initialized configuration structure

**Return Value** 

None

Description

Sets up the WDTIM register using the configuration structure. The values of the structure are written to the registers TCR, PRD, and TIM (see also WDTIM\_configArgs() and WDTIM\_Config).

Example

```
WDTIM_Config MyConfig = {
};
...
WDTIM_config(&MyConfig);
```

# WDTIM configArgs

# Sets up WDTIM using register values passed in

**Function** 

```
void WDTIM_configArgs(
Uint16 wdtcr,
Uint16 wdtscr,
Uint16 wdprd
);
```

**Arguments** 

wdtcr Control register value

wdtscr Secondary Control register value

wdprd Period register value

**Return Value** 

None

Description

Sets up the timer using the register values passed in. The register values are written to the timer registers. The timer control register (wdtcr) is written last (see also WDTIM\_config()).

You may use literal values for the arguments or for readability, you may use the WDTIM\_RMK macros to create the register values based on field values.

Example

```
WDTIM_configArgs (
    0x0010, /* wdtcr */
    0x0000, /* wdtscr */
    0x1000 /* wdprd */
);
```

WDTIM\_getConfig Gets the WDTIM configuration structure for a specified device

**Function** void WDTIM\_getConfig(

WDTIM\_Config \*Config

);

**Arguments** Config Pointer to a WDTIM configuration structure

Return Value None

**Description** Gets the WDTIM configuration structure for a specified device.

**Example** WDTIM\_Config MyConfig;

WDTIM\_getConfig(&MyCOnfig);

WDTIM\_service Writes to the watchdog key of the timer

Function void WDTIM\_service(

);

**Arguments** None

Return Value None

**Description** Services the watchdog timer by writing a sequence of A5C6h, followed by an

A7Eh to the WDKEY field of the WDTSCR register, before the watchdog timer times out. This function must be called periodically to prevent a

watchdog timeout.

**Example** WDTIM\_service();

WDTIM\_start Starts WDTIM device running

Function void WDTIM\_start(

);

**Arguments** None

Return Value None

**Description** Starts the timer device running. TSS field =0.

Example WDTIM\_start();

#### 16.4 Macros

CSL offers a collection of macros to access CPU control registers and fields. For additional details (see section 1.5).

Table 16–3 lists the available WDTIM macros.

Table 16–3 uses the following conventions:

To use the WDTIM macros, include csl\_wdtim.h and follow these restrictions:

Only writable fields are allowed

Values should be a right-justified constants.

If fieldval\_n value exceeds the number of bits allowed for that field, fieldval\_n is truncated accordingly

For examples that are similar to the WDTIM macros, see section 6.4 in the DMA chapter or section 11.4 in the McBSP chapter.

# Table 16-3. WDTIM CSL Macros Using Timer Port Number

(a) Macros to read/write WDTIM register values

| Macro        | Syntax                              |
|--------------|-------------------------------------|
| WDTIM_RGET() | Uint16 WDTIM_RGET(REG)              |
| WDTIM_RSET() | void WDTIM_RSET(REG, Uint16 regval) |
| (1) 14       |                                     |

(b) Macros to read/write WDTIM register field values (Applicable only to registers with more than one field)

| Macro        | Syntax                                       |  |
|--------------|----------------------------------------------|--|
| WDTIM_FGET() | Uint16 WDTIM_FGET(REG, FIELD)                |  |
| WDTIM_FSET() | void WDTIM_FSET(REG, FIELD, Uint16 fieldval) |  |

(c) Macros to create value to write to WDTIM registers and fields (Applicable only to registers with more than one field)

| Macro           | Syntax                                                                                                                                     |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------|
| WDTIM_REG_RMK() | Uint16 WDTIM_REG_RMK(fieldval_n,fieldval_0)                                                                                                |
|                 | Note: *Start with field values with most significant field positions: field_n: MSB field field_0: LSB field * only writable fields allowed |
| WDTIM_FMK()     | Uint16 WDTIM_FMK(REG, FIELD, fieldval)                                                                                                     |
| (1) 14          |                                                                                                                                            |

#### (d) Macros to read a register address

| Macro        | Syntax                          |  |
|--------------|---------------------------------|--|
| WDTIM_ADDR() | Uint16 WDTIM_ADDR( <i>REG</i> ) |  |

#### Notes:

- 1) REG indicates the register, WDTCR, WDPRD, WDTSCR, or WDTIM.
- 2) FIELD indicates the register field name as specified in Appendix A.
  - [2] For REG\_FSET and REG\_FMK, FIELD must be a writable field.
  - For REG\_FGET, the field must be a readable field.
- 3) regval indicates the value to write in the register (REG)
- 4) fieldval indicates the value to write in the field (FIELD)

# 16.5 Configuring the WATCHDOG TIMER Module Using CSL GUI

#### 16.5.1 Overview

The WATCHDOG TIMER module facilitates configuration/control of the onchip WATCHDOG TIMER. The WATCHDOG TIMER module consists of a configuration manager and a resource manager. The configuration manager allows the creation of one or more configuration objects. The configuration object consists of the necessary data to set the WATCHDOG TIMER control registers. The resource manager associates a selected configuration with a timer.

Figure 16–1 illustrates the WATCHDOG TIMER sections menu on the CSL graphical user interface (GUI).

Figure 16-1. WATCHDOG TIMER Sections Menu



The WATCHDOG TIMER includes the following two sections:

- WATCHDOG TIMER Configuration Manager: Allows you to create configuration objects. (There are no predefined configuration objects.)
- WATCHDOG TIMER Resource Manager: Allows you to associate a configuration object to the Watchdog Timer. The WATCHDOG TIMER is only available in the TMS320C5440 and TMS320C5441 devices.

# 16.5.2 WATCHDOG TIMER Configuration Manager

The WATCHDOG TIMER Configuration Manager allows you to create device configurations through the Properties page and generate the configuration objects.

# 16.5.2.1 Creating/Inserting a configuration

There are no predefined configuration objects available.

To configure a WATCHDOG TIMER device through the peripheral, you must insert a new configuration object.

To insert a new configuration object, right-click on the WATCHDOG TIMER Configuration Manager and select Insert wdtimCfg from the drop-down menu. The configuration objects can be renamed. Their use depends on the on-chip device resources.

#### Note:

The number of configuration objects is unlimited. Several configurations can be created and you can select the right one for a specific device and change the configuration later just by selecting a new one under the WATCHDOG TIMER Resource Manager. This feature provides you with more flexibility and reduces the time required to modify register values.

#### 16.5.2.2 Deleting/Renaming an Object

To delete or to rename an object, right-click on the configuration object you want to delete or rename. Select Delete to delete a configuration object. Select Rename to rename the object.

If a configuration object is used by one of the predefined handle objects of the WATCHDOG TIMER Resource Manager, the Delete and Rename options are grayed out and non-usable. The Show Dependency option is accessible and shows which device is using the configuration object (see Figure 2–1, *The CSL Tree*, on page 2-3).

#### 16.5.2.3 Configuring the Object Properties

You can configure object properties through the Properties dialog box (see Figure 16–2). To access the Properties dialog box, right-click on a configuration object and select Properties. By default, the General page of the Properties dialog box is displayed.

The Properties pages allow you to set the Peripheral registers related to the WATCHDOG TIMER. You can set the configuration options through the following tab pages:

| General: Allows you to configure the Breakpoint Emulation                                                                     |
|-------------------------------------------------------------------------------------------------------------------------------|
| Counter Control: Allows you to configure the Breakpoint Emulation Counter configuration                                       |
| Advanced Page: Allows you to configure the Summary of the previous two pages                                                  |
| This page contains the full hexadecimal register values and reflects the setting of the two pages                             |
| The full register values can be entered directly and the new options will be mirrored on the previous two pages automatically |

Figure 16–2 depicts the Properties Page dialog box.

Figure 16–2. WATCHDOG TIMER Properties Page



Each Tab page is composed of several options that are set to a default value (at device reset).

The options represent the fields of the WATCHDOG TIMER registers; the associated field name is shown in parenthesis.

# 16.5.3 WATCHDOG TIMER Resource Manager

The WATCHDOG TIMER Resource Manager allows you to generate the WDTIM\_config() CSL function.

Figure 16–3 illustrates the WATCHDOG TIMER Resource Manager Menu.

Figure 16-3. WATCHDOG TIMER Resource Manager Menu



#### 16.5.3.1 Properties Page

You can generate the WDTIM\_config() csl function through the Properties page.

To access the Properties page, right-click on a predefined TIMER handle object and select Properties from the drop-down menu (see Figure 16–4).

The first time the properties page appears, only the Enable Configuration of WATCHDOG TIMER check-box can be selected. Select this to open the WATCHDOG TIMER configuration, allowing pre-initialization.

WDTIM\_NOTHING is used to indicate that there is no configuration object selected for this device.

To pre-initialize the Watchdog Timer, check the Enable Configuration of WATCHDOG TIMER box. One of the available configuration objects (see section 16.5.2) can then be selected for this channel through the Pre-Initialize drop-down list.

If WDTIM\_NOTHING remains selected, no WDTIM\_config() function call will be generated for the WATCHDOG TIMER. (See section 16.5.4.)

In Figure 16–4, the Enable Configuration of Watchdog Timer option is checked and wdtimCfg0 is now accessible. The WDTIM\_config() function will be generated.

Figure 16-4. WATCHDOG TIMER Properties Page



#### 16.5.4 C Code Generation for WATCHDOG TIMER

Two C files are generated from the configuration tool:

- Header file
- Source file.

#### 16.5.4.1 Header File

The header file includes all the csl header files of the modules and contains the WATCHDOG TIMER configuration objects defined from the configuration tool (see Example 16–1).

# Example 16-1. WATCHDOG TIMER Header File

```
extern WDTIM_Config wdtimCfg0;
```

#### 16.5.4.2 Source File

The source file includes the declaration of the configuration structures (see Example 16–2).

# Example 16–2. WATCHDOG TIMER Source File (Declaration Section)

The source file contains the Configuration Pre-Initialization using the CSL WATCHDOG TIMER API WDTIM\_config() (see Example 16–3). This function is encapsulated into a unique function, CSL\_cfgInit(), which is called from your main C file.

WDTIM\_config() will be generated only if Enable Configuration of WATCH-DOG TIMER is checked and a configuration other than WDTIM\_NOTHING is selected on the Watchdog Timer Resource Manager Properties page.

#### Note:

You must use WDTIM\_start() in your code to start the WATCHDOG TIMER. The WDTIM\_Config structure generated by the CSL GUI does not start the WATCHDOG TIMER port.

# Example 16-3. WATCHDOG TIMER Source File (Body Section)

```
void CSL_cfgInit()
{
    WDTIM_config(&wdtimCfg0);
}
```

# Appendix A

# Peripheral Registers

This appendix provides symbolic constants for the peripheral registers.

| Topi       | C                                  | Page   |
|------------|------------------------------------|--------|
| A.1        | DMA Registers                      | A-2    |
| A.2        | EBUS Registers                     | . A-16 |
| A.3        | GPIO Registers (C5440 and C5441)   | . A-22 |
| <b>A.4</b> | HPI Registers                      | . A-24 |
| A.5        | Multichannel BSP (McBSP) Registers | . A-26 |
| A.6        | PLL Register (CLKMD)               | . A-47 |
| A.7        | Timer Registers                    | . A-49 |
| <b>A.8</b> | Watchdog Timer Registers (C5441)   | . A-52 |
|            |                                    |        |

# A.1 DMA Registers

# A.1.1 DMA Channel Priority and Enable Control Register (DMPREC)

Figure A–1. DMA Channel Priority and Enable Control Register (DMPREC)

|       | 15      | 14                  | 13 |       | 8 |
|-------|---------|---------------------|----|-------|---|
|       | FREE    | AUTOIX <sup>†</sup> |    | DPRC  |   |
|       | R/W-0   | R/W-0               |    | R/W-0 | _ |
|       | 7       | 6                   | 5  |       | 0 |
|       | INTOSEL |                     |    | DE    |   |
| R/W-0 |         |                     |    | R/W-0 |   |

<sup>†</sup> Only available on specific devices.

**Legend:** R/W-x = Read/Write-Reset value

Table A–1. DMA Channel Priority and Enable Control Register (DMPREC) Field Values (DMA\_DMPREC\_field\_symval)

| Bit  | field   | symval     | Value | Description                                                                                                                                                                                                         |
|------|---------|------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | FREE    |            |       | Controls the behavior of the DMA controller during emulation.                                                                                                                                                       |
|      |         | OFF        | 0     | DMA transfers are suspended when the emulator stops                                                                                                                                                                 |
|      |         | ON         | 1     | DMA transfers continue even during emulation stop                                                                                                                                                                   |
| 14   | AUTOIX  |            |       | For C5409A, C54010A, C5416, C5440, and C5441: Selects which DMA global reload registers are used to reload the DMA channels.                                                                                        |
|      |         | USE_DMA0   | 0     | All DMA channels use DMGSA0, DMGDA0, DMGCR0, and DMGFR0 as their reload registers.                                                                                                                                  |
|      |         | USE_CHAN   | 1     | Each DMA channel uses its local set of reload registers during autoinitialization mode.                                                                                                                             |
| 13-8 | DPRC    | OF(value)  | 0-63  | DMA channel priority control bit. Each bit specifies the priority of<br>a DMA channel. When the bit is cleared to 0, the channel is a low<br>priority; when the bit is set to 1, the channel is a high priority.    |
| 7-6  | INTOSEL |            |       | Interrupt multiplex control bits. The INTOSEL bits control how the DMA interrupts are assigned in the interrupt vector table and IMR/IMF registers. The effects of this field on the operation are device-specific. |
|      |         |            |       | For C5401, C5402, C5409, C5409A, C5420, 5421, and 5471                                                                                                                                                              |
|      |         | NONE       | 00    | Interrupts available: Timer 1, McBSP 1 RINT/XINT                                                                                                                                                                    |
|      |         | CH2_CH3    | 01    | Interrupts available: Timer 1, DMA channel 2, DMA channel 3                                                                                                                                                         |
|      |         | CH0_TO_CH3 | 10    | Interrupts available: DMA channel 0, DMA channel 1, DMA channel 2, DMA channel 3                                                                                                                                    |

Table A–1. DMA Channel Priority and Enable Control Register (DMPREC) Field Values (DMA\_DMPREC\_field\_symval) (Continued)

| Bit | field   | symval     | Value | Description                                                                                                                                                      |
|-----|---------|------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     |         |            | 11    | Reserved                                                                                                                                                         |
|     | INTOSEL |            |       | For C5410, C5410A, C5416, and C5420 54CST, 5404, 5407:                                                                                                           |
|     |         | CH4_CH5    | 00    | Interrupts available: McBSP 0 RINT/XINT, McBSP 1 RINT/XINT, McBSP 2 RINT/XINT, DMA channel 4, DMA channel 5                                                      |
|     |         | CH2_TO_CH5 | 01    | Interrupts available: McBSP 0 RINT/XINT, McBSP 2 RINT/XINT, DMA channel 2, DMA channel 3, DMA channel 4, DMA channel 5                                           |
|     |         | CH0_TO_CH5 | 10    | Interrupts available: McBSP 0 RINT/XINT, DMA channel 0, DMA channel 1, DMA channel 2, DMA channel 3, DMA channel 4, DMA channel 5                                |
|     |         |            | 11    | Reserved                                                                                                                                                         |
| 5-0 | DE      | OF(value)  | 0-63  | DMA channel enable bit. Each bit enables a DMA channel. When the bit is cleared to 0, the channel is disabled; when the bit is set to 1, the channel is enabled. |

# A.1.2 DMA Channel n Sync Select and Frame Count Register (DMSFCn)

Figure A–2. DMA Channel n Sync Select and Frame Count Register (DMSFCn)



**Legend:** R/W-x = Read/Write-Reset value

Table A–2. DMA Channel n Sync Select and Frame Count Register (DMSFCn) Field Values (DMA\_DMSFC\_field\_symval)

| Bit   | field | symval | Value | Description                                                                                                                                                                     |
|-------|-------|--------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12 | DSYN  |        |       | DMA sync event. Specifies which sync event is used to initiate DMA transfers for the corresponding DMA channel. The effects of this field on the operation are device-specific. |
|       |       |        |       | For C5401 and C5402:                                                                                                                                                            |
|       |       | NONE   | 0000  | No sync event (nonsynchronization operation)                                                                                                                                    |
|       |       | REVT0  | 0001  | McBSP 0 receive event (REVT0)                                                                                                                                                   |

Table A–2. DMA Channel n Sync Select and Frame Count Register (DMSFCn) Field Values (DMA\_DMSFC\_field\_symval) (Continued)

| Bit | field | symval | Value     | Description                                  |
|-----|-------|--------|-----------|----------------------------------------------|
|     |       | XEVT0  | 0010      | McBSP 0 transmit event (XEVT0)               |
|     |       |        | 0011      | Reserved                                     |
|     |       |        | 0100      | Reserved                                     |
|     | DSYN  | REVT1  | 0101      | McBSP 1 receive event (REVT1)                |
|     |       | XEVT1  | 0110      | McBSP 1 transmit event (XEVT1)               |
|     |       |        | 0111-1100 | Reserved                                     |
|     |       | TINT0  | 1101      | Timer 0 interrupt event                      |
|     |       | INT3   | 1110      | External interrupt 3 event                   |
|     |       | TINT1  | 1111      | Timer 1 interrupt event                      |
|     |       |        |           | For C5409, C5409A, and C5471:                |
|     |       | NONE   | 0000      | No sync event (nonsynchronization operation) |
|     |       | REVT0  | 0001      | McBSP 0 receive event (REVT0)                |
|     |       | XEVT0  | 0010      | McBSP 0 transmit event (XEVT0)               |
|     |       | REVT2  | 0011      | McBSP 2 receive event (REVT2)                |
|     |       | XEVT2  | 0100      | McBSP 2 transmit event (XEVT2)               |
|     |       | REVT1  | 0101      | McBSP 1 receive event (REVT1)                |
|     |       | XEVT1  | 0110      | McBSP 1 transmit event (XEVT1)               |
|     |       |        | 0111-1100 | Reserved                                     |
|     |       | TINT0  | 1101      | Timer interrupt event                        |
|     |       | INT3   | 1110      | External interrupt 3 event                   |
|     |       |        |           | For C5410, C5410A, and C5416:                |
|     |       | NONE   | 0000      | No sync event (nonsynchronization operation) |
|     |       | REVT0  | 0001      | McBSP 0 receive event (REVT0)                |
|     |       | XEVT0  | 0010      | McBSP 0 transmit event (XEVT0)               |
|     |       | REVT2  | 0011      | McBSP 2 receive event (REVT2)                |
|     |       | XEVT2  | 0100      | McBSP 2 transmit event (XEVT2)               |
|     |       | REVT1  | 0101      | McBSP 1 receive event (REVT1)                |
|     |       | XEVT1  | 0110      | McBSP 1 transmit event (XEVT1)               |
|     |       | REVTA0 | 0111      | McBSP 0 receive event — ABIS mode (REVTA0)   |
|     |       | XEVTA0 | 1000      | McBSP 0 transmit event — ABIS mode (XEVTA0)  |

Table A–2. DMA Channel n Sync Select and Frame Count Register (DMSFCn) Field Values (DMA\_DMSFC\_field\_symval) (Continued)

| Bit | field | symval    | Value     | Description                                  |
|-----|-------|-----------|-----------|----------------------------------------------|
|     |       | REVTA2    | 1001      | McBSP 2 receive event — ABIS mode (REVTA2)   |
|     |       | XEVTA2    | 1010      | McBSP 2 transmit event — ABIS mode (XEVTA2)  |
|     | DSYN  | REVTA1    | 1011      | McBSP 1 receive event — ABIS mode (REVTA1)   |
|     |       | XEVTA1    | 1100      | McBSP 1 transmit event — ABIS mode (XEVTA1)  |
|     |       | TINT0     | 1101      | Timer interrupt event                        |
|     |       | INT3      | 1110      | External interrupt 3 event                   |
|     |       |           | 1111      | Reserved                                     |
|     |       |           |           | For C5420 and C5421:                         |
|     |       | NONE      | 0000      | No sync event (nonsynchronization operation) |
|     |       | REVT0     | 0001      | McBSP 0 receive event (REVT0)                |
|     |       | XEVT0     | 0010      | McBSP 0 transmit event (XEVT0)               |
|     |       | REVT2     | 0011      | McBSP 2 receive event (REVT2)                |
|     |       | XEVT2     | 0100      | McBSP 2 transmit event (XEVT2)               |
|     |       | REVT1     | 0101      | McBSP 1 receive event (REVT1)                |
|     |       | XEVT1     | 0110      | McBSP 1 transmit event (XEVT1)               |
|     |       | FIFO_REVT | 0111      | FIFO receive buffer not empty event          |
|     |       | FIFO_XEVT | 1000      | FIFO transmit buffer not full event          |
|     |       |           | 1001-1111 | Reserved                                     |
|     |       |           |           | For C5440 and C5441:                         |
|     |       | NONE      | 0000      | No sync event (nonsynchronization operation) |
|     |       | REVT0     | 0001      | McBSP 0 receive event (REVT0)                |
|     |       | XEVT0     | 0010      | McBSP 0 transmit event (XEVT0)               |
|     |       | REVT2     | 0011      | McBSP 2 receive event (REVT2)                |
|     |       | XEVT2     | 0100      | McBSP 2 transmit event (XEVT2)               |
|     |       | REVT1     | 0101      | McBSP 1 receive event (REVT1)                |
|     |       | XEVT1     | 0110      | McBSP 1 transmit event (XEVT1)               |
|     |       |           | 0111-1100 | Reserved                                     |
|     |       |           |           | For C54CST, 5404, and 5407:                  |
|     |       | NONE      | 0000      | No sync event (nonsynchronization operation) |
|     |       | REVT0     | 0001      | McBSP 0 receive event (REVT0)                |

Table A–2. DMA Channel n Sync Select and Frame Count Register (DMSFCn) Field Values (DMA\_DMSFC\_field\_symval) (Continued)

| Bit  | field    | symval    | Value     | Description                                                                                                                                                                                                             |
|------|----------|-----------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |          | XEVT0     | 0010      | McBSP 0 transmit event (XEVT0)                                                                                                                                                                                          |
|      |          | REVT2     | 0011      | McBSP 2 receive event (REVT2)                                                                                                                                                                                           |
|      |          | XEVT2     | 0100      | McBSP 2 transmit event (XEVT2)                                                                                                                                                                                          |
|      |          | REVT1     | 0101      | McBSP 1 receive event (REVT1)                                                                                                                                                                                           |
|      |          | XEVT1     | 0110      | McBSP 1 transmit event (XEVT1)                                                                                                                                                                                          |
|      |          |           | 0611-1100 | Reserved                                                                                                                                                                                                                |
|      |          |           | 1000-1101 | Reserved                                                                                                                                                                                                                |
|      |          | UART      | 0111      | UART interrupt event                                                                                                                                                                                                    |
|      |          | TINT0     | 1101      | Timer interrupt event                                                                                                                                                                                                   |
|      |          | TINT1     | 111       | Timer1 interrupt event                                                                                                                                                                                                  |
|      |          | TINT3     | 1110      | External interrupt 3 event                                                                                                                                                                                              |
| 11   | DBLW     |           |           | Double-word mode enable bit.                                                                                                                                                                                            |
|      |          | OFF       | 0         | Single-word mode. DMA transfers 16-bit words.                                                                                                                                                                           |
|      |          | ON        | 1         | Double-word mode. Allows the DMA to transfer 32-bit words in any index mode. Two consecutive 16-bit transfers are initiated and the source and destination addresses are automatically updated following each transfer. |
| 10-8 | reserved |           |           | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect.                                                                                                                |
| 7-0  | FRAMECNT | OF(value) | 0-255     | Frame count. Specifies the number of frames to be included in a block transfer. The frame count is initialized to 1 less than the desired number of frames.                                                             |

# A.1.3 DMA Channel n Transfer Mode Control Register (DMMCRn)

Figure A–3. DMA Channel n Transfer Mode Control Register (DMMCRn)

| _ | 15       | 14    | 13     | 12    | 11     | 10 |       | 8 |
|---|----------|-------|--------|-------|--------|----|-------|---|
|   | AUTOINIT | DINM  | IMOD   | CTMOD | SLAXS† |    | SIND  |   |
| • | R/W-0    | R/W-0 | R/W-0  | R/W-0 | R/W-0  | •  | R/W-0 |   |
|   | 7        | 6     | 5      | 4     |        | 2  | 1     | 0 |
|   | DN       | //S   | DLAXS† |       | DIND   |    | DMD   |   |
| • | R/V      | V-0   | R/W-0  |       | R/W-0  |    | R/W-0 |   |

<sup>&</sup>lt;sup>†</sup>Only available on specific devices with DMA extended data memory.

Table A–3. DMA Channel n Transfer Mode Control Register (DMMCRn) Field Values (DMA\_DMMCR\_field\_symval)

| Bit  | field    | symval          | Value | Description                                                               |
|------|----------|-----------------|-------|---------------------------------------------------------------------------|
| 15   | AUTOINIT |                 |       | DMA autoinitialization mode enable bit.                                   |
|      |          | OFF             | 0     | Autoinitialization is disabled.                                           |
|      |          | ON              | 1     | Autoinitialization is enabled.                                            |
| 14   | DINM     |                 |       | DMA interrupt generation mask bit.                                        |
|      |          | OFF             | 0     | No interrupt is generated                                                 |
|      |          | ON              | 1     | Interrupt is generated based on IMOD bit                                  |
| 13   | IMOD     |                 |       | DMA interrupt generation mode bit operates in conjunction with CTMOD bit. |
|      |          |                 |       | In ABU mode (CTMOD = 1):                                                  |
|      |          | FULL_ONLY       | 0     | Interrupt at buffer full only.                                            |
|      |          | HALF_AND_FULL   | 1     | Interrupt at half full buffer and buffer full.                            |
|      |          |                 |       | In multiframe mode (CTMOD = 0):                                           |
|      |          | BLOCK_ONLY      | 0     | Interrupt at completion of block transfer.                                |
|      |          | FRAME_AND_BLOCK | 1     | Interrupt at end of frame and end of block.                               |
| 12   | CTMOD    |                 |       | DMA transfer counter mode control bit.                                    |
|      |          | MULTIFRAME      | 0     | Multiframe mode                                                           |
|      |          | ABU             | 1     | ABU mode                                                                  |
| 11   | SLAXS    |                 |       | For devices with DMA extended data memory: DMA source space select bit.   |
|      |          | OFF             | 0     | No external access                                                        |
|      |          | ON              | 1     | External access                                                           |
| 10-8 | SIND     |                 |       | DMA source address transfer index mode bit.                               |
|      |          | NOMOD           | 000   | No modification                                                           |
|      |          | POSTINC         | 001   | Postincrement                                                             |
|      |          | POSTDEC         | 010   | Postdecrement                                                             |
|      |          | DMIDX0          | 011   | Postincrement with index offset (DMIDX0)                                  |
|      |          | DMIDX1          | 100   | Postincrement with index offset (DMIDX1)                                  |
|      |          | DMFRI0          | 101   | Postincrement with index offset (DMIDX0 and DMFRI0)                       |
|      |          | DMFRI1          | 110   | Postincrement with index offset (DMIDX1 and DMFRI1)                       |
|      |          |                 | 111   | Reserved                                                                  |

Table A–3. DMA Channel n Transfer Mode Control Register (DMMCRn) Field Values (DMA\_DMMCR\_field\_symval) (Continued)

| Bit | field | symval  | Value | Description                                                                  |
|-----|-------|---------|-------|------------------------------------------------------------------------------|
| 7-6 | DMS   |         |       | DMA source address space select bit.                                         |
|     |       | PROGRAM | 00    | Program space                                                                |
|     |       | DATA    | 01    | Data space                                                                   |
|     |       | IO      | 10    | I/O space                                                                    |
|     |       |         | 11    | Reserved                                                                     |
| 5   | DLAXS |         |       | For devices with DMA extended data memory: DMA destination space select bit. |
|     |       | OFF     | 0     | No external access                                                           |
|     |       | ON      | 1     | External access                                                              |
| 4-2 | DIND  |         |       | DMA destination address transfer index mode bit.                             |
|     |       | NOMOD   | 000   | No modification                                                              |
|     |       | POSTINC | 001   | Postincrement                                                                |
|     |       | POSTDEC | 010   | Postdecrement                                                                |
|     |       | DMIDX0  | 011   | Postincrement with index offset (DMIDX0)                                     |
|     |       | DMIDX1  | 100   | Postincrement with index offset (DMIDX1)                                     |
|     |       | DMFRI0  | 101   | Postincrement with index offset (DMIDX0 and DMFRI0)                          |
|     |       | DMFRI1  | 110   | Postincrement with index offset (DMIDX1 and DMFRI1)                          |
|     |       |         | 111   | Reserved                                                                     |
| 1-0 | DMD   |         |       | DMA destination address space select bit.                                    |
|     |       | PROGRAM | 00    | Program space                                                                |
|     |       | DATA    | 01    | Data space                                                                   |
|     |       | IO      | 10    | I/O space                                                                    |
|     |       |         | 11    | Reserved                                                                     |

#### A.1.4 DMA Channel n Source Address Register (DMSRCn)

Figure A–4. DMA Channel n Source Address Register (DMSRCn)



**Legend:** R/W-x = Read/Write-Reset value

Table A–4. DMA Channel n Source Address Register (DMSRCn) Field Values (DMA DMSRC field symval)

| Bit  | field | symval             | Value   | Description                                                                                                                                                                                                                                           |
|------|-------|--------------------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | SRC   | OF( <i>value</i> ) | 0-FFFFh | Specifies the 16 least-significant bits of the extended address for the source location. The source address register is initialized prior to starting the DMA transfer in software, and updated automatically during transfers by the DMA controller. |

### A.1.5 DMA Global Source Address Reload Register (DMGSA)

Figure A–5. DMA Global Source Address Reload Register (DMGSA)



**Legend:** R/W-x = Read/Write-Reset value

Table A–5. DMA Global Source Address Reload Register (DMGSA) Field Values (DMA\_DMGSA\_field\_symval)

| Bit  | field | symval    | Value   | Description                                    |
|------|-------|-----------|---------|------------------------------------------------|
| 15-0 | GSA   | OF(value) | 0-FFFFh | A 16-bit source address used to reload DMSRCn. |

# A.1.6 DMA Source Program Page Address Register (DMSRCP)

Figure A–6. DMA Source Program Page Address Register (DMSRCP)



Table A–6. DMA Source Program Page Address Register (DMSRCP) Field Values (DMA\_DMSRCP\_field\_symval)

| Bit  | field    | symval    | Value | Description                                                                                              |
|------|----------|-----------|-------|----------------------------------------------------------------------------------------------------------|
| 15-7 | reserved |           |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect. |
| 6-0  | PAGE     | OF(value) | 0-127 | Specifies the 7 most-significant bits of the extended program page address for the source location.      |

### A.1.7 DMA Channel n Destination Address Register (DMDSTn)

Figure A–7. DMA Channel n Destination Address Register (DMDSTn)



**Legend:** R/W-x = Read/Write-Reset value

Table A–7. DMA Channel n Destination Address Register (DMDSTn) Field Values (DMA\_DMDST\_field\_symval)

| Bit  | field | symval             | Value   | Description                                                                                                                                                                                                                                                     |
|------|-------|--------------------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | DST   | OF( <i>value</i> ) | 0-FFFFh | Specifies the 16 least-significant bits of the extended address for the destination location. The destination address register is initialized prior to starting the DMA transfer in software, and updated automatically during transfers by the DMA controller. |

## A.1.8 DMA Global Destination Address Reload Register (DMGDA)

Figure A–8. DMA Global Destination Address Reload Register (DMGDA)



Table A–8. DMA Global Destination Address Reload Register (DMGDA) Field Values (DMA\_DMGDA\_field\_symval)

| Bit  | field | symval    | Value   | Description                                         |
|------|-------|-----------|---------|-----------------------------------------------------|
| 15-0 | GDA   | OF(value) | 0-FFFFh | A 16-bit destination address used to reload DMDSTn. |

### A.1.9 DMA Destination Program Page Address Register (DMDSTP)

Figure A–9. DMA Destination Program Page Address Register (DMDSTP)



**Legend:** R/W-x = Read/Write-Reset value

Table A–9. DMA Destination Program Page Address Register (DMDSTP) Field Values (DMA\_DMDSTP\_field\_symval)

| Bit  | field    | symval    | Value | Description                                                                                              |
|------|----------|-----------|-------|----------------------------------------------------------------------------------------------------------|
| 15-7 | reserved |           |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect. |
| 6-0  | PAGE     | OF(value) | 0-127 | Specifies the 7 most-significant bits of the extended program page address for the destination location. |

## A.1.10 DMA Channel n Element Count Register (DMCTRn)

Figure A-10. DMA Channel n Element Count Register (DMCTRn)



Table A–10. DMA Channel n Element Count Register (DMCTRn) Field Values (DMA\_DMCTR\_field\_symval)

| Bit  | field  | symval    | Value   | Description                                                                                                                                                                                        |
|------|--------|-----------|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | ELECNT | OF(value) | 0-FFFFh | A 16-bit element counter that keeps track of the number of DMA transfers to be performed. The element count register should be initialized to 1 less than the desired number of element transfers. |

### A.1.11 DMA Global Element Count Reload Register (DMGCR)

Figure A–11. DMA Global Element Count Reload Register (DMGCR)



**Legend:** R/W-x = Read/Write-Reset value

Table A-11. DMA Global Element Count Reload Register (DMGCR) Field Values (DMA\_DMGCR\_field\_symval)

| Bit  | field  | symval    | Value   | Description                                                 |
|------|--------|-----------|---------|-------------------------------------------------------------|
| 15-0 | ELECNT | OF(value) | 0-FFFFh | A 16-bit unsigned element count value used to reload DMCTR. |

## A.1.12 DMA Global Frame Count Reload Register (DMGFR)

Figure A–12. DMA Global Frame Count Reload Register (DMGFR)



Table A-12. DMA Global Frame Count Reload Register (DMGFR) Field Values (DMA\_DMGFR\_field\_symval)

| Bit  | field    | symval    | Value   | Description                                                                                              |
|------|----------|-----------|---------|----------------------------------------------------------------------------------------------------------|
| 15-8 | reserved |           |         | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect. |
| 7-0  | FRAMECNT | OF(value) | 0-FFFFh | An 8-bit unsigned frame count value used to reload the Frame Count field of DMSFCn.                      |

### A.1.13 DMA Element Address Index Register 0 (DMIDX0)

Figure A–13. DMA Element Address Index Register 0 (DMIDX0)



**Legend:** R/W-x = Read/Write-Reset value

Table A–13. DMA Element Address Index Register 0 (DMIDX0) Field Values (DMA\_DMIDX0\_field\_symval)

| Bit  | field  | symval    | Value   | Description                                                                                                            |
|------|--------|-----------|---------|------------------------------------------------------------------------------------------------------------------------|
| 15-0 | ELEIDX | OF(value) | 0-FFFFh | A 16-bit unsigned index value used to modify the source or destination address following the transfer of each element. |

### A.1.14 DMA Element Address Index Register 1 (DMIDX1)

Figure A–14. DMA Element Address Index Register 1 (DMIDX1)



Table A–14. DMA Element Address Index Register 1 (DMIDX1) Field Values (DMA\_DMIDX1\_field\_symval)

| Bit  | field  | symval    | Value   | Description                                                                                                            |  |  |  |
|------|--------|-----------|---------|------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 15-0 | ELEIDX | OF(value) | 0-FFFFh | A 16-bit unsigned index value used to modify the source or destination address following the transfer of each element. |  |  |  |

## A.1.15 DMA Frame Address Index Register 0 (DMFRI0)

Figure A–15. DMA Frame Address Index Register 0 (DMFRI0)



**Legend:** R/W-x = Read/Write-Reset value

Table A–15. DMA Frame Address Index Register 0 (DMFRI0) Field Values (DMA\_DMFRI0\_field\_symval)

| Bit  | field    | symval    | Value   | Description                                                                                                                                                                                                                                                                                                                       |
|------|----------|-----------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | FRAMEIDX | OF(value) | 0-FFFFh | A 16-bit unsigned index value used to modify the source or destination address following the completion of blocks (or frames) of element transfers. When both element and frame indexes are used, the address is modified by the element index after each transfer and then modified by the frame index at the end of each frame. |

## A.1.16 DMA Frame Address Index Register 1 (DMFRI1)

Figure A–16. DMA Frame Address Index Register 1 (DMFRI1)



Table A–16. DMA Frame Address Index Register 1 (DMFRI1) Field Values (DMA\_DMFRI1\_field\_symval)

| Bit  | field    | symval    | Value   | Description                                                                                                                                                                                                                                                                                                                       |
|------|----------|-----------|---------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | FRAMEIDX | OF(value) | 0-FFFFh | A 16-bit unsigned index value used to modify the source or destination address following the completion of blocks (or frames) of element transfers. When both element and frame indexes are used, the address is modified by the element index after each transfer and then modified by the frame index at the end of each frame. |

### A.1.17 DMA Global Extended Source Data Page Register (DMSRCDP)

Figure A–17. DMA Global Extended Source Data Page Register (DMSRCDP)



**Legend:** R/W-x = Read/Write-Reset value

Table A–17. DMA Global Extended Source Data Page Register (DMSRCDP) Field Values (DMA\_DMSRCDP\_field\_symval)

| Bit  | field    | symval    | Value | Description                                                                                              |
|------|----------|-----------|-------|----------------------------------------------------------------------------------------------------------|
| 15-7 | reserved |           |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect. |
| 6-0  | DMSRCDP  | OF(value) | 0-127 | Specifies 1 of the 128 extended source data pages.                                                       |

#### A.1.18 DMA Global Extended Destination Data Page Register (DMDSTDP)

Figure A–18. DMA Global Extended Destination Data Page Register (DMDSTDP)



Table A–18. DMA Global Extended Destination Data Page Register (DMDSTDP) Field Values (DMA\_DMDSTDP\_field\_symval)

| Bit  | field    | symval    | Value | Description                                                                                              |
|------|----------|-----------|-------|----------------------------------------------------------------------------------------------------------|
| 15-7 | reserved |           |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect. |
| 6-0  | DMDSTDP  | OF(value) | 0-127 | Specifies 1 of the 128 extended destination data pages.                                                  |

## A.2 EBUS Registers

## A.2.1 Software Wait-State Register (SWWSR)

Figure A–19. Software Wait-State Register(SWWSR)-All devices except C5440 and C5441

|   | 15                | 14 | 12       | 11 | 9        | 8        |  |
|---|-------------------|----|----------|----|----------|----------|--|
|   | XPA†              |    | IO       |    | DATAHI   | DATALO   |  |
|   | R/W-0             |    | R/W-111b |    | R/W-111b | R/W-111b |  |
|   |                   | 6  | 5        | 3  | 2        | 0        |  |
|   | DATALO PROGHI     |    |          |    | PROGLO   |          |  |
| • | R/W-111b R/W-111b |    |          |    | R/W-111b |          |  |

 $<sup>\</sup>ensuremath{^{\dagger}}\xspace$  XPA bit only on selected devices with extended program memory.

Table A–19. Software Wait-State Register (SWWSR) Field Values (EBUS\_SWWSR\_field\_symval)

| Bit   | field  | symval    | Value | Description                                                                                                                                |
|-------|--------|-----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------|
| 15    | XPA    |           |       | For devices with extended program memory: Extended program address control bit. Selects the address ranges selected by the program fields. |
|       |        | ADDRLO    | 0     | Address range: xx0000 - xxFFFFh                                                                                                            |
|       |        | ADDREXT   | 1     | Address range: 000000h-7FFFFF                                                                                                              |
| 14-12 | IO     | OF(value) | 0-7   | The value corresponds to the number of wait states for I/O space 0000-FFFFh.                                                               |
| 11-9  | DATAHI | OF(value) | 0-7   | The value corresponds to the number of wait states for data space 8000-FFFFh.                                                              |
| 8-6   | DATALO | OF(value) | 0-7   | The value corresponds to the number of wait states for data space 0000-7FFFh.                                                              |
| 5-3   | PROGHI | OF(value) | 0-7   | The value corresponds to the number of wait states for program space 8000-FFFFh.                                                           |
| 2-0   | PROGLO | OF(value) | 0-7   | The value corresponds to the number of wait states for program space 0000-7FFFh.                                                           |

### A.2.2 Software Wait-State Control Register (SWCR)

Figure A–20. Software Wait-State Control Register (SWCR)-All devices except C5440 and C5441



**Legend:** R/W-x = Read/Write-Reset value

Table A–20. Software Wait-State Control Register (SWCR) Field Values (EBUS\_SWCR\_field\_symval)

| Bit  | field    | symval  | Value | Description                                                                                                       |
|------|----------|---------|-------|-------------------------------------------------------------------------------------------------------------------|
| 15-1 | reserved |         |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect.          |
| 0    | SWSM     |         |       | Software wait-state multiplier bit.                                                                               |
|      |          | NOMULT  | 0     | The wait states specified in SWWSR are unchanged (not multiplied).                                                |
|      |          | MULTBY2 | 1     | The wait states specified in SWWSR are multiplied by 2, extending the maximum number of wait states from 7 to 14. |

## A.2.3 Bank-Switching Control Register (BSCR)

Figure A–21. Bank-Switching Control Register (BSCR) — C5401, C5402, C5409, C5420, C5421, and 5471

| 15                                           |           | 12               | 11    | 10    | 9    | 8      |
|----------------------------------------------|-----------|------------------|-------|-------|------|--------|
|                                              | BNKCMP    |                  | PSDS  | rese  | rved | IPIRQ† |
|                                              | R/W-1111b |                  | R/W-1 | R/W-0 |      | R/W-0  |
| 7                                            |           |                  | 3     | 2     | 1    | 0      |
|                                              | reserved  | HBH <sup>†</sup> | ВН    | EXIO  |      |        |
| <u>-                                    </u> | R/W-0     | R/W-0            | R/W-0 | R/W-0 |      |        |

<sup>&</sup>lt;sup>†</sup>HBH, IPIRQ, and EXIO bits only on selected devices.

Table A–21. Bank-Switching Control Register (BSCR) Field Values — C5401, C5402, C5409, and C5420, and C5471 (EBUS\_BSCR\_field\_symval)

| Bit   | field    | symval  | Value     | Description                                                                                                                                                                                    |
|-------|----------|---------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12 | BNKCMP   |         |           | Bank compare bit determines the number of MSBs of an address to be compared and the external memory-bank size.  Bank sizes from 4K words to 64K words are allowed.                             |
|       |          | 64K     | 0000      | No bits are compared, resulting in a bank size of 64K words.                                                                                                                                   |
|       |          |         | 0001-0111 | Reserved                                                                                                                                                                                       |
|       |          | 32K     | 1000      | The MSB (bit 15) is compared, resulting in a bank size of 32K words.                                                                                                                           |
|       |          |         | 1001-1011 | Reserved                                                                                                                                                                                       |
|       |          | 16K     | 1100      | The 2 MSBs (bits 15-14) are compared, resulting in a bank size of 16K words.                                                                                                                   |
|       |          |         | 1101      | Reserved                                                                                                                                                                                       |
|       |          | 8K      | 1110      | The 3 MSBs (bits 15-13) are compared, resulting in a bank size of 8K words.                                                                                                                    |
|       |          | 4K      | 1111      | The 4 MSBs (bits 15-12) are compared, resulting in a bank size of 4K words.                                                                                                                    |
| 11    | PSDS     |         |           | Program read-data read access bit controls the insertion of an extra cycle between consecutive program and data reads, or data and program reads.                                              |
|       |          | NOEXCY  | 0         | No extra cycles are inserted by this feature except when banks are crossed.                                                                                                                    |
|       |          | INSCY   | 1         | One extra cycle is inserted between consecutive program and data reads, or data and program reads.                                                                                             |
| 10-9  | reserved |         |           | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect.                                                                                       |
| 8     | IPIRQ    |         |           | For C5420: Interprocessor interrupt request enable bit is used to send an interprocessor interrupt to the other subsystem. IPIRQ must be cleared before any subsequent interrupts can be made. |
|       |          | CLR     | 0         | No interprocessor interrupt request is sent.                                                                                                                                                   |
|       |          | INTR    | 1         | An interprocessor interrupt request is sent.                                                                                                                                                   |
| 7-3   | reserved |         |           | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect.                                                                                       |
| 2     | НВН      |         |           | For C5401, C5402, C5409, and 5416: HPI data bus holder enable bit.                                                                                                                             |
|       |          | DISABLE | 0         | The HPI data bus holder is disabled. When HPI16 pin is set to a logic high, HPI data bus holder is enabled.                                                                                    |
|       |          | ENABLE  | 1         | The HPI data bus holder is enabled. When not driven, the HPI data bus, HD(7-0), is held in the previous logic level.                                                                           |

Table A–21. Bank-Switching Control Register (BSCR) Field Values — C5401, C5402, C5409, and C5420, and C5471 (EBUS\_BSCR\_field\_symval) (Continued)

| Bit | field | symval  | Value | Description                                                                                                                                                                                                                       |
|-----|-------|---------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | ВН    |         |       | For C5420: Data bus holder enable bit.                                                                                                                                                                                            |
|     |       | DISABLE | 0     | The data bus holder is disabled.                                                                                                                                                                                                  |
|     |       | ENABLE  | 1     | The data bus holder is enabled. When not driven, the data bus, PPD(15-0), is held in the previous logic level.                                                                                                                    |
| 1   | ВН    |         |       | For C5401, C5402, C5409, and 5416: Bus holder enable bit.                                                                                                                                                                         |
|     |       | DISABLE | 0     | The bus holder is disabled. When HPI16 pin is set to a logic high, address bus holder is enabled.                                                                                                                                 |
|     |       | ENABLE  | 1     | The data bus holder is enabled. When not driven, the data bus, D(15-0), is held in the previous logic level. When HPI16 pin is set to a logic high, address bus holder is enabled.                                                |
| 0   | EXIO  |         |       | Hot any call on <b>C5420</b> External bus interface off enable bit controls the external-bus-off function.                                                                                                                        |
|     |       | NORMAL  | 0     | The external-bus-off function is disabled.                                                                                                                                                                                        |
|     |       | INACTIF | 1     | The external-bus-off function is enabled. The address bus, data bus, and control signals become inactive after completing the current bus cycle. The DROM, MP/MC, and OVLY bits in PMST and the HM bit in ST1 cannot be modified. |

Figure A–22. Bank-Switching Control Register (BSCR) — C5410, C5410A, and C5416

| 15     | 14      | 13 | 12    | 11 |   |       |       |          |
|--------|---------|----|-------|----|---|-------|-------|----------|
| CONSEC | DIVFCT  |    | IACK  |    |   | rese  | rved  |          |
| R/W-1  | R/W-11b |    | R/W-0 |    |   | R/V   | V-0   |          |
|        |         |    |       | 3  | 3 | 2     | 1     | 0        |
|        | reserv  | ed |       |    |   | нвн†  | вн†   | reserved |
|        | R/W-    | 0  | _     |    |   | R/W-0 | R/W-0 | R/W-0    |

<sup>†</sup>BH and HBH bits only on selected devices.

Table A–22. Bank-Switching Control Register (BSCR) Field Values — C5410, and C5416 (EBUS\_BSCR\_field\_symval)

| Bit   | field    | symval      | Value | Description                                                                                                                                                                                                 |
|-------|----------|-------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15    | CONSEC   |             |       | Consecutive bank switching bit specifies the bank-switching mode. This bit is cleared if fast access is desired for continuous memory reads (that is, no starting and trailing cycles between read cycles). |
|       |          | 32KFASTREAD | 0     | Bank-switching on 32K bank boundaries only.                                                                                                                                                                 |
|       |          | EXTMEM      | 1     | Consecutive bank switches on external memory reads. Each read cycle consists of 3 cycles: starting, read, and trailing.                                                                                     |
| 14-13 | DIVFCT   |             |       | CLKOUT output divide factor. The CLKOUT output is driven by an on-chip source having a frequency equal to 1/(DIVFCT + 1) of the DSP clock.                                                                  |
|       |          | ZERO        | 00    | CLKOUT is not divided.                                                                                                                                                                                      |
|       |          | CLKBYTWO    | 01    | CLKOUT is divided by 2 from the DSP clock.                                                                                                                                                                  |
|       |          | CLKBYTHREE  | 10    | CLKOUT is divided by 3 from the DSP clock.                                                                                                                                                                  |
|       |          | CLKBYFOUR   | 11    | CLKOUT is divided by 4 from the DSP clock.                                                                                                                                                                  |
| 12    | IACK     |             |       | $\overline{\text{IACK}}$ signal output off enable bit controls the $\overline{\text{IACK}}$ signal output off function.                                                                                     |
|       |          | ON          | 0     | IACK signal output off function is disabled.                                                                                                                                                                |
|       |          | OFF         | 1     | IACK signal output off function is enabled.                                                                                                                                                                 |
| 11-3  | reserved |             |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect.                                                                                                    |
| 2     | HBH      |             |       | For C5416: HPI data bus holder enable bit.                                                                                                                                                                  |
|       |          | DISABLE     | 0     | The HPI data bus holder is disabled. When HPI16 pin is set to a logic high, HPI data bus holder is enabled.                                                                                                 |
|       |          | ENABLE      | 1     | The HPI data bus holder is enabled. When not driven, the HPI data bus, HD(7-0), is held in the previous logic level.                                                                                        |
| 1     | ВН       |             |       | For C5416: Bus holder enable bit.                                                                                                                                                                           |
|       |          | DISABLE     | 0     | The bus holder is disabled. When HPI16 pin is set to a logic high, address bus holder is enabled.                                                                                                           |
|       |          | ENABLE      | 1     | The data bus holder is enabled. When not driven, the data bus, D(15-0), is held in the previous logic level. When HPI16 pin is set to a logic high, address bus holder is enabled.                          |
| 0     | reserved |             |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect.                                                                                                    |

Figure A–23. Bank-Switching Control Register (BSCR) — C5440 and C5441



Table A–23. Bank-Switching Control Register (BSCR) Field Values — C5440 and C5441 (EBUS\_BSCR\_field\_symval)

| Bit  | field    | symval  | Value | Description                                                                                                                 |
|------|----------|---------|-------|-----------------------------------------------------------------------------------------------------------------------------|
| 15-3 | reserved |         |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect.                    |
| 2    | BHD      |         |       | HPI data bus holder enable bit.                                                                                             |
|      |          | DISABLE | 0     | The HPI data bus holder is disabled.                                                                                        |
|      |          | ENABLE  | 1     | The HPI data bus holder is enabled. When not driven, the HPI data bus, HD(15-0), is held in the previous logic level.       |
| 1    | BHA      |         |       | HPI address bus holder enable bit.                                                                                          |
|      |          | DISABLE | 0     | The HPI address bus holder is disabled.                                                                                     |
|      |          | ENABLE  | 1     | The HPI address bus holder is enabled. When not driven, the HPI address bus, HA(15-0), is held in the previous logic level. |
| 0    | reserved |         |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect.                    |

# A.3 GPIO Registers (C5440 and C5441)

# A.3.1 General Purpose I/O Register (GPIO)

Figure A–24. General Purpose I/O Register (GPIO)

| 15    | 14 12    | 11    | 10    | 9     | 8     |
|-------|----------|-------|-------|-------|-------|
| TOUT† | reserved | DIR3  | DIR2  | DIR1  | DIR0  |
| R/W-0 | R/W-0    | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
| 7     | 4        | 3     | 2     | 1     | 0     |
|       | reserved | DAT3  | DAT2  | DAT1  | DAT0  |
|       | R/W-0    | R/W-0 | R/W-0 | R/W-0 | R/W-0 |

<sup>†</sup>Only available on devices with a second on-chip timer.

Table A–24. General Purpose I/O Register (GPIO) Field Values (GPIO\_GPIO\_field\_symval)

| Bit   | field    | symval  | Value | Description                                                                                              |
|-------|----------|---------|-------|----------------------------------------------------------------------------------------------------------|
| 15    | TOUT     |         |       | Timer output enable                                                                                      |
|       |          | ENABLE  | 1     | Enables the timer output                                                                                 |
|       |          | DISABLE | 0     | Disables the timer output                                                                                |
| 14-12 | reserved |         |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect. |
| 11    | DIR3     |         |       | GPIO pin direction 3                                                                                     |
|       |          | INPUT   | 0     | GPIO pin 3 is used as input                                                                              |
|       |          | OUTPUT  | 1     | GPIO pin 3 is used as output                                                                             |
| 10    | DIR2     |         |       | GPIO pin direction 2                                                                                     |
|       |          | INPUT   | 0     | GPIO pin 2 is used as input                                                                              |
|       |          | OUTPUT  | 1     | GPIO pin 2 is used as output                                                                             |
| 9     | DIR1     |         |       | GPIO pin direction 1                                                                                     |
|       |          | INPUT   | 0     | GPIO pin 1 is used as input                                                                              |
|       |          | OUTPUT  | 1     | GPIO pin 1 is used as output                                                                             |
| 8     | DIR0     |         |       | GPIO pin direction 0                                                                                     |
|       |          | INPUT   | 0     | GPIO pin 0 is used as input                                                                              |
|       |          | OUTPUT  | 1     | GPIO pin 0 is used as output                                                                             |

Table A–24. General Purpose I/O Register (GPIO) Field Values (GPIO\_GPIO\_field\_symval) (Continued)

| Bit | field    | symval | Value | Description                                                                                              |
|-----|----------|--------|-------|----------------------------------------------------------------------------------------------------------|
| 7-4 | reserved |        |       | Reserved. The reserved but location is always read as zero. A value written to this field has no effect. |
| 3   | DAT3     |        |       | GPIO data bit 3                                                                                          |
|     |          | LOW    | 0     | GPIO0 is driven with a 0 (DIR3 = 1)                                                                      |
|     |          |        |       | GPIO0 is read as 0 (DIR3 = 0)                                                                            |
|     |          | HI     | 1     | GPIO0 is driven with a 1 (DIR3 = 1)                                                                      |
|     |          |        |       | GPIO0 is read as 1 (DIR3 = 0)                                                                            |
| 2   | DAT2     |        |       | GPIO data bit 2                                                                                          |
|     |          | LOW    | 0     | GPIO0 is driven with a 0 (DIR2 = 1)                                                                      |
|     |          |        |       | GPIO0 is read as 0 (DIR2 = 0)                                                                            |
|     |          | HI     | 1     | GPIO0 is driven with a 1 (DIR2 = 1)                                                                      |
|     |          |        |       | GPIO0 is read as 1 (DIR2 = 0)                                                                            |
| 1   | DAT1     |        |       | GPIO data bit 1                                                                                          |
|     |          | LOW    | 0     | GPIO0 is driven with a 0 (DIR1 = 1)                                                                      |
|     |          |        |       | GPIO0 is read as 0 (DIR1 = 0)                                                                            |
|     |          | HI     | 1     | GPIO0 is driven with a 1 (DIR1 = 1)                                                                      |
|     |          |        |       | GPIO0 is read as 1 (DIR1 = 0)                                                                            |
| 0   | DAT0     |        |       | GPIO data bit 0                                                                                          |
|     |          | LOW    | 0     | GPIO0 is driven with a 0 (DIR0 = 1)                                                                      |
|     |          |        |       | GPIO0 is read as 0 (DIR0 = 0)                                                                            |
|     |          | HI     | 1     | GPIO0 is driven with a 1 (DIR0 = 1)                                                                      |
|     |          |        |       | GPIO0 is read as 1 (DIR0 = 0)                                                                            |

# A.4 HPI Registers

# A.4.1 General Purpose I/O Control Register (GPIOCR)

Figure A–25. General Purpose I/O Control Register (GPIOCR)



<sup>†</sup>Only available on devices with a second on-chip timer.

Table A–25. General Purpose I/O Control Register (GPIOCR) Field Values (HPI\_GPIOCR\_field\_symval)

| Bit  | field    | symval | Value | Description                                                                                                                                                                                                                 |
|------|----------|--------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | TOUT1    |        |       | <b>For C5402:</b> Timer1 output enable bit enables or disables the timer1 output on the HINT pin. The timer1 output is only available when the HPI-8 is disabled. This bit is reserved on devices that have only one timer. |
|      |          |        | 0     | The timer1 output is not available externally.                                                                                                                                                                              |
|      |          | MASK   | 1     | The timer1 output is driven on the HINT pin.                                                                                                                                                                                |
| 14-8 | reserved |        |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect.                                                                                                                    |
| 7-0  | DIR      |        |       | I/O pins direction field to configure the HD pins as inputs or outputs. Bit 7-Bit 0 corresponds to the direction for PIN7 to 0 respectively.                                                                                |
|      |          |        | 0     | The HD corresponding pin is configured as an input.                                                                                                                                                                         |
|      |          | MASK   | 1     | The HD corresponding pin is configured as an output. When the HPI-8 is enabled, this bit is forced to 0 and is not affected by writes.                                                                                      |

## A.4.2 General Purpose I/O Status Register (GPIOSR)

Figure A–26. General Purpose Status Register (GPIOSR)



**Legend:** R/W-x = Read/Write-Reset value

Table A–26. General Purpose I/O Status Register (GPIOSR) Field Values (HPI\_GPIOSR\_field\_symval)

| Bit  | field <sup>†</sup> | symval | Value | Description                                                                                                                                                                                                                                                                                                                                                                                                 |
|------|--------------------|--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | Ю                  |        |       | I/O pin status bit reflects the logic level on the HD pin. When the HD pin is configured as an input (DIR = 0 in GPIOCR), the IO bit latches the logic value (1 or 0) of the HD pin. Writes to the IO bit have no effect when the HD pin is configured as an input. When the HD pin is configured as an output (DIR = 1 in GPIOCR), the HD pin is driven to the logic level (1 or 0) written in the IO bit. |
|      |                    |        | 0     | The HD input is externally driven low, or the HD output is internally driven low. $ \\$                                                                                                                                                                                                                                                                                                                     |
|      |                    | MASK   | 1     | The HD input is externally driven high, or the HD output is internally driven high.                                                                                                                                                                                                                                                                                                                         |

<sup>†</sup> The GPIOSR register can be treated as a single field register (IO).

# A.4.3 HPI Control Register (HPIC) (for 5401, 5402, 5409, and 5410 only)

Figure A–27. HPI Control Register (HPIC) (for 5410)



**Note:** X = Any value can be written

Refer to the specific device data sheet for an explanation fo the fields of this register.

# A.5 Multichannel BSP (McBSP) Registers

## A.5.1 McBSP Serial Port Control Register (SPCR1)

Figure A–28. McBSP Serial Port Control Register 1 (SPCR1)

|   | 15    | 14    | 13  | 12  | 11       | 10    |          |       | 8 |
|---|-------|-------|-----|-----|----------|-------|----------|-------|---|
|   | DLB   | RJI   | JST | CLk | STP      |       | reserved |       |   |
|   | R/W-0 | RΛ    | V-0 | R/\ | W-0      |       | R/W-0    |       |   |
|   | 7     | 6     | 5   | 4   | 3        | 2     | 1        | 0     |   |
|   | DXENA | ABIS† | RIN | ITM | RSYNCERR | RFULL | RRDY     | RRST  |   |
| , | R/W-0 | R/W-0 | R/V | V-0 | R/W-0    | R-0   | R-0      | R/W-0 |   |

<sup>†</sup>Only available on specific devices.

Table A–27. McBSP Serial Port Control Register 1 (SPCR1) Field Values (MCBSP\_SPCR1\_field\_symval)

| Bit   | field    | symval  | Value | Description                                                                                              |
|-------|----------|---------|-------|----------------------------------------------------------------------------------------------------------|
| 15    | DLB      |         |       | Digital loop back mode enable bit.                                                                       |
|       |          | OFF     | 0     | Digital loop back mode is disabled.                                                                      |
|       |          | ON      | 1     | Digital loop back mode is enabled.                                                                       |
| 14-13 | RJUST    |         |       | Receive sign-extension and justification mode bit.                                                       |
|       |          | RZF     | 00    | Right-justify and zero-fill MSBs in DRR[1, 2].                                                           |
|       |          | RSE     | 01    | Right-justify and sign-extend MSBs in DRR[1, 2].                                                         |
|       |          | LZF     | 10    | Left-justify and zero-fill LSBs in DRR[1, 2].                                                            |
|       |          |         | 11    | Reserved                                                                                                 |
| 12-11 | CLKSTP   |         |       | Clock stop mode bit. In SPI mode, operates in conjunction with CLKXP bit of Pin Control Register (PCR).  |
|       |          | DISABLE | 0x    | Clock stop mode is disabled. Normal clocking for non-SPI mode.                                           |
|       |          |         |       | In SPI mode with data sampled on rising edge (CLKXP = 0):                                                |
|       |          | NODELAY | 10    | Clock starts with rising edge without delay.                                                             |
|       |          | DELAY   | 11    | Clock starts with rising edge with delay.                                                                |
|       |          |         |       | In SPI mode with data sampled on falling edge (CLKXP = 1):                                               |
|       |          | NODELAY | 10    | Clock starts with falling edge without delay.                                                            |
|       |          | DELAY   | 11    | Clock starts with falling edge with delay.                                                               |
| 10-8  | reserved |         |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect. |

Table A–27. McBSP Serial Port Control Register 1 (SPCR1) Field Values (MCBSP\_SPCR1\_field\_symval) (Continued)

| Bit | field    | symval   | Value | Description                                                                         |
|-----|----------|----------|-------|-------------------------------------------------------------------------------------|
| 7   | DXENA    |          |       | DX enabler bit.                                                                     |
|     |          | OFF      | 0     | DX enabler is off.                                                                  |
|     |          | ON       | 1     | DX enabler is on.                                                                   |
| 6   | ABIS     |          |       | For C5410, C5410A, and C5416: A-bis enable mode bit.                                |
|     |          | DISABLE  | 0     | A-bis mode is disabled.                                                             |
|     |          | ENABLE   | 1     | A-bis mode is enabled.                                                              |
| 5-4 | RINTM    |          |       | Receive interrupt (RINT) mode bit.                                                  |
|     |          | RRDY     | 00    | RINT is driven by RRDY (end-of-word) and end-of-frame in A-bis mode.                |
|     |          | EOS      | 01    | RINT is generated by end-of-block or end-of-frame in multichannel operation.        |
|     |          | FRM      | 10    | RINT is generated by a new frame synchronization.                                   |
|     |          | RSYNCERR | 11    | RINT is generated by RSYNCERR.                                                      |
| 3   | RSYNCERR |          |       | Receive synchronization error bit.                                                  |
|     |          | NO       | 0     | No synchronization error is detected.                                               |
|     |          | YES      | 1     | Synchronization error is detected.                                                  |
| 2   | RFULL    |          |       | Receive shift register full bit.                                                    |
|     |          | NO       | 0     | RBR[1, 2] is not in overrun condition.                                              |
|     |          | YES      | 1     | DRR[1, 2] is not read, RBR[1, 2] is full, and RSR[1, 2] is also full with new word. |
| 1   | RRDY     |          |       | Receiver ready bit.                                                                 |
|     |          | NO       | 0     | Receiver is not ready.                                                              |
|     |          | YES      | 1     | Receiver is ready with data to be read from DRR[1, 2].                              |
| 0   | RRST     |          |       | Receiver reset bit resets or enables the receiver.                                  |
|     |          | DISABLE  | 0     | The serial port receiver is disabled and in reset state.                            |
|     |          | ENABLE   | 1     | The serial port receiver is enabled.                                                |

# A.5.2 McBSP Serial Port Control Register 2 (SPCR2)

Figure A-29. McBSP Serial Port Control Register 2 (SPCR2)

| 15    |       |       |      |           | 10     | 9     | 8     |
|-------|-------|-------|------|-----------|--------|-------|-------|
|       |       |       | FREE | SOFT      |        |       |       |
|       |       | R/W-0 | )    |           |        | R/W-0 | R/W-0 |
| 7     | 6     | 5     | 4    | 3         | 2      | 1     | 0     |
| FRST  | GRST  | XINTM |      | XSYNCERR† | XEMPTY | XRDY  | XRST  |
| R/W-0 | R/W-0 | R/W-0 |      | R/W-0     | R-0    | R-0   | R/W-0 |

<sup>†</sup> Caution: Writing a 1 to this bit sets the error condition; thus, it is mainly used for testing purposes or if this operation is desired.

Table A–28. McBSP Serial Port Control Register 2 (SPCR2) Field Values (MCBSP\_SPCR2\_field\_symval)

| Bit   | field    | symval | Value | Description                                                                                                                                       |
|-------|----------|--------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-10 | reserved |        |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect.                                          |
| 9     | FREE     |        |       | Free-running enable mode bit.                                                                                                                     |
|       |          | NO     | 0     | Free-running mode is disabled.                                                                                                                    |
|       |          | YES    | 1     | Free-running mode is enabled.                                                                                                                     |
| 8     | SOFT     |        |       | Soft bit enable mode bit.                                                                                                                         |
|       |          | NO     | 0     | Soft mode is disabled.                                                                                                                            |
|       |          | YES    | 1     | Soft mode is enabled.                                                                                                                             |
| 7     | FRST     |        |       | Frame-sync generator reset.                                                                                                                       |
|       |          | RESET  | 0     | Frame-synchronization logic is reset. Frame-sync signal (FSG) is not generated by the sample-rate generator.                                      |
|       |          | FSG    | 1     | Frame-sync signal (FSG) is generated after (FPER + 1) number of CLKG clocks; that is, all frame counters are loaded with their programmed values. |
| 6     | GRST     |        |       | Sample-rate generator reset.                                                                                                                      |
|       |          | RESET  | 0     | Sample-rate generator is reset.                                                                                                                   |
|       |          | CLKG   | 1     | Sample-rate generator is taken out of reset. CLKG is driven as per programmed value in sample-rate generator registers (SRGR[1, 2]).              |

Table A–28. McBSP Serial Port Control Register 2 (SPCR2) Field Values (MCBSP\_SPCR2\_field\_symval) (Continued)

| Bit | field    | symval   | Value | Description                                                                       |
|-----|----------|----------|-------|-----------------------------------------------------------------------------------|
| 5-4 | XINTM    |          |       | Transmit interrupt (XINT) mode bit.                                               |
|     |          | XRDY     | 00    | XINT is driven by XRDY (end-of-word) and end-of-frame in A-bis mode.              |
|     |          | EOS      | 01    | XINT is generated by end-of-block or end-of-frame in multi-<br>channel operation. |
|     |          | FRM      | 10    | XINT is generated by a new frame synchronization.                                 |
|     |          | XSYNCERR | 11    | XINT is generated by XSYNCERR.                                                    |
| 3   | XSYNCERR |          |       | Transmit synchronization error bit.                                               |
|     |          | NO       | 0     | No synchronization error is detected.                                             |
|     |          | YES      | 1     | Synchronization error is detected.                                                |
| 2   | XEMPTY   |          |       | Transmit shift register empty bit.                                                |
|     |          | YES      | 0     | XSR[1, 2] is empty.                                                               |
|     |          | NO       | 1     | XSR[1, 2] is not empty.                                                           |
| 1   | XRDY     |          |       | Transmitter ready bit.                                                            |
|     |          | NO       | 0     | Transmitter is not ready.                                                         |
|     |          | YES      | 1     | Transmitter is ready for new data in DXR[1, 2].                                   |
| 0   | XRST     |          |       | Transmitter reset bit resets or enables the transmitter.                          |
|     |          | DISABLE  | 0     | Serial port transmitter is disabled and in reset state.                           |
|     |          | ENABLE   | 1     | Serial port transmitter is enabled.                                               |

# A.5.3 McBSP Pin Control Register (PCR)

Figure A-30. McBSP Pin Control Register (PCR)

| 15      | 14       | 13     | 12     | 11    | 10    | 9     | 8     |
|---------|----------|--------|--------|-------|-------|-------|-------|
| rese    | erved    | XIOEN  | RIOEN  | FSXM  | FSRM  | CLKXM | CLKRM |
| R/      | W-0      | R/W-0  | R/W-0  | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
| 7       | 6        | 5      | 4      | 3     | 2     | 1     | 0     |
| SCLKME† | CLKSSTAT | DXSTAT | DRSTAT | FSXP  | FSRP  | CLKXP | CLKRP |
| R/W-0   | R-0      | R-0    | R-0    | R/W-0 | R/W-0 | R/W-0 | R/W-0 |

<sup>&</sup>lt;sup>†</sup>Only available on specific devices with 128-channel selection capability.

Table A–29. McBSP Pin Control Register (PCR) Field Values (MCBSP\_PCR\_field\_symval)

| Bit   | field    | symval   | Value | Description                                                                                                                                                                                |
|-------|----------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-14 | reserved |          |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect.                                                                                   |
| 13    | XIOEN    |          |       | Transmit general-purpose I/O mode only when transmitter is disabled (XRST = 0 in SPCR2).                                                                                                   |
|       |          | SP       | 0     | DX, FSX, and CLKX pins are configured as serial port pins and do not function as general-purpose I/O pins.                                                                                 |
|       |          | GPIO     | 1     | DX pin is configured as general-purpose output pin; FSX and CLKX pins are configured as general-purpose I/O pins. These serial port pins do not perform serial port operations.            |
| 12    | RIOEN    |          |       | Receive general-purpose I/O mode only when receiver is disabled (RRST = $0$ in SPCR1).                                                                                                     |
|       |          | SP       | 0     | DR, FSR, CLKR, and CLKS pins are configured as serial port pins and do not function as general-purpose I/O pins.                                                                           |
|       |          | GPIO     | 1     | DR and CLKS pins are configured as general-purpose input pins; FSR and CLKR pins are configured as general-purpose I/O pins. These serial port pins do not perform serial port operations. |
| 11    | FSXM     |          |       | Transmit frame-synchronization mode bit.                                                                                                                                                   |
|       |          | EXTERNAL | 0     | Frame-synchronization signal is derived from an external source.                                                                                                                           |
|       |          | INTERNAL | 1     | Frame-synchronization signal is determined by FSGM bit in SRGR2.                                                                                                                           |

Table A–29. McBSP Pin Control Register (PCR) Field Values (MCBSP\_PCR\_field\_symval) (Continued)

| Bit | field  | symval   | Value | Description                                                                                                                                       |
|-----|--------|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 10  | FSRM   |          |       | Receive frame-synchronization mode bit.                                                                                                           |
|     |        | EXTERNAL | 0     | Frame-synchronization signal is derived from an external source. FSR is an input pin.                                                             |
|     |        | INTERNAL | 1     | Frame-synchronization signal is generated internally by the sample-rate generator. FSR is an output pin, except when GSYNC = 1 in SRGR2.          |
| 9   | CLKXM  |          |       | Transmitter clock mode bit.                                                                                                                       |
|     |        | INPUT    | 0     | CLKX is an input pin and is driven by an external clock.                                                                                          |
|     |        | OUTPUT   | 1     | CLKX is an output pin and is driven by the internal sample-rate generator.                                                                        |
|     |        |          |       | In SPI mode when CLKSTP in SPCR1 is a non-zero value:                                                                                             |
|     |        | INPUT    | 0     | McBSP is a slave and clock (CLKX) is driven by the SPI master in the system. CLKR is internally driven by CLKX.                                   |
|     |        | OUTPUT   | 1     | McBSP is a master and generates the clock (CLKX) to drive its receive clock (CLKR) and the shift clock of the SPI-compliant slaves in the system. |
| 8   | CLKRM  |          |       | Receiver clock mode bit.                                                                                                                          |
|     |        |          |       | Digital loop back mode is disabled (DLB = 0 in SPCR1):                                                                                            |
|     |        | INPUT    | 0     | CLKR is an input pin and is driven by an external clock.                                                                                          |
|     |        | OUTPUT   | 1     | CLKR is an output pin and is driven by the internal sample-rate generator.                                                                        |
|     |        |          |       | Digital loop back mode is enabled (DLB = 1 in SPCR1):                                                                                             |
|     |        | INPUT    | 0     | Receive clock (not the CLKR pin) is driven by transmit clock (CLKX) that is based on CLKXM bit. CLKR pin is in high-impedance state.              |
|     |        | OUTPUT   | 1     | CLKR is an output pin and is driven by the transmit clock. The transmit clock is based on CLKXM bit.                                              |
| 7   | SCLKME |          |       | For devices with 128-channel selection capability: Sample-rate clock mode extended enable bit.                                                    |
|     |        | NO       | 0     | BCLKR and BCLKX are not used by the sample-rate generator for external synchronization.                                                           |
|     |        | BCLK     | 1     | BCLKR and BCLKX are used by the sample-rate generator for external synchronization.                                                               |

Table A–29. McBSP Pin Control Register (PCR) Field Values (MCBSP\_PCR\_field\_symval) (Continued)

| Bit | field    | symval     | Value | Description                                                                                    |
|-----|----------|------------|-------|------------------------------------------------------------------------------------------------|
| 6   | CLKSSTAT |            |       | CLKS pin status reflects value on CLKS pin when configured as a general-purpose input pin.     |
|     |          | 0          | 0     | CLKS pin reflects a logic low.                                                                 |
|     |          | 1          | 1     | CLKS pin reflects a logic high.                                                                |
| 5   | DXSTAT   |            |       | DX pin status reflects value driven to DX pin when configured as a general-purpose output pin. |
|     |          | 0          | 0     | DX pin reflects a logic low.                                                                   |
|     |          | 1          | 1     | DX pin reflects a logic high.                                                                  |
| 4   | DRSTAT   |            |       | DR pin status reflects value on DR pin when configured as a general-purpose input pin.         |
|     |          | 0          | 0     | DR pin reflects a logic low.                                                                   |
|     |          | 1          | 1     | DR pin reflects a logic high.                                                                  |
| 3   | FSXP     |            |       | Transmit frame-synchronization polarity bit.                                                   |
|     |          | ACTIVEHIGH | 0     | Transmit frame-synchronization pulse is active high.                                           |
|     |          | ACTIVELOW  | 1     | Transmit frame-synchronization pulse is active low.                                            |
| 2   | FSRP     |            |       | Receive frame-synchronization polarity bit.                                                    |
|     |          | ACTIVEHIGH | 0     | Receive frame-synchronization pulse is active high.                                            |
|     |          | ACTIVELOW  | 1     | Receive frame-synchronization pulse is active low.                                             |
| 1   | CLKXP    |            |       | Transmit clock polarity bit.                                                                   |
|     |          | RISING     | 0     | Transmit data sampled on rising edge of CLKX.                                                  |
|     |          | FALLING    | 1     | Transmit data sampled on falling edge of CLKX.                                                 |
| 0   | CLKRP    |            |       | Receive clock polarity bit.                                                                    |
|     |          | FALLING    | 0     | Receive data sampled on falling edge of CLKR.                                                  |
|     |          | RISING     | 1     | Receive data sampled on rising edge of CLKR.                                                   |

## A.5.4 Receive Control Register 1 (RCR1)

Figure A-31. Receive Control Register 1 (RCR1)



Table A–30. Receive Control Register 1 (RCR1) Field Values (MCBSP\_RCR1\_field\_symval)

| Bit  | field    | symval    | Value | Description                                                                                              |
|------|----------|-----------|-------|----------------------------------------------------------------------------------------------------------|
| 15   | reserved |           |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect. |
| 14-8 | RFRLEN1  | OF(value) | 0-127 | Specifies the number of words (length) in the receive frame.                                             |
| 7-5  | RWDLEN1  |           |       | Specifies the number of bits (length) in the receive word.                                               |
|      |          | 8BIT      | 000   | Receive word length is 8 bits.                                                                           |
|      |          | 12BIT     | 001   | Receive word length is 12 bits.                                                                          |
|      |          | 16BIT     | 010   | Receive word length is 16 bits.                                                                          |
|      |          | 20BIT     | 011   | Receive word length is 20 bits.                                                                          |
|      |          | 24BIT     | 100   | Receive word length is 24 bits.                                                                          |
|      |          | 32BIT     | 101   | Receive word length is 32 bits.                                                                          |
|      |          |           | 110   | Reserved                                                                                                 |
|      |          |           | 111   | Reserved                                                                                                 |
| 4-0  | reserved |           |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect. |

# A.5.5 Receive Control Register 2 (RCR2)

Figure A-32. Receive Control Register 2 (RCR2)



Table A–31. Receive Control Register 2 (RCR2) Field Values (MCBSP\_RCR2\_field\_symval)

| Bit  | field    | symval    | Value | Description                                                                                                         |
|------|----------|-----------|-------|---------------------------------------------------------------------------------------------------------------------|
| 15   | RPHASE   |           |       | Receive phases bit.                                                                                                 |
|      |          | SINGLE    | 0     | Single-phase frame                                                                                                  |
|      |          | DUAL      | 1     | Dual-phase frame                                                                                                    |
| 14-8 | RFRLEN2  | OF(value) | 0-127 | Specifies the number of words (length) in the receive frame.                                                        |
| 7-5  | RWDLEN2  |           |       | Specifies the number of bits (length) in the receive word.                                                          |
|      |          | 8BIT      | 000   | Receive word length is 8 bits.                                                                                      |
|      |          | 12BIT     | 001   | Receive word length is 12 bits.                                                                                     |
|      |          | 16BIT     | 010   | Receive word length is 16 bits.                                                                                     |
|      |          | 20BIT     | 011   | Receive word length is 20 bits.                                                                                     |
|      |          | 24BIT     | 100   | Receive word length is 24 bits.                                                                                     |
|      |          | 32BIT     | 101   | Receive word length is 32 bits.                                                                                     |
|      |          |           | 110   | Reserved                                                                                                            |
|      |          |           | 111   | Reserved                                                                                                            |
| 4-3  | RCOMPAND |           |       | Receive companding mode. Modes other than 00 are only enabled when RWDLEN[1, 2] bit is 000 (indicating 8-bit data). |
|      |          | MSB       | 00    | No companding, data transfer starts with MSB first.                                                                 |
|      |          | 8BITLSB   | 01    | No companding, 8-bit data transfer starts with LSB first.                                                           |
|      |          | ULAW      | 10    | Compand using $\mu$ -law for receive data.                                                                          |
| -    |          | ALAW      | 11    | Compand using A-law for receive data.                                                                               |

Table A–31. Receive Control Register 2 (RCR2) Field Values (MCBSP\_RCR2\_field\_symval) (Continued)

| Bit | field   | symval | Value | Description                                                                       |
|-----|---------|--------|-------|-----------------------------------------------------------------------------------|
| 2   | RFIG    |        |       | Receive frame ignore bit.                                                         |
|     |         | YES    | 0     | Receive frame-synchronization pulses after the first pulse restarts the transfer. |
|     |         | NO     | 1     | Receive frame-synchronization pulses after the first pulse are ignored.           |
| 1-0 | RDATDLY |        |       | Receive data delay bit.                                                           |
|     |         | 0BIT   | 00    | 0-bit data delay                                                                  |
|     |         | 1BIT   | 01    | 1-bit data delay                                                                  |
|     |         | 2BIT   | 10    | 2-bit data delay                                                                  |
|     |         |        | 11    | Reserved                                                                          |

## A.5.6 Transmit Control Register 1 (XCR1)

Figure A-33. Transmit Control Register 1 (XCR1)



Table A–32. Transmit Control Register 1 (XCR1) Field Values (MCBSP\_XCR1\_field\_symval)

| Bit  | field    | symval    | Value | Description                                                                                              |
|------|----------|-----------|-------|----------------------------------------------------------------------------------------------------------|
| 15   | reserved |           |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect. |
| 14-8 | XFRLEN1  | OF(value) | 0-127 | Specifies the number of words (length) in the transmit frame.                                            |
| 7-5  | XWDLEN1  |           |       | Specifies the number of bits (length) in the transmit word.                                              |
|      |          | 8BIT      | 000   | Transmit word length is 8 bits.                                                                          |
|      |          | 12BIT     | 001   | Transmit word length is 12 bits.                                                                         |
|      |          | 16BIT     | 010   | Transmit word length is 16 bits.                                                                         |

Table A–32. Transmit Control Register 1 (XCR1) Field Values (MCBSP\_XCR1\_field\_symval)

| Bit | field    | symval | Value | Description                                                                                              |
|-----|----------|--------|-------|----------------------------------------------------------------------------------------------------------|
|     |          | 20BIT  | 011   | Transmit word length is 20 bits.                                                                         |
|     |          | 24BIT  | 100   | Transmit word length is 24 bits.                                                                         |
|     |          | 32BIT  | 101   | Transmit word length is 32 bits.                                                                         |
|     |          |        | 110   | Reserved                                                                                                 |
|     |          |        | 111   | Reserved                                                                                                 |
| 4-0 | reserved |        |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect. |

## A.5.7 Transmit Control Register 2 (XCR2)

Figure A-34. Transmit Control Register 2 (XCR2)



Table A–33. Transmit Control Register 2 (XCR2) Field Values (MCBSP XCR2 field symval)

| Bit  | field   | symval    | Value | Description                                                   |  |
|------|---------|-----------|-------|---------------------------------------------------------------|--|
| 15   | XPHASE  |           |       | Transmit phases bit.                                          |  |
|      |         | SINGLE    | 0     | Single-phase frame                                            |  |
|      |         | DUAL      | 1     | Dual-phase frame                                              |  |
| 14-8 | XFRLEN2 | OF(value) | 0-127 | Specifies the number of words (length) in the transmit frame. |  |
| 7-5  | XWDLEN2 |           |       | Specifies the number of bits (length) in the transmit word.   |  |
|      |         | 8BIT      | 000   | Transmit word length is 8 bits.                               |  |
|      |         | 12BIT     | 001   | Transmit word length is 12 bits.                              |  |
|      |         | 16BIT     | 010   | Transmit word length is 16 bits.                              |  |
|      |         | 20BIT     | 011   | Transmit word length is 20 bits.                              |  |
|      |         | 24BIT     | 100   | Transmit word length is 24 bits.                              |  |

Table A–33. Transmit Control Register 2 (XCR2) Field Values (MCBSP\_XCR2\_field\_symval) (Continued)

| Bit | field    | symval  | Value | Description                                                                                                          |
|-----|----------|---------|-------|----------------------------------------------------------------------------------------------------------------------|
|     |          | 32BIT   | 101   | Transmit word length is 32 bits.                                                                                     |
|     |          |         | 110   | Reserved                                                                                                             |
|     |          |         | 111   | Reserved                                                                                                             |
| 4-3 | XCOMPAND |         |       | Transmit companding mode. Modes other than 00 are only enabled when XWDLEN[1, 2] bit is 000 (indicating 8-bit data). |
|     |          | MSB     | 00    | No companding, data transfer starts with MSB first.                                                                  |
|     |          | 8BITLSB | 01    | No companding, 8-bit data transfer starts with LSB first.                                                            |
|     |          | ULAW    | 10    | Compand using $\mu$ -law for transmit data.                                                                          |
|     |          | ALAW    | 11    | Compand using A-law for transmit data.                                                                               |
| 2   | XFIG     |         |       | Transmit frame ignore bit.                                                                                           |
|     |          | YES     | 0     | Transmit frame-synchronization pulses after the first pulse restarts the transfer.                                   |
|     |          | NO      | 1     | Transmit frame-synchronization pulses after the first pulse are ignored.                                             |
| 1-0 | XDATDLY  |         |       | Transmit data delay bit.                                                                                             |
|     |          | 0BIT    | 00    | 0-bit data delay                                                                                                     |
|     |          | 1BIT    | 01    | 1-bit data delay                                                                                                     |
|     |          | 2BIT    | 10    | 2-bit data delay                                                                                                     |
|     |          |         | 11    | Reserved                                                                                                             |

### A.5.8 Sample Rate Generator Register 1 (SRGR1)

Figure A-35. Sample Rate Generator Register 1 (SRGR1)



**Legend:** R/W-x = Read/Write-Reset value

Table A–34. Sample Rate Generator Register 1 (SRGR1) Field Values (MCBSP\_SRGR1\_field\_symval)

| Bit  | field  | symval    | Value | Description                                                                                                 |
|------|--------|-----------|-------|-------------------------------------------------------------------------------------------------------------|
| 15-8 | FWID   | OF(value) | 0-255 | The value plus 1 specifies the width of the frame-sync pulse (FSG) during its active period.                |
| 7-0  | CLKGDV | OF(value) | 0-255 | The value is used as the divide-down number to generate the required sample-rate generator clock frequency. |

### A.5.9 Sample Rate Generator Register 2 (SRGR2)

Figure A–36. Sample Rate Generator Register 2 (SRGR2)



Table A–35. Sample Rate Generator Register 2 (SRGR2) Field Values (MCBSP\_SRGR2\_field\_symval)

| Bit | field | symval | Value | Description                                                                                                                                                                                                                                                                                                 |
|-----|-------|--------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15  | GSYNC |        |       | Sample-rate generator clock synchronization bit only used when the external clock (CLKS) drives the sample-rate generator clock (CLKSM = 0).                                                                                                                                                                |
|     |       | FREE   | 0     | The sample-rate generator clock (CLKG) is free running.                                                                                                                                                                                                                                                     |
|     |       | SYNC   | 1     | The sample-rate generator clock (CLKG) is running; however, CLKG is resynchronized and frame-sync signal (FSG) is generated only after detecting the receive frame-synchronization signal (FSR). Also, frame period (FPER) is a don't care because the period is dictated by the external frame-sync pulse. |

Table A–35. Sample Rate Generator Register 2 (SRGR2) Field Values (MCBSP\_SRGR2\_field\_symval) (Continued)

| Bit  | field | symval             | Value  | Description                                                                                                                             |
|------|-------|--------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------|
| 14   | CLKSP |                    |        | CLKS polarity clock edge select bit only used when the external clock (CLKS) drives the sample-rate generator clock (CLKSM = 0).        |
|      |       | RISING             | 0      | Rising edge of CLKS generates CLKG and FSG.                                                                                             |
|      |       | FALLING            | 1      | Falling edge of CLKS generates CLKG and FSG.                                                                                            |
| 13   | CLKSM |                    |        | McBSP sample-rate generator clock mode bit.                                                                                             |
|      |       | CLKS               | 0      | Sample-rate generator clock derived from the CLKS pin.                                                                                  |
|      |       | INTERNAL           | 1      | Sample-rate generator clock derived from CPU clock.                                                                                     |
| 12   | FSGM  |                    |        | Sample-rate generator transmit frame-synchronization mode bit used when $FSXM = 1$ in $PCR$ .                                           |
|      |       | DXR2XSR            | 0      | Transmit frame-sync signal (FSX) due to DXR[1, 2]-to-XSR[1, 2] copy. When FSGM = 0, FWID bit in SRGR1 and FPER bit are ignored.         |
|      |       | FSG                | 1      | Transmit frame-sync signal (FSX) driven by the sample-rate generator frame-sync signal (FSG).                                           |
| 11-0 | FPER  | OF( <i>value</i> ) | 0-4095 | The value plus 1 specifies when the next frame-sync signal becomes active. Range: 1 to 4096 sample-rate generator clock (CLKG) periods. |

# A.5.10 Multichannel Control Register 1 (MCR1)

Figure A-37. Multichannel Control Register 1 (MCR1)

| 15     |        |      |       | 10 | 9        | 8      |
|--------|--------|------|-------|----|----------|--------|
|        | rese   | rved |       |    | RMCME†   | RPBBLK |
|        | RΛ     | N-0  |       |    | R/W-0    | R/W-0  |
| 7      | 6 5    | 4    |       | 2  | 1        | 0      |
| RPBBLK | RPABLK |      | RCBLK |    | reserved | RMCM   |
| R/W-0  | R/W-0  |      | R-0   |    | R/W-0    | R/W-0  |

<sup>&</sup>lt;sup>†</sup>Only available on specific devices that provide 128-channel selection capability.

Table A–36. Multichannel Control Register 1 (MCR1) Field Values (MCBSP\_MCR1\_field\_symval)

| Bit   | field    | symval | Value | Description                                                                                              |
|-------|----------|--------|-------|----------------------------------------------------------------------------------------------------------|
| 15-10 | reserved |        |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect. |
| 9     | RMCME    |        |       | For devices with 128-channel selection capability: Receive 128-channel selection enable bit.             |
|       |          | NO     | 0     | Normal 32-channel selection is enabled.                                                                  |
|       |          | АТОН   | 1     | Six additional registers (RCERC-RCERH) are used to enable 128-channel selection.                         |
| 8-7   | RPBBLK   |        |       | Receive partition B block bit. Enables 16 contiguous channels in each block.                             |
|       |          | SF1    | 00    | Block 1. Channel 16 to channel 31                                                                        |
|       |          | SF3    | 01    | Block 3. Channel 48 to channel 63                                                                        |
|       |          | SF5    | 10    | Block 5. Channel 80 to channel 95                                                                        |
|       |          | SF7    | 11    | Block 7. Channel 112 to channel 127                                                                      |
| 6-5   | RPABLK   |        |       | Receive partition A block bit. Enables 16 contiguous channels in each block.                             |
|       |          | SF0    | 00    | Block 0. Channel 0 to channel 15                                                                         |
|       |          | SF2    | 01    | Block 2. Channel 32 to channel 47                                                                        |
|       |          | SF4    | 10    | Block 4. Channel 64 to channel 79                                                                        |
|       |          | SF6    | 11    | Block 6. Channel 96 to channel 111                                                                       |
| 4-2   | RCBLK    |        |       | Receive current block bit.                                                                               |
|       |          | SF0    | 000   | Block 0. Channel 0 to channel 15                                                                         |
|       |          | SF1    | 001   | Block 1. Channel 16 to channel 31                                                                        |

Table A–36. Multichannel Control Register 1 (MCR1) Field Values (MCBSP\_MCR1\_field\_symval) (Continued)

| Bit | field    | symval    | Value | Description                                                                                                            |
|-----|----------|-----------|-------|------------------------------------------------------------------------------------------------------------------------|
|     |          | SF2       | 010   | Block 2. Channel 32 to channel 47                                                                                      |
|     |          | SF3       | 011   | Block 3. Channel 48 to channel 63                                                                                      |
|     |          | SF4       | 100   | Block 4. Channel 64 to channel 79                                                                                      |
|     | RCBLK    | SF5       | 101   | Block 5. Channel 80 to channel 95                                                                                      |
|     |          | SF6       | 110   | Block 6. Channel 96 to channel 111                                                                                     |
|     |          | SF7       | 111   | Block 7. Channel 112 to channel 127                                                                                    |
| 1   | reserved |           |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect.               |
| 0   | RMCM     |           |       | Receive multichannel selection enable bit.                                                                             |
|     |          | CHENABLE  | 0     | All 128 channels enabled.                                                                                              |
|     |          | ELDISABLE | 1     | All channels disabled by default. Required channels are selected by enabling RP[A, B]BLK and RCER[A, B] appropriately. |

### A.5.11 Multichannel Control Register 2 (MCR2)

Figure A-38. Multichannel Control Register 2 (MCR2)



<sup>&</sup>lt;sup>†</sup> Only available on specific devices that provide 128-channel selection capability.

Table A–37. Multichannel Control Register 2 (MCR2) Field Values (MCBSP\_MCR2\_field\_symval)

| Bit   | field    | symval | Value | Description                                                                                              |
|-------|----------|--------|-------|----------------------------------------------------------------------------------------------------------|
| 15-10 | reserved |        |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect. |
| 9     | XMCME    |        |       | For devices with 128-channel selection capability: Transmit 128-channel selection enable bit.            |
|       |          | NO     | 0     | Normal 32-channel selection is enabled.                                                                  |
|       |          | АТОН   | 1     | Six additional registers (XCERC-XCERH) are used to enable 128-channel selection.                         |
| 8-7   | XPBBLK   |        |       | Transmit partition B block bit. Enables 16 contiguous channels in each block.                            |
|       |          | SF1    | 00    | Block 1. Channel 16 to channel 31                                                                        |
|       |          | SF3    | 01    | Block 3. Channel 48 to channel 63                                                                        |
|       |          | SF5    | 10    | Block 5. Channel 80 to channel 95                                                                        |
|       |          | SF7    | 11    | Block 7. Channel 112 to channel 127                                                                      |
| 6-5   | XPABLK   |        |       | Transmit partition A block bit. Enables 16 contiguous channels in each block.                            |
|       |          | SF0    | 00    | Block 0. Channel 0 to channel 15                                                                         |
|       |          | SF2    | 01    | Block 2. Channel 32 to channel 47                                                                        |
|       |          | SF4    | 10    | Block 4. Channel 64 to channel 79                                                                        |
|       |          | SF6    | 11    | Block 6. Channel 96 to channel 111                                                                       |
| 4-2   | XCBLK    |        |       | Transmit current block bit.                                                                              |
|       |          | SF0    | 000   | Block 0. Channel 0 to channel 15                                                                         |
|       |          | SF1    | 001   | Block 1. Channel 16 to channel 31                                                                        |
|       |          | SF2    | 010   | Block 2. Channel 32 to channel 47                                                                        |
|       |          | SF3    | 011   | Block 3. Channel 48 to channel 63                                                                        |
|       |          | SF4    | 100   | Block 4. Channel 64 to channel 79                                                                        |
|       |          | SF5    | 101   | Block 5. Channel 80 to channel 95                                                                        |
|       |          | SF6    | 110   | Block 6. Channel 96 to channel 111                                                                       |
|       |          | SF7    | 111   | Block 7. Channel 112 to channel 127                                                                      |

Table A–37. Multichannel Control Register 2 (MCR2) Field Values (MCBSP\_MCR2\_field\_symval) (Continued)

| Bit | field | symval   | Value | Description                                                                                                                                                                                                                                                                    |
|-----|-------|----------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1-0 | XMCM  |          |       | Transmit multichannel selection enable bit.                                                                                                                                                                                                                                    |
|     |       | ENNOMASK | 00    | All channels enabled without masking (DX is always driven during transmission of data $\sp \uparrow$ ).                                                                                                                                                                        |
|     |       | DISXP    | 01    | All channels disabled and, therefore, masked by default. Required channels are selected by enabling XP[A, B]BLK and XCER[A, B] appropriately. Also, these selected channels are not masked and, therefore, DX is always driven.                                                |
|     |       | ENMASK   | 10    | All channels enabled, but masked. Selected channels enabled using XP[A, B]BLK and XCER[A, B] are unmasked.                                                                                                                                                                     |
|     |       | DISRP    | 11    | All channels disabled and, therefore, masked by default. Required channels are selected by enabling RP[A, B]BLK and RCER[A, B] appropriately. Selected channels can be unmasked by RP[A, B]BLK and XCER[A, B]. This mode is used for symmetric transmit and receive operation. |

<sup>†</sup> DX is masked or driven to a high-impedance state during (a) interpacket intervals, (b) when a channel is masked regardless of whether it is enabled, or (c) when a channel is disabled.

#### A.5.12 Receive Channel Enable Register (RCERn)

Figure A-39. Receive Channel Enable Register (RCERn)

| 15    | 14    | 13    | 12    | 11    | 10    | 9     | 8     |
|-------|-------|-------|-------|-------|-------|-------|-------|
| RCE15 | RCE14 | RCE13 | RCE12 | RCE11 | RCE10 | RCE9  | RCE8  |
| R/W-0 |
| 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| RCE7  | RCE6  | RCE5  | RCE4  | RCE3  | RCE2  | RCE1  | RCE0  |
|       | 11020 | 11020 | 1.021 |       |       | 11021 |       |

Table A–38. Receive Channel Enable Register (RCERn) Field Values (MCBSP\_RCERn\_field\_symval)

| Bit  | field <sup>†</sup> | symval    | Value   | Description                                                                                                                                                                                                                         |
|------|--------------------|-----------|---------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                    |           |         | For devices with only 32-channel selection capability:                                                                                                                                                                              |
| 15-0 | RCEA               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) reception of the $n$ th channel within the 16-channel-wide block in partition A. The 16-channel-wide block is selected by the RPABLK bit in MCR1. |

<sup>&</sup>lt;sup>†</sup> The register is also treated as having a single field (RCEn).

Table A–38. Receive Channel Enable Register (RCERn) Field Values (MCBSP\_RCERn\_field\_symval) (Continued)

| Bit  | field <sup>†</sup> | symval    | Value   | Description                                                                                                                                                                                                                              |
|------|--------------------|-----------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | RCEB               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) reception of the <i>n</i> th channel within the 16-channel-wide block in partition B. The 16-channel-wide block is selected by the RPBBLK bit in MCR1. |
|      |                    |           |         | For devices with 128-channel selection capability:                                                                                                                                                                                       |
| 15-0 | RCEA               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) reception of channels 0-15 within the 16-channel-wide block.                                                                                           |
| 15-0 | RCEB               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) reception of channels 16-31 within the 16-channel-wide block.                                                                                          |
| 15-0 | RCEC               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) reception of channels $32-47$ within the $16$ -channel-wide block.                                                                                     |
| 15-0 | RCED               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) reception of channels $48-63$ within the $16$ -channel-wide block.                                                                                     |
| 15-0 | RCEE               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) reception of channels $64-79$ within the $16$ -channel-wide block.                                                                                     |
| 15-0 | RCEF               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) reception of channels 80-95 within the 16-channel-wide block.                                                                                          |
| 15-0 | RCEG               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) reception of channels 96-111 within the 16-channel-wide block.                                                                                         |
| 15-0 | RCEH               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) reception of channels 112-127 within the 16-channel-wide block.                                                                                        |

<sup>&</sup>lt;sup>†</sup>The register is also treated as having a single field (RCEn).

### A.5.13 Transmit Channel Enable Register (XCERn)

Figure A-40. Transmit Channel Enable Register (XCERn)

|   | 15    | 14    | 13    | 12    | 11    | 10    | 9     | 8     |
|---|-------|-------|-------|-------|-------|-------|-------|-------|
|   | XCE15 | XCE14 | XCE13 | XCE12 | XCE11 | XCE10 | XCE9  | XCE8  |
|   | R/W-0 |
|   | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|   | XCE7  | XCE6  | XCE5  | XCE4  | XCE3  | XCE2  | XCE1  | XCE0  |
| , | R/W-0 |

Table A–39. Transmit Channel Enable Register (XCERn) Field Values (MCBSP\_XCERn\_field\_symval)

| Bit  | field <sup>†</sup> | symval    | Value   | Description                                                                                                                                                                                                                                 |
|------|--------------------|-----------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      |                    |           |         | For devices with only 32-channel selection capability:                                                                                                                                                                                      |
| 15-0 | XCEA               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) transmission of the <i>n</i> th channel within the 16-channel-wide block in partition A. The 16-channel-wide block is selected by the XPABLK bit in MCR2. |
| 15-0 | XCEB               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) transmission of the <i>n</i> th channel within the 16-channel-wide block in partition B. The 16-channel-wide block is selected by the XPBBLK bit in MCR2. |
|      |                    |           |         | For devices with 128-channel selection capability:                                                                                                                                                                                          |
| 15-0 | XCEA               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) transmission of channels 0-15 within the 16-channel-wide block.                                                                                           |
| 15-0 | XCEB               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) transmission of channels 16-31 within the 16-channel-wide block.                                                                                          |
| 15-0 | XCEC               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) transmission of channels 32-47 within the 16-channel-wide block.                                                                                          |
| 15-0 | XCED               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) transmission of channels $48-63$ within the 16-channel-wide block.                                                                                        |
| 15-0 | XCEE               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) transmission of channels 64-79 within the 16-channel-wide block.                                                                                          |

<sup>&</sup>lt;sup>†</sup> The registers are also treated as having a single field (XCEn).

Table A–39. Transmit Channel Enable Register (XCERn) Field Values (MCBSP\_XCERn\_field\_symval) (Continued)

| Bit  | field <sup>†</sup> | symval    | Value   | Description                                                                                                                                          |
|------|--------------------|-----------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-0 | XCEF               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) transmission of channels 80-95 within the 16-channel-wide block.   |
| 15-0 | XCEG               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) transmission of channels 96-111 within the 16-channel-wide block.  |
| 15-0 | XCEH               | OF(value) | 0-FFFFh | A 16-bit unsigned value used to disable (bit value = 0) or enable (bit value = 1) transmission of channels 112-127 within the 16-channel-wide block. |

<sup>&</sup>lt;sup>†</sup>The registers are also treated as having a single field (XCEn).

## A.6 PLL Registers (CLKMD)

Figure A-41. Clock Mode Register (CLKMD)

| 15 | 5 12     | 11     | 10       |         |            |
|----|----------|--------|----------|---------|------------|
|    | PLLMUL   | PLLDIV |          | PLLCOUN | Г          |
|    | R/W-0    | R/W-0  |          | R/W-0   |            |
|    |          | 3      | 2        | 1       | 0          |
|    | PLLCOUNT |        | PLLONOFF | PLLNDIV | PLLSTATUS† |
|    | R/W-0    |        | R/W-0    | R/W-0   | R-0        |

<sup>†</sup> When in DIV mode (PLLSTATUS is low), PLLMUL, PLLDIV, PLLCOUNT, and PLLONOFF are don't cares, and their contents are indeterminate.

Table A–40. Clock Mode Register (CLKMD) Field Values (PLL\_CLKMD\_field\_symval)

| Bit   | field    | symval             | Value | Description                                                                                                                                                                                                                                                                                                                                                       |
|-------|----------|--------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12 | PLLMUL   | OF(value)          | 0-15  | This PLL multiplier value defines the frequency multiplier in conjunction with the PLLDIV and PLLNDIV bits.                                                                                                                                                                                                                                                       |
| 11    | PLLDIV   |                    |       | PLL divider. Defines the frequency multiplier in conjunction with the PLLMUL and PLLNDIV bits.                                                                                                                                                                                                                                                                    |
|       |          | OFF                | 0     |                                                                                                                                                                                                                                                                                                                                                                   |
|       |          | ON                 | 1     |                                                                                                                                                                                                                                                                                                                                                                   |
| 10-3  | PLLCOUNT | OF( <i>value</i> ) | 0-255 | This PLL counter value specifies the number of input clock cycles (in increments of 16 cycles) for the PLL lock timer to count before the PLL begins clocking the processor after the PLL is started. The PLL counter is a down-counter, which is driven by the input clock divided by 16; therefore, for every 16 input clocks, the PLL counter decrements by 1. |
|       |          |                    |       | The PLL counter can be used to ensure that the processor is not clocked until the PLL is locked, so that only valid clock signals are sent to the device.                                                                                                                                                                                                         |
| 2     | PLLONOFF |                    |       | PLL on/off mode bit. Enables or disables the PLL part of the clock generator in conjunction with the PLLNDIV bit.                                                                                                                                                                                                                                                 |
|       |          | OFF                | 0     | PLL is off unless PLLNDIV = 1.                                                                                                                                                                                                                                                                                                                                    |
|       |          | ON                 | 1     | PLL is on regardless of the PLLNDIV bit status.                                                                                                                                                                                                                                                                                                                   |

Table A–40. Clock Mode Register (CLKMD) Field Values (PLL\_CLKMD\_field\_symval) (Continued)

| Bit | field     | symval | Value | Description                                                                                                                                                                                                    |
|-----|-----------|--------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1   | PLLNDIV   |        |       | PLL clock generator mode select bit. Determines whether the clock generator works in PLL mode or in divider (DIV) mode, thus defining the frequency multiplier in conjunction with the PLLMUL and PLLDIV bits. |
|     |           | OFF    | 0     | DIV mode is used.                                                                                                                                                                                              |
|     |           | ON     | 1     | PLL mode is used.                                                                                                                                                                                              |
| 0   | PLLSTATUS |        |       | This read-only bit indicates the mode that the clock generator is operating.                                                                                                                                   |
|     |           |        | 0     | Divider (DIV) mode                                                                                                                                                                                             |
|     |           |        | 1     | PLL mode                                                                                                                                                                                                       |

## A.7 Timer Registers

#### A.7.1 Timer Control Register (TCR)

Figure A-42. Timer Control Register (TCR)



Table A–41. Timer Control Register (TCR) Field Values (TIMER\_TCR\_field\_symval)

| Bit   | field    | symval   | Value | Description                                                                                                                                                                                                                                                                         |
|-------|----------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12 | reserved |          |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect.                                                                                                                                                                            |
| 11    | SOFT     |          |       | Used in conjunction with FREE bit to determine the state of the timer when a breakpoint is encountered in the HLL debugger. When FREE bit is cleared, SOFT bit selects the timer mode.                                                                                              |
|       |          | BRKPTNOW | 0     | The timer stops immediately.                                                                                                                                                                                                                                                        |
|       |          | WAITZERO | 1     | The timer stops when the counter decrements to 0.                                                                                                                                                                                                                                   |
| 10    | FREE     |          |       | Used in conjunction with SOFT bit to determine the state of the timer when a breakpoint is encountered in the HLL debugger. When FREE bit is cleared, SOFT bit selects the timer mode.                                                                                              |
|       |          | WITHSOFT | 0     | SOFT bit selects the timer mode.                                                                                                                                                                                                                                                    |
|       |          | NOSOFT   | 1     | The timer runs free regardless of SOFT bit status.                                                                                                                                                                                                                                  |
| 9-6   | PSC      |          |       | Timer prescalar counter. This read-only bit specifies the count for the on-chip timer when in direct mode (PREMD bit is cleared in the TSCR). When PSC bit is decremented past 0 or the timer is reset, PSC bit is loaded with the contents of TDDR bit and the TIM is decremented. |
| 5     | TRB      |          |       | Timer reload bit. TRB bit is always read as a 0.                                                                                                                                                                                                                                    |
|       |          | NORESET  | 0     | The on-chip timer is not reset.                                                                                                                                                                                                                                                     |
|       |          | RESET    | 1     | The on-chip timer is reset. When TRB bit is set, the TIM is loaded with the value in the PRD and PSC bit is loaded with the value in TDDR bit when in direct mode (PREMD bit is cleared in the TSCR).                                                                               |

Table A–41. Timer Control Register (TCR) Field Values (TIMER\_TCR\_field\_symval) (Continued)

| Bit | field | symval    | Value | Description                                                                                                                                                             |
|-----|-------|-----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4   | TSS   |           |       | Timer stop status bit. Stops or starts the on-chip timer. At reset, TSS bit is cleared and the timer immediately starts timing.                                         |
|     |       | START     | 0     | The timer is started.                                                                                                                                                   |
|     |       | STOP      | 1     | The timer is stopped.                                                                                                                                                   |
| 3-0 | TDDR  |           |       | The timer prescalar for the on-chip timer.                                                                                                                              |
|     |       |           |       | In prescalar direct mode (PREMD = 0 in TSCR):                                                                                                                           |
|     |       | OF(value) | 0-15  | This value specifies the prescalar count for the on-chip timer. When PSC bit is decremented past 0, PSC bit is loaded with this TDDR content.                           |
|     |       |           |       | In prescalar indirect mode (PREMD = 1 in TSCR):                                                                                                                         |
|     |       | OF(value) |       | This value relates to an indirect prescalar count, up to 65535, for the on-chip timer. When PSC bit is decremented past 0, PSC bit is loaded with this prescalar value. |
|     |       |           | 0000  | Prescalar value: 0001h                                                                                                                                                  |
|     |       |           | 0001  | Prescalar value: 0003h                                                                                                                                                  |
|     |       |           | 0010  | Prescalar value: 0007h                                                                                                                                                  |
|     |       |           | 0011  | Prescalar value: 000Fh                                                                                                                                                  |
|     |       |           | 0100  | Prescalar value: 001Fh                                                                                                                                                  |
|     |       |           | 0101  | Prescalar value: 003Fh                                                                                                                                                  |
|     |       |           | 0110  | Prescalar value: 007Fh                                                                                                                                                  |
|     |       |           | 0111  | Prescalar value: 00FFh                                                                                                                                                  |
|     |       |           | 1000  | Prescalar value: 01FFh                                                                                                                                                  |
|     |       |           | 1001  | Prescalar value: 03FFh                                                                                                                                                  |
|     |       |           | 1010  | Prescalar value: 07FFh                                                                                                                                                  |
|     |       |           | 1011  | Prescalar value: 0FFFh                                                                                                                                                  |
|     |       |           | 1100  | Prescalar value: 1FFFh                                                                                                                                                  |
|     |       |           | 1101  | Prescalar value: 3FFFh                                                                                                                                                  |
|     |       |           | 1110  | Prescalar value: 7FFFh                                                                                                                                                  |
|     |       |           | 1111  | Prescalar value: FFFFh                                                                                                                                                  |

#### A.7.2 Timer Secondary Control Register (TSCR)

Figure A-43. Timer Secondary Control Register (TSCR) — C5440, C5441, and C5471



**Legend:** R/W-x = Read/Write-Reset value

Table A–42. Timer Secondary Control Register (TSCR) Field Values (TIMER\_TSCR\_field\_symval)

| Bit   | field    | symval   | Value | Description                                                                                                                           |
|-------|----------|----------|-------|---------------------------------------------------------------------------------------------------------------------------------------|
| 15-13 | reserved |          |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect.                              |
| 12    | PREMD    |          |       | Prescalar mode select bit.                                                                                                            |
|       |          | DIRECT   | 0     | Direct mode. When PSC bit in TCR is decremented past 0, PSC bit is loaded with TDDR content in TCR.                                   |
|       |          | INDIRECT | 1     | Indirect mode. When PSC bit in TCR is decremented past 0, PSC bit is loaded with the prescalar value associated with TDDR bit in TCR. |
| 11-0  | reserved |          |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect.                              |

#### A.7.3 Timer Period Register (PRD)

Figure A–44. Timer Period Register (PRD)



Table A-43. Timer Period Register (PRD)

| Bit  | field | symval    | Value   | Description                                                                                        |
|------|-------|-----------|---------|----------------------------------------------------------------------------------------------------|
| 15-0 | PRD   | 0F(value) | 0-FFFFh | Used to store a 16-bit value that is used to load the timer register (TIM). Set to FFFFh at reset. |

## A.8 Watchdog Timer Registers (C5441)

### A.8.1 Watchdog Timer Control Register (WDTCR)

Figure A–45. Watchdog Timer Control Register (WDTCR)

| _ | 15   | 12       | 11    | 10    | 9     |   |
|---|------|----------|-------|-------|-------|---|
|   | rese | rved     | SOFT  | FREE  | PSC   |   |
|   | RΛ   | V-0      | R/W-0 | R/W-0 | R-0   |   |
|   | 6    | 5 4      | 3     |       |       | 0 |
|   | PSC  | reserved |       | TD    | DR    |   |
|   | R-0  | R/W-0    | _     | R/W-  | 1111b |   |

Table A–44. Watchdog Timer Control Register (WDTCR) Field Values (WDTIM\_WDTCR\_field\_symval)

| Bit   | field    | symval   | Value | Description                                                                                                                                                                                                                                                                                               |
|-------|----------|----------|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15-12 | reserved |          |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect.                                                                                                                                                                                                  |
| 11    | SOFT     |          |       | Used in conjunction with FREE bit to determine the state of the watchdog timer when a breakpoint is encountered in the HLL debugger. When FREE bit is cleared, SOFT bit selects the watchdog timer mode.                                                                                                  |
|       |          | BRKPTNOW | 0     | The watchdog timer stops immediately.                                                                                                                                                                                                                                                                     |
|       |          | WAITZERO | 1     | The watchdog timer stops when the counter decrements to 0.                                                                                                                                                                                                                                                |
| 10    | FREE     |          |       | Used in conjunction with SOFT bit to determine the state of the watchdog timer when a breakpoint is encountered in the HLL debugger. When FREE bit is cleared, SOFT bit selects the watchdog timer mode.                                                                                                  |
|       |          | WITHSOFT | 0     | SOFT bit selects the watchdog timer mode.                                                                                                                                                                                                                                                                 |
|       |          | NOSOFT   | 1     | The watchdog timer runs free regardless of SOFT bit status.                                                                                                                                                                                                                                               |
| 9-6   | PSC      |          |       | Timer prescalar counter. This read-only bit specifies the count for the on-chip watchdog timer when in direct mode (PREMD bit is cleared in the WDTSCR). When PSC bit is decremented past 0 or the watchdog timer is reset, PSC bit is loaded with the contents of TDDR bit and the WDTIM is decremented. |
| 5-4   | reserved |          |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect.                                                                                                                                                                                                  |

Table A–44. Watchdog Timer Control Register (WDTCR) Field Values (WDTIM\_WDTCR\_field\_symval) (Continued)

| Bit | field | symval             | Value | Description                                                                                                                                                                      |
|-----|-------|--------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3-0 | TDDR  |                    |       | The timer prescalar for the on-chip watchdog timer.                                                                                                                              |
|     |       |                    |       | In prescalar direct mode (PREMD = 0 in WDTSCR):                                                                                                                                  |
|     |       | OF( <i>value</i> ) | 0-15  | This value specifies the prescalar count for the on-chip watchdog timer. When PSC bit is decremented past 0, PSC bit is loaded with this TDDR content.                           |
|     | TDDR  |                    |       | In prescalar indirect mode (PREMD = 1 in WDTSCR):                                                                                                                                |
|     |       | OF( <i>value</i> ) |       | This value relates to an indirect prescalar count, up to 65535, for the on-chip watchdog timer. When PSC bit is decremented past 0, PSC bit is loaded with this prescalar value. |
|     |       |                    | 0000  | Prescalar value: 0001h                                                                                                                                                           |
|     |       |                    | 0001  | Prescalar value: 0003h                                                                                                                                                           |
|     |       |                    | 0010  | Prescalar value: 0007h                                                                                                                                                           |
|     |       |                    | 0011  | Prescalar value: 000Fh                                                                                                                                                           |
|     |       |                    | 0100  | Prescalar value: 001Fh                                                                                                                                                           |
|     |       |                    | 0101  | Prescalar value: 003Fh                                                                                                                                                           |
|     |       |                    | 0110  | Prescalar value: 007Fh                                                                                                                                                           |
|     |       |                    | 0111  | Prescalar value: 00FFh                                                                                                                                                           |
|     |       |                    | 1000  | Prescalar value: 01FFh                                                                                                                                                           |
|     |       |                    | 1001  | Prescalar value: 03FFh                                                                                                                                                           |
|     |       |                    | 1010  | Prescalar value: 07FFh                                                                                                                                                           |
|     |       |                    | 1011  | Prescalar value: 0FFFh                                                                                                                                                           |
|     |       |                    | 1100  | Prescalar value: 1FFFh                                                                                                                                                           |
|     |       |                    | 1101  | Prescalar value: 3FFFh                                                                                                                                                           |
|     |       |                    | 1110  | Prescalar value: 7FFFh                                                                                                                                                           |
|     |       |                    | 1111  | Prescalar value: FFFFh                                                                                                                                                           |

## A.8.2 Watchdog Timer Secondary Control Register (WDTSCR)

Figure A–46. Watchdog Timer Secondary Control Register (WDTSCR)

| 15     | 14    | 13       | 12    | 11 0  |
|--------|-------|----------|-------|-------|
| WDFLAG | WDEN  | reserved | PREMD | WDKEY |
| R/W-0  | R/W-0 | R/W-0    | R/W-1 | R/W-0 |

Table A–45. Watchdog Timer Secondary Control Register (WDTSCR) Field Values (WDTIM\_WDTSCR\_field\_symval)

| Bit  | field    | symval    | Value | Description                                                                                                                                                                                                                              |
|------|----------|-----------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15   | WDFLAG   |           |       | Watchdog timer flag bit. This bit can be cleared by enabling the watchdog timer, by a device reset, or by being written with a 1.                                                                                                        |
|      |          | TIMEOUT   | 0     | No watchdog timer time-out event occurred.                                                                                                                                                                                               |
|      |          | NOTIMEOUT | 1     | Watchdog timer time-out event occurred.                                                                                                                                                                                                  |
| 14   | WDEN     |           |       | Watchdog timer enable bit.                                                                                                                                                                                                               |
|      |          | DISABLE   | 0     | Watchdog timer is disabled. Watchdog timer output pin is disconnected from the watchdog timer time-out event and the counter starts to run.                                                                                              |
|      |          | ENABLE    | 1     | Watchdog timer is enabled. Watchdog timer output pin is connected to the watchdog timer time-out event. Watchdog timer can be disabled by a watchdog timer time-out event or by a device reset.                                          |
| 13   | reserved |           |       | Reserved. The reserved bit location is always read as zero. A value written to this field has no effect.                                                                                                                                 |
| 12   | PREMD    |           |       | Prescalar mode select bit.                                                                                                                                                                                                               |
|      |          | DIRECT    | 0     | Direct mode. When PSC bit in WDTCR is decremented past 0, PSC bit is loaded with TDDR content in WDTCR.                                                                                                                                  |
|      |          | INDIRECT  | 1     | Indirect mode. When PSC bit in WDTCR is decremented past 0, PSC bit is loaded with the prescalar value associated with TDDR bit in WDTCR.                                                                                                |
| 11-0 | WDKEY    |           |       | Watchdog timer reset key. A 12-bit value that before a watchdog timer times out, only a write sequence of a 5C6h followed by an A7Eh services the watchdog timer. Any other writes triggers a watchdog timer time-out event immediately. |
|      |          | PREACTIVE | 5C6h  |                                                                                                                                                                                                                                          |
|      |          | ACTIVE    | A7Eh  |                                                                                                                                                                                                                                          |

## A.8.3 Watchdog Timer Period Register (WDPRD)

Figure A–47. Watchdog Timer Period Register (WDPRD)



Table A–46. Watchdog Timer Period Register (WDPRD)

| Bit  | field | symval    | Value   | Description                                                                        |
|------|-------|-----------|---------|------------------------------------------------------------------------------------|
| 15-0 | PRD   | 0F(value) | 0-FFFFh | Stores a value that is used to reload the Watchdog timer counter register. (WDTIM) |

# Index

| A                                                                 | C code generation for PLL module, 12-11 header file, 12-11 source file, 12-11 |
|-------------------------------------------------------------------|-------------------------------------------------------------------------------|
| accessing data                                                    | C code generation for TIMER, 14-16                                            |
| as defined under the CSL GUI, 2-11 header file mytimercfg.h, 2-12 | C code generation for TIMER module header file, 14-16                         |
| source file mytimercfg.c, 2-15                                    | source file, 14-16                                                            |
| adding a .cdb file to your project, 2-7                           | C code generation for UART module, 15-24                                      |
| adding a linker command file associated with the .cdb file, 2-7   | header file, 15-24<br>source file, 15-25                                      |
| advanced A and B pages, 6-33                                      | C code generation for WATCHDOG TIMER module.                                  |
| API modules, illustration of, 1-3                                 | 16-11                                                                         |
| architecture, of the CSL, 1-2                                     | header file, 16-11                                                            |
| autoinit, 6-33                                                    | source file, 16-12                                                            |
|                                                                   | CCStudio project view, illustration of, 2-9                                   |
| В                                                                 | CCStudio project window, illustration of, 2-8                                 |
| Б                                                                 | CHIP, functions, 3-2                                                          |
| bank-switching control register (BSCR), A-17                      | CHIP functions                                                                |
| breakpoint emulation behavior, 6-33                               | CHIP_getCpuld, 3-3                                                            |
| •                                                                 | CHIP_getMapMode, 3-3                                                          |
| BSCR (bank-switching control register), A-17                      | CHIP_getRevId, 3-4                                                            |
| build options                                                     | CHIP_getSubsysld, 3-4                                                         |
| defining a target device, 2-21 defining far mode, 2-22            | CHIP module                                                                   |
| defining large memory model, 2-23                                 | device-specific support, 1-17                                                 |
| defining library paths, 2-24                                      | functions, 3-3                                                                |
| domining library patrio, 2 2 1                                    | include file, 1-4                                                             |
|                                                                   | module support symbol, 1-4 overview, 3-2                                      |
| C                                                                 | chip support library, 1-2                                                     |
|                                                                   | CLKMD (clock mode register), A-47                                             |
| C code generation for DMA module, 6-37                            |                                                                               |
| header file, 6-37<br>source file, 6-38                            | clock mode register (CLKMD), A-47<br>Code Composer Studio                     |
|                                                                   | defining a target device, 2-21                                                |
| C code generation for GPIO module, 8-8                            | defining a target device, 2-21<br>defining far mode, 2-22                     |
| header file, 8-8<br>source file, 8-8                              | defining large memory model, 2-23                                             |
| C code generation for McBSP module, 11-47                         | defining library paths, 2-24                                                  |
| header file, 11-47                                                | code section, 2-13                                                            |
|                                                                   |                                                                               |

compiling, with CSL, 2-19

source file, 11-48

| compiling and linking with CSL, 2-19                                                          | CSL bool. See data types                             |
|-----------------------------------------------------------------------------------------------|------------------------------------------------------|
| configuration structure, WDTIM, 16-3                                                          | CSL tree (for 5510), illustration of, 2-3            |
| configuring peripherals using CSL GUI                                                         | CSL tree (for C5510), expanded, illustration of, 2-4 |
| DMA module, 6-32                                                                              | CSL_cfgInit, 2-13, 6-39, 8-8, 11-49, 12-12, 15-25    |
| McBSP module, 11-42                                                                           | CSL_init, 2-25                                       |
| PLL module, 12-8                                                                              | .csldata, allocation of, 2-25                        |
| TIMER module, 14-12                                                                           |                                                      |
| WATCHDOG TIMER module, 16-8                                                                   |                                                      |
| configuring peripherals using CSL GUI, GPIO mod-                                              |                                                      |
| ule, 8-7                                                                                      | DAA Module                                           |
| configuring TIMER1, 2-9                                                                       | Configuration Structures, 4-4                        |
| illustration of, 2-10                                                                         | DAA_CircBufCtrl, 4-4                                 |
| constant values for fields, 1-14                                                              | DAA_DevSetup, 4-6                                    |
| constant values for registers, 1-14                                                           | DAA_Params, 4-4                                      |
| CSL CSL                                                                                       | DAA_PrivateObject/DAA_Handle, 4-5                    |
| architecture, 1-2                                                                             | DAA_Setup, 4-6                                       |
| benefits of, 1-2                                                                              | Functions, 4-7                                       |
| data types, 1-7                                                                               | DAA_availability, 4-9                                |
| device support, 1-5                                                                           | DAA_delay, 4-10                                      |
| functions, 1-8                                                                                | DAA_Handle, 4-8                                      |
| introduction to, 1-2                                                                          | DAA_isr, 4-10                                        |
| macros, 1-11                                                                                  | DAA_readWrite, 4-9                                   |
| generic, 1-12                                                                                 | DAA_reset, 4-8                                       |
| macros, generic, handle-based, 1-13                                                           | DAA_resetInternalBuffer, 4-9                         |
| modules and include files, 1-4                                                                | DAA_setup, 4-7                                       |
| naming conventions, 1-6                                                                       | Macros, 4-11                                         |
| symbolic constants, 1-14                                                                      | DAA_ADDR, 4-12<br>DAA_FMK, 4-12                      |
| using interrupts with, 10-7                                                                   | DAA_RGETH, 4-11                                      |
| CSL, generic functions, 1-9                                                                   | DAA_RSETH, 4-11                                      |
| CSL                                                                                           | Overview, 4-2                                        |
| compiling and linking with, 2-19                                                              | DAT, 5-2                                             |
| configuration methods, 2-2                                                                    | functions, 5-3                                       |
| configuring without the use of the CSL GUI, 2-17                                              | module support symbol, 1-4                           |
| destination address, 2-17                                                                     | DAT functions                                        |
| directory structure, 2-20                                                                     | DAT_close, 5-4                                       |
| how to use                                                                                    | DAT_copy, 5-4                                        |
| introduction to the DSP/BIOS configuration                                                    | DAT_copy2D, 5-6                                      |
| tool, 2-3                                                                                     | DAT_fill, 5-8                                        |
| overview, 2-2                                                                                 | DAT_open, 5-9                                        |
| linking with, 2-19                                                                            | DAT_wait, 5-10                                       |
| rebuilding CSL, 2-26<br>source address, 2-17                                                  | DAT module                                           |
| transfer size, 2-17                                                                           | functions, 5-4                                       |
|                                                                                               | include file, 1-4                                    |
| CSL GUI                                                                                       | overview, 5-2                                        |
| accessing data defined in files under, 2-11 configuring a peripheral, basic workflow, 2-7     | DAT_close(), 5-2                                     |
| configuring a peripheral, basic worknow, 2-7 configuring peripherals without the use of, 2-17 | DAT_open(), 5-2                                      |
| how to use, 2-3                                                                               | DAT_wait(), 5-2                                      |
| introduction to, 2-3                                                                          | data types, 1-7                                      |

| declaration list, variables handle and configuration            | DMA functions                                                      |
|-----------------------------------------------------------------|--------------------------------------------------------------------|
| names, 2-11                                                     | DMA_autostart, 6-18                                                |
| declaration section, description of, 2-13                       | DMA_close, 6-7                                                     |
| delete/rename options, illustration of, 2-5                     | DMA_config, 6-7                                                    |
| device-specific features, support for, 1-17                     | DMA_configArgs, 6-8                                                |
| device Sspport symbols, 1-5                                     | DMA_getConfig, 6-18                                                |
| device support, 1-5                                             | DMA_getEventId, 6-19                                               |
| devices. See CSL device support                                 | DMA_getStatus, 6-19<br>DMA_globalAlloc, 6-12                       |
|                                                                 | DMA_globalConfig, 6-14                                             |
| direct register initialization, 1-8                             | DMA_globalConfigArgs, 6-15                                         |
| directory structure, 2-20                                       | DMA_globalFree, 6-16                                               |
| documentation, 2-20                                             | DMA_globalGetConfig, 6-17                                          |
| examples, 2-20 include files, 2-20                              | DMA_open, 6-10                                                     |
| libraries, 2-20                                                 | DMA_pause, 6-11                                                    |
| source library, 2-20                                            | DMA_reset, 6-11                                                    |
| DMA, configuration structure, 6-2                               | DMA_resetGbl, 6-17                                                 |
| -                                                               | DMA_start, 6-11                                                    |
| DMA channel n destination address register                      | DMA_stop, 6-12                                                     |
| (DMDSTn), A-10                                                  | primary summary, 6-2                                               |
| DMA channel n element count register (DMCTRn),<br>A-11          | DMA global destination address reload register (DMGDA), A-10       |
| DMA channel n source address register (DMMCRn),<br>A-9          | DMA global element count reload register (DMGCR), A-12             |
| DMA channel n sync event and frame count register (DMSFCn), A-3 | DMA global extended destination data page register (DMDSTDP), A-15 |
| DMA channel n transfer mode control register                    |                                                                    |
| (DMMCRn), A-6                                                   | DMA global extended source data page register                      |
| DMA channel priority and enable control register                | (DMSRCDP), A-15                                                    |
| (DMPREC), A-2                                                   | DMA global frame count reload register (DMGFR),<br>A-12            |
| DMA Configuration Manager, address formats, 6-34                |                                                                    |
| DMA configuration manager, 6-32                                 | DMA global source address reload register                          |
| configuring the object properties, 6-33                         | (DMGSA), A-9                                                       |
| creating/inserting a configuration, 6-32                        | DMA header file, example of, 6-37                                  |
| deleting/renaming an object, 6-33                               | DMA Macros                                                         |
| description of, 6-32                                            | DMA_ADDR, 6-28                                                     |
| DMA configuration structure                                     | DMA_RGETH, 6-28                                                    |
| DMA_Config, 6-4                                                 | DMA macros                                                         |
| DMA_GblConfig, 6-5                                              | DMA_ADDRH, 6-31                                                    |
| DMA destination program page address register                   | DMA_FGET, 6-26<br>DMA_FGETH, 6-29                                  |
| (DMDSTP), A-11                                                  | DMA_FGETH, 6-29<br>DMA_FMK, 6-25                                   |
| DMA element address index register 0 (DMIDX0),                  | DMA_FSET, 6-27                                                     |
| A-13                                                            | DMA_FSETH, 6-30                                                    |
| DMA element address index register 1 (DMIDX1),                  | DMA_REG_RMK, 6-24                                                  |
| A-13                                                            | DMA_RGET, 6-22                                                     |
| DMA frame address index register 0 (DMFRI0),                    | DMA_RSET, 6-23                                                     |
| A-14                                                            | DMA_RSETH, 6-29                                                    |
| DMA frame address index register 1 (DMFRI1),                    | to read a register address, 6-20                                   |
| A-14                                                            | to read a register address (using handles), 6-21                   |

| to read/write register field values, 6-20 to read/write register field values (using handles), | global extended destination data page register (DMDSTDP), A-15 |
|------------------------------------------------------------------------------------------------|----------------------------------------------------------------|
| 6-21                                                                                           | global extended source data page register                      |
| to read/write register values, 6-20                                                            | (DMSRCDP), A-15                                                |
| to read/write register values (using handles),<br>6-21                                         | global frame count reload register (DMGFR),<br>A-12            |
| DMA module                                                                                     | global source address reload register (DMGSA),<br>A-9          |
| C code generation for, 6-37 channel reload support, 1-17                                       | source program page address register                           |
| configuration manager, 6-32                                                                    | (DMSRCP), A-9                                                  |
| configuration structure, 6-4                                                                   | DMA resource manager, 6-35<br>description of, 6-32             |
| configuring using CSL GUI, 6-32                                                                | predefined objects, 6-35                                       |
| extended data reach, 1-17                                                                      | properties page, 6-35                                          |
| functions, 6-7                                                                                 | DMA resource manager menu, illustration of, 6-35               |
| include file, 1-4                                                                              | DMA sections menu, illustration of, 6-32                       |
| initialization examples, 6-40 using DMA_config(), 6-41                                         | DMA source file, example of, 6-38, 6-39                        |
| macros, 6-20                                                                                   | DMA source program page address register                       |
| using channel number, 6-20                                                                     | (DMSRCP), A-9                                                  |
| module support symbol, 1-4                                                                     | DMA_AdrPtr, 1-7                                                |
| overview, 6-2, 6-32                                                                            | DMA_config, 6-38                                               |
| resource manager, 6-35                                                                         | DMA_config(), using, 2-18                                      |
| DMA properties page                                                                            | DMA_open(), 6-38                                               |
| illustration of, 6-34                                                                          | DMA0, 6-35                                                     |
| with handle object accessible, illustration of, 6-36                                           | DMA1, 6-35                                                     |
| DMA registers, A-2                                                                             | DMA2, 6-35                                                     |
| channel n destination address register                                                         | DMA3, 6-35                                                     |
| (DMDSTn), A-10 channel n element count register (DMCTRn),                                      | DMA4, 6-35                                                     |
| A-11                                                                                           | DMA5, 6-35                                                     |
| channel n source address register (DMSRCn),                                                    | DMCTRn (channel n element count register, A-11                 |
| A-9                                                                                            | DMDSTDP (DMA global extended destination data                  |
| channel n sync event and frame count register (DMSFCn), A-3                                    | page register), A-15                                           |
| channel n transfer mode control register                                                       | DMDSTn (DMA channel n destination address register), A-10      |
| (DMMCRn), A-6                                                                                  | DMDSTP (DMA destination program page address                   |
| channel priority and enable control register                                                   | register), A-11                                                |
| (DMPREC), A-2<br>destination program page address register                                     | DMFRI0 (DMA frame address index register 0),                   |
| (DMDSTP), A-11                                                                                 | A-14                                                           |
| element address index register 0 (DMIDX0), A-13                                                | DMFRI1 (DMA frame address index register 1),                   |
| element address index register 1 (DMIDX1), A-13                                                | A-14                                                           |
| frame address index register 0 (DMFRI0), A-14                                                  | DMGCR (DMA global element count reload register), A-12         |
| frame address index register 1 (DMFRI1), A-14                                                  | DMGDA (DMA global destination address reload                   |
| global destination address reload register (DMGDA), A-10                                       | register), A-10                                                |
| global element count reload register (DMGCR),                                                  | DMGFR (DMA global frame count reload register),                |
| Δ-12                                                                                           | A-12                                                           |

| DMGSA (DMA global source address reload register), A-9          | fieldval, explanation of, 1-11                                                              |
|-----------------------------------------------------------------|---------------------------------------------------------------------------------------------|
|                                                                 | funcArg. See naming conventions                                                             |
| DMIDX0 (DMA element address index register 0),<br>A-13          | function, naming conventions, 1-6                                                           |
| DMIDX1 (DMA element address index register 1),                  | function argument, naming conventions, 1-6                                                  |
| A-13                                                            | function inlining, using, 2-25                                                              |
| DMMCRn (DMA channel n transfer mode control register), A-6      | functions, 1-8<br>generic, 1-9                                                              |
| DMPREC (DMA channel priority and enable control register), A-2  | WDTIM, 16-4                                                                                 |
| DMSFCn (DMA channel n sync event and frame count register), A-3 | G                                                                                           |
| DMSRCDP (DMA global extended source data page register), A-15   | general purpose I/O control register (GPIOCR),<br>A-22, A-24                                |
| DMSRCn (DMA channel n source address register),<br>A-9          | general purpose I/O registers, A-22, A-24<br>general purpose I/O control register (GPIOCR), |
| DMSRCP (DMA source program page address register), A-9          | A-22, A-24 general purpose I/O status register (GPIOSR), A-25                               |
| documentation. See directory structure                          | general purpose I/O status register (GPIOSR), A-25                                          |
|                                                                 | generation of the C files                                                                   |
|                                                                 | header files, 2-11 source files, 2-11                                                       |
| EBUS                                                            | generic CSL functions, 1-9                                                                  |
| configuration structure, 7-2                                    | GPIO, macros, 8-5                                                                           |
| functions, 7-2                                                  | GPIO, macros, 6-3 GPIO configuration manager, 8-7                                           |
| macros, 7-6                                                     | description of, 8-7                                                                         |
| EBUS configuration structure, EBUS_Config, 7-3                  | GPIO functions, listing of, 8-2                                                             |
| EBUS functions                                                  | GPIO module                                                                                 |
| EBUS_config, 7-4                                                | configuring using CSL GUI, 8-7                                                              |
| EBUS_configArgs, 7-5                                            | functions, 8-3                                                                              |
| for C544X devices, 7-5                                          | include file, 1-4                                                                           |
| for C54X devices, 7-5                                           | macros, 8-5                                                                                 |
| EBUS module configuration structure, 7-3                        | module support symbol, 1-4                                                                  |
| functions, 7-4                                                  | overview, 8-2                                                                               |
| include file, 1-4                                               | GPIO properties page, illustration of, 8-7                                                  |
| macros, 7-6                                                     | GPIO source file (body section), example of, 8-8                                            |
| module support symbol, 1-4                                      | GPIO_pinDirection, 8-3                                                                      |
| overview, 7-2                                                   | GPIO_pinRead, 8-3                                                                           |
| examples. See directory structure                               | GPIO_pinWrite, 8-4                                                                          |
|                                                                 | GPIO_RSET(), 8-8                                                                            |
| F                                                               | GPIOCR (general purpose I/O control register),<br>A-22, A-24                                |
| far-mode library. See CSL device support                        | GPIOSR (general purpose I/O status register), A-25                                          |
| far/near mode selection, instructions, 2-21                     | graphical user interface. See CSL GUI                                                       |
| FIELD, 1-14                                                     | GUI. See CSL GUI                                                                            |
| explanation of, 1-11                                            | guidelines, EBUS, 7-2                                                                       |

| Н                                                                 | IRQ module configuration structure, 10-8                     |
|-------------------------------------------------------------------|--------------------------------------------------------------|
| handles<br>resource management, 1-15<br>use of, 1-15              | functions, 10-9 include file, 1-4 module support symbol, 1-4 |
| header file, mytimercfg.h, 2-11                                   | overview, 10-2 using interrupts with CSL, 10-7               |
| header file mytimercfg.h. See accessing data                      | IRQ_EVT_NNNN, 10-4                                           |
| HPI, macros, 9-2                                                  | event list, 10-4                                             |
| HPI module                                                        |                                                              |
| include file, 1-4                                                 | 1                                                            |
| macros, 9-2                                                       | -                                                            |
| module support symbol, 1-4                                        | large/small memory model selection, instructions, 2-23       |
|                                                                   | libraries                                                    |
|                                                                   | See also directory structure                                 |
| include Files. See directory structure                            | linking to a project, 2-22, 2-24                             |
| include files, for CSL modules, 1-4                               | linker command file                                          |
|                                                                   | creating. See compiling and linking with CSL                 |
| include section, description of, 2-12                             | using, 2-25                                                  |
| inserting a configuration object, illustration of, 2-5            | linking, with CSL, 2-19                                      |
| Int16, 1-7                                                        | NA.                                                          |
| Int32, 1-7                                                        | IVI                                                          |
| interrupts                                                        | macro, naming conventions, 1-6                               |
| See also IRQ module                                               | macros, generic, 1-12                                        |
| example of a manual interrupt setting outside DSP/BIOS HWIs, 10-7 | handle-based, 1-13                                           |
| using with CSL, 10-7                                              | macros, generic description of                               |
| IRQ                                                               | CSL, 1-11                                                    |
| configuration structure, 10-3                                     | FIELD, 1-11                                                  |
| functions, 10-3                                                   | fieldval, 1-11                                               |
| IRQ configuration structure, IRQ_Config, 10-3, 10-8               | PER, 1-11                                                    |
| IRQ functions                                                     | REG, 1-11                                                    |
| IRQ_clear, 10-9                                                   | REG#, 1-11                                                   |
| IRQ_config, 10-9                                                  | regval, 1-11                                                 |
| IRQ_configArgs, 10-10                                             | main.c file, example of. See using data generated by         |
| IRQ_disable, 10-10                                                | the DSP/BIOS configuration tool                              |
| IRQ_enable, 10-11                                                 | McBSP                                                        |
| IRQ_getArg, 10-11                                                 | configuration manager, 11-42 configuration structure, 11-2   |
| IRQ_getConfig, 10-12                                              | functions, 11-2                                              |
| IRQ_globalDisable, 10-12                                          | macros using handle, 11-25                                   |
| IRQ_globalEnable, 10-13 IRQ_globalRestore, 10-13                  | macros using port number, 11-24                              |
| IRQ_map, 10-14                                                    | McBSP configuration manager, 11-42                           |
| IRQ_plug, 10-14                                                   | configuring the object properties, 11-43                     |
| IRQ_restore, 10-15                                                | creating/inserting a configuration object, 11-42             |
| IRQ_setArg, 10-15                                                 | deleting/renaming an object, 11-43                           |
| IRQ_setVecs, 10-16                                                | McBSP configuration structure, MCBSP_Config,                 |
| IRQ_test, 10-16                                                   | 11-4                                                         |

| McBSP functions                      | module channel support, 1-17                         |
|--------------------------------------|------------------------------------------------------|
| auxillary, 11-3                      | module support symbol, 1-4                           |
| channel control, 11-3                | overview, 11-2                                       |
| interrupt control, 11-3              | McBSP properties page                                |
| MCBSP_channelDisable, 11-6           | illustration of, 11-45                               |
| MCBSP_channelEnable, 11-7            | with handle object accessible, illustration of,      |
| MCBSP_channelStatus, 11-9            | 11-47                                                |
| MCBSP_close, 11-10                   | McBSP registers, A-26                                |
| MCBSP_config, 11-10                  | multichannel control register 1 (MCR1), A-40         |
| MCBSP_configArgs, 11-12              | multichannel control register 2 (MCR2), A-41         |
| MCBSP_getConfig, 11-15               | pin control register (PCR), A-30                     |
| MCBSP_getPort, 11-15                 | receive channel enable register (RCERn), A-43        |
| MCBSP_getRcvEventID, 11-16           | receive control register 1 (RCR1), A-33              |
| MCBSP_getXmtEventID, 11-16           | receive control register 2 (RCR2), A-34              |
| MCBSP_open, 11-17                    | sample rate generator register 1 (SRGR1), A-38       |
| MCBSP_read16, 11-17                  | sample rate generator register 2 (SRGR2), A-38       |
| MCBSP_read32, 11-18                  | serial port control register 1 (SPCR1), A-26         |
| MCBSP_reset, 11-18                   | serial port control register 2 (SPCR2), A-28         |
| MCBSP_rfull, 11-19                   | transmit channel enable register (XCERn), A-45       |
| MCBSP_rrdy, 11-19                    | transmit control register 1 (XCR1), A-35             |
| MCBSP_start, 11-20                   | transmit control register 2 (XCR2), A-36             |
| MCBSP_write16, 11-22                 | McBSP resource manager, 11-42, 11-46                 |
| MCBSP_write32, 11-22                 | description of, 11-42                                |
| MCBSP_xempty, 11-23                  | predefined objects, 11-46                            |
| MCBSP_xrdy, 11-23                    | properties page, 11-46                               |
| primary, 11-2                        | McBSP resource manager menu, illustration of,        |
| McBSP header file, example of, 11-48 | 11-46                                                |
| McBSP macros                         | McBSP sections menu, illustration of, 11-42          |
| MCBSP_ADDR, 11-24, 11-33             | McBSP source file (body section), example of, 11-49  |
| MCBSP_ADDRH, 11-40                   | McBSP source file (declaration section), example of, |
| MCBSP_FGET, 11-24, 11-31             | 11-48                                                |
| MCBSP_FGET_H, 11-37                  | MCBSP_config, 11-48                                  |
| MCBSP_FMK, 11-24, 11-29              | <b>C</b> ,                                           |
| MCBSP_FSET, 11-24, 11-32             | MCBSP_open, 11-49                                    |
| MCBSP_FSETH, 11-38                   | McBSP0, 11-46                                        |
| MCBSP_REG_RMK, 11-24, 11-28          | McBSP1, 11-46                                        |
| MCBSP_RGET, 11-24, 11-26             | McBSP2, 11-46                                        |
| MCBSP_RGETH, 11-34                   | mcbspCfg, 11-42, 15-21                               |
| MCBSP_RSET, 11-24, 11-27             | MCR1 (multichannel control register 1), A-40         |
| MCBSP_RSETH, 11-36                   | MCR2 (multichannel control register 2), A-41         |
| McBSP module                         | memberName. See naming conventions                   |
| C code generation for, 11-47         | _                                                    |
| configuration structure, 11-4        | memory spaces, DAT module, 5-2                       |
| configuring using the CSL GUI, 11-42 | modifying your user code (main.c), 2-15              |
| overview, 11-42                      | module support symbols, for CSL modules, 1-4         |
| examples, 11-50                      | multichannel control register 1 (MCR1), A-40         |
| functions, 11-6                      | multichannel control register 2 (MCR2), A-41         |
| include file, 1-4                    | multiplexing across different devices, DAT module,   |
| macros, 11-24                        | 5-2                                                  |

| N                                         | PER_varName(). See naming conventions                 |
|-------------------------------------------|-------------------------------------------------------|
| IN                                        | peripheral configuration                              |
| naming conventions, 1-6                   | basic workflow, 2-7                                   |
| near-mode library. See CSL device support | using CSL GUI, 2-7                                    |
|                                           | peripheral configuration manager, description of, 2-4 |
|                                           | peripheral initialization via registers, 1-10         |
| U                                         | using PER_config or PER_configArgs, 1-10              |
| object types. See naming conventions      | peripheral modules                                    |
| object types. See naming conventions      | descriptions of, 1-4                                  |
| P                                         | include files, 1-4                                    |
|                                           | peripheral resource manager, description of, 2-4      |
| PCR (pin control register), A-30          | pin control register (PCR), A-30                      |
| PER, 1-14                                 | PLL, macros, 12-6                                     |
| explanation of, 1-11                      | PLL configuration structure, 12-2                     |
| PER_ADDR, 1-12                            | functions, 12-2                                       |
| PER_ADDRH, 1-13                           | PLL module, overview, 12-2                            |
| PER_close, 1-9                            | PLL configuration manager, 12-8                       |
| PER_config, 1-9                           | configuring the object properties, 12-9               |
| initialization of registers, 1-10         | creating/inserting a configuration, 12-8              |
| PER_config(), 1-9                         | deleting/renaming an object, 12-9                     |
| PER_configArgs, 1-9                       | description of, 12-8                                  |
| initialization of registers, 1-10         | PLL configuration structure, PLL_Config, 12-3         |
| PER_configArgs(), 1-9                     | PLL functions                                         |
| PER_FGET, 1-12                            | PLL_config, 12-4 PLL_configArgs, 12-4                 |
| PER_FGETH, 1-13                           | PLL_setFreq, 12-5                                     |
| PER_FMK, 1-12                             | PLL header file, example of, 12-11                    |
| PER_FSET, 1-12                            | PLL macros                                            |
| PER_FSETH, 1-13                           | PLL_ADDR, 12-6                                        |
| PER_funcName(). See naming conventions    | PLL_FGET, 12-6                                        |
| PER_Handle, 1-7                           | PLL_FMK, 12-6                                         |
| PER_MACRO_NAME. See naming conventions    | PLL_FSET, 12-6<br>PLL_REG_RMK, 12-6                   |
| PER_open, 1-9                             | PLL_RGET, 12-6                                        |
| PER_open(), 1-9                           | PLL_RSET, 12-6                                        |
| PER_REG_DEFAULT, 1-14                     | PLL module                                            |
| PER_REG_FIELD_DEFAULT, 1-14               | configuration structure, 12-3                         |
| PER_REG_FIELD_SYMVAL, 1-14                | configuring using the CSL GUI, 12-8                   |
| PER_REG_RMK, 1-12                         | functions, 12-4                                       |
| PER_reset, 1-9                            | include file, 1-4<br>macros, 12-6                     |
| PER_RGET, 1-12                            | module support symbol, 1-4                            |
| PER_RGETH, 1-13                           | PLL properties page, illustration of, 12-9            |
| PER_RSET, 1-12                            | PLL resource manager, 12-10                           |
| PER_RSETH, 1-13                           | description of, 12-8                                  |
| PER_start, 1-9                            | properties page, 12-10                                |
| PER_Typename. See naming conventions      | PLL resource manager menu, illustration of, 12-10     |

| PLL sections menu, illustration of, 8-7, 12-8      | REG, 1-14                                          |
|----------------------------------------------------|----------------------------------------------------|
| PLL source file (body section), example of, 12-12  | explanation of, 1-11                               |
| PLL source file (declaration section), example of, | REG#, explanation of, 1-11                         |
| 12-11                                              | registers, peripheral initialization, 1-10         |
| PLL_config, 12-12                                  | regval, explanation of, 1-11                       |
| predefined objects, 11-46                          | resource management, using CSL handles, 1-15       |
| DMA0, 6-35                                         | resource manager                                   |
| DMA1, 6-35                                         | McBSP, 11-46                                       |
| DMA2, 6-35                                         | TIMER, 14-14                                       |
| DMA3, 6-35                                         | WATCHDOG TIMER, 16-10                              |
| DMA4, 6-35                                         | resource manager properties page, illustration of, |
| DMA5, 6-35                                         | 2-14                                               |
| McBSP0, 11-46                                      |                                                    |
| McBSP1, 11-46                                      | S                                                  |
| McBSP2, 11-46<br>TIMER, 14-14                      |                                                    |
| TIMERO, 14-14                                      | sample rate generator register 1 (SRGR1), A-38     |
| TIMER1, 14-14                                      | sample rate generator register 2 (SRGR2), A-38     |
| project.cdb, 2-11                                  | scratch pad memory, 2-25                           |
| projectcfg.h, 2-11                                 | serial port control register 1 (SPCR1), A-26       |
| projectcfg_c.c, 2-11                               | serial port control register 2 (SPCR2), A-28       |
| properties page                                    | show dependency option, illustration of, 2-6       |
| TIMER, 14-15                                       | software wait-state control register (SWCR), A-17  |
| WATCHDOG TIMER, 16-10                              | software wait-state register (SWWSR), A-16         |
| properties pages                                   | software wait-state registers, A-16                |
| advanced A and B pages, 6-33                       | software wait-state control register (SWCR), A-17  |
| autoinit, 6-33                                     | software wait-state register (SWWSR), A-16         |
| breakpoint emulation behavior, 6-33                | source file, 11-48                                 |
| source/destination, 6-33                           | mytimercfg_c.c, 2-12                               |
| properties pages of the non-multiplexed GPIO con-  | source file mytimercfg.c. See accessing data       |
| figuration, GPIO, 8-7                              | source file projectcfg_c.c                         |
| PWR, functions, 13-2                               | code section , 2-13                                |
| PWR functions, PWR_powerDown, 13-2, 13-3           | declaration section, 2-13                          |
| PWR module                                         | include section, 2-12                              |
| functions, 13-3                                    | source library. See directory structure            |
| include file, 1-4                                  | source/destination, 6-33                           |
| module support symbol, 1-4                         | SPCR1 (serial port control register 1), A-26       |
| overview, 13-2                                     | SPCR2 (serial port control register 2), A-28       |
|                                                    | SRGR1 (sample rate generator register 1), A-38     |
| R                                                  | SRGR2 (sample rate generator register 2), A-38     |
|                                                    | static inline. See function inlining               |
| RCERn (receive channel enable register), A-43      | structure member, naming conventions, 1-6          |
| RCR1 (receive control register 1), A-33            | SWCR (software wait-state control register), A-17  |
| RCR2 (receive control register 2), A-34            | SWWSR (software wait-state register), A-16         |
| receive channel enable register (RCERn), A-43      | symbolic constant values, 1-14                     |
| receive control register 1 (RCR1), A-33            | symbolic constants, generic, 1-14                  |
| receive control register 2 (RCR2), A-34            | SYMVAL, 1-14                                       |

| T                                                                  |
|--------------------------------------------------------------------|
| target device, specifying. See compiling and linking with CSL      |
| TCR (timer control register), A-49                                 |
| TIMER                                                              |
| C code generation for, 14-16                                       |
| configuration structure, 14-2                                      |
| functions, 14-2                                                    |
| TIMER configuration manager, 14-12                                 |
| configuring the object properties, 14-13                           |
| creating/inserting a configuration, 14-12                          |
| deleting/renaming an object, 14-13                                 |
| description of, 14-12                                              |
| TIMER configuration structure, TIMER_Config, 14-3                  |
| for C5440, C541, and C5472 devices only, 14-3                      |
| timer control register (TCR), A-49                                 |
| TIMER functions                                                    |
| TIMER_close, 14-4                                                  |
| TIMER_config, 14-4                                                 |
| TIMER_configArgs, 14-5                                             |
| TIMER_getEventID, 14-6                                             |
| TIMER_open, 14-6                                                   |
| TIMER_reload, 14-7                                                 |
| TIMER_reset, 14-7 TIMER_start, 14-7                                |
| TIMER_stop, 14-8                                                   |
| timer header file, example of, 14-16                               |
|                                                                    |
| TIMER macros TIMER_ADDR, 14-10                                     |
| TIMER_ADDRH, 14-10                                                 |
| TIMER_FGET, 14-10                                                  |
| TIMER_FGETH, 14-11                                                 |
| TIMER_FMK, 14-10                                                   |
| TIMER_FSET, 14-10                                                  |
| TIMER_FSETH, 14-11                                                 |
| TIMER_REG_RMK, 14-10                                               |
| TIMER_RGET, 14-10                                                  |
| TIMER_RGETH, 14-11                                                 |
| TIMER_RSET, 14-10                                                  |
| TIMER_RSETH, 14-11                                                 |
| using handle, 14-11 using timer port number, 14-10                 |
| •                                                                  |
| TIMER module, 14-12                                                |
| configuration structure, 14-3 configuring using the CSL GUI, 14-12 |
| device-specific support 1-17                                       |

include file, 1-4 macros, 14-9 module support symbol, 1-4 overview, 14-2 TIMER properties page, illustration of, 14-14 timer properties page with handle object accessible, illustration of, 14-15 timer registers, A-49 timer control register (TCR), A-49 timer secondary control register (TSCR), A-51, A-55 TIMER resource manager, 14-14 description of, 14-12 timer resource manager menu, illustration of, 14-14 timer secondary control register (TSCR), A-51, A-55 timer sections menu, illustration of, 14-12 timer source file (body section), example of, 14-17 timer source file (declaration section), example of, 14-16 TIMER0, 14-14 TIMER1, 14-14 configuration of, 2-9 transfer modes, 6-33 transmit channel enable register (XCERn), A-45 transmit control register 1 (XCR1), A-35 transmit control register 2 (XCR2), A-36 TSCR (timer secondary control register), A-51, A-55 typedef, naming conventions, 1-6 **UART** C code generation for, 15-24 Control Signal Macros, 15-16 UART configuration manager, 15-21 configuring the object properties, 15-22 creating/inserting a configuration object, 15-21 deleting/renaming an object, 15-22 **UART Functions** UART\_config, 15-8 UART\_configArgs, 15-8 UART\_eventDisable, 15-9 UART\_eventEnable, 15-9 UART\_fgetc, 15-11 UART\_fgets, 15-11 UART\_fputc, 15-12 UART\_fputs, 15-12 UART\_getConfig, 15-12

functions, 14-4

| UART_read, 15-13                                    | Uint32, 1-7                                                                        |
|-----------------------------------------------------|------------------------------------------------------------------------------------|
| UART_setCallback, 15-13                             | using CSL without the CSL GUI, 2-17                                                |
| UART_setup, 15-14                                   | using data generated by the DSP/BIOS configura-                                    |
| UART_write, 15-14                                   | tion tool, main.c file, example of, 2-16                                           |
| UART header file, example of, 15-24                 |                                                                                    |
| UART macros                                         | V                                                                                  |
| UART_ctsOff, 15-17                                  |                                                                                    |
| UART_ctsOn, 15-17                                   | variable, naming conventions, 1-6                                                  |
| UART_dsrOff, 15-18                                  | VAZ                                                                                |
| UART_dsrOn, 15-18                                   | VV                                                                                 |
| UART_dtcOff, 15-17                                  | Watchdog module, device-specific support, 1-17                                     |
| UART_dtcOn, 15-18                                   |                                                                                    |
| UART_flowCtrllnit, 15-17                            | WATCHDOG TIMER, overview, 16-8                                                     |
| UART_isDtr, 15-19                                   | WATCHDOG TIMER configuration manager, 16-8 configuring the object properties, 16-9 |
| UART_isRts, 15-17                                   | creating/inserting a configuration, 16-8                                           |
| UART_riOff, 15-18                                   | deleting/renaming an object, 16-9                                                  |
| UART_riOn, 15-18<br>WDTIM_ADDR, 15-16               | description of, 16-8                                                               |
| WDTIM_FGET, 15-15                                   | watchdog timer control register (WDTCR), A-52                                      |
| WDTIM_FMK, 15-15                                    | WATCHDOG TIMER header file, example of, 16-12                                      |
| WDTIM_FSET, 15-15                                   | WATCHDOG TIMER module                                                              |
| WDTIM_REG_RMK, 15-15                                | configuring using the CSL GUI, 16-8                                                |
| WDTIM_RGET, 15-15                                   | macros, 16-6                                                                       |
| WDTIM_RSET, 15-15                                   | Watchdog Timer module                                                              |
| UART module                                         | include file, 1-4                                                                  |
| configuration structure, 15-2                       | module support symbol, 1-4                                                         |
| configuration structures, 15-5                      | WATCHDOG TIMER properties page, illustration of,                                   |
| UART_Config, 15-5                                   | 16-10                                                                              |
| UART_Setup, 15-5                                    | WATCHDOG TIMER properties page with handle                                         |
| configuring using CSL GUI, 15-21                    | object accessible, illustration of, 16-11                                          |
| functions, 15-2, 15-8                               | watchdog timer registers, A-52                                                     |
| include file, 1-4                                   | watchdog timer control register (WDTCR), A-52                                      |
| macros, 15-15                                       | watchdog timer secondary control register                                          |
| module support symbol, 1-4                          | (WDTSCR), A-54                                                                     |
| overview, 15-2                                      | WATCHDOG TIMER resource manager, 16-10                                             |
| UART properties page, illustration of, 15-23        | description of, 16-8                                                               |
| UART resource manager, 15-23                        | illustration of, 16-10                                                             |
| properties page, illustration of, 15-24             | watchdog timer secondary control register                                          |
| UART resource manager menu                          | (WDTSCR), A-54                                                                     |
| illustration of, 15-23                              | WATCHDOG TIMER sections menu, illustration of,                                     |
| properties page, 15-23                              | 16-8                                                                               |
| UART sections menu, illustration of, 15-21          | WATCHDOG TIMER source file (body section), ex-                                     |
| UART source file (body section), example of, 15-25  | ample of, 16-12                                                                    |
| UART source file (declaration section), example of, | WATCHDOG TIMER source file (declaration section), example of, 16-12                |
| 15-25                                               | WDTCR (watchdog timer control register), A-52                                      |
| UART_config, 15-25                                  | WDTCK (watchdog timer control register), A-52 WDTIM                                |
| Uchar, 1-7                                          | configuration structure, 16-2                                                      |
| Uint16, 1-7                                         | functions, 16-2                                                                    |
|                                                     |                                                                                    |

WDTIM configuration structure, WDTIM\_Config, 16-3

WDTIM functions

WDTIM\_config, 16-4

WDTIM\_configArgs, 16-4

WDTIM\_getConfig, 16-5

WDTIM\_service, 16-5

WDTIM\_start, 16-5

WDTIM macros

using timer port number, 16-7

WDTIM\_ADDR, 16-7

WDTIM\_FGET, 16-7

WDTIM\_FMK, 16-7

WDTIM\_FSET, 16-7

WDTIM\_REG\_RMK, 16-7 WDTIM\_RGET, 16-7 WDTIM\_RSET, 16-7

WDTIM module, overview, 16-2

WDTIMER\_config, 16-12

WDTSCR (watchdog timer secondary control register), A-54



XCERn (transmit channel enable register), A-45 XCR1 (transmit control register 1), A-35 XCR2 (transmit control register 2), A-36