SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

- 200-MIPS Dual-Core DSP Consisting of Two Independent Subsystems
- Each Core Has an Advanced Multibus Architecture With Three Separate 16-Bit Data Memory Buses and One Program Bus
- 40-Bit Arithmetic Logic Unit (ALU) Including a 40-Bit Barrel-Shifter and Two 40-Bit Accumulators Per Core
- Each Core Has a 17- × 17-Bit Parallel Multiplier Coupled to a 40-Bit Adder for Non-Pipelined Single-Cycle Multiply/ Accumulate (MAC) Operations
- Each Core Has a Compare, Select, and Store Unit (CSSU) for the Add/Compare Selection of the Viterbi Operator
- Each Core Has an Exponent Encoder to Compute an Exponent Value of a 40-Bit Accumulator Value in a Single Cycle
- Each Core Has Two Address Generators With Eight Auxiliary Registers and Two Auxiliary Register Arithmetic Units (ARAUs)
- 16-Bit Data Bus With Data Bus Holder Feature
- 256K × 16 Extended Program Address Space
- Total of 192K × 16 Dual- and Single-Access On-Chip RAM
- Single-Instruction Repeat and Block-Repeat Operations
- Instructions With 32-Bit Long Word Operands
- Instructions With 2 or 3 Operand Reads
- Fast Return From Interrupts

- Arithmetic Instructions With Parallel Store and Parallel Load
- Conditional Store Instructions
- Output Control of CLKOUT
- Output Control of TOUT
- Power Consumption Control With IDLE1, IDLE2, and IDLE3 Instructions
- Dual 1.8-V (Core) and 3.3-V (I/O) Power Supplies for Low Power, Fast Operation
- 10-ns Single-Cycle Fixed-Point Instruction Execution
- Interprocessor Communication via Two Internal 8-Element FIFOs
- 12 Channels of Direct Memory Access (DMA) for Data Transfers With No CPU Loading (6 Channels Per Subsystem)
- Six Multichannel Buffered Serial Ports (McBSPs) (Three McBSPs Per Subsystem)
- 16-Bit Host-Port Interface (HPI16) Multiplexed With External Memory Interface Pins
- Software-Programmable Phase-Locked Loop (PLL) Provides Several Clocking Options (Requires External TTL Oscillator)
- On-Chip Scan-Based Emulation Logic
- Two Software-Programmable Timers (One Per Subsystem)
- Software-Programmable Wait-State Generator (14 Wait States Maximum)
- Provided in 144-pin BGA Ball Grid Array (GGU Suffix) and 144-pin Low-Profile Quad Flatpack (LQFP) (PGE Suffix) Packages

**NOTE:** This data sheet is designed to be used in conjunction with the *TMS320C54x*<sup>™</sup> *DSP Functional Overview* (literature number SPRU307).



Please be aware that an important notice concerning availability, standard warranty, and use in critical applications of Texas Instruments semiconductor products and disclaimers thereto appears at the end of this data sheet.

TMS320C54x is a trademark of Texas Instruments. All trademarks are the property of their respective owners

PRODUCTION DATA information is current as of publication date. Products conform to specifications per the terms of Texas Instruments standard warranty. Production processing does not necessarily include testing of all parameters.

Copyright © 2008, Texas Instruments Incorporated

SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### **Table of Contents**

| Absolute Maximum Ratings 41                             |
|---------------------------------------------------------|
| Recommended Operating Conditions                        |
| Electrical Characteristics                              |
| External Multiply-By-N Clock Option                     |
| Bypass Option                                           |
| External Memory Interface Timing for One Wait State 45  |
| Ready Timing for Externally Generated Wait States 49    |
| Parallel I/O Interface Timing51                         |
| I/O Port Timing for Externally Generated Wait States 53 |
| Reset, BIO, Interrupt, and XIO Timing                   |
| External Flag (XF) and Timer Output (TOUT) Timing 57    |
| General-Purpose Input/Output (GPIO) Timing              |
| SELA/B Timing                                           |
| Multichannel Buffered Serial Port Timing                |
| HPI16 Timing                                            |
| Mechanical Data                                         |
|                                                         |

#### **REVISION HISTORY**

| REVISION | DATE           | PRODUCT STATUS                      | HIGHLIGHTS                                                                                                                                                                                                                                                                                                                           |
|----------|----------------|-------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| *        | March 1999     | h 1999 Advance Information Original |                                                                                                                                                                                                                                                                                                                                      |
| А        | April 1999     | Advance Information                 | Updated characteristics data.                                                                                                                                                                                                                                                                                                        |
| В        | September 1999 | Production Data                     | Updated characteristics data.                                                                                                                                                                                                                                                                                                        |
| С        | April 2000     | Production Data                     | Updated characteristics data.                                                                                                                                                                                                                                                                                                        |
| D        | June 2000      | Production Data                     | Updated characteristics data.                                                                                                                                                                                                                                                                                                        |
| E        | April 2001     | Production Data                     | Removed $4K \times 16$ -bit block of on-chip memory labeled SARAM4. This is no longer a supported feature of this device.                                                                                                                                                                                                            |
| F        | October 2008   | Production Data                     | <ul> <li>Signal Descriptions table:</li> <li>Added footnote about TRST</li> <li>Mechanical Data section:</li> <li>Added paragraph about packaging information</li> <li>Added "Package Thermal Resistance Characteristics" section</li> <li>Mechanical drawings will be appended to this document via an automated process</li> </ul> |



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

## description

The TMS320VC5420 fixed-point digital signal processor (DSP) is a dual CPU device capable of up to 200-MIPS performance. The 5420 consists of two independent 54x subsystems capable of core-to-core communications.

Each subsystem CPU is based on an advanced, modified Harvard architecture that has one program memory bus and three data memory buses. The processor also provides an arithmetic logic unit (ALU) that has a high degree of parallelism, application-specific hardware logic, on-chip memory, and additional on-chip peripherals.

Each subsystem has separate program and data spaces, allowing simultaneous accesses to program instructions and data. Two read operations and one write operation can be performed in one cycle. Instructions with parallel store and application-specific instructions can fully utilize this architecture. Furthermore, data can be transferred between program and data spaces. Such parallelism supports a powerful set of arithmetic, logic, and bit manipulation operations that can be performed in a single machine cycle. In addition, the 5420 includes the control mechanisms to manage interrupts, repeated operations, and function calls.

The 5420 is offered in two temperature ranges and individual part numbers as shown below. (Please note that the industrial temperature device part numbers do not follow the typical numbering tradition.)

Commercial temperature devices (0°C to 100°C) TMS320VC5420PGE200 (144-pin LQFP) TMS320VC5420GGU200 (144-pin BGA)

Industrial temperature range devices (-40°C to 100°C) TMS320C5420PGEA200 (144-pin LQFP) TMS320C5420GGUA200 (144-pin BGA)



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008



<sup>†</sup>NC = No internal connection

<sup>‡</sup> DV<sub>DD</sub> is the power supply for the I/O pins while CV<sub>DD</sub> is the power supply for the core CPU. V<sub>SS</sub> is the ground for both the I/O pins and the core CPU.

§ Pin configuration shown for nonmultiplexed mode only. See the Pin Assignments for the TMS320VC5420PGE table for multiplexed functions of specific pins.



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

TMS320VC5420 GGU PACKAGE (BOTTOM VIEW)



The pin assignments table for the TMS320VC5420GGU lists each pin name and its associated pin number for this 144-pin ball grid array (BGA) package.



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

## pin assignments

The 5420 pin assignments tables list each pin name and corresponding pin number for the two package types. Some of the 5420 pins can be configured for one of two functions. For these pins, the primary pin name is listed in the primary column. The secondary pin name is listed in the secondary column and is shaded grey.

# Pin Assignments for the TMS320VC5420PGE (144-Pin Low-Profile Quad Flatpack)

| PRIMARY<br>SIGNAL NAME | SECONDARY<br>SIGNAL NAME | PIN<br>NO. | PRIMARY<br>SIGNAL NAME | SECONDARY<br>SIGNAL NAME | PIN<br>NO. |
|------------------------|--------------------------|------------|------------------------|--------------------------|------------|
| PPD7                   | HD7                      | 1          | PPA8                   |                          | 2          |
| PPA0                   | A_HINT                   | 3          | DVDD                   |                          | 4          |
| PPA9                   |                          | 5          | PPD1                   | HD1                      | 6          |
| A_INT1                 |                          | 7          | A_NMI                  |                          | 8          |
| 10.07555               | A_GPIO3                  |            |                        |                          |            |
| IOSTRB                 | A_TOUT                   | 9          | A_GPIO2/BIO            |                          | 10         |
| A_GPIO1                |                          | 11         | A_RS                   |                          | 12         |
| A_GPIO0                |                          | 13         | V <sub>SS</sub>        |                          | 14         |
| V <sub>SS</sub>        |                          | 15         | CV <sub>DD</sub>       |                          | 16         |
| A_BFSR1                |                          | 17         | A_BDR1                 |                          | 18         |
| A_BCLKR1               |                          | 19         | A_BFSX1                |                          | 20         |
| CV <sub>DD</sub>       |                          | 21         | V <sub>SS</sub>        |                          | 22         |
| A_BDX1                 |                          | 23         | A_BCLKX1               |                          | 24         |
| A_XF                   |                          | 25         | A_CLKOUT               |                          | 26         |
| VCO                    |                          | 27         | ТСК                    |                          | 28         |
| TMS                    |                          | 29         | TDI                    |                          | 30         |
| TRST                   |                          | 31         | EMU1                   |                          | 32         |
| DVDD                   |                          | 33         | A_INT0                 |                          | 34         |
| EMU0                   |                          | 35         | TDO                    |                          | 36         |
| V <sub>SS</sub>        |                          | 37         | PPD15                  | HD15                     | 38         |
| PPD14                  | HD14                     | 39         | V <sub>SS</sub>        |                          | 40         |
| PPD13                  | HD13                     | 41         | PPD12                  | HD12                     | 42         |
| A_BFSR0                |                          | 43         | A_BDR0                 |                          | 44         |
| A_BCLKR0               |                          | 45         | A_BFSX0                |                          | 46         |
| V <sub>SS</sub>        |                          | 47         | CVDD                   |                          | 48         |
| A_BDX0                 |                          | 49         | A_BCLKX0               |                          | 50         |
| MSTRB                  | HCS                      | 51         | DS                     | HDS2                     | 52         |
| PS                     | HDS1                     | 53         | B_BCLKX0               |                          | 54         |
| B_BDX0                 |                          | 55         | DV <sub>DD</sub>       |                          | 56         |
| V <sub>SS</sub>        |                          | 57         | B_BFSX0                |                          | 58         |
| B_BCLKR0               |                          | 59         | B_BDR0                 |                          | 60         |
| CV <sub>DD</sub>       |                          | 61         | V <sub>SS</sub>        |                          | 62         |
| B_BFSR0                |                          | 63         | R/W                    | HR/W                     | 64         |
| PPA2                   | HCNTL1                   | 65         | PPA3                   | HCNTL0                   | 66         |
| SELA/B                 |                          | 67         | PPD8                   | HD8                      | 68         |
| PPD9                   | HD9                      | 69         | PPD10                  | HD10                     | 70         |
| PPD11                  | HD11                     | 71         | V <sub>SS</sub>        |                          | 72         |



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

# Pin Assignments for the TMS320VC5420PGE (144-Pin Low-Profile Quad Flatpack) (Continued)

| PRIMARY<br>SIGNAL NAME | SECONDARY<br>SIGNAL NAME | PIN<br>NO. | PRIMARY<br>SIGNAL NAME | SECONDARY<br>SIGNAL NAME | PIN<br>NO. |
|------------------------|--------------------------|------------|------------------------|--------------------------|------------|
| PPA10                  |                          | 73         | PPA11                  |                          | 74         |
| DVDD                   |                          | 75         | V <sub>SS</sub>        |                          | 76         |
| PPA12                  |                          | 77         | PPA13                  |                          | 78         |
| HPIRS                  |                          | 79         | HMODE                  |                          | 80         |
| B_CLKOUT               |                          | 81         | B_XF                   |                          | 82         |
| B_RS                   |                          | 83         | XIO                    |                          | 84         |
| TEST                   |                          | 85         | V <sub>SS</sub>        |                          | 86         |
| CVDD                   |                          | 87         | B_BCLKX1               |                          | 88         |
| B_BDX1                 |                          | 89         | V <sub>SS</sub>        |                          | 90         |
| B_BFSX1                |                          | 91         | B_BCLKR1               |                          | 92         |
| VSS                    |                          | 93         | CVDD                   |                          | 94         |
| B_BDR1                 |                          | 95         | B_BFSR1                |                          | 96         |
| B_GPIO0                |                          | 97         | B_GPIO1                |                          | 98         |
| B_GPIO2/BIO            |                          | 99         | IS                     | B_GPIO3                  | 100        |
| B_NMI                  |                          | 101        | B_INT1                 |                          | 102        |
| B_INT0                 |                          | 103        | PPA17                  |                          | 104        |
| PPA16                  |                          | 105        | V <sub>SS</sub>        |                          | 106        |
| PPA15                  |                          | 107        | PPA14                  |                          | 108        |
| PPA7                   |                          | 109        | PPA6                   |                          | 110        |
| PPA4                   | HAS                      | 111        | DVDD                   |                          | 112        |
| PPA5                   |                          | 113        | PPA1                   | B_HINT                   | 114        |
| PPD3                   | HD3                      | 115        | PPD2                   | HD2                      | 116        |
| B_BFSR2                |                          | 117        | B_BDR2                 |                          | 118        |
| V <sub>SS</sub>        |                          | 119        | CV <sub>DD</sub>       |                          | 120        |
| B_BCLKR2               |                          | 121        | B_BFSX2                |                          | 122        |
| B_BDX2                 |                          | 123        | B_BCLKX2               |                          | 124        |
| VSS                    |                          | 125        | AV <sub>DD</sub>       |                          | 126        |
| VSSA                   |                          | 127        | NC                     |                          | 128        |
| CLKIN                  |                          | 129        | DVDD                   |                          | 130        |
| READY                  | HRDY                     | 131        | A_BCLKX2               |                          | 132        |
| CV <sub>DD</sub>       |                          | 133        | V <sub>SS</sub>        |                          | 134        |
| A_BCLKR2               |                          | 135        | A_BDR2                 |                          | 136        |
| A_BFSR2                |                          | 137        | A_BDX2                 |                          | 138        |
| A_BFSX2                |                          | 139        | PPD6                   | HD6                      | 140        |
| PPD4                   | HD4                      | 141        | PPD5                   | HD5                      | 142        |
| PPD0                   | HD0                      | 143        | V <sub>SS</sub>        |                          | 144        |



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

| PRIMARY<br>SIGNAL NAME | SECONDARY<br>SIGNAL NAME | BALL<br>NO. | PRIMARY<br>SIGNAL NAME | SECONDARY<br>SIGNAL NAME | BALL<br>NO. |
|------------------------|--------------------------|-------------|------------------------|--------------------------|-------------|
| PPD7                   | HD7                      | A1          | PPA8                   |                          | B1          |
| DV <sub>DD</sub>       |                          | C1          | A_NMI                  |                          | D1          |
| A_RS                   |                          | E1          | CV <sub>DD</sub>       |                          | F1          |
| A_BDR1                 |                          | G1          | CVDD                   |                          | H1          |
| A_XF                   |                          | J1          | TMS                    |                          | K1          |
| EMU1/OFF               |                          | L1          | EMU0                   |                          | M1          |
| V <sub>SS</sub>        |                          | N1          | PPD0                   | HD0                      | A2          |
| V <sub>SS</sub>        |                          | B2          | PPA0                   | A_HINT                   | C2          |
| A_INT1                 |                          | D2          | A_GPIO1                |                          | E2          |
| V <sub>SS</sub>        |                          | F2          | A_BFSR1                |                          | G2          |
| V <sub>SS</sub>        |                          | H2          | A_CLKOUT               |                          | J2          |
| TDI                    |                          | K2          | DV <sub>DD</sub>       |                          | L2          |
| TDO                    |                          | M2          | PPD15                  | HD15                     | N2          |
| PDD6                   | HD6                      | A3          | PPD4                   | HD4                      | B3          |
| PPD5                   | HD5                      | C3          | PPD1                   | HD1                      | D3          |
| A_GPIO2/BIO            |                          | E3          | V <sub>SS</sub>        |                          | F3          |
| A_BCLKR1               |                          | G3          | A_BDX1                 |                          | H3          |
| VCO                    |                          | J3          | TRST                   |                          | K3          |
| A_INT0                 |                          | L3          | PPD14                  | HD14                     | M3          |
| V <sub>SS</sub>        |                          | N3          | A_BFSR2                |                          | A4          |
| A_BDX2                 |                          | B4          | A_BFSX2                |                          | C4          |
|                        |                          | D4 IOSTRB   | ľ                      | A_GPIO3                  |             |
| PPA9                   |                          |             | A_TOUT                 | — E4                     |             |
| A_GPIO0                |                          | F4          | A_BFSX1                |                          | G4          |
| A_BCLKX1               |                          | H4          | тск                    |                          | J4          |
| PPD13                  | HD13                     | K4          | PPD12                  | HD12                     | L4          |
| A_BFSR0                |                          | M4          | A_BDR0                 |                          | N4          |
| CVDD                   |                          | A5          | VSS                    |                          | B5          |
| A_BCLKR2               |                          | C5          | A_BDR2                 |                          | D5          |
| A_BCLKR0               |                          | K5          | A_BFSX0                |                          | L5          |
| V <sub>SS</sub>        |                          | M5          | CV <sub>DD</sub>       | 1                        | N5          |
| CLKIN                  |                          | A6          | DV <sub>DD</sub>       |                          | B6          |
| READY                  | HRDY                     | C6          | A_BCLKX2               |                          | D6          |
| A_BDX0                 |                          | K6          | A_BCLKX0               |                          | L6          |
| MSTRB                  | HCS                      | M6          | DS                     | HDS2                     | N6          |
| AVDD                   |                          | A7          | V <sub>SS</sub>        |                          | B7          |
| VSSA                   |                          | C7          | NC                     |                          | D7          |

## Pin Assignments for the TMS320VC5420GGU (144-Pin MicroStar BGA™)

MicroStar BGA is a trademark of Texas Instruments.



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

| PRIMARY<br>SIGNAL NAME  | SECONDARY<br>SIGNAL NAME | BALL<br>NO. | PRIMARY<br>SIGNAL NAME | SECONDARY<br>SIGNAL NAME | BALL<br>NO. |
|-------------------------|--------------------------|-------------|------------------------|--------------------------|-------------|
|                         | SIGNAL NAME              | K7          | B_BDX0                 | SIGNAL NAME              | L7          |
| PS                      | HDS1                     | M7          | B_BCLKX0               |                          | N7          |
| B_BCLKX2                |                          | A8          | B_BDX2                 |                          | B8          |
| B_BFSX2                 |                          | C8          | B_BCLKR2               |                          | D8          |
| B_BDR0                  |                          | K8          | B_BCLKR0               |                          | L8          |
| B_BFSX0                 |                          | M8          | V <sub>SS</sub>        |                          | N8          |
| CV <sub>DD</sub>        |                          | A9          | V <sub>SS</sub>        |                          | B9          |
| B_BDR2                  |                          | C9          | B_BFSR2                |                          | D9          |
| R/W                     | HR/W                     | K9          | B_BFSR0                |                          | L9          |
|                         |                          | M9          | CV <sub>DD</sub>       |                          | N9          |
| V <sub>SS</sub><br>PPD2 | HD2                      | A10         | PPD3                   | HD3                      | B10         |
| PPA1                    | B_HINT                   |             | PPD5<br>PPA5           |                          |             |
| PPAT                    |                          | C10         | PPAD                   |                          | D10         |
| ĪS                      | B_GPIO3<br>B_TOUT        | E10         | B_BFSR1                |                          | F10         |
| B_BCLKR1                |                          | G10         | TEST                   |                          | H10         |
| B_CLKOUT                |                          | J10         | PPA12                  |                          | K10         |
| SELA/B                  |                          | L10         | PPA3                   | HCNTL0                   | M10         |
| PPA2                    | HCNTL1                   | N10         | DV <sub>DD</sub>       |                          | A11         |
| PPA4                    | HAS                      | B11         | V <sub>SS</sub>        |                          | C11         |
| B_INT0                  |                          | D11         | B_GPIO2/BIO            |                          | E11         |
| B_BDR1                  |                          | F11         | B_BFSX1                |                          | G11         |
| V <sub>SS</sub>         |                          | H11         | B_XF                   |                          | J11         |
| PPA13                   |                          | K11         | PPD10                  | HD10                     | L11         |
| PPD9                    | HD9                      | M11         | PPD8                   | HD8                      | N11         |
| PPA6                    |                          | A12         | PPA14                  |                          | B12         |
| PPA16                   |                          | C12         | B_INT1                 |                          | D12         |
| B_GPIO1                 |                          | E12         | CV <sub>DD</sub>       |                          | F12         |
| B_BDX1                  |                          | G12         | CV <sub>DD</sub>       |                          | H12         |
| B_RS                    |                          | J12         | HPIRS                  |                          | K12         |
| DVDD                    |                          | L12         | V <sub>SS</sub>        |                          | M12         |
| PPD11                   | HD11                     | N12         | PPA7                   |                          | A13         |
| PPA15                   |                          | B13         | PPA17                  |                          | C13         |
| B_NMI                   |                          | D13         | B_GPIO0                |                          | E13         |
| V <sub>SS</sub>         |                          | F13         | V <sub>SS</sub>        |                          | G13         |
| B_BCLKX1                |                          | H13         | XIO                    |                          | J13         |
| HMODE                   |                          | K13         | V <sub>SS</sub>        | 1                        | L13         |
| PPA11                   |                          | M13         | PPA10                  |                          | N13         |

## Pin Assignments for the TMS320VC5420GGU (144-Pin MicroStar BGA™) (Continued)



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### signal descriptions

The 5420 signal descriptions table lists each pin name, function, and operating mode(s) for the 5420 device. Some of the 5420 pins can be configured for one of two functions; a primary function and a secondary function. The names of these pins in secondary mode are shaded in grey in the following table.

| NAME                                                                                                                                                                                     | TYPE <sup>†</sup>                               | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| DATA SIGNALS                                                                                                                                                                             |                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| PPA17 (MSB)<br>PPA16<br>PPA15<br>PPA14<br>PPA13<br>PPA12<br>PPA12<br>PPA10<br>PPA9<br>PPA8<br>PPA7<br>PPA6<br>PPA5<br>PPA4 <sup>‡</sup> \$<br>PPA3<br>PPA3<br>PPA2<br>PPA1<br>PPA0 (LSB) | 1/O/Z                                           | Parallel port address bus. The DSP can access the external memory locations by way of the external memory interface using PPA[17:0] in external memory interface (EMIF) mode when the XIO pin is logic high.<br>The PPA[17:0] pins are also multiplexed with the HPI interface. In HPI mode (XIO pin is low), the external address pins PPA[17:0] are used by a host processor for access to the memory map by way of the on-chip HPI. Refer to the HPI section of this table for details on the secondary functions of these pins.<br>These pins are placed into the high-impedance state when OFF is low.                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| PPD15 (MSB)<br>PPD14<br>PPD13<br>PPD12<br>PPD11<br>PPD10<br>PPD9<br>PPD8<br>PPD7<br>PPD6<br>PPD5<br>PPD4<br>PPD5<br>PPD4<br>PPD3<br>PPD2<br>PPD1<br>PPD0 (LSB)                           | I/O/Z¶                                          | Parallel port data bus. The DSP uses this bidirectional data bus to access external memory when the device is in external memory interface (EMIF) mode (the XIO pin is logic high).<br>This data bus is also multiplexed with the 16-bit HPI data bus. When in HPI mode, the bus is used to transfer data between the host processor and internal DSP memory via the HPI. Refer to the HPI section of this table for details on the secondary functions of these pins.<br>The data bus includes bus holders to reduce power dissipation caused by floating, unused pins. The bus holders also eliminate the need for external pullup resistors on unused pins. When the data bus is not being driven by the 5420, the bus holders keep data pins at the last driven logic level. The data bus keepers are disabled at reset and can be enabled/disabled via the BH bit of the BSCR register.<br>These pins are placed into high-impedance state when OFF is low. |  |  |  |  |
|                                                                                                                                                                                          | INITIALIZATION, INTERRUPT, AND RESET OPERATIONS |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |
| A_INT0<br>B_INT0<br>A_INT1<br>B_INT1<br>\$                                                                                                                                               | I                                               | External user interrupts. INT0–INT3 are prioritized and are maskable by the interrupt mask register (IMR) and the interrupt mode bit. INT0 –INT3 can be polled and reset by way of the interrupt flag register (IFR).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| A_NMI<br>B_NMI                                                                                                                                                                           | I                                               | Nonmaskable interrupt. NMI is an external interrupt that cannot be masked by way of the INTM or the IMR. When NMI is activated, the processor traps to the appropriate vector location.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |

## **Signal Descriptions**

† I = Input, O = Output, S = Supply, Z = High Impedance

<sup>‡</sup> This pin has an internal pullup resistor.

§ These pins have Schmitt trigger inputs.

 $\P$  This pin has an internal bus holder controlled by way of the BSCR register in subchip A.

<sup>#</sup> This pin is used by Texas Instruments for device testing and should be left unconnected.

|| This pin has an internal pulldown resistor.

\*Although this pin includes an internal pulldown resistor, a 470-Ω external pulldown is required. If the TRST pin is connected to multiple DSPs, a buffer is recommended to ensure the VIL and VIH specifications are met.



## Signal Descriptions (Continued)

| NAME                                       | TYPE <sup>†</sup> | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
|--------------------------------------------|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                                            |                   | INITIALIZATION, INTERRUPT, AND RESET OPERATIONS (CONTINUED)                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| A_RS<br>B_RS§                              | I                 | Reset. $\overline{\text{RS}}$ causes the digital signal processor (DSP) to terminate execution and causes a reinitialization of the CPU and peripherals. When $\overline{\text{RS}}$ is brought to a high level, execution begins at location 0FF80h of program memory. $\overline{\text{RS}}$ affects various registers and status bits.                                                                              |  |  |  |  |
| XIO                                        | I                 | e XIO pin is used to configure the parallel port as a host-port interface (HPI mode when XIO pin is low), or as<br>asynchronous memory interface (EMIF mode when XIO pin is high).<br>device reset, the logic combination of the XIO, HMODE, and SELA/B pin levels determines the initialization<br>ue of the MP/MC bit (a bit in the processor mode status (PMST) register ) Refer to the memory section for<br>ails. |  |  |  |  |
|                                            | 1                 | GENERAL-PURPOSE I/O SIGNALS                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |
| A_XF<br>B_XF                               | 0                 | External flag output (latched software-programmable output-only signal). Bit addressable. A_XF and B_XF are placed into the high-impedance state when OFF is low.                                                                                                                                                                                                                                                      |  |  |  |  |
| A_GPIO0<br>B_GPIO0<br>A_GPIO1<br>B_GPIO1   | I/O               | General-purpose I/O pins (software-programmable I/O signal). Values can be latched (output) by writing into the GPIO register. The states of GPIO pins (inputs) can be read by reading the GPIO register. The GPIO direction is also programmable by way of the DIRn field in the GPIO register.                                                                                                                       |  |  |  |  |
| A_GPIO2/ <u>BIO</u><br>B_GPIO2/BIO         |                   | General-purpose I/O. These pins can be configured in the same manner as GPIO0–1; however in input mode, the pins also operate as the traditional branch control bit (BIO). If application code does not perform BIO-conditional instructions, these pins operate as general inputs.                                                                                                                                    |  |  |  |  |
| A_GPIO3<br>(A_TOUT)<br>B_GPIO3<br>(B_TOUT) | I/O               | PRIMARY       When the device is in HPI mode and HMODE = 0 (multiplexed), these pins are controlled by the general-purpose I/O control register. TOUT bit must be set to "1" to drive the timer output on the pin. IF TOUT = 0, then these pins are general-purpose I/Os. In EMIF mode (XIO pin high), these signals serve their primary functions and are active during external I/O space accesses.                  |  |  |  |  |
|                                            | -                 | MEMORY CONTROL SIGNALS                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
| PS‡                                        | 0                 | Program space select signal. The PS signal is asserted during external program space accesses. This pin is placed into the high-impedance state when OFF is low.<br>This pin is also multiplexed with the HPI, and functions as the HDS1 data strobe input signal in HPI mode. Refer to the HPI section of this table for details on the secondary function of this pin.                                               |  |  |  |  |
| <del>DS</del> ‡                            | 0                 | ata space select signal. The DS signal is asserted during external data space accesses. This pin is placed into high-impedance state when OFF is low.<br>his pin is also multiplexed with the HPI, and functions as the HDS2 data strobe input signal in HPI mode. Refer                                                                                                                                               |  |  |  |  |
| ĪS                                         | 0                 | /O space select signal. The IS signal is asserted during external I/O space accesses. This pin is placed into the<br>high-impedance state when OFF is low.<br>This pin is also multiplexed with the general purpose I/O feature, and functions as the B_GPIO3 (B_TOUT)<br>input/output signal in HPI mode. Refer to the General Purpose I/O section of this table for details on the secondary<br>unction of this pin. |  |  |  |  |
| MSTRB <sup>‡§</sup>                        | 0                 | Program and data memory strobe (active in EMIF mode). This pin is placed into the high-impedance state when OFF is low.                                                                                                                                                                                                                                                                                                |  |  |  |  |

<sup>†</sup>I = Input, O = Output, S = Supply, Z = High Impedance

<sup>‡</sup> This pin has an internal pullup resistor.

§ These pins have Schmitt trigger inputs.

 $\P$  This pin has an internal bus holder controlled by way of the BSCR register in subchip A.

<sup>#</sup> This pin is used by Texas Instruments for device testing and should be left unconnected.

|| This pin has an internal pulldown resistor.

\*Although this pin includes an internal pulldown resistor, a 470-Ω external pulldown is required. If the TRST pin is connected to multiple DSPs, a buffer is recommended to ensure the VIL and VIH specifications are met.



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

## Signal Descriptions (Continued)

| NAME                               | TYPE <sup>†</sup> | DESCRIPTION                                                                                                                                                                                                                                                                                                          |  |  |  |  |
|------------------------------------|-------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| MEMORY CONTROL SIGNALS (CONTINUED) |                   |                                                                                                                                                                                                                                                                                                                      |  |  |  |  |
| READY                              | 1                 | Data-ready input signal. READY indicates that the external device is prepared for a bus transaction to be completed. If the device is not ready (READY = 0), the processor waits one cycle and checks READY again. The processor performs the READY detection if at least two software wait states are programmed.   |  |  |  |  |
|                                    |                   | This pin is also multiplexed with the HPI, and functions as the Host-port data ready (output) in HPI mode. Refer to the HPI section of this table for details on the secondary function of this pin.                                                                                                                 |  |  |  |  |
|                                    |                   | Read/write output signal. $R/\overline{W}$ indicates transfer direction during communication to an external device. $R/\overline{W}$ is normally in the read mode (high), unless it is asserted low when the DSP performs a write operation.                                                                         |  |  |  |  |
| R/W                                | 0                 | This pin is also multiplexed with the HPI, and functions as the Host-port Read/write input in HPI mode. Refer to the HPI section of this table for details on the secondary function of this pin.                                                                                                                    |  |  |  |  |
|                                    |                   | This pin is placed into the high-impedance state when $\overline{OFF}$ is low.                                                                                                                                                                                                                                       |  |  |  |  |
|                                    |                   | I/O space memory strobe. External I/O space is accessible by the CPU and not the direct memory access (DMA) controller. The DMA has its own dedicated I/O space that is not accessible by the CPU.                                                                                                                   |  |  |  |  |
| IOSTRB                             | 0                 | This pin is also multiplexed with the general pupose I/O feature, and functions as the A_GPIO3(A_TOUT) signal in HPI mode. Refer to the general purpose I/O section of this table for details on the secondary function of this pin.                                                                                 |  |  |  |  |
|                                    |                   | This pin is placed into the high-impedance state when $\overline{OFF}$ is low.                                                                                                                                                                                                                                       |  |  |  |  |
|                                    |                   | The SELA/B pin designates which DSP subsystem has access to the parallel-port interface. Furthermore, this pin determines which subsystem is accessible by the host via the HPI.                                                                                                                                     |  |  |  |  |
| SELA/B                             |                   | For external memory accesses (XIO pin high), when SELA/B is low subsystem A has control of the external memory interface. Similarly, when SELA/B is high subsystem B has control.                                                                                                                                    |  |  |  |  |
| JLLA/D                             |                   | See Table 7 for a truth table of SELA/B, HMODE and XIO pins and functionality.                                                                                                                                                                                                                                       |  |  |  |  |
|                                    |                   | At device reset, the logic combination of the XIO, HMODE, and SELA/B pin levels determines the initialization value of the MP/MC bit (a bit in the processor mode status (PMST) register ) Refer to the memory section for details.                                                                                  |  |  |  |  |
|                                    |                   | CLOCKING SIGNALS                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| A_CLKOUT<br>B_CLKOUT               | 0                 | Master clock output signal. CLKOUT cycles at the machine-cycle rate of the CPU. The internal machine cycle is bounded by the falling edges of this signal. The CLKOUT pin can be turned off by writing a "1" to the CLKOFF bit of the PMST register. CLKOUT goes into the high-impedance state when EMU1/OFF is low. |  |  |  |  |
| CLKIN§                             | I                 | Input clock to the device. CLKIN connects to an oscillator circuit/device.                                                                                                                                                                                                                                           |  |  |  |  |
| VCO                                | 0                 | VCO is the output of the voltage-controlled oscillator stage of the PLL. This is a 3-state output during normal operation. Active in silicon test/debug mode.                                                                                                                                                        |  |  |  |  |

<sup>†</sup> I = Input, O = Output, S = Supply, Z = High Impedance

<sup>‡</sup> This pin has an internal pullup resistor.

§ These pins have Schmitt trigger inputs.

This pin has an internal bus holder controlled by way of the BSCR register in subchip A.

# This pin is used by Texas Instruments for device testing and should be left unconnected.

|| This pin has an internal pulldown resistor.

 $\star$ Although this pin includes an internal pulldown resistor, a 470- $\Omega$  external pulldown is required. If the TRST pin is connected to multiple DSPs, a buffer is recommended to ensure the V<sub>IL</sub> and V<sub>IH</sub> specifications are met.



## Signal Descriptions (Continued)

| NAME                                                                                                                                                           | TYPE <sup>†</sup>                                     | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                                                                                                                                                                | MULTICHANNEL BUFFERED SERIAL PORT 0, 1, AND 2 SIGNALS |                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
| A_BCLKR0 <sup>‡</sup> §<br>B_BCLKR0 <sup>‡</sup> §<br>A_BCLKR1 <sup>‡</sup> §<br>B_BCLKR1 <sup>‡</sup> §<br>A_BCLKR2 <sup>‡</sup> §<br>B_BCLKR2 <sup>‡</sup> § | I/O/Z                                                 | Receive clocks. BCLKR serves as the serial shift clock for the buffered serial-port receiver. Input from an external clock source for clocking data into the McBSP. When not being used as a clock, these pins can be used as general-purpose I/O by setting RIOEN = 1.<br>BCLKR can be configured as an output by the way of the CLKRM bit in the PCR register.                                                                                            |  |  |  |  |
| A_BCLKX0 <sup>‡</sup> §<br>B_BCLKX0 <sup>‡</sup> §<br>A_BCLKX1 <sup>‡</sup> §<br>B_BCLKX1 <sup>‡</sup> §<br>A_BCLKX2 <sup>‡</sup> §<br>B_BCLKX2 <sup>‡</sup> § | I/O/Z                                                 | Transmit clocks. Clock signal used to clock data from the transmit register. This pin can also be configured as an input by setting the CLKXM = 0 in the PCR register. BCLKX can be sampled as an input by way of the IN1 bit in the SPC register. When not being used as a clock, these pins can be used as general-purpose I/O by setting XIOEN = 1.<br>These pins are placed into the high-impedance state when $\overline{OFF}$ is low.                 |  |  |  |  |
| A_BDR0<br>B_BDR0<br>A_BDR1<br>B_BDR1<br>A_BDR2<br>B_BDR2                                                                                                       | I                                                     | Buffered serial data receive (input) pin. When not being used as data-receive pins, these pins can be used as general-purpose I/O by setting RIOEN = 1.                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| A_BDX0<br>B_BDX0<br>A_BDX1<br>B_BDX1<br>A_BDX2<br>B_BDX2                                                                                                       | O/Z                                                   | Buffered serial-port transmit (output) pin. When not being used as data-transmit pins, these pins can be used as general-purpose I/O by setting XIOEN = 1. These pins are placed into the high-impedance state when OFF is low.                                                                                                                                                                                                                             |  |  |  |  |
| A_BFSR0<br>B_BFSR0<br>A_BFSR1<br>B_BFSR1<br>A_BFSR2<br>B_BFSR2                                                                                                 | I/O/Z                                                 | Frame synchronization pin for buffered serial-port input data. The BFSR pulse initiates the receive-data process over BDR pin. When not being used as data-receive synchronization pins, these pins can be used as general-purpose I/O by setting RIOEN = 1.                                                                                                                                                                                                |  |  |  |  |
| A_BFSX0<br>B_BFSX0<br>A_BFSX1<br>B_BFSX1<br>A_BFSX2<br>B_BFSX2                                                                                                 | I/O/Z                                                 | Buffered serial-port frame synchronization pin for transmitting data. The BFSX pulse initiates the transmit-data process over BDX pin. If RS is asserted when BFSX is configured as output, then BFSX is turned into input mode by the reset operation. When not being used as data-transmit synchronization pins, these pins can be used as general-purpose I/O by setting XIOEN = 1. These pins are placed into the high-impedance state when OFF is low. |  |  |  |  |

<sup>†</sup> I = Input, O = Output, S = Supply, Z = High Impedance

<sup>‡</sup> This pin has an internal pullup resistor.

§ These pins have Schmitt trigger inputs.

 $\P$  This pin has an internal bus holder controlled by way of the BSCR register in subchip A.

<sup>#</sup> This pin is used by Texas Instruments for device testing and should be left unconnected.

|| This pin has an internal pulldown resistor.

\*Although this pin includes an internal pulldown resistor, a 470-Ω external pulldown is required. If the TRST pin is connected to multiple DSPs, a buffer is recommended to ensure the VIL and VIH specifications are met.



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

## Signal Descriptions (Continued)

| NAME               | TYPE <sup>†</sup>           |                      | DESCRIPTION |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|--------------------|-----------------------------|----------------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                    | HOST-PORT INTERFACE SIGNALS |                      |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
|                    |                             | PRIMARY              |             | HPI address inputs. HA[0:17] are used by the host device, in the HPI non-multiplexed mode (HMODE pin is high), to address the on-chip RAM of the 5420. These pins are                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| HA[0:17]           | I                           | PPA[0:17]            | 0           | shared with the external memory interface and are only used by the HPI when the interface is in HPI mode (XIO pin is low).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| HD[0:15]           | I/O/Z                       | PPD[0:15]            | I/O/Z       | Parallel bidirectional data bus. HD[0:15] are used by the host device to transfer data to and from the on-chip RAM of the 5420. These pins are shared with the external memory interface and are only used by the HPI when the interface is in HPI mode (XIO pin is low). The data bus includes bus holders to reduce power dissipation caused by floating, unused pins. The bus holders also eliminate the need for external pullup resistors on unused pins. When the data bus is not being driven by the 5420, the bus holders keep data pins at the last driven logic level. The data bus keepers are disabled at reset and can be enabled/disabled via the BH bit of the BSCR register. These pins are placed into the high-impedance state when OFF is low. |  |  |  |
|                    |                             | PRIMA                | RY          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| HCNTL0<br>HCNTL1   | I                           | PPA3<br>PPA2         | 0           | HPI control inputs. The HCNTL0 and HCNTL1 values between HPIA, and HPID registers during HPI reads and writes. These signals are only used in HPI multiplexed address/data mode (HMODE pin is low). These pins are shared with the external memory interface and are only used by the HPI when the interface is in HPI mode (XIO pin is low).                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| HAS‡§              | I                           | PPA4‡§               | 0           | Address strobe input. Hosts with multiplexed address and data pins require HAS to latch the address in the HPIA register. This signal is only used in HPI multiplexed address/data mode (HMODE pin is low).<br>This pin is shared with the external memory interface and is only used by the HPI when the interface is in HPI mode (XIO pin is low).                                                                                                                                                                                                                                                                                                                                                                                                              |  |  |  |
| HCS‡§              | I                           | MSTRB <sup>‡§</sup>  | 0           | HPI chip-select signal. This signal must be active during HPI transfers, and can remain active between concurrent transfers.<br>This pin is shared with the external memory interface and is only used by the HPI when the interface is in HPI mode (XIO pin is low).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |
| HDS1<br>HDS2<br>+§ | I                           | <u>PS</u> ‡§<br>DS‡§ | 0           | HPI data strobes. HDS1 and HDS2 are driven by the host read and write strobes to control transfer HPI transfers.<br>These pins are shared with the external memory interface and are only used by the HPI when the interface is in HPI mode (XIO pin is low).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |
| HR/W               | I                           | R/W                  | 0           | HPI read/write signal. This signal is used by the host to control the direction of an HPI transfer.<br>This pin is shared with the external memory interface and is only used by the HPI when the interface is in HPI mode (XIO pin is low).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| HRDY               | 0                           | READY                | I           | HPI data-ready output. The ready output informs the host when the HPI is ready for the next transfer.<br>This pin is shared with the external memory interface and is only used by the HPI when the interface is in HPI mode (XIO pin is low). HRDY is placed into the high-impedance state when OFF is low.                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
| A_HINT<br>B_HINT   | ο                           | PPA0<br>PPA1         | 0           | Host interrupt pin. HPI can interrupt the host by asserting this low. The host can clear this interrupt by writing a "1" to the HINT bit of the HPIC register. Only supported in HPI multiplexed address/data mode (HMODE pin is low). These pins are placed into the high-impedance state when OFF is low.                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |

<sup>†</sup>I = Input, O = Output, S = Supply, Z = High Impedance

<sup>‡</sup> This pin has an internal pullup resistor.

§ These pins have Schmitt trigger inputs.

This pin has an internal bus holder controlled by way of the BSCR register in subchip A.

<sup>#</sup> This pin is used by Texas Instruments for device testing and should be left unconnected.

|| This pin has an internal pulldown resistor.

\*Although this pin includes an internal pulldown resistor, a 470- $\Omega$  external pulldown is required. If the TRST pin is connected to multiple DSPs, a buffer is recommended to ensure the V<sub>IL</sub> and V<sub>IH</sub> specifications are met.



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

## Signal Descriptions (Continued)

| NAME              | TYPE <sup>†</sup> | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   | _                 | HOST-PORT INTERFACE SIGNALS (CONTINUED)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| HPIRS§            | I                 | Host-port interface (HPI) reset pin. This signal resets the host port interface and both subsystems.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| HMODE             | I                 | Host mode select. When this pin is low it selects the HPI multiplexed address/data mode. The multiplexed address/data mode allows hosts with multiplexed address/data lines access to the HPI registers HPIC, HPIA, and HPID. Host-to-DSP and DSP-to-host interrupts are supported in this mode.<br>When HMODE is high, it selects the HPI nonmultiplexed mode. HPI nonmultiplexed mode allows hosts with separate address/data buses to access the HPI address range by way of the 18-bit address bus and the HPI data (HPID) register via the 16-bit data bus. Host-to-DSP and DSP-to-host interrupts are not supported in this mode. |
|                   |                   | SUPPLY PINS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| AVDD              | S                 | Dedicated power supply that powers the PLL. $AV_{DD}$ = 1.8 V. $AV_{DD}$ can be connected to $CV_{DD}$ .                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| CVDD              | S                 | Dedicated power supply that powers the core CPUs. $CV_{DD}$ = 1.8 V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| DVDD              | S                 | Dedicated power supply that powers the I/O pins. $DV_{DD}$ = 3.3 V                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| V <sub>SS</sub>   | S                 | Digital ground. Dedicated ground plane for the device.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| V <sub>SSA</sub>  | S                 | Analog ground. Dedicated ground for the PLL. $V_{\mbox{SSA}}$ can be connected to $V_{\mbox{SS}}$ if digital and analog grounds are not separated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                   | _                 | TEST PIN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| TEST <sup>#</sup> |                   | No connection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|                   |                   | EMULATION/TEST PINS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| tck‡§             | I                 | Standard test clock. This is normally a free-running clock signal with a 50% duty cycle. Changes on the test access port (TAP) of input signals TMS and TDI are clocked into the TAP controller, instruction register, or selected test-data register on the rising edge of TCK. Changes at the TAP output signal (TDO) occur on the falling edge of TCK.                                                                                                                                                                                                                                                                               |
| tdi‡              | I                 | Test data input. Pin with an internal pullup device. TDI is clocked into the selected register (instruction or data) on a rising edge of TCK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| TDO               | 0                 | Test data pin. The contents of the selected register is shifted out of TDO on the falling edge of TCK. TDO is in high-impedance state except when the scanning of data is in progress. These pins are placed into high-impedance state when OFF is low.                                                                                                                                                                                                                                                                                                                                                                                 |
| TMS‡              | I                 | Test mode select. Pin with internal pullup device. This serial control input is clocked into the TAP controller on the rising edge of TCK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| TRSTII≭           | I                 | Test reset. When high, TRST gives the scan system control of the operations of the device. If TRST is driven low, the device operates in its functional mode and the emulation signals are ignored. Pin with internal pulldown device.                                                                                                                                                                                                                                                                                                                                                                                                  |
| EMU0              | I/O/Z             | Emulator interrupt 0 pin. When TRST is driven low, EMU0 must be high for the activation of the EMU1/OFF condition. When TRST is driven high, EMU0 is used as an interrupt to or from the emulator system and is defined as I/O.                                                                                                                                                                                                                                                                                                                                                                                                         |
| EMU1/OFF          | I/O/Z             | Emulator interrupt 1 pin. When TRST is driven high, EMU1/OFF is used as an interrupt to or from the emulator system and is defined as I/O. When TRST transitions from high to low, then EMU1 operates as OFF. EMU/OFF = 0 puts all output drivers into the high-impedance state.<br>Note that OFF is used exclusively for testing and emulation purposes (and not for multiprocessing applications). Therefore, for the OFF condition, the following conditions apply:<br>TRST = 0, EMU0 = 1, EMU1 = 0                                                                                                                                  |

<sup>†</sup>I = Input, O = Output, S = Supply, Z = High Impedance

<sup>‡</sup> This pin has an internal pullup resistor.

§ These pins have Schmitt trigger inputs.

 $\P$  This pin has an internal bus holder controlled by way of the BSCR register in subchip A.

<sup>#</sup> This pin is used by Texas Instruments for device testing and should be left unconnected.

|| This pin has an internal pulldown resistor.

\*Although this pin includes an internal pulldown resistor, a 470-Ω external pulldown is required. If the TRST pin is connected to multiple DSPs, a buffer is recommended to ensure the VIL and VIH specifications are met.



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### functional overview



Figure 1. Functional Block Diagram

C54x is a trademark of Texas Instruments.



#### memory

The total memory address range for each 5420 subsystem is 384K 16-bit words. The memory space is divided into three specific memory segments: 256K-word program, 64K-word data, and 64K-word I/O. The program memory space contains the instructions to be executed as well as tables used in execution. The data memory space stores data used by the instructions. The I/O memory space is used to interface to external memory-mapped peripherals and can also serve as extra data storage space. The CPU I/O space should not be confused with the DMA I/O space, which is completely independent and not accessible by the CPU.

#### on-chip dual-access RAM (DARAM)

The 5420 subsystems A and B each have 16K × 16-bit on-chip DARAM (2 blocks of 8K words).

Each of these RAM blocks can be accessed twice per machine cycle. This memory is intended primarily to store data values; however, it can be used to store program as well. At reset, the DARAM is mapped into data memory space. DARAM can be mapped into program/data memory space by setting the OVLY bit in the PMST register.

#### on-chip single-access RAM (SARAM)

The 5420 subsystems A and B each have 80K-word × 16-bit on-chip SARAM (ten blocks of 8K words each).

Each of these SARAM blocks is a single-access memory. This memory is intended primarily to store data values; however, it can be used to store program as well. At reset, the SARAM (4000h–7FFFh) is mapped into data memory space. This memory range can be mapped into program/data memory space by setting the OVLY bit in the PMST register. The SARAM at 8000h–FFFFh is program memory at reset and can be configured as program/data memory by setting the DROM bit. SARAM space18000h–1FFFFh is mapped as program memory only.

#### program memory

The 5420 device features a paged extended memory scheme in program space to allow access of up to 256K of program memory relative to each subsystem. This extended program memory (each subsystem) is organized into four pages (0–3), each 64K in length. A hardware pin is used to select which DSP subsystem (A or B) has control of the external memory interface. To implement the extended program memory scheme, the 5420 device includes the following features:

- Two additional address lines (for a total of 18)
- A pin (SELA/B) for external memory interface arbitration between subsystem A and B

#### data memory

The data memory space on each 5420 subsystem contains up to 64K 16-bit word addresses. The device automatically accesses the on-chip RAM when addressing within its bounds. When an address is generated outside the RAM bounds, the device automatically generates an external access.

#### parallel I/O ports

Each subsystem of the 5420 has a total of 64K I/O ports. These ports can be addressed by PORTR and PORTW. The IS signal indicates the read/write access through an I/O port. The devices can interface easily with external devices through the I/O ports while requiring minimal off-chip address-decoding logic. The SELA/B pin selects which subsystem has access to the external I/O space.



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### external memory interface

The 5420 has a single external memory interface shared between both subsystems. The external memory interface enables the 5420 subsystems to connect to external memory devices or other parallel interfaces. The SELA/B pin is used to determine which subsystem has access to the external memory interface. When the SELA/B pin is low, subsystem A has access to the external memory interface, and when it is high, subsystem

B has access to the interface. The external memory interface is also shared with the host port interface (HPI). The XIO pin is used to select between the external memory interface and the hostport interface. When the XIO pin is high, the external memory interface is active, and when it is low, the host port interface is active.

#### processor mode status register (PMST)

Each subsystem has a processor-mode status register (PMST) that controls memory configuration. The bit layout of the PMST register is shown in Figure 1

| 15   | 7 | 6     | 5    | 4    | 3    | 2      | 1    | 0   |
|------|---|-------|------|------|------|--------|------|-----|
| IPTR |   | MP/MC | OVLY | AVIS | DROM | CLKOFF | SMUL | SST |
| R/W  |   | R/W   | R/W  | R/W  | R/W  | R/W    | R/W  | R/W |

LEGEND: R = Read, W = Write

#### Figure 1. Processor Mode Status Register (PMST) Bit Layout

The functions of the PMST register bits are illustrated in the memory map. The MP/MC bit is used to map the upper address range of all program space pages (x8000–xFFFF) as either external or internal memory. The OVLY bit is used to overlay the on-chip DARAMO and SARAM1 blocks from dataspace onto to program space. Similarly, the DROM bit is used to overlay the SARAM2 block from program space onto data space. See the *TMS320C54x DSP Reference Set, Volume 1: CPU and Peripherals* (literature number SPRU131) for a description of the other bits of the PMST register.

Due to the dual-processor configuration and the several EMIF/HPI options available, the MP/MC bit is initialized at the time of device reset to a logic level that is dependent on the XIO, HMODE, and SELA/B pins. Table 1 shows the initialized logic level of the MP/MC bit and how it depends on these pins.

|     | 5420 PIN | S      | MP/M        | MP/MC BIT   |  |  |  |  |  |
|-----|----------|--------|-------------|-------------|--|--|--|--|--|
| XIO | HMODE    | SELA/B | SUBSYSTEM A | SUBSYSTEM B |  |  |  |  |  |
| 0   | Х        | Х      | 0           | 0           |  |  |  |  |  |
| 1   | 0        | Х      | 1           | 1           |  |  |  |  |  |
| 1   | 1        | 0      | 1           | 0           |  |  |  |  |  |
| 1   | 1        | 1      | 0           | 1           |  |  |  |  |  |

## Table 1. MP/MC Bit Logic Levels at Reset



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008



#### <sup>†</sup> The external memory interface must be enabled by driving the XIO pin high, in order for external memory accesses to occur.

#### Figure 2. Memory Map for Each CPU Subsystem

#### multicore reset signals

The 5420 device includes three reset signals:  $\overline{A_RS}$ ,  $\overline{B_RS}$ , and  $\overline{HPIRS}$ . The  $\overline{A_RS}$  and  $\overline{B_RS}$  pins function as the CPU reset signal for subsystem A and subsystem B, respectively. These signals reset the state of the CPU registers and upon release, initiates the reset function. Additionally, the  $\overline{A_RS}$  signal resets the on-chip PLL and initializes the CLKMD register to bypass mode.

The HPI reset signal (HPIRS) places the HPI peripheral into a reset state. It is necessary to wait three clock cycles after the rising edge of HPIRS before performing an HPI access.

#### reset vector initialization

The 5420 device does not have on-chip ROM and therefore does not contain bootloader routines/software. Consequently, the user must have a valid reset vector in place before releasing the reset signal. This is referred to as *reset vector initialization*. After reset, the 5420 device fetches the reset vector at address 0xFF80 in program memory and begins to execute the instructions found in memory. The application code is raw program and data words and does not require the traditional *boot-table* or *boot-packet* format.



### memory map

#### SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### reset vector initialization (continued)

The selection of the reset initialization option is determined by the state of three pins; XIO, XMODE, and SELA/B. The options include:

- HPI (host-dependent)
- EMIF-to-HPI (stand-alone)
- Simultaneous EMIF (stand-alone)
- Sequential EMIF (stand-alone)

#### HPI

The HPI method is only valid when the level of the XIO pin is low. The 5420 acts as a slave to an external master host. The host device must keep the 5420 device in reset as it downloads code to the subsystem that is determined by the logic level of the SELA/B pin. When SELA/B is low, the master downloads code to subsystem A. By driving SELA/B high, the master host can subsequently download code to subsystem B. The HMODE pin determines the configuration of the HPI (multiplexed or nonmultiplexed) and is an asynchronous input. Therefore, HMODE can be changed to the desired configuration while A\_RS and B\_RS are low prior to the transfer. Once the subsystem(s) have been loaded and are ready to execute, the master host can release the reset pin(s).

There are two valid options for controlling the reset function of the subsystems. The first option is to hold the  $\overline{A}_RS$  and  $\overline{B}_RS$  pins low while the HPIRS pin transitions from low to high. This keeps the cores in reset while allowing the HPI full access to download the application code. The host can now drive the  $\overline{A}_RS$  and  $\overline{B}_RS$  signals high simultaneously or separately to release the respective subsystem from reset. The subsystems then fetch their respective reset vector. If the subsystems are released from reset seperately, subsystem A should be released from reset first, since the  $\overline{A}_RS$  pin resets the on-chip PLL that is common to both subsystems.

Another valid option is to keep the  $\overline{A_RS}$  and  $\overline{B_RS}$  pins high while the host transitions the  $\overline{HPIRS}$  pin from low to high. Special internal logic causes the HPI to be fully operable and the cores remain in reset. As a result, after the host processor has downloaded the application code via the HPI, it must perform an additional HPI write (any value) to address 0x2F. This releases the respective subsystem from reset. By changing the value of SELA/B, the host can write to 0x2F via the HPI to release the other subsystem from reset.

## EMIF-to-HPI

In this particular vector initialization method, the host processor controlling the HPI is one of the subsystems. The master host is subsystem A if SELA/B is low and subsystem B when SELA/B is high. As described in the signal descriptions table, the address, data, and control signals of the program space are multiplexed with the HPI signals. In a special mode when XIO is high (EMIF mode) and HMODE is high (HPI nonmultiplexed mode), these multiplexed signals are connected, making it possible for the master subsystem's EMIF to initialize the slave subsystem via the slave's HPI. The master subsystem then releases the slave from reset either by transitioning the hardware reset signal ( $\overline{x}$ \_RS) high, or in software, by writing to memory location 0x2F via the HPI. As a result, the slave core fetches the reset vector.

#### simultaneous EMIF

The simultaneous EMIF vector initialization option allows both subsystems to access external memory simultaneously. The subsystems are designed to operate synchronized with one another while accessing the same locations simultaneously. In this mode, when XIO is high and HMODE is low, one subsystem is given full control of the EMIF while the other subsystem relies on the synchronization of the two subsystems. Instructions fetched by one subsystem are ready for both subsystems to execute. After the application code is executed or transferred to internal memory, write accesses to external memory are prohibited.

This method requires the  $\overline{A}RS$  and  $\overline{B}RS$  pins to be tied high while  $\overline{HPIRS}$  transitions from low to high. When HPIRS transitions high, both subsystems fetches the same reset vector.



#### sequential EMIF

The sequential EMIF option allows one master subsystem to run from external memory while controlling the slave subsystem's  $\overline{RS}$  signal and the SELA/B pin. At system reset, only the master subsystem is actually reset. Upon a low-to-high transition of the master's  $\overline{RS}$  signal, the master subsystem fetches the reset vector and proceeds to copy external application code to internal memory space. The master subsystem begins executing the application code, then changes the state of SELA/B, relinquishing the external EMIF to the slave subsystem. The master then releases the slave  $\overline{RS}$  signal. As a result, the slave fetches the reset vector and begins to copy the external application code to internal memory space. Note, GPIO pins on the master subsystem can be used to control the SELA/B and slave reset ( $\overline{x}$ \_RS) pins externally.

## on-chip peripherals

All the 54x devices have the same CPU structure; however, they have different on-chip peripherals connected to their CPUs. The on-chip peripheral options provided on each subsystem of the 5420 are:

- Software-programmable wait-state generator
- Programmable bank-switching
- 16-bit host-port interface (HPI16)
- Multichannel buffered serial ports (McBSPs)
- A hardware timer
- A software-programmable clock generator with a phase-locked loop (PLL)

#### software-programmable wait-state generators

The Software-programmable wait-state generator can be used to extend external bus cycles up to fourteen machine cycles to interface with slower off-chip memory and I/O devices. Note that all external memory accesses on the 5420 require at least one wait state. The software wait-state register (SWWSR) controls the operation of the wait-state generator. The SWWSR of a particular DSP subsystem (A or B) is used for the external memory interface, depending on the logic level of the SELA/B pin.The 14 LSBs of the SWWSR specify the number of wait states (0 to 7) to be inserted for external memory accesses to five separate address ranges. This allows a different number of wait states for each of the five address ranges.

Additionally, the software wait-state multiplier (SWSM) bit of the software wait-state control register (SWCR) defines a multiplication factor of 1 or 2 for the number of wait states. At reset, the wait-state generator is initialized to provide seven wait states on all external memory accesses. The SWWSR bit fields are shown in Figure 3 and described in Table 2.

| 15    | 14  | 12    | 11 | 9       | 8 |         | 6 | 5    | 3     | 2 | C      | ) |
|-------|-----|-------|----|---------|---|---------|---|------|-------|---|--------|---|
| XPA   | I/C | C     |    | Data    |   | Data    |   | Prog | jram  | Р | rogram |   |
| R/W-0 | R/W | /-111 |    | R/W-111 |   | R/W-111 |   | R/V  | V-111 | R | /W-111 | _ |

LEGEND: R=Read, W=Write, 0=Value after reset

Figure 3. Software Wait-State Register (SWWSR) [Memory-Mapped Register (MMR) Address 0028h]



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### software-programmable wait-state generator (continued)

|       | BIT         | RESET | FUNCTION                                                                                                                                                                                                                                                   |
|-------|-------------|-------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NO.   | NAME        | VALUE | FUNCTION                                                                                                                                                                                                                                                   |
| 15    | XPA         | 0     | Extended program address control bit. XPA is used in conjunction with the program space fields (bits 0 through 5) to select the address range for program space wait states.                                                                               |
| 14–12 | I/O         | 1     | I/O space. The field value (0–7) corresponds to the base number of wait states for I/O space accesses within addresses 0000–FFFFh. The SWSM bit of the SWCR defines a multiplication factor of 1 or 2 for the base number of wait states.                  |
| 11–9  | Data        | 1     | Upper data space. The field value (0–7) corresponds to the base number of wait states for external data space accesses within addresses 8000–FFFFh. The SWSM bit of the SWCR defines a multiplication factor of 1 or 2 for the base number of wait states. |
| 8–6   | Data        | 1     | Lower data space. The field value (0–7) corresponds to the base number of wait states for external data space accesses within addresses 0000–7FFFh. The SWSM bit of the SWCR defines a multiplication factor of 1 or 2 for the base number of wait states. |
|       |             |       | Upper program space. The field value $(0-7)$ corresponds to the base number of wait states for external program space accesses within the following addresses:<br>$\Box$ XPA = 0: x8000 - xFFFFh                                                           |
| 5–3   | 5–3 Program |       | <ul> <li>XPA = 1: The upper program space bit field has no effect on wait states.</li> <li>The SWSM bit of the SWCR defines a multiplication factor of 1 or 2 for the base number of wait states.</li> </ul>                                               |
| 2-0   | Program     | 1     | Program space. The field value (0–7) corresponds to the base number of wait states for external program space accesses within the following addresses:<br>XPA = 0: x0000-x7FFFh                                                                            |
| 2-0   | riogram     | 1     | <ul> <li>XPA = 1: 00000–3FFFFh</li> <li>The SWSM bit of the SWCR defines a multiplication factor of 1 or 2 for the base number of wait states.</li> </ul>                                                                                                  |

#### Table 2. Software Wait-State Register (SWWSR) Bit Fields

The software wait-state multiplier bit of the software wait-state control register (SWCR) is used to extend the base number of wait states selected by the SWWSR. The SWCR bit fields are shown in Figure 4 and described in Table 3.

| 15 | 1        | 0     |
|----|----------|-------|
|    | Reserved | SWSM  |
|    | R/W-0    | R/W-0 |

**LEGEND:** R = Read, W = Write

#### Figure 4. Software Wait-State Control Register (SWCR) [MMR Address 002Bh]

#### Table 3. Software Wait-State Control Register (SWCR) Bit Fields

|    | PIN         | RESET | FUNCTION                                                                                                                                                                                  |
|----|-------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| N  | D. NAME     | VALUE | FUNCTION                                                                                                                                                                                  |
| 15 | -1 Reserved | 0     | These bits are reserved and are unaffected by writes.                                                                                                                                     |
| (  | ) SWSM      | 0     | Software wait-state multiplier. Used to multiply the number of wait states defined in the SWWSR by a factor of 1 or 2.  SWSM = 0: wait-state base values are unchanged (multiplied by 1). |
|    |             |       | SWSM = 1: wait-state base values are mulitplied by 2 for a maximum of 14 wait states.                                                                                                     |



#### programmable bank-switching

Programmable bank-switching can be used to insert one cycle automatically when crossing memory-bank boundaries inside program memory or data memory space. One cycle can also be inserted when crossing from program-memory space to data-memory space (54x) or one program memory page to another program memory page. This extra cycle allows memory devices to release the bus before other devices start driving the bus; thereby avoiding bus contention. The size of the memory bank for the bank-switching is defined by the bank-switching control register (BSCR). The BSCR of a particular DSP subsystem (A or B) is used for the external memory interface depending on the logic level of the SELA/B pin.

| _ | 15  | 12  | 11    | 10   | 9    | 8     | 7 |          | 3 | 2   | 1        | 0    |
|---|-----|-----|-------|------|------|-------|---|----------|---|-----|----------|------|
|   | BNK | CMP | PS-DS | Rese | rved | IPIRQ |   | Reserved |   | BH  | Reserved | EXIO |
|   | R/  | N   | R/W   | R/   | w    | R/W   |   |          |   | R/W |          | R/W  |

LEGEND: R = Read, W = Write

#### Figure 5. BSCR Register Bit Layout for Each DSP Subsystem

| BIT<br>NO. | BIT<br>NAME | RESET<br>VALUE | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|-------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15–12      | BNKCMP      | 1111           | Bank compare. BNKCMP determines the external memory-bank size. BNKCMP is used to mask the four MSBs of an address. For example, if BNKCMP = 1111b, the four MSBs (bits 12–15) are compared, resulting in a bank size of 4K words. Bank sizes of 4K words to 64K words are allowed.                                                                                                                                 |
| 11         | PS-DS       | 1              | Program read - data read access. PS-DS inserts an extra cycle between consecutive accesses of<br>program read and data read or data read and program read.PS-DS = 0No extra cycles are inserted by this feature.PS-DS = 1One extra cycle is inserted between consecutive data and program reads.                                                                                                                   |
| 10–9       | Reserved    | 0              | These bits are reserved and are unaffected by writes.                                                                                                                                                                                                                                                                                                                                                              |
| 8          | IPIRQ       | 0              | The IPIRQ bit is used to send an interprocessor interrupt to the other subsystem. IPIRQ=1 sends the interrupt. IPIRQ must be cleared before subsequent interrupts can be made. Refer to the interrupts section for more details                                                                                                                                                                                    |
| 7–3        | Reserved    | 0              | These bits are reserved and are unaffected by writes.                                                                                                                                                                                                                                                                                                                                                              |
| 2          | вн          | 0              | Bus holder. BH controls the data bus holder feature: BH is cleared to 0 at reset.         BH = 0       The bus holder is disabled.         BH = 1       The bus holder is enabled. When not driven, the data bus (PPD[15:0]) is held in the previous logic level.                                                                                                                                                  |
| 1          | Reserved    | 0              | These bits are reserved and are unaffected by writes.                                                                                                                                                                                                                                                                                                                                                              |
| 0          | EXIO        | 0              | External bus interface off. The EXIO bit controls the external bus-off function.         EXIO = 0       The external bus interface functions as usual.         EXIO = 1       The address bus, data bus, and control signals become inactive after completing the current bus cycle. Note that the DROM, MP/MC, and OVLY bits in the PMST and the HM bit of ST1 cannot be modified when the interface is disabled. |

#### Table 4. BSCR Register Bit Functions for Each DSP Subsystem



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### 16-bit host-port interface (HPI16)

The HPI16 is an enhanced 16-bit version of the C54x 8-bit host-port interface (HPI). The HPI16 is designed to allow a 16-bit host to access the DSP on-chip memory, with the host acting as the master of the interface. Figure 6 illustrates the available memory accessible by the HPI. It should be noted that neither the CPU nor DMA I/O spaces can be accessed using the host-port interface.

## 16-bit bidirectional host-port interface (HPI16)

| Hex  | Program Page 0                                 | Hex   | Program Page 1                                 | Hex   | Program Page 2                                 | Hex   | Program Page 3                                 |
|------|------------------------------------------------|-------|------------------------------------------------|-------|------------------------------------------------|-------|------------------------------------------------|
| 0000 |                                                | 10000 |                                                | 20000 |                                                | 30000 |                                                |
| 001F | Reserved                                       |       |                                                |       |                                                |       |                                                |
| 0020 | McBSP                                          |       | Reserved                                       |       | Reserved                                       |       | Reserved                                       |
| 005F | DXR/DRR<br>MMRegs Only                         | 1005F |                                                | 2005F |                                                | 3005F |                                                |
| 0060 |                                                | 10060 |                                                | 20060 |                                                | 30060 |                                                |
|      | On-Chip<br>DARAM 0<br>(Overlayed)<br>Prog/Data |       | On-Chip<br>DARAM 0<br>(Overlayed)<br>Prog/Data |       | On-Chip<br>DARAM 0<br>(Overlayed)<br>Prog/Data |       | On-Chip<br>DARAM 0<br>(Overlayed)<br>Prog/Data |
| 3FFF |                                                | 13FFF |                                                | 23FFF |                                                | 33FFF |                                                |
| 4000 |                                                | 14000 |                                                | 24000 |                                                | 34000 |                                                |
|      | On-Chip<br>SARAM 1<br>(Overlayed)<br>Prog/Data |       | On-Chip<br>SARAM 1<br>(Overlayed)<br>Prog/Data |       | On-Chip<br>SARAM 1<br>(Overlayed)<br>Prog/Data |       | On-Chip<br>SARAM 1<br>(Overlayed)<br>Prog/Data |
| 7FFF |                                                | 17FFF |                                                | 27FFF |                                                | 37FFF |                                                |
| 8000 | On-Chip<br>SARAM 2<br>(32K Words)<br>Prog/Data | 18000 | On-Chip<br>SARAM 3<br>(32K Words)<br>Program   | 28000 | Reserved                                       | 38000 | Reserved                                       |
| FFFF |                                                | 1FFFF |                                                | 2FFFF |                                                | 3FFFF |                                                |

Figure 6. Memory Map Relative to Host-Port interface



## 16-bit bidirectional host-port interface (HPI16) (continued)

Some of the features of the HPI16 include:

- 16-bit bidirectional data bus
- Multiple data strobes and control signals to allow glueless interfacing to a variety of hosts
- Multiplexed and nonmultiplexed address/data modes
- 18-bit address bus used in nonmultiplexed mode to allow access to all internal memory (including internal extended address pages)
- 18-bit address register used in multiplexed mode. Includes address autoincrement feature for faster accesses to sequential addresses
- Interface to on-chip DMA module to allow access to entire internal memory space
- HRDY signal to hold off host accesses due to DMA latency
- Control register available in *multiplexed* mode only. Accessible by either host or DSP to provide host/DSP interrupts, extended addressing, and data prefetch capability

The HPI16 acts as a slave to a 16-bit host processor and allows access to the on-chip memory of the DSP. There are two modes of operation as determined by the HMODE signal: *multiplexed* mode and *nonmultiplexed* mode.

#### HPI multiplexed mode

In *multiplexed* mode, HPI16 operation is very similar to the standard 8-bit HPI, which is available with other C54x products. A host with a multiplexed address/data bus can access the HPI16 data register (HPID), address register (HPIA), or control register (HPIC) via the HD bidirectional data bus. The host initiates the access with the strobe signals (HDS1, HDS2, HCS) and controls the type of access with the HCNTL, HR/W, and HAS signals. The DSP can interrupt the host via the HINT signal, and can stall host accesses via the HRDY signal.

#### host/DSP interrupts

In *multiplexed* mode, the HPI16 offers the capability for the host and DSP to interrupt each other through the HPIC register.

For host-to-DSP interrupts, the host must write a "1" to the DSPINT bit of the HPIC register. This generates an interrupt to the DSP. This interrupt can also be used to wake the DSP from any of the IDLE 1,2, or 3 states. Note that the DSPINT bit is always read as "0" by both the host and DSP.

For DSP-to-host interrupts, the DSP must write a "1" to the HINT bit of the HPIC register to interrupt the host via the HINT pin. The host acknowledges and clear this interrupt by also writing a "1" to the HINT bit of the HPIC register. Note that writing a "0" to the HINT bit by either host or DSP has no effect.

## HPI nonmultiplexed mode

In *nonmultiplexed* mode, a host with separate address/data buses can access the HPI16 data register (HPID) via the HD 16-bit bidirectional data bus, and the address register (HPIA) via the 18-bit HA address bus. The host initiates the access with the strobe signals (HDS1, HDS2, HCS) and controls the direction of the access with the HR/W signal. The HPI16 can stall host accesses via the HRDY signal. Note that the HPIC register is not available in *nonmultiplexed* mode since there are no HCNTL signals available. All host accesses initiate a DMA read or write access.

#### other HPI16 system considerations

#### operation during IDLE2

The HPI16 can continue to operate during IDLE1 or IDLE2 by using special clock management logic that turns on relevant clocks to perform a synchronous memory access, and then turns the clocks back off to save power. The DSP CPU does not wake up from the IDLE mode during this process.



#### SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### downloading code during reset

The HPI16 can download code while the DSP is in reset. However, the system provides a pin (HPIRS) that provides a way to take the HPI16 module out of reset while leaving the DSP in reset.

#### emulation considerations

The HPI16 can continue operation even when the DSP CPU is halted due to debugger breakpoints or other emulation events.

#### 5420 boundary scan implementation

The 5420 does not implement a fully compliant IEEE1149.1 boundary scan capability. Observe-only boundary scan cells are used on all of the device pins that allow the pins to be observed (read) but not controlled (driven) using boundary scan. Driving nodes to perform board interconnect test must be accomplished using other boundary scan capable devices on the board. Although this implies some reduction in testability, compared to full boundary scan, this implementation is still compatible with the boundary scan automatic test pattern generation (ATPG) tools.

## multichannel buffered serial port (McBSP)

The 5420 device provides high-speed, full-duplex serial ports that allow direct interface to other C54x<sup>™</sup> devices, codecs, and other devices in a system. There are six multichannel buffered serial ports (McBSPs) on chip (three per subsystem).

The McBSP is based on the standard serial port interface found on the 54x devices. Like its predecessors, the McBSP provides:

- Full-duplex communication
- Double-buffer data registers, which allow a continuous data stream
- Independent framing and clocking for receive and transmit

In addition, the McBSP has the following capabilities:

- Direct interface to:
  - T1/E1 framers
  - MVIP switching-compatible and ST-BUS compliant devices
  - IOM-2 compliant device
  - Serial peripheral interface devices
- Multichannel transmit and receive of up to 128 channels
- A wide selection of data sizes, including: 8, 12, 16, 20, 24, or 32 bits
- μ-law and A-law companding
- Programmable polarity for both frame synchronization and data clocks
- Programmable internal clock and frame generation

The McBSP consists of a data path and control path. The six pins, BDX, BDR, BFSX, BFSR, BCLKX, and BCLKR, connect the control and data paths to external devices. The pins can be programmed as general-purpose I/O pins if they are not used for serial communication.



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

## multichannel buffered serial port (McBSP) (continued)

Like the standard serial port interface on the McBSP, the data is communicated to devices interfacing to the McBSP by way of the data transmit (BDX) pin for transmit and the data receive (BDR) pin for receive. Control information in the form of clocking and frame synchronization is communicated by way of BCLKX, BCLKR, BFSX, and BFSR. The device communicates to the McBSP by way of 16-bit-wide control registers accessible via the internal peripheral bus. The CPU or DMA reads the received data from the data receive register (DRR) and writes the data to be transmitted to the data transmit register (DXR). Data written to the DXR is shifted out to BDX by way of the transmit shift register (XSR). Similarly, receive data on the BDR pin is shifted into the receive shift register (RSR) and copied into the receive buffer register (RBR). RBR is then copied to DRR, which can be read by the CPU or DMA. This allows internal data movement and external data communications simultaneously. The control block consists of internal clock generation, frame synchronization signal generation, and their control, and multichannel selection. This control block sends notification of important events to the CPU and DMA by way of two interrupt signals, XINT and RINT, and two event signals, XEVT and REVT.

The on-chip companding hardware allows compression and expansion of data in either  $\mu$ -law or A-law format. When companding is used, transmitted data is encoded according to specified companding law and received data is decoded to 2's complement format.

The sample rate generator provides the McBSP with several means of selecting clocking and framing for both the receiver and transmitter. Both the receiver and transmitter can select clocking and framing independently.

The McBSP allows the multiple channels to be independently selected for the transmitter and receiver. When multiple channels are selected, each frame represents a time-division multiplexed (TDM) data stream. In using time-division multiplexed data streams, the CPU may only need to process a few of them. Thus, to save memory and bus bandwidth, multichannel selection allows independent enabling of particular channels for transmission and reception. Up to 32 channels in a bit stream consisting of a maximum of 128 channels can be enabled.

The clock stop mode (CLKSTP) in the McBSP provides compatibility with the SPI protocol. Clock stop mode works with only single-phase frames and one word per frame. The word sizes supported by the McBSP are programmable for 8-, 12-, 16-, 20-, 24-, or 32-bit operation. When the McBSP is configured to operate in SPI mode, both the transmitter and the receiver operate together as a master or as a slave.

## direct memory access unit (DMA)

The 5420 direct memory access (DMA) controller transfers data between points in the memory map without intervention by the CPU. The DMA allows movements of data to and from internal program/data memory, internal peripherals, such as the McBSPs and the HPI to occur in the background of the CPU operation. Each subsystem has its own independent DMA with six programmable channels, allowing six different contexts for DMA operation. The HPI has a dedicated auxiliary DMA channel. Figure 7 illustrates the memory map accessible by the DMA.



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

## direct memory access unit (DMA) (continued)



<sup>†</sup> When the source or destination for a DMA channel is programmed for I/O space, the channel accesses the core-to-core FIFO irrespective of the address specified.

## Figure 7. Memory Map Relative to DMA

#### features

The 5420 DMA has the following features:

- The DMA operates independently of the CPU.
- The DMA has six channels. The DMA can keep track of the contexts of six independent block transfers.
- The DMA has higher priority than the CPU for internal accesses.
- Each channel has independently programmable priorities.
- Each channel's source and destination address registers can have configurable indexes through memory on each read and write transfer, respectively. The address can remain constant, postincrement, postdecrement or be adjusted by a programmable value.
- Each read or write transfer can be initialized by selected events.
- On completion of a half-block or full-block transfer, each DMA channel can send an interrupt to the CPU.
- An on-chip RAM DMA transfer requires 4 clock cycles to complete. External transfers are not supported.
- The DMA can perform double word transfers (a 32-bit transfer of two16-bit-words).



### DMA controller synchronization events

The transfers associated with each DMA channel can be synchronized to one of several events. The DSYN bit field of the DMA channel x sync select and frame count (DMSFCx) register selects the synchronization event for a channel. The list of possible events and the DSYN values are shown in Table 5.

| DSYN VALUE    | DMA SYNCHRONIZATION EVENT           |
|---------------|-------------------------------------|
| 0000b         | No synchronization used             |
| 0001b         | McBSP0 Receive Event                |
| 0010b         | McBSP0 Transmit Event               |
| 0011b         | McBSP2 Receive Event                |
| 0100b         | McBSP2 Transmit Event               |
| 0101b         | McBSP1 Receive Event                |
| 0110b         | McBSP1 Transmit Event               |
| 0111b         | FIFO Receive Buffer Not Empty Event |
| 1000b         | FIFO Transmit Buffer Not Full Event |
| 1001b – 1111b | Reserved                            |

| Table 5. DMA Synchronization Events | Table 5. | DMA | Synchronization | <b>Events</b> |
|-------------------------------------|----------|-----|-----------------|---------------|
|-------------------------------------|----------|-----|-----------------|---------------|

#### DMA channel interrupt selection

The DMA controller can generate a CPU interrupt for each of the six channels. However, channels 0, 1, 2, and 3 are multiplexed with other interrupt sources. DMA channels 0 and 1 share an interrupt line with the receive and transmit portions of McBSP2 (IMR/IFR bits 6 and 7), and DMA channels 2 and 3 share an interrupt line with the receive and transmit portions of McBSP1 (IMR/IFR bits 10 and 11). When the 5402 is reset, the interrupts from these four DMA channels are deselected. The INTSEL bit field in the DMA channel priority and enable control (DMPREC) register can be used to select these interrupts, as shown in Table 6.

| Table 6 | . DMA | Channel | Interrupt | Selection |
|---------|-------|---------|-----------|-----------|
|---------|-------|---------|-----------|-----------|

| INTSEL Value | IMR/IFR[6] | IMR/IFR[7] | IMR/IFR[10] | IMR/IFR[11] |
|--------------|------------|------------|-------------|-------------|
| 00b (reset)  | BRINT2     | BXINT2     | BRINT1      | BXINT1      |
| 01b          | BRINT2     | BXINT2     | DMAC2       | DMAC3       |
| 10b          | DMAC0      | DMAC1      | DMAC2       | DMAC3       |
| 11b          |            | Rese       | erved       |             |

#### subsystem communications

The 5420 device provides two options for efficient core-to-core communications:

- Core-to-core FIFO communications
- EMIF-to-HPI communications (asynchronous external memory interface-to host-port interface)



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### FIFO data communications

The subsystems' FIFO communications interface is shown in the 5420 functional block diagram (Figure 1). Two unidirectional 8-word-deep FIFOs are available in the device for efficient interprocessor communication: one configured for core A-to-core B data transfers, and the other configured for core B-to-core A data transfers. Each subsystem, by way of DMA control, can write to its respective output data FIFO and read from its respective input data FIFO. The FIFOs are accessed using the DMA's I/O space, which is completely independent of the CPU I/O space. The DMA transfers to or from the FIFOs can be synchronized to "receive FIFO not empty" and "transmit FIFO not full" events providing protection from overflow and underflow. Subsystems can interrupt each other to flag when the FIFOs are either full or empty. The interprocessor interrupt request bit (IPIRQ) (bit 8 in the BSCR register ) is set to "1" to generate an interprocessor interrupt (IPINT) in the other subsystem. See the *interrupts* section for more information.

#### **EMIF-to-HPI data communication**

The 5420 also provides the capability for one subsystem to act as a master and transfer data to the other subsystem via an EMIF-to-HPI connection. The master device is configured in EMIF mode (XIO pin is high); while by default, when HMODE=1, the slave device external interface is configured to operate as an HPI (nonmultiplexed mode). The data-transfer direction is defined by the logic level of SELA/B. See Table 7 for a complete description of HMODE, SELA/B, and XIO pin functionality. The EMIF-to-HPI option is bidirectional, but does not permit full duplex communication without external SELA/B arbitration. This mode does not offer master/slave interrupts due to the nonmultiplexed HPI configuration.

| HMODE | SELA/B | HPI MODES (XIO PIN =0)                                       | EMIF MODES (XIO PIN = 1)                                                |  |
|-------|--------|--------------------------------------------------------------|-------------------------------------------------------------------------|--|
| 0     | 0      | HPI multiplexed address/data<br>Subsystem A slave to host    | Subsystem A can access EMIF<br>Subsystem B has no access to EMIF or HPI |  |
| 0     | 1      | HPI multiplexed address/data<br>Subsystem B slave to host    | Subsystem B can access EMIF<br>Subsystem A has no access to EMIF or HPI |  |
| 1     | 0      | HPI nonmultiplexed address/data<br>Subsystem A slave to host | EMIF-to-HPI master is subsystem A, slave is<br>subsystem B              |  |
| 1     | 1      | HPI nonmultiplexed address/data<br>Subsystem B slave to host | EMIF-to-HPI master is subsystem B, slave is subsystem A                 |  |

#### Table 7. EMIF/HPI Modes

## general-purpose I/O

In addition to the standard XF and BIO pins, the 5420 has eight general-purpose I/O pins. These pins are:

A\_GPIO0, A\_GPIO1, A\_GPIO2, A\_GPIO3

B\_GPIO0, B\_GPIO1, B\_GPIO2, B\_GPIO3

Each subsystem's CPU has one general-purpose I/O register located at address 0x3c in data memory. Each I/O register controls four general-purpose I/O pins. Figure 8 shows the bit layout of the general-purpose I/O control register and Table 8 describes the bit functions.



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008



**LEGEND:** R = Read, W = Write

### Figure 8. General-Purpose I/O Control Register Bit Layout

| BIT<br>NO. | BIT<br>NAME | BIT<br>VALUE | FUNCTION                                                                                   |                                 |  |
|------------|-------------|--------------|--------------------------------------------------------------------------------------------|---------------------------------|--|
| 45         | 0           |              | Timer output disable. Uses GPIO3 as general-purpose I/O. (Reset value)                     |                                 |  |
| 15         | TOUT        | 1            | Timer output enable. Overrides DIR3. Timer output is driven on GPIO3 and readable in DAT3. |                                 |  |
| 14-12      | Reserved    | Х            | Register bit is reserved.                                                                  |                                 |  |
| 44.0       | 11–8 DIRn†  | 0            | GPIOn pin is used as an input. <i>(Reset value)</i>                                        |                                 |  |
| 11–8       |             | -8 DIRNI     | 1                                                                                          | GPIOn pin is used as an output. |  |
| 7–4        | Reserved    | Х            | Register bit is reserved.                                                                  |                                 |  |
|            | 3–0 DATn†   | 0            | GPIOn is driven with a 0 (DIRn=1). GPIOn is read as 0 (DIRn=0).                            |                                 |  |
| 3–0        |             | 1            | GPIOn is driven with a 1 (DIRn=1). GPIOn is read as 1 (DIRn=0).                            |                                 |  |

#### Table 8. General-Purpose I/O Control Register Bit Functions

† n = 0, 1, 2, or 3

The TOUT bit is used to multiplex the output of the timer and GPIO3. DIR3 has no affect when TOUT = 1. All pins are programmable as an input or output via the direction bit (DIRn). Data is either driven or read from the data bit field (DATn).

GPIO2 is a special case where the logic level determines the operation of  $\overline{\text{BIO}}$ -conditional instructions on the CPU. GPIO2 is always mapped as a general-purpose I/O, but the  $\overline{\text{BIO}}$  function exists when this pin is configured as an input.

#### hardware timer

Each subsystem of the 5420 features a 16-bit timing circuit with a 4-bit prescaler. The timer counter decrements by one at every CLKOUT cycle. Each time the counter decrements to zero, a timer interrupt is generated. The timer can be stopped, restarted, reset, or disabled by specific status bits. The timer output pulse is driven on GPIO3 when the TOUT bit is set to one in the general-purpose I/O control register. The device must be in HPI mode (XIO = 0) to drive TOUT on the GPIO3 pin.

#### software-programmable phase-locked loop (PLL)

The clock generator provides clocks to the 5420 device, and consists of a phase-locked loop (PLL) circuit. The clock generator requires a reference clock input, which must be provided by using an external clock source. The reference clock input is then divided by two (DIV mode) to generate clocks for the 5420 device. Alternately, the PLL circuit can be used (PLL mode) to generate the device clock by multiplying the reference clock frequency by a scale factor, allowing use of a clock source with a lower frequency than that of the CPU. The default startup mode for the PLL on the 5420 device is bypass (multiply-by-1).

The PLL is an adaptive circuit that, once synchronized, locks onto and tracks an input clock signal. When the PLL is initially started, it enters a transitional mode during which the PLL acquires lock with the input signal. Once the PLL is locked, it continues to track and maintain synchronization with the input signal. Only subsystem A controls the PLL. Subsystem B cannot access the PLL registers.



#### SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### software-programmable phase-locked loop (PLL) (continued)

The software-programmable PLL features a high level of flexibility, and includes a clock scaler that provides various clock multiplier ratios, capability to directly enable and disable the PLL, and a PLL lock timer that can be used to delay switching to PLL clocking mode of the device until lock is achieved. Devices that have a built-in software-programmable PLL can be configured in one of two clock modes:

- PLL mode. The input clock (CLKIN) is multiplied by 1 of 31 possible ratios. These ratios are achieved using the PLL circuitry.
- DIV (divider) mode. The input clock is divided by 2 or 4. Note that when DIV mode is used, the PLL can be completely disabled in order to minimize power dissipation.

The software-programmable PLL is controlled by the 16-bit memory-mapped (address 0058h) clock mode register (CLKMD) in subsystem A. The CLKMD register is used to define the clock configuration of the PLL clock module.



## memory-mapped registers

Each 5420 subsystem has 27 memory-mapped CPU registers, which are mapped in data memory space addresses 0h to 1Fh. Table 9 gives a list of CPU memory-mapped registers (MMRs) available on 5420. Each subsystem device also has a set of memory-mapped registers associated with peripherals. Table 10, and Table 11 show additional peripheral MMRs associated with the 5420.

| NAME | ADDF<br>DEC | RESS<br>HEX | DESCRIPTION                      |  |
|------|-------------|-------------|----------------------------------|--|
| IMR  | 0           | 0           | Interrupt Mask Register          |  |
| IFR  | 1           | 1           | Interrupt Flag Register          |  |
| —    | 2–5         | 2–5         | Reserved for testing             |  |
| ST0  | 6           | 6           | Status Register 0                |  |
| ST1  | 7           | 7           | Status Register 1                |  |
| AL   | 8           | 8           | Accumulator A Low Word (15–0)    |  |
| AH   | 9           | 9           | Accumulator A High Word (31–16)  |  |
| AG   | 10          | А           | Accumulator A Guard Bits (39–32) |  |
| BL   | 11          | В           | Accumulator B Low Word (15–0)    |  |
| вн   | 12          | С           | Accumulator B High Word (31–16)  |  |
| BG   | 13          | D           | Accumulator B Guard Bits (39–32) |  |
| TREG | 14          | E           | Temporary Register               |  |
| TRN  | 15          | F           | Transition Register              |  |
| AR0  | 16          | 10          | Auxiliary Register 0             |  |
| AR1  | 17          | 11          | Auxiliary Register 1             |  |
| AR2  | 18          | 12          | Auxiliary Register 2             |  |
| AR3  | 19          | 13          | Auxiliary Register 3             |  |
| AR4  | 20          | 14          | Auxiliary Register 4             |  |
| AR5  | 21          | 15          | Auxiliary Register 5             |  |
| AR6  | 22          | 16          | Auxiliary Register 6             |  |
| AR7  | 23          | 17          | Auxiliary Register 7             |  |
| SP   | 24          | 18          | Stack Pointer                    |  |
| ВК   | 25          | 19          | Circular Buffer Size Register    |  |
| BRC  | 26          | 1A          | Block-Repeat Counter             |  |
| RSA  | 27          | 1B          | Block-Repeat Start Address       |  |
| REA  | 28          | 1C          | Block-Repeat End Address         |  |
| PMST | 29          | 1D          | Processor Mode Status Register   |  |
| XPC  | 30          | 1E          | Extended Program Counter         |  |
| _    | 31          | 1F          | Reserved                         |  |

 Table 9. Processor Memory-Mapped Registers for Each DSP Subsystem



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

## memory-mapped registers (continued)

## Table 10. Peripheral Memory-Mapped Registers for Each DSP Subsystem

| NAME   | ADDI<br>DEC | RESS<br>HEX | DESCRIPTION                                               |  |  |  |
|--------|-------------|-------------|-----------------------------------------------------------|--|--|--|
| DRR20  | 32          | 20          | McBSP 0 Data Receive Register 2                           |  |  |  |
| DRR10  | 33          | 21          | McBSP 0 Data Receive Register 1                           |  |  |  |
| DXR20  | 34          | 22          | McBSP 0 Data Transmit Register 2                          |  |  |  |
| DXR10  | 35          | 23          | McBSP 0 Data Transmit Register 1                          |  |  |  |
| TIM    | 36          | 24          | Timer Register                                            |  |  |  |
| PRD    | 37          | 25          | Timer Period Register                                     |  |  |  |
| TCR    | 38          | 26          | Timer Control Register                                    |  |  |  |
| —      | 39          | 27          | Reserved                                                  |  |  |  |
| SWWSR  | 40          | 28          | Software Wait-State Register                              |  |  |  |
| BSCR   | 41          | 29          | Bank-Switching Control Register                           |  |  |  |
|        | 42          | 2A          | Reserved                                                  |  |  |  |
| SWCR   | 43          | 2B          | Software Wait-State Control Register                      |  |  |  |
| HPIC   | 44          | 2C          | HPI Control Register (HMODE=0 only)                       |  |  |  |
| —      | 45–47       | 2D-2F       | Reserved                                                  |  |  |  |
| DRR22  | 48          | 30          | McBSP 2 Data Receive Register 2                           |  |  |  |
| DRR12  | 49          | 31          | McBSP 2 Data Receive Register 1                           |  |  |  |
| DXR22  | 50          | 32          | McBSP 2 Data Transmit Register 2                          |  |  |  |
| DXR12  | 51          | 33          | McBSP 2 Data Transmit Register 1                          |  |  |  |
| SPSA2  | 52          | 34          | McBSP 2 Subbank Address Register <sup>†</sup>             |  |  |  |
| SPSD2  | 53          | 35          | McBSP 2 Subbank Data Register <sup>†</sup>                |  |  |  |
|        | 54–55       | 36–37       | Reserved                                                  |  |  |  |
| SPSA0  | 56          | 38          | McBSP 0 Subbank Address Register <sup>†</sup>             |  |  |  |
| SPSD0  | 57          | 39          | McBSP 0 Subbank Data Register <sup>†</sup>                |  |  |  |
|        | 58–59       | 3A-3B       | Reserved                                                  |  |  |  |
| GPIO   | 60          | 3C          | General-Purpose I/O Register                              |  |  |  |
|        | 61–63       | 3D-3F       | Reserved                                                  |  |  |  |
| DRR21  | 64          | 40          | McBSP 1 Data Receive Register 2                           |  |  |  |
| DRR11  | 65          | 41          | McBSP 1 Data Receive Register 1                           |  |  |  |
| DXR21  | 66          | 42          | McBSP 1 Data Transmit Register 2                          |  |  |  |
| DXR11  | 67          | 43          | McBSP 1 Data Transmit Register 1                          |  |  |  |
|        | 68–71       | 44–47       | Reserved                                                  |  |  |  |
| SPSA1  | 72          | 48          | McBSP 1 Subbank Address Register <sup>†</sup>             |  |  |  |
| SPSD1  | 73          | 49          | McBSP 1 Subbank Data Register <sup>†</sup>                |  |  |  |
| —      | 74–83       | 4A-53       | Reserved                                                  |  |  |  |
| DMPREC | 84          | 54          | DMA Priority and Enable Control Register                  |  |  |  |
| DMSA   | 85          | 55          | DMA Subbank Address Register <sup>‡</sup>                 |  |  |  |
| DMSDI  | 86          | 56          | DMA Subbank Data Register with Autoincrement <sup>‡</sup> |  |  |  |
| DMSDN  | 87          | 57          | DMA Subbank Data Register‡                                |  |  |  |
| CLKMD  | 88          | 58          | Clock Mode Register (CLKMD)                               |  |  |  |
| _      | 89–95       | 59–5F       | Reserved                                                  |  |  |  |
|        |             |             |                                                           |  |  |  |

<sup>†</sup> See Table 11 for a detailed description of the McBSP control registers and their subaddresses.

<sup>‡</sup> See Table 12 for a detailed description of the DMA sub-bank addressed registers.



#### McBSP control registers and subaddresses

The control registers for the multichannel buffered serial port (McBSP) are accessed using the subbank addressing scheme. This allows a set or subbank of registers to be accessed through a single memory location. The McBSP subbank address register (SPSA) is used as a pointer to select a particular register within the subbank. The McBSP data register (SPSDI) and the DMA autoincrement subaddress register (SPSDN) register are used to access (read or write) the selected register. Table 11 shows the McBSP control registers and their corresponding subaddresses.

| McBSP0 |         | McBSP1 |         | McBSP2 |         |                 |                                              |
|--------|---------|--------|---------|--------|---------|-----------------|----------------------------------------------|
| NAME   | ADDRESS | NAME   | ADDRESS | NAME   | ADDRESS | SUB-<br>ADDRESS | DESCRIPTION                                  |
| SPCR10 | 39h     | SPCR11 | 49h     | SPCR12 | 35h     | 00h             | Serial port control register 1               |
| SPCR20 | 39h     | SPCR21 | 49h     | SPCR22 | 35h     | 01h             | Serial port control register 2               |
| RCR10  | 39h     | RCR11  | 49h     | RCR12  | 35h     | 02h             | Receive control register 1                   |
| RCR20  | 39h     | RCR21  | 49h     | RCR22  | 35h     | 03h             | Receive control register 2                   |
| XCR10  | 39h     | XCR11  | 49h     | XCR12  | 35h     | 04h             | Transmit control register 1                  |
| XCR20  | 39h     | XCR21  | 49h     | XCR22  | 35h     | 05h             | Transmit control register 2                  |
| SRGR10 | 39h     | SRGR11 | 49h     | SRGR12 | 35h     | 06h             | Sample rate generator register 1             |
| SRGR20 | 39h     | SRGR21 | 49h     | SRGR22 | 35h     | 07h             | Sample rate generator register 2             |
| MCR10  | 39h     | MCR11  | 49h     | MCR12  | 35h     | 08h             | Multichannel register 1                      |
| MCR20  | 39h     | MCR21  | 49h     | MCR22  | 35h     | 09h             | Multichannel register 2                      |
| RCERA0 | 39h     | RCERA1 | 49h     | RCERA2 | 35h     | 0Ah             | Receive channel enable register partition A  |
| RCERB0 | 39h     | RCERB1 | 49h     | RCERA2 | 35h     | 0Bh             | Receive channel enable register partition B  |
| XCERA0 | 39h     | XCERA1 | 49h     | XCERA2 | 35h     | 0Ch             | Transmit channel enable register partition A |
| XCERB0 | 39h     | XCERB1 | 49h     | XCERA2 | 35h     | 0Dh             | Transmit channel enable register partition B |
| PCR0   | 39h     | PCR1   | 49h     | PCR2   | 35h     | 0Eh             | Pin control register                         |

Table 11. McBSP Control Registers and Subaddresses

## DMA subbank addressed registers

The direct memory access (DMA) controller has several control registers associated with it. The main control register (DMPREC) is a standard memory-mapped register. However, the other registers are accessed using the subbank addressing scheme. This allows a set or subbank of registers to be accessed through a single memory location. The DMA subbank address (DMSA) register is used as a pointer to select a particular register within the subbank, while the DMA subbank data (DMSD) register or the DMA subbank data register with autoincrement (DMSDI) is used to access (read or write) the selected register.

When the DMSDI register is used to access the subbank, the subbank address is automatically postincremented so that a subsequent access affects the next register within the subbank. This autoincrement feature is intended for efficient, successive accesses to several control registers. If the autoincrement feature is not required, the DMSDN register should be used to access the subbank. Table 12 shows the DMA controller subbank addressed registers and their corresponding subaddresses.



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### DMA subbank addressed registers (continued)

#### Table 12. DMA Subbank Addressed Registers

| NAME   | ADDRESS | SUB-<br>ADDRESS | DESCRIPTION                                           |
|--------|---------|-----------------|-------------------------------------------------------|
| DMSRC0 | 56h/57h | 00h             | DMA channel 0 source address register                 |
| DMDST0 | 56h/57h | 01h             | DMA channel 0 destination address register            |
| DMCTR0 | 56h/57h | 02h             | DMA channel 0 element count register                  |
| DMSFC0 | 56h/57h | 03h             | DMA channel 0 sync select and frame count register    |
| DMMCR0 | 56h/57h | 04h             | DMA channel 0 transfer mode control register          |
| DMSRC1 | 56h/57h | 05h             | DMA channel 1 source address register                 |
| DMDST1 | 56h/57h | 06h             | DMA channel 1 destination address register            |
| DMCTR1 | 56h/57h | 07h             | DMA channel 1 element count register                  |
| DMSFC1 | 56h/57h | 08h             | DMA channel 1 sync select and frame count register    |
| DMMCR1 | 56h/57h | 09h             | DMA channel 1 transfer mode control register          |
| DMSRC2 | 56h/57h | 0Ah             | DMA channel 2 source address register                 |
| DMDST2 | 56h/57h | 0Bh             | DMA channel 2 destination address register            |
| DMCTR2 | 56h/57h | 0Ch             | DMA channel 2 element count register                  |
| DMSFC2 | 56h/57h | 0Dh             | DMA channel 2 sync select and frame count register    |
| DMMCR2 | 56h/57h | 0Eh             | DMA channel 2 transfer mode control register          |
| DMSRC3 | 56h/57h | 0Fh             | DMA channel 3 source address register                 |
| DMDST3 | 56h/57h | 10h             | DMA channel 3 destination address register            |
| DMCTR3 | 56h/57h | 11h             | DMA channel 3 element count register                  |
| DMSFC3 | 56h/57h | 12h             | DMA channel 3 sync select and frame count register    |
| DMMCR3 | 56h/57h | 13h             | DMA channel 3 transfer mode control register          |
| DMSRC4 | 56h/57h | 14h             | DMA channel 4 source address register                 |
| DMDST4 | 56h/57h | 15h             | DMA channel 4 destination address register            |
| DMCTR4 | 56h/57h | 16h             | DMA channel 4 element count register                  |
| DMSFC4 | 56h/57h | 17h             | DMA channel 4 sync select and frame count register    |
| DMMCR4 | 56h/57h | 18h             | DMA channel 4 transfer mode control register          |
| DMSRC5 | 56h/57h | 19h             | DMA channel 5 source address register                 |
| DMDST5 | 56h/57h | 1Ah             | DMA channel 5 destination address register            |
| DMCTR5 | 56h/57h | 1Bh             | DMA channel 5 element count register                  |
| DMSFC5 | 56h/57h | 1Ch             | DMA channel 5 sync select and frame count register    |
| DMMCR5 | 56h/57h | 1Dh             | DMA channel 5 transfer mode control register          |
| DMSRCP | 56h/57h | 1Eh             | DMA source program page address (common channel)      |
| DMDSTP | 56h/57h | 1Fh             | DMA destination program page address (common channel) |
| DMIDX0 | 56h/57h | 20h             | DMA element index address register 0                  |
| DMIDX1 | 56h/57h | 21h             | DMA element index address register 1                  |
| DMFRI0 | 56h/57h | 22h             | DMA frame index register 0                            |
| DMFRI1 | 56h/57h | 23h             | DMA frame index register 1                            |
| DMGSA  | 56h/57h | 24h             | DMA global source address reload register             |
| DMGDA  | 56h/57h | 25h             | DMA global destination address reload register        |
| DMGCR  | 56h/57h | 26h             | DMA global count reload register                      |
| DMGFR  | 56h/57h | 27h             | DMA global frame count reload register                |



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

## interrupts

Vector-relative locations and priorities for all internal and external interrupts are shown in Table 13.

| NAME                      | LOCA<br>DECIMAL | TION<br>HEX | PRIORITY | FUNCTION                                                                                                             |
|---------------------------|-----------------|-------------|----------|----------------------------------------------------------------------------------------------------------------------|
| RS, SINTR                 | 0               | 00          | 1        | Reset (Hardware and Software Reset)                                                                                  |
| NMI, SINT16               | 4               | 04          | 2        | Nonmaskable Interrupt                                                                                                |
| SINT17                    | 8               | 08          | _        | Software Interrupt #17                                                                                               |
| SINT18                    | 12              | 0C          | _        | Software Interrupt #18                                                                                               |
| SINT19                    | 16              | 10          | _        | Software Interrupt #19                                                                                               |
| SINT20                    | 20              | 14          | _        | Software Interrupt #20                                                                                               |
| SINT21                    | 24              | 18          | _        | Software Interrupt #21                                                                                               |
| SINT22                    | 28              | 1C          | _        | Software Interrupt #22                                                                                               |
| SINT23                    | 32              | 20          | _        | Software Interrupt #23                                                                                               |
| SINT24                    | 36              | 24          | _        | Software Interrupt #24                                                                                               |
| SINT25                    | 40              | 28          | _        | Software Interrupt #25                                                                                               |
| SINT26                    | 44              | 2C          | _        | Software Interrupt #26                                                                                               |
| SINT27                    | 48              | 30          | _        | Software Interrupt #27                                                                                               |
| SINT28                    | 52              | 34          | _        | Software Interrupt #28                                                                                               |
| SINT29                    | 56              | 38          |          | Software Interrupt #29                                                                                               |
| SINT30                    | 60              | 3C          | _        | Software Interrupt #30                                                                                               |
| INTO, SINTO               | 64              | 40          | 3        | External User Interrupt #0                                                                                           |
| INT1, SINT1               | 68              | 44          | 4        | External User Interrupt #1                                                                                           |
| INT2, SINT2               | 72              | 48          | 5        | Reserved                                                                                                             |
| TINT, SINT3               | 76              | 4C          | 6        | External Timer Interrupt                                                                                             |
| BRINT0, SINT4             | 80              | 50          | 7        | McBSP #0 Receive Interrupt                                                                                           |
| BXINT0, SINT5             | 84              | 54          | 8        | McBSP #0 Transmit Interrupt                                                                                          |
| BRINT2 (DMAC0),<br>SINT6  | 88              | 58          | 9        | McBSP #2 Receive Interrupt (default) or DMA<br>Channel 0 interrupt. The selection is made in<br>the DMPREC register. |
| BXINT2 (DMAC1),<br>SINT7  | 92              | 5C          | 10       | McBSP #2 Receive Interrupt (default) or DMA<br>Channel 1 interrupt. The selection is made in<br>the DMPREC register. |
| INT3, SINT8               | 96              | 60          | 11       | Reserved                                                                                                             |
| HPINT, SINT9              | 100             | 64          | 12       | HPI Interrupt (from DSPINT in HPIC)                                                                                  |
| BRINT1 (DMAC2),<br>SINT10 | 104             | 68          | 13       | McBSP #1 Receive Interrupt (default) or DMA<br>Channel 2 interrupt. The selection is made in<br>the DMPREC register. |
| BXINT1 (DMAC3),<br>SINT11 | 108             | 6C          | 14       | McBSP #1 transmit Interrupt (default) or DMA channel 3 interrupt. The selection is made in the DMPREC register.      |
| DMAC4, SINT12             | 112             | 70          | 15       | DMA Channel 4                                                                                                        |
| DMAC5, SINT13             | 116             | 74          | 16       | DMA Channel 5                                                                                                        |
| IPINT, SINT14             | 120             | 78          | 17       | Interprocessor Interrupt                                                                                             |
| _                         | 124–127         | 7C–7F       | _        | Reserved                                                                                                             |

## Table 13. 5420 Interrupt Locations and Priorities for Each DSP Subsystem



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### interrupts (continued)

Figure 9 shows the bit layout of the interrupt mask register (IMR) and the interrupt flag register (IFR). Table 14 describes the bit functions.

The interprocessor interrupt (IPINT) bit of the interrupt mask register (IMR) and the interrupt flag register (IFR) allows the subsystem to perform interrupt service routines based on the other subsystem activity. Incoming IPINT interrupts are latched in bit 14 of the IFR. Generating an interprocessor interrupt is performed by writing a "1" to the IPIRQ field of the bank-switching control register (BSCR). Subsequent interrupts must first clear the interrupt by writing "0" to the IPIRQ field.

For example, if subsystem A is required to notify subsystem B of a completed task, subsystem A must write a "1" to the IPIRQ field to generate a IPINT interrupt on subsystem B. On subsystem B, the IPINT interrupt is latched in bit 14 of the IFR.

| 15  | 14    | 13    | 12    | 11                    | 10                    | 9     | 8   | 7                     | 6                     | 5      | 4      | 3    | 2   | 1    | 0    |
|-----|-------|-------|-------|-----------------------|-----------------------|-------|-----|-----------------------|-----------------------|--------|--------|------|-----|------|------|
| RES | IPINT | DMAC5 | DMAC4 | BXINT1<br>or<br>DMAC3 | BRINT1<br>or<br>DMAC2 | HPINT | RES | BXINT2<br>or<br>DMAC1 | BRINT2<br>or<br>DMAC0 | BXINT0 | BRINT0 | TINT | RES | INT1 | INT0 |

#### Figure 9. Bit Layout of the IMR and IFR Registers for Each Subsystem

#### Table 14. Bit Functions for IMR and IFR Registers for Each DSP Subsystem

|        | BIT          | FUNCTION                                                                                                                                                                      |
|--------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NUMBER | NAME         | FUNCTION                                                                                                                                                                      |
| 15     | -            | Reserved                                                                                                                                                                      |
| 14     | IPINT        | Interprocessor IRQ.                                                                                                                                                           |
| 13     | DMAC5        | DMA channel 5 interrupt flag/mask bit                                                                                                                                         |
| 12     | DMAC4        | DMA channel 4 interrupt flag/mask bit                                                                                                                                         |
| 11     | BXINT1/DMAC3 | This bit can be configured as either the McBSP1 transmit interrupt flag/mask bit, or the DMA channel 3 interrupt flag/mask bit. The selection is made in the DMPREC register. |
| 10     | BRINT1/DMAC2 | This bit can be configured as either the McBSP1 receive interrupt flag/mask bit, or the DMA channel 2 interrupt flag/mask bit. The selection is made in the DMPREC register.  |
| 9      | HPINT        | Host to 54x interrupt flag/mask                                                                                                                                               |
| 8      | -            | Reserved                                                                                                                                                                      |
| 7      | BXINT2/DMAC1 | This bit can be configured as either the McBSP2 transmit interrupt flag/mask bit, or the DMA channel 1 interrupt flag/mask bit. The selection is made in the DMPREC register. |
| 6      | BRINT2/DMAC0 | This bit can be configured as either the McBSP2 receive interrupt flag/mask bit, or the DMA channel 0 interrupt flag/mask bit. The selection is made in the DMPREC register.  |
| 5      | BXINT0       | McBSP0 transmit interrupt flag/mask bit                                                                                                                                       |
| 4      | BRINT0       | McBSP0 receive interrupt flag/mask bit                                                                                                                                        |
| 3      | TINT         | Timer interrupt flag/mask bit                                                                                                                                                 |
| 2      | -            | Reserved                                                                                                                                                                      |
| 1      | INT1         | External interrupt 1 flag/mask bit                                                                                                                                            |
| 0      | INT0         | External interrupt 0 flag/mask bit                                                                                                                                            |



#### IDLE3 power-down mode

The IDLE1 and IDLE2 power-down modes operate as described in the *TMS320C54x DSP Reference Set*, *Volume 1: CPU and Peripherals* (literature number SPRU131). The IDLE3 mode is special in that the clocking circuitry is shut off to conserve power. The 5420 cannot enter an IDLE3 mode unless both subsystems execute an IDLE3 instruction. The power-reduced benefits of IDLE3 cannot be realized until both subsystems enter the IDLE3 state and the internal clocks are automatically shut off. The order in which subsystems enter IDLE3 does not matter.

#### emulating the 5420 device

The 5420 is a single device, but actually consists of two independent subsystems that contain register/status information used by the emulator tools. The emulator tools must be informed of the multicore device by modifying the **board.cfg** file. The board.cfg file is an ASCII file that can be modified with most editors. This provides the emulator with a description of the JTAG chain. The board.cfg file must identify two processors when using the 5420. The file contents would look something like this:

"CPU\_B" TI320C5xx

"CPU\_A" TI320C5xx

Use the compose program to make this file into a binary file (**board.dat**), readable by the emulation tools. Place the board.dat file in the directory that contains the emulator software.

The subsystems are serially connected together internally. Emulation information is serially transmitted into the device using TDI. The device responds with serial scan information transmitted out the TDO pin.



#### SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### documentation support

Extensive documentation supports all TMS320<sup>™</sup> DSP family of devices from product announcement through applications development. The following types of documentation are available to support the design and use of the TMS320C5000<sup>™</sup> platform of DSPs:

- *TMS320C54x*<sup>™</sup> *DSP Functional Overview* (literature number SPRU307)
- Device-specific data sheets
- Complete User Guides
- Development-support tools
- Hardware and software application reports

The five-volume TMS320C54x DSP Reference Set (literature number SPRU210) consists of:

- Volume 1: CPU and Peripherals (literature number SPRU131)
- Volume 2: Mnemonic Instruction Set (literature number SPRU172)
- Volume 3: Algebraic Instruction Set (literature number SPRU179)
- Volume 4: Applications Guide (literature number SPRU173)
- Volume 5: Enhanced Peripherals (literature number SPRU302)

The reference set describes in detail the TMS320C54x<sup>™</sup> DSP products currently available and the hardware and software applications, including algorithms, for fixed-point TMS320<sup>™</sup> DSP family of devices.

A series of DSP textbooks is published by Prentice-Hall and John Wiley & Sons to support digital signal processing research and education. The TMS320<sup>TM</sup> DSP newsletter, *Details on Signal Processing*, is published quarterly and distributed to update TMS320<sup>TM</sup> DSP customers on product information.

Information regarding Texas Instruments (TI) DSP products is also available on the Worldwide Web at *http://www.ti.com* uniform resource locator (URL).

TMS320 and TMS320C5000 are trademarks of Texas Instruments.



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### absolute maximum ratings over specified temperature range (unless otherwise noted)<sup>†</sup>

| Supply voltage I/O range, DV <sub>DD</sub> <sup>‡</sup> – 0.8                                                             | 5 V to 4.0 V          |
|---------------------------------------------------------------------------------------------------------------------------|-----------------------|
| Supply voltage core range, CV <sub>DD</sub> <sup>‡</sup> – 0.8                                                            | 5 V to 2.0 V          |
| Supply voltage analog PLL, AV <sub>DD</sub> <sup>‡</sup> – 0.8                                                            | 5 V to 2.0 V          |
| Input voltage range, V <sub>I</sub> – 0.5 V to DV                                                                         | <sub>DD</sub> + 0.5 V |
| Output voltage range, Vo                                                                                                  | <sub>DD</sub> + 0.5 V |
| Operating case temperature range, T <sub>C</sub> – 40°                                                                    | C to 100°C            |
| Storage temperature range T <sub>stg</sub> – 65°                                                                          | C to 150°C            |
| traces beyond these listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ra | tings only and        |

<sup>†</sup> Stresses beyond those listed under "absolute maximum ratings" may cause permanent damage to the device. These are stress ratings only, and functional operation of the device at these or any other conditions beyond those indicated under "recommended operating conditions" is not implied. Exposure to absolute-maximum-rated conditions for extended periods may affect device reliability.

<sup>‡</sup> All voltage values are with respect to V<sub>SS</sub>.

#### recommended operating conditions

|      |                                   |                                                              | MIN                 | NOM  | MAX                                                           | UNIT |
|------|-----------------------------------|--------------------------------------------------------------|---------------------|------|---------------------------------------------------------------|------|
| DVDD | Device supply voltage, I/O        |                                                              | 3.0                 | 3.3  | 3.6                                                           | V    |
| CVDD | Device supply voltage, core       |                                                              | 1.71                | 1.80 | 1.98                                                          | V    |
| AVDD | Device supply voltage, PLL        |                                                              | 1.71                | 1.80 | 1.98                                                          | V    |
| VSS  | Supply voltage, GND               |                                                              |                     | 0    |                                                               | V    |
| VIH  | High-level input voltage, I/O     | Schmitt trigger inputs, TRST, SELA/B $DV_{DD}$ = 3.3 ± 0.3 V | 0.7DV <sub>DD</sub> |      | DVDD                                                          | V    |
|      |                                   | All other inputs                                             | 2                   |      | DVDD                                                          |      |
| VIL  | Low-level input voltage, I/O      | Schmitt trigger inputs $DV_{DD} = 3.3 \pm 0.3 V$             | 0                   |      | 0.3DV <sub>DD</sub>                                           | V    |
|      |                                   | All other inputs                                             | 0                   |      | DV <sub>DD</sub><br>0.3DV <sub>DD</sub><br>0.8<br>-300<br>1.5 |      |
| ЮН   | High-level output current         |                                                              |                     |      | -300                                                          | μΑ   |
| IOL  | Low-level output current          |                                                              |                     |      | 1.5                                                           | mA   |
|      | Operating case temperature, indus | trial                                                        | -40                 |      | 100                                                           |      |
| тс   | Operating case temperature, comm  | nercial                                                      | 0                   |      | 100                                                           | °C   |

Refer to Figure 10 for 3.3-V device test load circuit values.



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

# electrical characteristics over recommended operating case temperature range (unless otherwise noted)

|      | PARAM                                                     | ETER                      | TEST CONDITIONS                                                                                         | MIN  | TYP† | MAX | UNIT |
|------|-----------------------------------------------------------|---------------------------|---------------------------------------------------------------------------------------------------------|------|------|-----|------|
| Vон  | High-level output                                         | voltage <sup>‡</sup>      | $DV_{DD} = 3.3 \pm 0.3 \text{ V}, \text{ I}_{OH} = \text{MAX}$                                          | 2.4  |      |     | V    |
| Vol  | Low-level output v                                        | /oltage <sup>‡</sup>      | I <sub>OL</sub> = MAX                                                                                   |      |      | 0.4 | V    |
| IIZ  | Input current in high                                     | gh impedance              | $DV_{DD} = MAX, V_O = V_{SS}$ to $DV_{DD}$                                                              | -10  |      | 10  | μA   |
|      |                                                           | TRST                      | With internal pulldown                                                                                  | -10  |      | 35  |      |
|      | Input current                                             | See pin descriptions      | With internal pullups                                                                                   | -35  |      | 10  |      |
| lı   | (V <sub>I</sub> = V <sub>SS</sub> to<br>V <sub>DD</sub> ) | PPD[15:0]                 | Bus holders enabled, $DV_{DD} = MAX$ ,<br>$V_I = V_{SS}$ to $V_{IL}$ (MAX); $V_{IH}$ (MIN) to $DV_{DD}$ | -200 |      | 200 | μA   |
|      |                                                           | All other input-only pins |                                                                                                         | -10  |      | 10  |      |
| IDDC | Supply current, bo                                        | oth core CPUs             | CV <sub>DD</sub> = 1.8 V, f <sub>X</sub> =100 MHz§, T <sub>C</sub> =25°C¶                               |      | 180  |     | mA   |
| IDDP | Supply current, pi                                        | ns                        | $DV_{DD} = 3.3 \text{ V}, \text{ f}_{clock} = 100 \text{ MHz}$ , $T_{C} = 25^{\circ}\text{C}^{\#}$      |      | 54   |     | mA   |
| IDDA | Supply current, Pl                                        | L                         |                                                                                                         |      | 5    |     | mA   |
|      | Supply current,                                           | IDLE2                     | PLL × n mode, 20 MHz input                                                                              |      | 2    |     | mA   |
| IDDC | standby                                                   | IDLE3                     | PLL x n mode, 20 MHz input                                                                              |      | 600  |     | μA   |
| Ci   | Input capacitance                                         | -                         |                                                                                                         |      | 5    |     | pF   |
| Co   | Output capacitand                                         | ce                        |                                                                                                         |      | 5    |     | pF   |

<sup>†</sup> All values are typical unless otherwise specified.

<sup>‡</sup> All input and output voltage levels except A\_RS, B\_RS, INTO INT1, NMI, CLKIN, BCLKX, BCLKR, HAS, HCS, TCK, TRST, SELA/B, HDS1, HDS2, and HPIRS are LVTTL-compatible.

§ Clock mode:  $PLL \times 1$  with external source

I This value represents the current consumption of the CPU, on-chip memory, and on-chip peripherals. Conditions include: program execution from on-chip RAM, with 50% usage of MAC and 50% usage of NOP instructions. Actual operating current varies with program being executed.
# This value was obtained using the following conditions: external memory writes at a rate of 20 million writes per second, CLKOFF=0, full-duplex

operation of all six McBSPs at a rate of 10 million bits per second each, and 15-pF loads on all outputs. For more details on how this calculation is performed, refer to the *Calculation of TMS320C54x Power Dissipation Application Report* (literature number SPRA164).

#### PARAMETER MEASUREMENT INFORMATION



Figure 10. 3.3-V Test Load Circuit



#### external multiply-by-N clock option

An external frequency can be used by injecting the frequency directly into CLKIN. This external frequency is multiplied by N to generate the internal machine cycle.

The external frequency injected must conform to specifications listed in the timing requirements table.

#### switching characteristics over recommended operating conditions [H = 0.5t<sub>c(CO)</sub>] (see Figure 11 and the recommended operating conditions table)

|                        | PARAMETER                                     | MIN   | TYP                               | MAX | UNIT |
|------------------------|-----------------------------------------------|-------|-----------------------------------|-----|------|
| t <sub>c(CO)</sub>     | Cycle time, CLKOUT                            | 10    | <sup>t</sup> c(CI)/N <sup>†</sup> |     | ns   |
| <sup>t</sup> d(CIH-CO) | Delay time, CLKIN high/low to CLKOUT high/low | 4     | 10                                | 16  | ns   |
| <sup>t</sup> f(CO)     | Fall time, CLKOUT                             |       | 2                                 |     | ns   |
| <sup>t</sup> r(CO)     | Rise time, CLKOUT                             |       | 2                                 |     | ns   |
| <sup>t</sup> w(COL)    | Pulse duration, CLKOUT low                    | H – 2 | H – 1                             | Н   | ns   |
| <sup>t</sup> w(COH)    | Pulse duration, CLKOUT high                   | H – 2 | H – 1                             | Н   | ns   |
| tp                     | Transitory phase, PLL lock-up time            |       |                                   | 35  | μs   |

<sup>†</sup>N is the PLL multiplier. N = 1 - 15

#### timing requirements (see Figure 11)

|                    |                   |                                            | MIN | MAX | UNIT |
|--------------------|-------------------|--------------------------------------------|-----|-----|------|
|                    |                   | Integer PLL multiplier N                   | 10N | 200 |      |
| <sup>t</sup> c(CI) | Cycle time, CLKIN | PLL multiplier $N = x.5$                   | 10N | 100 | ns   |
| . ,                |                   | PLL multiplier N = $x.25$ , $x.75$         | 10N | 50  |      |
| <sup>t</sup> f(CI) | Fall time, CLKIN  |                                            |     | 8   | ns   |
| <sup>t</sup> r(CI) | Rise time, CLKIN  |                                            |     | 8   | ns   |
|                    |                   | $t_{r(CI)} \rightarrow   \leftarrow t_{i}$ |     |     | F    |

Figure 11. External Multiply-By-One Clock



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### bypass option

An external frequency can be used by injecting the frequency directly into CLKIN.

The external frequency injected must conform to specifications listed in the timing requirements table.

# switching characteristics over recommended operating conditions $[H = 0.5t_{c(CO)}]$ (see Figure 12 and the recommended operating conditions table)

|                        | PARAMETER                                     | MIN   | TYP                | MAX | UNIT |
|------------------------|-----------------------------------------------|-------|--------------------|-----|------|
| tc(CO)                 | Cycle time, CLKOUT                            | 10    | <sup>t</sup> c(CI) |     | ns   |
| <sup>t</sup> d(CIH-CO) | Delay time, CLKIN high/low to CLKOUT high/low | 4     | 10                 | 16  | ns   |
| <sup>t</sup> f(CO)     | Fall time, CLKOUT                             |       | 2                  |     | ns   |
| <sup>t</sup> r(CO)     | Rise time, CLKOUT                             |       | 2                  |     | ns   |
| <sup>t</sup> w(COL)    | Pulse duration, CLKOUT low                    | H – 2 | H – 1              | Н   | ns   |
| <sup>t</sup> w(COH)    | Pulse duration, CLKOUT high                   | H – 2 | H – 1              | Н   | ns   |

#### timing requirements (see Figure 12)

|                    |                   | MIN | MAX | UNIT |
|--------------------|-------------------|-----|-----|------|
| tc(CI)             | Cycle time, CLKIN | 10  | †   | ns   |
| <sup>t</sup> f(CI) | Fall time, CLKIN  |     | 8   | ns   |
| <sup>t</sup> r(CI) | Rise time, CLKIN  |     | 8   | ns   |

<sup>†</sup> This device utilizes a fully static design and therefore can operate with  $t_{C(CI)}$  approaching  $\infty$ . The device is characterized at frequencies approaching 0 Hz.



Figure 12. Timing Diagram for Bypass Mode



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### external memory interface timing for one wait state

# switching characteristics over recommended operating conditions for a one-wait-state memory read ( $\overline{\text{MSTRB}} = 0$ )<sup>†</sup> (see Figure 13)

|                          | PARAMETER                                              | MIN | MAX | UNIT |
|--------------------------|--------------------------------------------------------|-----|-----|------|
| <sup>t</sup> d(CLKL-A)   | Delay time, CLKOUT low to address valid <sup>‡</sup>   | -1  | 5   | ns   |
| <sup>t</sup> d(CLKH-A)   | Delay time, CLKOUT high (transition) to address valid§ | -1  | 6   | ns   |
| <sup>t</sup> d(CLKL-MSL) | Delay time, CLKOUT low to MSTRB low                    | -1  | 4   | ns   |
| <sup>t</sup> d(CLKL-MSH) | Delay time, CLKOUT low to MSTRB high                   | -1  | 4   | ns   |
| <sup>t</sup> h(CLKL-A)R  | Hold time, address valid after CLKOUT low <sup>‡</sup> | -1  | 5   | ns   |
| <sup>t</sup> h(CLKH-A)R  | Hold time, address valid after CLKOUT high§            | -1  | 6   | ns   |

<sup>†</sup> Address, PS, and DS timings are all included in timings referenced as address.

<sup>‡</sup> In the case of a memory read preceded by a memory read

 $\$  In the case of a memory read preceded by a memory write

#### timing requirements for a one-wait-state memory read (MSTRB = 0) [H = 0.5 t<sub>c(CO)</sub>]<sup>†</sup> (see Figure 13)

|                         |                                                                          | MIN | MAX   | UNIT |
|-------------------------|--------------------------------------------------------------------------|-----|-------|------|
| <sup>t</sup> a(A)M      | Access time, read data access from address valid (1 wait state required) |     | 4H–15 | ns   |
| <sup>t</sup> a(MSTRBL)  | Access time, read data access from MSTRB low                             |     | 4H–14 | ns   |
| t <sub>su(D)R</sub>     | Setup time, read data before CLKOUT low                                  | 12  |       | ns   |
| <sup>t</sup> h(D)R      | Hold time, read data after CLKOUT low                                    | 0   |       | ns   |
| <sup>t</sup> h(A-D)R    | Hold time, read data after address invalid                               | 0   |       | ns   |
| <sup>t</sup> h(D)MSTRBH | Hold time, read data after MSTRB high                                    | 0   |       | ns   |

<sup>†</sup> Address, PS, and DS timings are all included in timings referenced as address.



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008



#### external memory interface timing for one wait state (continued)

Figure 13. Memory Read (MSTRB = 0)



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### external memory interface timing for a memory write for one wait state

# <u>switching</u> characteristics over recommended operating conditions for a memory write (MSTRB = 0) [H = 0.5 $t_{c(CO)}$ ]<sup>†</sup> (see Figure 14)

|                            | PARAMETER                                               | MIN   | MAX   | UNIT |
|----------------------------|---------------------------------------------------------|-------|-------|------|
| <sup>t</sup> d(CLKH-A)     | Delay time, CLKOUT high to address valid <sup>‡</sup>   | – 1   | 6     | ns   |
| <sup>t</sup> d(CLKL-A)     | Delay time, CLKOUT low to address valid§                | -1    | 5     | ns   |
| <sup>t</sup> d(CLKL-MSL)   | Delay time, CLKOUT low to MSTRB low                     | -1    | 4     | ns   |
| <sup>t</sup> d(CLKL-D)W    | Delay time, CLKOUT low to data valid                    | 0     | 12    | ns   |
| <sup>t</sup> d(CLKL-MSH)   | Delay time, CLKOUT low to MSTRB high                    | – 1   | 4     | ns   |
| <sup>t</sup> d(CLKH-RWL)   | Delay time, CLKOUT high to R/W low                      | 0     | 4     | ns   |
| <sup>t</sup> d(CLKH-RWH)   | Delay time, CLKOUT high to R/W high                     | -1    | 4     | ns   |
| <sup>t</sup> d(RWL-MSTRBL) | Delay time, R/W low to MSTRB low                        | H – 2 | H + 2 | ns   |
| <sup>t</sup> h(A)W         | Hold time, address valid after CLKOUT high <sup>‡</sup> | -1    | 6     | ns   |

<sup>†</sup> Address, PS, and DS timings are all included in timings referenced as address.

<sup>‡</sup> In the case of a memory write preceded by a memory write

§ In the case of a memory write preceded by an I/O cycle.

# timing requirements for a memory write ( $\overline{MSTRB} = 0$ ) [H = 0.5 t<sub>c(CO)</sub>]<sup>†</sup> (see Figure 14)

|                        |                                                |    | MIN   | MAX   | UNIT |
|------------------------|------------------------------------------------|----|-------|-------|------|
| <sup>t</sup> h(D)MSH   | Hold time, write data valid after MSTRB high   | ŀ  | H – 3 | H +3§ | ns   |
| <sup>t</sup> w(SL)MS   | Pulse duration, MSTRB low§                     | 2  | IH-4  |       | ns   |
| t <sub>su(A)W</sub>    | Setup time, address valid before MSTRB low     |    | H–4   |       | ns   |
| t <sub>su</sub> (D)MSH | Setup time, write data valid before MSTRB high | 41 | H–10  | 4H+5§ | ns   |

<sup>†</sup>Address, <u>PS</u>, and <u>DS</u> timings are all included in timings referenced as address.

§ In the case of a memory write preceded by an I/O cycle.



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

## external memory interface timing for a memory write for one wait state (continued)



Figure 14. Memory Write ( $\overline{MSTRB} = 0$ )



#### ready timing for externally generated wait states

# timing requirements for externally generated wait states $[H = 0.5 t_{c(CO)}]^{\dagger}$ (see Figure 15 and Figure 16)

|                          |                                                | MIN | MAX  | UNIT |
|--------------------------|------------------------------------------------|-----|------|------|
| <sup>t</sup> su(RDY)     | Setup time, READY before CLKOUT low            | 7   |      | ns   |
| <sup>t</sup> h(RDY)      | Hold time, READY after CLKOUT low              | 0   |      | ns   |
| <sup>t</sup> v(RDY)MSTRB | Valid time, READY after MSTRB low <sup>‡</sup> |     | 4H-8 | ns   |
| <sup>t</sup> h(RDY)MSTRB | Hold time, READY after MSTRB low <sup>‡</sup>  | 4H  |      | ns   |

<sup>†</sup> The hardware wait states can be used only in conjunction with the software wait states to extend the bus cycles. To generate wait states by READY, at least two software wait states must be programmed. READY is not sampled until the completion of the internal software wait states.
 <sup>‡</sup> These timings are included for reference only. The critical timings for READY are those referenced to CLKOUT



Figure 15. Memory Read With Externally Generated Wait States



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008



ready timing for externally generated wait states (continued)

Figure 16. Memory Write With Externally Generated Wait States



### parallel I/O interface timing

# switching characteristics over recommended operating conditions for a parallel I/O port read (IOSTRB = 0)<sup>†</sup> (see Figure 17)

|                             | PARAMETER                               | MIN | MAX | UNIT |
|-----------------------------|-----------------------------------------|-----|-----|------|
| <sup>t</sup> d(CLKL-A)      | Delay time, CLKOUT low to address valid | -1  | 5   | ns   |
| <sup>t</sup> d(CLKH-ISTRBL) | Delay time, CLKOUT high to IOSTRB low   | 0   | 5   | ns   |
| <sup>t</sup> d(CLKH-ISTRBH) | Delay time, CLKOUT high to IOSTRB high  | 0   | 5   | ns   |
| <sup>t</sup> h(A)IOR        | Hold time, address after CLKOUT low     | -1  | 5   | ns   |

<sup>†</sup> Address and IS timings are included in timings referenced as address.

# timing requirements for a parallel I/O port read ( $\overline{IOSTRB} = 0$ ) [H = 0.5 t<sub>c(CO)</sub>]<sup>†</sup> (see Figure 17)

|                           |                                                  | MIN | MAX   | UNIT |
|---------------------------|--------------------------------------------------|-----|-------|------|
| ta(A)IO                   | Access time, read data access from address valid |     | 5H–15 | ns   |
| <sup>t</sup> a(ISTRBL)IO  | Access time, read data access from IOSTRB low    |     | 4H–14 | ns   |
| <sup>t</sup> su(D)IOR     | Setup time, read data before CLKOUT high         | 10  |       | ns   |
| <sup>t</sup> h(D)IOR      | Hold time, read data after CLKOUT high           | 0   |       | ns   |
| <sup>t</sup> h(ISTRBH-D)R | Hold time, read data after IOSTRB high           | 0   |       | ns   |

<sup>†</sup>Address and IS timings are included in timings referenced as address.



Figure 17. Parallel I/O Port Read (IOSTRB=0)



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

### parallel I/O interface timing (continued)

# switching characteristics over recommended operating conditions for a parallel I/O port write ( $\overline{IOSTRB} = 0$ ) [H = 0.5 t<sub>c(CO)</sub>]<sup>†</sup> (see Figure 18)

|                             | PARAMETER                                      | MIN  | MAX  | UNIT |
|-----------------------------|------------------------------------------------|------|------|------|
| <sup>t</sup> d(CLKL-A)      | Delay time, CLKOUT low to address valid        | -1   | 5    | ns   |
| <sup>t</sup> d(CLKH-ISTRBL) | Delay time, CLKOUT high to IOSTRB low          | 0    | 5    | ns   |
| <sup>t</sup> d(CLKH-D)IOW   | Delay time, CLKOUT high to write data valid    | H–5  | H+11 | ns   |
| <sup>t</sup> d(CLKH-ISTRBH) | Delay time,CLKOUT high to IOSTRB high          | 0    | 5    | ns   |
| <sup>t</sup> d(CLKL-RWL)    | Delay time, CLKOUT low to $R/\overline{W}$ low | 0    | 4    | ns   |
| <sup>t</sup> d(CLKL-RWH)    | Delay time, CLKOUT low to R/W high             | 0    | 4    | ns   |
| <sup>t</sup> h(A)IOW        | Hold time, address valid after CLKOUT low      | -1   | 5    | ns   |
| <sup>t</sup> h(D)IOW        | Hold time, write data after IOSTRB high        | H–3  | H+5  | ns   |
| <sup>t</sup> su(D)IOSTRBH   | Setup time, write data before IOSTRB high      | 3H-9 | 3H+5 | ns   |
| <sup>t</sup> su(A)IOSTRBL   | Setup time, address valid before IOSTRB low    | H–3  | H+3  | ns   |

<sup>†</sup> Address and IS timings are included in timings referenced as address.



Figure 18. Parallel I/O Port Write (IOSTRB=0)



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### I/O port timing for externally generated wait states

# timing requirements for externally generated wait states $[H = 0.5 t_{c(CO)}]^{\dagger}$ (see Figure 19 and Figure 20)

|                           |                                                 | MIN | MAX  | UNIT |
|---------------------------|-------------------------------------------------|-----|------|------|
| <sup>t</sup> su(RDY)      | Setup time, READY before CLKOUT low             | 7   |      | ns   |
| <sup>t</sup> h(RDY)       | Hold time, READY after CLKOUT low               | 0   |      | ns   |
| <sup>t</sup> v(RDY)IOSTRB | Valid time, READY after IOSTRB low <sup>‡</sup> |     | 5H–8 | ns   |
| <sup>t</sup> h(RDY)IOSTRB | Hold time, READY after IOSTRB low <sup>‡</sup>  | 5H  |      | ns   |

<sup>†</sup> The hardware wait states can be used only in conjunction with the software wait states to extend the bus cycles. To generate wait states using READY, at least two software wait states must be programmed.

<sup>‡</sup>These timings are included for reference only. The critical timings for READY are those referenced to CLKOUT.



Figure 19. I/O Port Read With Externally Generated Wait States



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008



#### I/O port timing for externally generated wait states (continued)

Figure 20. I/O Port Write With Externally Generated Wait States



### reset, BIO, interrupt, and XIO timing

timing requirements for reset,  $\overline{\text{BIO}}$ , interrupt, and XIO [H = 0.5 t<sub>c(CO)</sub>] (see Figure 21, Figure 22, and Figure 23)

|                         |                                                                    | MIN  | MAX | UNIT |
|-------------------------|--------------------------------------------------------------------|------|-----|------|
| <sup>t</sup> h(RS)      | Hold time, A_RS or B_RS after CLKOUT low                           | 0    |     | ns   |
| <sup>t</sup> h(BIO)     | Hold time, BIO after CLKOUT low                                    | 0    |     | ns   |
| <sup>t</sup> h(INT)     | Hold time, INTn, NMI, after CLKOUT low <sup>†</sup>                | 0    |     | ns   |
| th(XIO) <sup>‡</sup>    | Hold time, XIO after CLKOUT low                                    | 0    |     | ns   |
| <sup>t</sup> w(RSL)     | Pulse duration, $\overline{A}_{RS}$ or $\overline{B}_{RS}$ low§¶   | 4H+5 |     | ns   |
| <sup>t</sup> w(BIO)A    | Pulse duration, BIO low, asynchronous                              | 5H   |     | ns   |
| <sup>t</sup> w(INTH)A   | Pulse duration, INTn, NMI high (asynchronous) <sup>†</sup>         | 4H   |     | ns   |
| <sup>t</sup> w(INTL)A   | Pulse duration, INTn, NMI low (asynchronous) <sup>†</sup>          | 4H   |     | ns   |
| <sup>t</sup> w(INTL)WKP | Pulse duration, INTn, NMI low for IDLE2/IDLE3 wakeup <sup>†</sup>  | 8    |     | ns   |
| t <sub>su(RS)</sub>     | Setup time, A_RS or B_RS before CLKIN low¶                         | 7    |     | ns   |
| t <sub>su(BIO)</sub>    | Setup time, BIO before CLKOUT low                                  | 9    |     | ns   |
| <sup>t</sup> su(INT)    | Setup time, INTn, NMI, A_RS or B_RS before CLKOUT low <sup>†</sup> | 9    |     | ns   |
| t <sub>su(XIO)</sub> ‡  | Setup time, XIO before CLKOUT low                                  | 10   |     | ns   |

<sup>†</sup> The external interrupts (INTO-INT1, NMI) are synchronized to the core CPU by way of a two flip-flop synchronizer which samples these inputs with consecutive falling edges of CLKOUT. The input to the interrupt pins is required to represent a 1-0-0 sequence at the timing that is corresponding to a three-CLKOUT sampling sequence.

<sup>‡</sup>Once the setup and hold times are met for XIO, the following falling edge of CLKOUT is either an HPI or EMIF cycle.

§ If the PLL mode is selected, then at power-on sequence, or at wakeup from IDLE3, A\_RS must be held low for at least 50 μs to ensure synchronization and lock-in of the PLL.

Note that A\_RS can cause a change in clock frequency, therefore changing the value of H (see the *software-programmable phase-locked loop (PLL)* section).



Figure 21. Reset and BIO Timings



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

### reset, BIO, interrupt, and XIO timing (continued)



rigure 25. Ale rinning



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

## external flag (XF) and timer output (TOUT) timing

# switching characteristics over recommended operating conditions for external flag (XF) and TOUT [H = $0.5 t_{c(CO)}$ ] (see Figure 24 and Figure 25)

|                       | PARAMETER                            | MIN  | MAX | UNIT |
|-----------------------|--------------------------------------|------|-----|------|
|                       | Delay time, CLKOUT low to XF high    | 0 3  |     |      |
| <sup>t</sup> d(XF)    | Delay time, CLKOUT low to XF low     | 0    | 3   | ns   |
| <sup>t</sup> d(TOUTH) | Delay time, CLKOUT high to TOUT high | 0    | 5   | ns   |
| <sup>t</sup> d(TOUTL) | Delay time, CLKOUT high to TOUT low  | 0    | 5   | ns   |
| <sup>t</sup> w(TOUT)  | Pulse duration, TOUT                 | 2H–2 |     | ns   |



Figure 24. External Flag (XF) Timing



Figure 25. Timer (TOUT) Timing



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

### general-purpose input/output (GPIO) timing

#### timing requirements for GPIO (see Figure 26)

|                           |                                                                                              | MIN | MAX | UNIT |
|---------------------------|----------------------------------------------------------------------------------------------|-----|-----|------|
| <sup>t</sup> su(GPIO-COH) | Setup time, GPIOx input valid before CLKOUT high, GPIOx configured as general-purpose input. | 7   |     | ns   |
| <sup>t</sup> h(GPIO-COH)  | Hold time, GPIOx input valid after CLKOUT high, GPIOx configured as general-purpose input.   | 0   |     | ns   |

## switching characteristics for GPIO (see Figure 26)

|                          | PARAMETER                                                                                   | MIN | MAX | UNIT |
|--------------------------|---------------------------------------------------------------------------------------------|-----|-----|------|
| <sup>t</sup> d(COH-GPIO) | Delay time, CLKOUT high to GPIOx output change. GPIOx configured as general-purpose output. | 0   | 5   | ns   |







SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

## **SELA/B** timing

## switching characteristics in XIO = 1 mode for SELA/B (see Figure 27)

|                             | PARAMETER                                                | MIN | MAX | UNIT |
|-----------------------------|----------------------------------------------------------|-----|-----|------|
| <sup>t</sup> d(SELA/B-ABUS) | Delay time, SELA/B to address bus valid in XIO = 1 mode. | 3   | 10  | ns   |



Figure 27. SELA/B Timing in XIO = 1 Mode



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### multichannel buffered serial port timing

# timing requirements for the McBSP<sup>†</sup> [H=0.5t<sub>c(CO)</sub>] (see Figure 28 and Figure 29)

|                             |                                                 |             | MIN | MAX | UNIT |
|-----------------------------|-------------------------------------------------|-------------|-----|-----|------|
| <sup>t</sup> c(BCKRX)       | Cycle time, BCLKR/X                             | BCLKR/X ext | 4H  |     | ns   |
| <sup>t</sup> w(BCKRX)       | Pulse duration, BCLKR/X or BCLKR/X high         | BCLKR/X ext | 6   |     | ns   |
|                             |                                                 | BCLKR int   | 0   |     |      |
| <sup>t</sup> h(BCKRL-BFRH)  | Hold time, external BFSR high after BCLKR low   | BCLKR ext   | 4   |     | ns   |
|                             |                                                 | BCLKR int   | 0   |     |      |
| <sup>t</sup> h(BCKRL-BDRV)  | Hold time, BDR valid after BCLKR low            | BCLKR ext   | 5   |     | ns   |
|                             |                                                 | BCLKX int   | 0   |     | ns   |
| <sup>t</sup> h(BCKXL-BFXH)  | · · · · · · · · · · · · · · · · · · ·           | BCLKX ext   | 4   | 4   |      |
|                             |                                                 | BCLKR int   | 10  |     |      |
| <sup>t</sup> su(BFRH-BCKRL) | Setup time, external BFSR high before BCLKR low | BCLKR ext   | 4   |     | ns   |
|                             |                                                 | BCLKR int   | 10  |     |      |
| <sup>t</sup> su(BDRV-BCKRL) | Setup time, BDR valid before BCLKR low          | BCLKR ext   | 3   |     | ns   |
|                             | Onter the anter a DEOX birth for DOUKY has      | BCLKX int   | 10  |     |      |
| <sup>t</sup> su(BFXH-BCKXL) | Setup time, external BFSX high before BCLKX low | BCLKX ext   | 6   |     | ns   |
| <sup>t</sup> r(BCKRX)       | Rise time, BCKR/X                               | BCLKR/X ext |     | 8   | ns   |
| <sup>t</sup> f(BCKRX)       | Fall time, BCKR/X                               | BCLKR/X ext |     | 8   | ns   |

<sup>†</sup> Polarity bits CLKRP = CLKXP = FSRP = FSXP = 0. If the polarity of any of the signals is inverted, then the timing references of that signal are also inverted.



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

## multichannel buffered serial port timing (continued)

## switching characteristics for the McBSP<sup>†</sup> [H=0.5t<sub>c(CO)</sub>] (see Figure 28 and Figure 29)

|                               | PARAMETER                                                                                            |                                  |             | MIN  | MAX  | UNIT       |
|-------------------------------|------------------------------------------------------------------------------------------------------|----------------------------------|-------------|------|------|------------|
| <sup>t</sup> c(BCKRX)         | Cycle time, BCLKR/X                                                                                  |                                  | BCLKR/X int | 4H   |      | ns         |
| <sup>t</sup> w(BCKRXH)        | Pulse duration, BCLKR/X high                                                                         |                                  | BCLKR/X int | D-4‡ | D+1‡ | ns         |
| <sup>t</sup> w(BCKRXL)        | Pulse duration, BCLKR/X low                                                                          |                                  | BCLKR/X int | C-4‡ | C+1‡ | ns         |
| <sup>t</sup> d(BCKRH-BFRV)    | Delay time, BCLKR high to internal BFSR valid                                                        |                                  | BCLKR int   | -3   | 3    | ns         |
| • · · = = · · · · = = · · · · | Delay time, BCLKX high to internal BFSX valid                                                        |                                  | BCLKX int   | -3   | 8    |            |
| <sup>t</sup> d(BCKXH-BFXV)    | Delay time, BCLKA high to Internal BFSA valid                                                        |                                  | BCLKX ext   | 2    | 15   | ns         |
| t                             | Disable time, BCLKX high to BDX high impedance followi                                               | ing last data bit                | BCLKX int   | -8   | 5    | ns         |
| <sup>t</sup> dis(BCKXH-BDXHZ) |                                                                                                      | ing last data bit                | BCLKX ext   | 1    | 19   | 115        |
|                               | Delay time, BCLKX high to BDX valid. This applies to all bit                                         | s except the first               | BCLKX int   | 0    | 11   |            |
|                               | bit transmitted.                                                                                     |                                  | BCLKX ext   | 5    | 20   |            |
| <sup>t</sup> d(BCKXH-BDXV)    |                                                                                                      |                                  | BCLKX int   |      | 11   | <b>n</b> 0 |
|                               | Delay time, BCLKX high to BDX valid.§<br>Only applies to first bit transmitted when in Data Delay 1  | DAENA = 0                        | BCLKX ext   |      | 20   | ns         |
|                               | or 2 (XDATDLY=01b or 10b) modes                                                                      | elay 1<br>DXENA = 0<br>DXENA = 1 | BCLKX int   |      | 25   |            |
|                               |                                                                                                      | DAENA = 1                        | BCLKX ext   |      | 27   |            |
|                               |                                                                                                      | DXENA = 0                        | BCLKX int   | -4   |      |            |
| t (50)0(1) 5500               | Enable time, BCLKX high to BDX driven.<br>Only applies to first bit transmitted when in Data Delay 1 | DAENA = 0                        | BCLKX ext   | 2    |      | <b>n</b> 0 |
| <sup>t</sup> e(BCKXH-BDX)     | or 2 (XDATDLY=01b or 10b) modes                                                                      | DXENA = 1                        | BCLKX int   | 6    |      | ns         |
|                               |                                                                                                      | DAENA = 1                        | BCLKX ext   | 12   |      |            |
|                               |                                                                                                      | DXENA = 0                        | BFSX int    |      | 9    |            |
| t                             | Delay time, BFSX high to BDX valid.<br>Only applies to first bit transmitted when in Data Delay 0    | DAENA = 0                        | BFSX ext    |      | 12   | <b>n</b> 0 |
| <sup>t</sup> d(BFXH-BDXV)     | (XDATDLY=00b) mode.                                                                                  | DXENA = 1                        | BFSX int    |      | 25   | ns         |
|                               |                                                                                                      | DAENA = 1                        | BFSX ext    |      | 26   |            |
|                               |                                                                                                      | DXENA = 0                        | BFSX int    | -1   |      |            |
|                               | Enable time, BFSX high to BDX driven.<br>Only applies to first bit transmitted when in Data Delay 0  | D = 0                            | BFSX ext    | 2    |      | ne         |
| <sup>t</sup> e(BFXH-BDX)      | (XDATDLY=00b) mode                                                                                   | DXENA = 1                        | BFSX int    | 9    |      | ns         |
|                               |                                                                                                      |                                  | BFSX ext    | 13   |      |            |

<sup>+</sup> Polarity bits CLKRP = CLKXP = FSRP = FSXP = 0. If the polarity of any of the signals is inverted, then the timing references of that signal are also inverted.

<sup>‡</sup>T=BCLKRX period = (1 + CLKGDV) \* 2H

C=BCLKRX low pulse width = T/2 when CLKGDV is odd or zero and = (CLKGDV/2) \* 2H when CLKGDV is even

D=BCLKRX high pulse width = T/2 when CLKGDV is odd or zero and = (CLKGDV/2 + 1) \* 2H when CLKGDV is even

§ See the TMS320C54x DSP Reference Set, Volume 5: Enhanced Peripherals (literature number SPRU302) for a description of the DX enable (DXENA) and data delay features of the McBSP.



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### multichannel buffered serial port timing (continued)



Figure 29. McBSP Transmit Timings



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

## multichannel buffered serial port timing (continued)

#### timing requirements for McBSP general-purpose I/O (see Figure 30)

|                           |                                                               | MIN | MAX | UNIT |
|---------------------------|---------------------------------------------------------------|-----|-----|------|
| tsu(BGPIO-COH)            | Setup time, BGPIOx input mode before CLKOUT high <sup>†</sup> | 9   |     | ns   |
| <sup>t</sup> h(COH-BGPIO) | Hold time, BGPIOx input mode after CLKOUT high <sup>†</sup>   | 0   |     | ns   |

<sup>†</sup>BGPIOx refers to BCLKRx, BFSRx, BDRx, BCLKXx, or BFSXx when configured as a general-purpose input.

#### switching characteristics for McBSP general-purpose I/O (see Figure 30)

| PARAMETER                                                                | MIN | MAX | UNIT |
|--------------------------------------------------------------------------|-----|-----|------|
| td(COH-BGPIO) Delay time, CLKOUT high to BGPIOx output mode <sup>‡</sup> | -10 | 10  | ns   |

BGPIOx refers to BCLKRx, BFSRx, BCLKXx, BFSXx, or BDXx when configured as a general-purpose output.



<sup>†</sup> BGPIOx refers to BCLKRx, BFSRx, BDRx, BCLKXx, or BFSXx when configured as a general-purpose input. <sup>‡</sup> BGPIOx refers to BCLKRx, BFSRx, BCLKXx, BFSXx, or BDXx when configured as a general-purpose output.

#### Figure 30. McBSP General-Purpose I/O Timings



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### multichannel buffered serial port timing (continued)

# timing requirements for McBSP as SPI master or slave: $[H=0.5t_{c(CO)}]$ CLKSTP = 10b, CLKXP = 0<sup>†</sup> (see Figure 31)

|                             |                                        | MAST | ER  | SLAV    | /E  |      |
|-----------------------------|----------------------------------------|------|-----|---------|-----|------|
|                             |                                        | MIN  | MAX | MIN     | MAX | UNIT |
| tsu(BDRV-BCKXL)             | Setup time, BDR valid before BCLKX low | 12   |     | 2 – 12H |     | ns   |
| <sup>t</sup> h(BCKXL-BDRV)  | Hold time, BDR valid after BCLKX low   | 4    |     | 6 + 12H |     | ns   |
| <sup>t</sup> su(BFXL-BCKXH) | Setup time, BFSX low before BCLKX high |      |     | 10      |     | ns   |
| t <sub>c(BCKX)</sub>        | Cycle time, BCLKX                      | 12H  |     | 32H     |     | ns   |

<sup>†</sup> For all SPI slave modes, CLKG is programmed as 1/2 of the CPU clock by setting CLKSM = CLKGDV = 1.

# switching characteristics for McBSP as SPI master or slave: $[H=0.5t_{c(CO)}]$ CLKSTP = 10b, CLKXP = 0<sup>†</sup> (see Figure 31)

|                               |                                                                         | MAS   | ter‡  | SL     | AVE      | LINUT |
|-------------------------------|-------------------------------------------------------------------------|-------|-------|--------|----------|-------|
|                               | PARAMETER                                                               | MIN   | MAX   | MIN    | MAX      | UNIT  |
| <sup>t</sup> h(BCKXL-BFXL)    | Hold time, BFSX low after BCLKX low§                                    | T – 5 | T + 5 |        |          | ns    |
| td(BFXL-BCKXH)                | Delay time, BFSX low to BCLKX high                                      | C – 5 | C + 5 |        |          | ns    |
| td(BCKXH-BDXV)                | Delay time, BCLKX high to BDX valid                                     | -2    | 12    | 6H + 4 | 10H + 19 | ns    |
| <sup>t</sup> dis(BCKXL-BDXHZ) | Disable time, BDX high impedance following last data bit from BCLKX low | C – 2 | C +10 |        |          | ns    |
| <sup>t</sup> dis(BFXH-BDXHZ)  | Disable time, BDX high impedance following last data bit from BFSX high |       |       | 4H+ 4  | 8H + 17  | ns    |
| <sup>t</sup> d(BFXL-BDXV)     | Delay time, BFSX low to BDX valid                                       |       |       | 4H + 4 | 8H + 17  | ns    |

<sup>†</sup> For all SPI slave modes, CLKG is programmed as 1/2 of the CPU clock by setting CLKSM = CLKGDV = 1.

<sup>‡</sup>T = BCLKX period = (1 + CLKGDV) \* 2H

C = BCLKX low pulse width = T/2 when CLKGDV is odd or zero and = (CLKGDV/2) \* 2H when CLKGDV is even

§ FSRP = FSXP = 1. As a SPI master, BFSX is inverted to provide active-low slave-enable output. As a slave, the active-low signal input on BFSX and BFSR is inverted before being used internally.

CLKXM = FSXM = 1, CLKRM = FSRM = 0 for master McBSP

CLKXM = CLKRM = FSXM = FSRM = 0 for slave McBSP

BFSX should be low before the rising edge of clock to enable slave devices and then begin a SPI transfer at the rising edge of the master clock (BCLKX).



Figure 31. McBSP Timing as SPI Master or Slave: CLKSTP = 10b, CLKXP = 0



SPRS080F – MARCH 1999 – REVISED OCTOBER 2008

## multichannel buffered serial port timing (continued)

# timing requirements for McBSP as SPI master or slave: $[H=0.5t_{c(CO)}]$ CLKSTP = 11b, CLKXP = 0<sup>†</sup> (see Figure 32)

|                              |                                         | MAST | ER  | SLAV    | SLAVE |      |
|------------------------------|-----------------------------------------|------|-----|---------|-------|------|
|                              |                                         | MIN  | MAX | MIN     | MAX   | UNIT |
| t <sub>su</sub> (BDRV-BCKXH) | Setup time, BDR valid before BCLKX high | 12   |     | 2 – 12H |       | ns   |
| <sup>t</sup> h(BCKXH-BDRV)   | Hold time, BDR valid after BCLKX high   | 4    |     | 5 +12H  |       | ns   |
| <sup>t</sup> su(BFXL-BCKXH)  | Setup time, BFSX low before BCLKX high  |      |     | 10      |       | ns   |
| tc(BCKX)                     | Cycle time, BCLKX                       | 12H  |     | 32H     |       | ns   |

<sup>†</sup> For all SPI slave modes, CLKG is programmed as 1/2 of the CPU clock by setting CLKSM = CLKGDV = 1.

# switching characteristics for McBSP as SPI master or slave: $[H=0.5t_{c(CO)}]$ CLKSTP = 11b, CLKXP = 0<sup>†</sup> (see Figure 32)

|                               | DADAMETED                                                                                                        | MAS   | rer‡  | SL     | UNIT     |      |
|-------------------------------|------------------------------------------------------------------------------------------------------------------|-------|-------|--------|----------|------|
|                               | FXL-BCKXH)       Delay time, BFSX low to BCLKX high¶         CKXL-BDXV)       Delay time, BCLKX low to BDX valid | MIN   | MAX   | MIN    | MAX      | UNIT |
| th(BCKXL-BFXL)                | Hold time, BFSX low after BCLKX low§                                                                             | C – 5 | C + 5 |        |          | ns   |
| td(BFXL-BCKXH)                | Delay time, BFSX low to BCLKX high                                                                               | T – 5 | T + 5 |        |          | ns   |
| td(BCKXL-BDXV)                | Delay time, BCLKX low to BDX valid                                                                               | -2    | 12    | 6H + 4 | 10H + 19 | ns   |
| <sup>t</sup> dis(BCKXL-BDXHZ) | Disable time, BDX high impedance following last data bit from BCLKX low                                          | -2    | 10    | 6H + 4 | 10H + 17 | ns   |
| <sup>t</sup> d(BFXL-BDXV)     | Delay time, BFSX low to BDX valid                                                                                | D – 2 | D +10 | 4H – 4 | 8H + 17  | ns   |

<sup>†</sup> For all SPI slave modes, CLKG is programmed as 1/2 of the CPU clock by setting CLKSM = CLKGDV = 1.

T = BCLKX period = (1 + CLKGDV) \* 2H

C = BCLKX low pulse width = T/2 when CLKGDV is odd or zero and = (CLKGDV/2) \* 2H when CLKGDV is even

D = BCLKX high pulse width = T/2 when CLKGDV is odd or zero and = (CLKGDV/2 + 1) \* 2H when CLKGDV is even

§ FSRP = FSXP = 1. As a SPI master, BFSX is inverted to provide active-low slave-enable output. As a slave, the active-low signal input on BFSX and BFSR is inverted before being used internally.

CLKXM = FSXM = 1, CLKRM = FSRM = 0 for master McBSP

CLKXM = CLKRM = FSXM = FSRM = 0 for slave McBSP

BFSX should be low before the rising edge of clock to enable slave devices and then begin a SPI transfer at the rising edge of the master clock (BCLKX).



Figure 32. McBSP Timing as SPI Master or Slave: CLKSTP = 11b, CLKXP = 0



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### multichannel buffered serial port timing (continued)

# timing requirements for McBSP as SPI master or slave: $[H=0.5t_{c(CO)}]$ CLKSTP = 10b, CLKXP = 1<sup>†</sup> (see Figure 33)

|                            |                                         | MAST | TER SLAVE |         | /E  |      |
|----------------------------|-----------------------------------------|------|-----------|---------|-----|------|
|                            |                                         | MIN  | MAX       | MIN     | MAX | UNIT |
| tsu(BDRV-BCKXH)            | Setup time, BDR valid before BCLKX high | 12   |           | 2 – 12H |     | ns   |
| <sup>t</sup> h(BCKXH-BDRV) | Hold time, BDR valid after BCLKX high   | 4    |           | 6 + 12H |     | ns   |
| tsu(BFXL-BCKXL)            | Setup time, BFSX low before BCLKX low   |      |           | 10      |     | ns   |
| tc(BCKX)                   | Cycle time, BCLKX                       | 12H  |           | 32H     |     | ns   |

<sup>†</sup> For all SPI slave modes, CLKG is programmed as 1/2 of the CPU clock by setting CLKSM = CLKGDV = 1.

# switching characteristics for McBSP as SPI master or slave: $[H=0.5t_{c(CO)}]$ CLKSTP = 10b, CLKXP = 1<sup>†</sup> (see Figure 33)

|                               | PARAMETER                                                                | MAS   | ter‡  | SLAVE  |          | UNIT |
|-------------------------------|--------------------------------------------------------------------------|-------|-------|--------|----------|------|
|                               | PARAMETER                                                                | MIN   | MAX   | MIN    | MAX      | UNIT |
| <sup>t</sup> h(BCKXH-BFXL)    | Hold time, BFSX low after BCLKX high§                                    | T – 5 | T + 5 |        |          | ns   |
| td(BFXL-BCKXL)                | Delay time, BFSX low to BCLKX low¶                                       | D – 5 | D + 5 |        |          | ns   |
| td(BCKXL-BDXV)                | Delay time, BCLKX low to BDX valid                                       | -2    | 12    | 6H + 4 | 10H + 19 | ns   |
| <sup>t</sup> dis(BCKXH-BDXHZ) | Disable time, BDX high impedance following last data bit from BCLKX high | D – 2 | D +10 |        |          | ns   |
| <sup>t</sup> dis(BFXH-BDXHZ)  | Disable time, BDX high impedance following last data bit from BFSX high  |       |       | 4H + 4 | 8H + 17  | ns   |
| <sup>t</sup> d(BFXL-BDXV)     | Delay time, BFSX low to BDX valid                                        |       |       | 4H – 4 | 8H + 17  | ns   |

<sup>†</sup> For all SPI slave modes, CLKG is programmed as 1/2 of the CPU clock by setting CLKSM = CLKGDV = 1.

T = BCLKX period = (1 + CLKGDV) \* 2H

D = BCLKX high pulse width = T/2 when CLKGDV is odd or zero and = (CLKGDV/2 + 1) \* 2H when CLKGDV is even

§ FSRP = FSXP = 1. As a SPI master, BFSX is inverted to provide active-low slave-enable output. As a slave, the active-low signal input on BFSX and BFSR is inverted before being used internally.

CLKXM = FSXM = 1, CLKRM = FSRM = 0 for master McBSP

CLKXM = CLKRM = FSXM = FSRM = 0 for slave McBSP

¶ BFSX should be low before the rising edge of clock to enable slave devices and then begin a SPI transfer at the rising edge of the master clock (BCLKX).



Figure 33. McBSP Timing as SPI Master or Slave: CLKSTP = 10b, CLKXP = 1



SPRS080F – MARCH 1999 – REVISED OCTOBER 2008

## multichannel buffered serial port timing (continued)

# timing requirements for McBSP as SPI master or slave: $[H=0.5t_{c(CO)}]$ CLKSTP = 11b, CLKXP = 1<sup>†</sup> (see Figure 34)

|                              |                                        | MAST | ER  | SLAVE   |     |      |
|------------------------------|----------------------------------------|------|-----|---------|-----|------|
|                              |                                        | MIN  | MAX | MIN     | MAX | UNIT |
| t <sub>su</sub> (BDRV-BCKXL) | Setup time, BDR valid before BCLKX low | 12   |     | 2 – 12H |     | ns   |
| <sup>t</sup> h(BCKXL-BDRV)   | Hold time, BDR valid after BCLKX low   | 4    |     | 6 + 12H |     | ns   |
| <sup>t</sup> su(BFXL-BCKXL)  | Setup time, BFSX low before BCLKX low  |      |     | 10      |     | ns   |
| tc(BCKX)                     | Cycle time, BCLKX                      | 12H  |     | 32H     |     | ns   |

<sup>+</sup> For all SPI slave modes, CLKG is programmed as 1/2 of the CPU clock by setting CLKSM = CLKGDV = 1.

# switching characteristics for McBSP as SPI master or slave: $[H=0.5t_{c(CO)}]$ CLKSTP = 11b, CLKXP = 1<sup>†</sup> (see Figure 34)

|                               | PARAMETER                                                                | MAS   | rer‡  | SL     | AVE      | UNIT |
|-------------------------------|--------------------------------------------------------------------------|-------|-------|--------|----------|------|
|                               | PARAMETER                                                                | MIN   | MAX   | MIN    | MAX      | UNIT |
| th(BCKXH-BFXL)                | Hold time, BFSX low after BCLKX high§                                    | D – 5 | D + 5 |        |          | ns   |
| td(BFXL-BCKXL)                | Delay time, BFSX low to BCLKX low $\P$                                   | T – 5 | T + 5 |        |          | ns   |
| td(BCKXH-BDXV)                | Delay time, BCLKX high to BDX valid                                      | -2    | 12    | 6H + 4 | 10H + 19 | ns   |
| <sup>t</sup> dis(BCKXH-BDXHZ) | Disable time, BDX high impedance following last data bit from BCLKX high | -2    | 10    | 6H + 4 | 10H + 17 | ns   |
| <sup>t</sup> d(BFXL-BDXV)     | Delay time, BFSX low to BDX valid                                        | C – 2 | C +10 | 4H – 4 | 8H + 17  | ns   |

<sup>†</sup> For all SPI slave modes, CLKG is programmed as 1/2 of the CPU clock by setting CLKSM = CLKGDV = 1.

T = BCLKX period = (1 + CLKGDV) \* 2H

C = BCLKX low pulse width = T/2 when CLKGDV is odd or zero and = (CLKGDV/2) \* 2H when CLKGDV is even

D = BCLKX high pulse width = T/2 when CLKGDV is odd or zero and = (CLKGDV/2 + 1) \* 2H when CLKGDV is even

§ FSRP = FSXP = 1. As a SPI master, BFSX is inverted to provide active-low slave-enable output. As a slave, the active-low signal input on BFSX and BFSR is inverted before being used internally.

CLKXM = FSXM = 1, CLKRM = FSRM = 0 for master McBSP

CLKXM = CLKRM = FSXM = FSRM = 0 for slave McBSP

BFSX should be low before the rising edge of clock to enable slave devices and then begin a SPI transfer at the rising edge of the master clock (BCLKX).



Figure 34. McBSP Timing as SPI Master or Slave: CLKSTP = 11b, CLKXP = 1



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### HPI16 timing

# switching characteristics over recommended operating conditions<sup>†‡</sup> [H = 0.5t<sub>c(CO)</sub>] (see Figure 35 – Figure 42)

|                          | PARAMETER                                                              | MIN                                                                                | UNIT                         |                               |    |  |  |
|--------------------------|------------------------------------------------------------------------|------------------------------------------------------------------------------------|------------------------------|-------------------------------|----|--|--|
| <sup>t</sup> d(DSL-HDD)  | Delay time, DS low to HD driven§                                       |                                                                                    | 3                            | 20                            | ns |  |  |
| <sup>t</sup> d(DSL-HDV1) |                                                                        | Case 1a: Memory accesses when DMAC is active in 16-bit mode and $t_{w}(DSH) < 18H$ |                              | 18H+20 – t <sub>w</sub> (DSH) |    |  |  |
|                          |                                                                        | Case 1b: Memory accesses when DMAC is active in 16-bit mode and $t_W(DSH) \ge 18H$ | 20                           |                               |    |  |  |
|                          | Delay time, DS low to HDx valid for first                              | Case 1c: Memory access when<br>DMAC is active in 32-bit mode and<br>tw(DSH) < 26H  | 26H+20 - t <sub>w(DSH)</sub> |                               |    |  |  |
|                          | byte of an HPI read                                                    | Case 1d: Memory access when DMAC is active in 32-bit mode and $t_{W}(DSH) \ge 26H$ |                              | ns                            |    |  |  |
|                          |                                                                        | Case 2a: Memory accesses when DMAC is inactive and $t_{W(DSH)} < 10H$              |                              |                               |    |  |  |
|                          |                                                                        | Case 2b: Memory accesses when DMAC is inactive and $t_{W}(DSH) \ge 10H$            |                              |                               | 20 |  |  |
|                          |                                                                        | Case 3: Register accesses                                                          |                              | 20                            |    |  |  |
| <sup>t</sup> d(DSL-HDV2) | Multiplexed reads with autoincrement. Prefetch completed.              |                                                                                    |                              | 20                            | ns |  |  |
| <sup>t</sup> d(DSH-HYH)  |                                                                        | No DMA channel active                                                              |                              | 12H+5                         | ns |  |  |
|                          | Delay time, DS high to HRDY high $\$$ (writes and autoincrement reads) | One or more 16-bit DMA channels active                                             |                              | 18H+5                         |    |  |  |
|                          |                                                                        | One or more 32-bit DMA channels active                                             |                              | 26H+5                         |    |  |  |
|                          |                                                                        | Writes to DSPINT and HINT                                                          |                              | 4H + 5                        |    |  |  |
| <sup>t</sup> v(HYH-HDV)  | Valid time, HDx valid after HRDY high                                  |                                                                                    | 7                            | ns                            |    |  |  |
| <sup>t</sup> h(DSH-HDV)R | Hold time, HD valid after DS rising edge                               | 0                                                                                  | 10                           | ns                            |    |  |  |
| td(COH-HYH)              | Delay time, CLKOUT rising edge to HRDY high                            |                                                                                    |                              | 5                             | ns |  |  |
| td(DSH-HYL)              | Delay time, HDS or HCS high to HRDY low <sup>‡</sup>                   |                                                                                    |                              | 12                            | ns |  |  |
| td(COH-HTX)              | Delay time, CLKOUT rising edge to HINT change                          |                                                                                    |                              | 5                             | ns |  |  |

<sup>†</sup> HAD stands for HCN<u>TL0, HCNTL1, and HR/W</u>.

 $\ddagger$  HDS refers to either HDS1 or HDS2.

 $\$  DS refers to the logical OR of  $\overline{\text{HCS}}$  and  $\overline{\text{HDS}}.$ 



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

# HPI16 timing (continued)

# timing requirements [H = $0.5t_{c(CO)}$ ] (see Figure 35 – Figure 42)

|                            |                                                                |                                                         |        | MIN     | MAX | UNIT |  |
|----------------------------|----------------------------------------------------------------|---------------------------------------------------------|--------|---------|-----|------|--|
| <sup>t</sup> su(HBV-DSL)   | Setup time, HAD valid before DS falling                        | 5                                                       |        | ns      |     |      |  |
| <sup>t</sup> h(DSL-HBV)    | Hold time, HAD valid after DS falling ec                       | lge†‡                                                   |        | 5       |     | ns   |  |
| <sup>t</sup> su(HBV-HSL)   | Setup time, HAD valid before HAS fallir                        | ng edge†                                                |        | 5       |     | ns   |  |
| <sup>t</sup> h(HSL-HBV)    | Hold time, HAD valid after HAS falling e                       | edge†                                                   |        | 5       |     | ns   |  |
| <sup>t</sup> su(HAV-DSH)   | Setup time, address valid before DS ris                        | ing edge (nonmultiplexed write)                         |        | 5       |     | ns   |  |
| <sup>t</sup> su(HAV-DSL)   | Setup time, address valid before DS fall                       | ling edge (nonmultiplexed mode)‡                        |        | –4H – 5 |     | ns   |  |
| <sup>t</sup> h(DSH-HAV)    | Hold time, address valid after DS rising                       | edge (nonmultiplexed mode) <sup>‡</sup>                 |        | 1       |     | ns   |  |
| <sup>t</sup> su(HSL-DSL)   | Setup time, HAS low before DS falling                          | Setup time, HAS low before DS falling edge <sup>‡</sup> |        |         |     |      |  |
| <sup>t</sup> h(HSL-DSL)    | Hold time, HAS low after DS falling edg                        | 2                                                       |        | ns      |     |      |  |
| <sup>t</sup> w(DSL)        | Pulse duration, DS low <sup>‡</sup>                            | 30                                                      |        | ns      |     |      |  |
| <sup>t</sup> w(DSH)        | Pulse duration, DS high <sup>‡</sup>                           | 10                                                      |        | ns      |     |      |  |
| <sup>t</sup> c(DSH-DSH)    | Cycle time, DS rising edge to next DS rising edge‡             | Nonmultiplexed or multiplexed mode                      | Reads  | 12H     |     | ns   |  |
|                            |                                                                | (no increment) with no DMA activity.                    | Writes | 14H     |     | ns   |  |
|                            |                                                                | Nonmultiplexed or multiplexed mode                      | Reads  | 18H     |     | ns   |  |
|                            |                                                                | (no increment) with 16-bit DMA activity.                | Writes | 20H     |     |      |  |
|                            |                                                                | Nonmultiplexed or multiplexed mode                      | Reads  | 26H     |     | ns   |  |
|                            |                                                                | (no increment) with 32-bit DMA activity.                | Writes | 28H     |     |      |  |
|                            | Cycle time, DS rising edge to next DS                          | Multiplexed (autoincrement) with na activity.           | 12H    |         | ns  |      |  |
|                            | rising edge <sup>‡</sup><br>(In autoincrement mode, WRITE tim- | Multiplexed (autoincrement) with 16-t activity.         | 18H    |         | ns  |      |  |
|                            | ings are the same as READ timings.)                            | Multiplexed (autoincrement) with 32-t activity.         | 26H    |         | ns  |      |  |
|                            | Cycle time, DS rising edge to next DS r                        | 8H                                                      |        | ns      |     |      |  |
| <sup>t</sup> su(HDV-DSH)   | Setup time, HD valid before DS rising e                        | 10                                                      |        | ns      |     |      |  |
| th(DSH-HDV)W               | Hold time, HD valid after DS rising edge                       | 0                                                       |        | ns      |     |      |  |
| t <sub>su</sub> (SELV-DSL) | Setup time, SELA/B valid before DS fal                         | 5                                                       |        | ns      |     |      |  |
| th(DSH-SELV)               | Hold time, SELA/B valid after DS Rising                        | 0                                                       |        | ns      |     |      |  |

<sup>†</sup> HAD stands for HCNTL0, HCNTL1, and HR/W. <sup>‡</sup> DS refers to the logical OR of HCS and HDS.



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### HPI16 timing (continued)





Figure 36. Multiplexed Read Timings Without HAS



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008



Figure 37. Multiplexed Write Timings Using HAS



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### HPI16 timing (continued) HCS tc(DSH-DSH) <sup>t</sup>w(DSH) HDS tsu(HBV-DSL) <sup>t</sup>w(DSL) HR/W <sup>-t</sup>h(DSL–HBV) HCNTL[1:0] 01 01 tsu(HDV-DSH) H <sup>-</sup> <sup>t</sup>h(DSH-HDV)W Data n HD[15:0] Data 1 td(DSH-HYL) HRDY H td(DSH-HYH)

Figure 38. Multiplexed Write Timings Without HAS



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008



Figure 39. Nonmultiplexed Read Timings



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### HPI16 timing (continued)



Figure 40. Nonmultiplexed Write Timings



SPRS080F - MARCH 1999 - REVISED OCTOBER 2008





SPRS080F - MARCH 1999 - REVISED OCTOBER 2008

#### mechanical data

The following packaging information reflects the most current released data available for the designated device(s). This data is subject to change without notice and without revision of this document.

#### package thermal resistance characteristics

Table 15 provides the estimated thermal resistance characteristics for the recommended package types used on the device.

| PARAMETER        | PGE PACKAGE | GGU PACKAGE | UNIT |
|------------------|-------------|-------------|------|
| R <sub>OJA</sub> | 56          | 38          | °C/W |
| R <sub>OJC</sub> | 5           | 5           | °C/W |

#### **Table 15. Thermal Resistance Characteristics**



#### PACKAGING INFORMATION

| Orderable Device   | Status <sup>(1)</sup> | Package<br>Type | Package<br>Drawing | Pins | Package<br>Qty | Eco Plan <sup>(2)</sup>    | Lead/Ball Finish | MSL Peak Temp <sup>(3)</sup> |
|--------------------|-----------------------|-----------------|--------------------|------|----------------|----------------------------|------------------|------------------------------|
| TMS320C5420GGUA200 | ACTIVE                | BGA             | GGU                | 144  | 160            | TBD                        | SNPB             | Level-3-220C-168 HR          |
| TMS320C5420GGUR200 | ACTIVE                | BGA             | GGU                | 144  | 1000           | TBD                        | SNPB             | Level-3-220C-168 HR          |
| TMS320C5420PGEA200 | ACTIVE                | LQFP            | PGE                | 144  | 60             | Green (RoHS &<br>no Sb/Br) | CU NIPDAU        | Level-1-260C-UNLIM           |
| TMS320VC5420GGU200 | ACTIVE                | BGA             | GGU                | 144  | 160            | TBD                        | SNPB             | Level-3-220C-168 HR          |
| TMS320VC5420PGE200 | ACTIVE                | LQFP            | PGE                | 144  | 60             | Green (RoHS &<br>no Sb/Br) | CU NIPDAU        | Level-1-260C-UNLIM           |
| TMS320VC5420ZGU200 | ACTIVE                | BGA             | ZGU                | 144  | 1              | Green (RoHS &<br>no Sb/Br) | SNAGCU           | Level-3-260C-168 HR          |

<sup>(1)</sup> The marketing status values are defined as follows:

ACTIVE: Product device recommended for new designs.

LIFEBUY: TI has announced that the device will be discontinued, and a lifetime-buy period is in effect.

NRND: Not recommended for new designs. Device is in production to support existing customers, but TI does not recommend using this part in a new design.

PREVIEW: Device has been announced but is not in production. Samples may or may not be available.

**OBSOLETE:** TI has discontinued the production of the device.

<sup>(2)</sup> Eco Plan - The planned eco-friendly classification: Pb-Free (RoHS), Pb-Free (RoHS Exempt), or Green (RoHS & no Sb/Br) - please check http://www.ti.com/productcontent for the latest availability information and additional product content details.

TBD: The Pb-Free/Green conversion plan has not been defined.

**Pb-Free (RoHS):** TI's terms "Lead-Free" or "Pb-Free" mean semiconductor products that are compatible with the current RoHS requirements for all 6 substances, including the requirement that lead not exceed 0.1% by weight in homogeneous materials. Where designed to be soldered at high temperatures, TI Pb-Free products are suitable for use in specified lead-free processes.

**Pb-Free (RoHS Exempt):** This component has a RoHS exemption for either 1) lead-based flip-chip solder bumps used between the die and package, or 2) lead-based die adhesive used between the die and leadframe. The component is otherwise considered Pb-Free (RoHS compatible) as defined above.

Green (RoHS & no Sb/Br): TI defines "Green" to mean Pb-Free (RoHS compatible), and free of Bromine (Br) and Antimony (Sb) based flame retardants (Br or Sb do not exceed 0.1% by weight in homogeneous material)

<sup>(3)</sup> MSL, Peak Temp. -- The Moisture Sensitivity Level rating according to the JEDEC industry standard classifications, and peak solder temperature.

**Important Information and Disclaimer:**The information provided on this page represents TI's knowledge and belief as of the date that it is provided. TI bases its knowledge and belief on information provided by third parties, and makes no representation or warranty as to the accuracy of such information. Efforts are underway to better integrate information from third parties. TI has taken and continues to take reasonable steps to provide representative and accurate information but may not have conducted destructive testing or chemical analysis on incoming materials and chemicals. TI and TI suppliers consider certain information to be proprietary, and thus CAS numbers and other limited information may not be available for release.

In no event shall TI's liability arising out of such information exceed the total purchase price of the TI part(s) at issue in this document sold by TI to Customer on an annual basis.

# www.BDTIC.com/TI

# **MECHANICAL DATA**

MTQF017A - OCTOBER 1994 - REVISED DECEMBER 1996

#### PGE (S-PQFP-G144)

#### PLASTIC QUAD FLATPACK



- NOTES: A. All linear dimensions are in millimeters.
  - B. This drawing is subject to change without notice.
  - C. Falls within JEDEC MS-026



ZGU (S-PBGA-N144)

PLASTIC BALL GRID ARRAY



- Α. All linear dimensions are in millimeters. This drawing is subject to change without notice.
- Β.
- Micro Star BGA configuration C. D. This is a lead-free solder ball design.



# **MECHANICAL DATA**

MPBG021C - DECEMBER 1996 - REVISED MAY 2002



- NOTES: A. All linear dimensions are in millimeters.
  - B. This drawing is subject to change without notice
  - C. MicroStar BGA<sup>™</sup> configuration

MicroStar BGA is a trademark of Texas Instruments Incorporated.

# WWW.BSTEFFCE BURGESSES CALAR, TAXABLE DE BURGESCES CALAR, TAXABLE DE BURGESCESCES CALAR, TAXABLE DE BURGESCES CALA

#### **IMPORTANT NOTICE**

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

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

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

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

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

Resale of TI products or services with statements different from or beyond the parameters stated by TI for that product or service voids all express and 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.

TI products are not authorized for use in safety-critical applications (such as life support) where a failure of the TI product would reasonably be expected to cause severe personal injury or death, unless officers of the parties have executed an agreement specifically governing such use. Buyers represent that they have all necessary expertise in the safety and regulatory ramifications of their applications, and acknowledge and agree that they are solely responsible for all legal, regulatory and safety-related requirements concerning their products and any use of TI products in such safety-critical applications, notwithstanding any applications-related information or support that may be provided by TI. Further, Buyers must fully indemnify TI and its representatives against any damages arising out of the use of TI products in such safety-critical applications.

TI products are neither designed nor intended for use in military/aerospace applications or environments unless the TI products are specifically designated by TI as military-grade or "enhanced plastic." Only products designated by TI as military-grade meet military specifications. Buyers acknowledge and agree that any such use of TI products which TI has not designated as military-grade is solely at the Buyer's risk, and that they are solely responsible for compliance with all legal and regulatory requirements in connection with such use.

TI products are neither designed nor intended for use in automotive applications or environments unless the specific TI products are designated by TI as compliant with ISO/TS 16949 requirements. Buyers acknowledge and agree that, if they use any non-designated products in automotive applications, TI will not be responsible for any failure to meet such requirements.

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

| Products                    |                        | Applications       |                           |
|-----------------------------|------------------------|--------------------|---------------------------|
| Amplifiers                  | amplifier.ti.com       | Audio              | www.ti.com/audio          |
| Data Converters             | dataconverter.ti.com   | Automotive         | www.ti.com/automotive     |
| DSP                         | dsp.ti.com             | Broadband          | www.ti.com/broadband      |
| Clocks and Timers           | www.ti.com/clocks      | Digital Control    | www.ti.com/digitalcontrol |
| Interface                   | interface.ti.com       | Medical            | www.ti.com/medical        |
| Logic                       | logic.ti.com           | Military           | www.ti.com/military       |
| Power Mgmt                  | power.ti.com           | Optical Networking | www.ti.com/opticalnetwork |
| Microcontrollers            | microcontroller.ti.com | Security           | www.ti.com/security       |
| RFID                        | www.ti-rfid.com        | Telephony          | www.ti.com/telephony      |
| RF/IF and ZigBee® Solutions | www.ti.com/lprf        | Video & Imaging    | www.ti.com/video          |
|                             |                        | Wireless           | www.ti.com/wireless       |

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

# www.BDTIC.com/TI