- Advanced Multibus Architecture With Three Separate 16-Bit Data Memory Buses and One Program Memory Bus
- 40-Bit Arithmetic Logic Unit (ALU), Including a 40-Bit Barrel Shifter and Two Independent 40-Bit Accumulators
- 17- × 17-Bit Parallel Multiplier Coupled to a 40-Bit Dedicated Adder for Non-Pipelined Single-Cycle Multiply/Accumulate (MAC) Operation
- Compare, Select, and Store Unit (CSSU) for the Add/Compare Selection of the Viterbi Operator
- Exponent Encoder to Compute an Exponent Value of a 40-Bit Accumulator Value in a Single Cycle
- Two Address Generators With Eight Auxiliary Registers and Two Auxiliary Register Arithmetic Units (ARAUs)
- Data Bus With a Bus-Holder Feature
- Extended Addressing Mode for 1M × 16-Bit Maximum Addressable External Program Space
- 4K x 16-Bit On-Chip ROM
- 16K x 16-Bit Dual-Access On-Chip RAM
- Single-Instruction-Repeat and Block-Repeat Operations for Program Code
- Block-Memory-Move Instructions for Efficient Program and Data Management
- Instructions With a 32-Bit Long Word Operand
- Instructions With Two- or Three-Operand Reads

- Arithmetic Instructions With Parallel Store and Parallel Load
- Conditional Store Instructions
- Fast Return From Interrupt
- On-Chip Peripherals
  - Software-Programmable Wait-State Generator and Programmable Bank Switching
  - On-Chip Phase-Locked Loop (PLL) Clock Generator With Internal Oscillator or External Clock Source
  - Two Multichannel Buffered Serial Ports (McBSPs)
  - Enhanced 8-Bit Parallel Host-Port Interface (HPI8)
  - Two 16-Bit Timers
  - Six-Channel Direct Memory Access (DMA) Controller
- Power Consumption Control With IDLE1, IDLE2, and IDLE3 Instructions With Power-Down Modes
- CLKOUT Off Control to Disable CLKOUT
- On-Chip Scan-Based Emulation Logic, IEEE Std 1149.1<sup>†</sup> (JTAG) Boundary Scan Logic
- 10-ns Single-Cycle Fixed-Point Instruction Execution Time (100 MIPS) for 3.3-V Power Supply (1.8-V Core)
- Available in a 144-Pin Plastic Thin Quad Flatpack (TQFP) (PGE Suffix) and a 144-Pin Ball Grid Array (BGA) (GGU Suffix)

### description

The TMS320VC5402 fixed-point, digital signal processor (DSP) (hereafter referred to as the '5402 unless otherwise specified) is based on an advanced modified Harvard architecture that has one program memory bus and three data memory buses. This processor provides an arithmetic logic unit (ALU) with a high degree of parallelism, application-specific hardware logic, on-chip memory, and additional on-chip peripherals. The basis of the operational flexibility and speed of this DSP is a highly specialized instruction set.

Separate program and data spaces allow simultaneous access to program instructions and data, providing the high degree of parallelism. Two read operations and one write operation can be performed in a single cycle. Instructions with parallel store and application-specific instructions can fully utilize this architecture. In addition,



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.

†IEEE Standard 1149.1-1990 Standard-Test-Access Port and Boundary Scan Architecture.



#### description (continued)

data can be transferred between data and program 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 '5402 includes the control mechanisms to manage interrupts, repeated operations, and function calls.

For detailed information on the architecture of the 'C5000 family of DSPs, see the *TMS320C5000 DSP Family Functional Overview* (literature number SPRU307).

## TMS320VC5402 PGE PACKAGE<sup>†‡</sup> (TOP VIEW)



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

The TMS320VC5402PGE (144-pin TQFP) package is footprint-compatible with the 'LC548, 'LC/VC549, and 'VC5410 devices.



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

## TMS320VC5402 GGU PACKAGE (BOTTOM VIEW)



The pin assignments table to follow lists each signal quadrant and BGA ball number for the TMS320VC5402GGU (144-pin BGA) package which is footprint-compatible with the 'LC548 and 'LC/VC549 devices.

## Pin Assignments for the TMS320VC5402GGU (144-Pin BGA) Package<sup>†</sup>

| SIGNAL<br>NAME   | BGA BALL# |
|------------------|-----------|------------------|-----------|------------------|-----------|------------------|-----------|
| NC               | A1        | NC               | N13       | NC               | N1        | A19              | A13       |
| NC               | B1        | NC               | M13       | NC               | N2        | NC               | A12       |
| V <sub>SS</sub>  | C2        | DV <sub>DD</sub> | L12       | HCNTL0           | M3        | V <sub>SS</sub>  | B11       |
| DV <sub>DD</sub> | C1        | V <sub>SS</sub>  | L13       | V <sub>SS</sub>  | N3        | DV <sub>DD</sub> | A11       |
| A10              | D4        | CLKMD1           | K10       | BCLKR0           | K4        | D6               | D10       |
| HD7              | D3        | CLKMD2           | K11       | BCLKR1           | L4        | D7               | C10       |
| A11              | D2        | CLKMD3           | K12       | BFSR0            | M4        | D8               | B10       |
| A12              | D1        | NC               | K13       | BFSR1            | N4        | D9               | A10       |
| A13              | E4        | HD2              | J10       | BDR0             | K5        | D10              | D9        |
| A14              | E3        | TOUT0            | J11       | HCNTL1           | L5        | D11              | C9        |
| A15              | E2        | EMU0             | J12       | BDR1             | M5        | D12              | В9        |
| NC               | E1        | EMU1/OFF         | J13       | BCLKX0           | N5        | HD4              | A9        |
| HAS              | F4        | TDO              | H10       | BCLKX1           | K6        | D13              | D8        |
| Vss              | F3        | TDI              | H11       | Vss              | L6        | D14              | C8        |
| NC               | F2        | TRST             | H12       | HINT/TOUT1       | M6        | D15              | B8        |
| CV <sub>DD</sub> | F1        | TCK              | H13       | CV <sub>DD</sub> | N6        | HD5              | A8        |
| HCS              | G2        | TMS              | G12       | BFSX0            | M7        | CV <sub>DD</sub> | В7        |
| HR/W             | G1        | NC               | G13       | BFSX1            | N7        | NC               | A7        |
| READY            | G3        | CV <sub>DD</sub> | G11       | HRDY             | L7        | HDS1             | C7        |
| PS               | G4        | HPIENA           | G10       | $DV_DD$          | K7        | VSS              | D7        |
| DS               | H1        | VSS              | F13       | Vss              | N8        | HDS2             | A6        |
| ĪS               | H2        | CLKOUT           | F12       | HD0              | M8        | $DV_DD$          | В6        |
| R/W              | H3        | HD3              | F11       | BDX0             | L8        | A0               | C6        |
| MSTRB            | H4        | X1               | F10       | BDX1             | K8        | A1               | D6        |
| IOSTRB           | J1        | X2/CLKIN         | E13       | ĪACK             | N9        | A2               | A5        |
| MSC              | J2        | RS               | E12       | HBIL             | M9        | А3               | B5        |
| XF               | J3        | D0               | E11       | NMI              | L9        | HD6              | C5        |
| HOLDA            | J4        | D1               | E10       | INT0             | K9        | A4               | D5        |
| ĪAQ              | K1        | D2               | D13       | INT1             | N10       | A5               | A4        |
| HOLD             | K2        | D3               | D12       | ĪNT2             | M10       | A6               | B4        |
| BIO              | K3        | D4               | D11       | ĪNT3             | L10       | A7               | C4        |
| MP/MC            | L1        | D5               | C13       | CV <sub>DD</sub> | N11       | A8               | А3        |
| DV <sub>DD</sub> | L2        | A16              | C12       | HD1              | M11       | A9               | В3        |
| VSS              | L3        | V <sub>SS</sub>  | C11       | V <sub>SS</sub>  | L11       | CV <sub>DD</sub> | C3        |
| NC               | M1        | A17              | B13       | NC               | N12       | NC               | A2        |
| NC               | M2        | A18              | B12       | NC               | M12       | NC               | B2        |

<sup>&</sup>lt;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.



#### terminal functions

The following table lists each signal, function, and operating mode(s) grouped by function.

#### **Terminal Functions**

|                                                                                                                                | RMINAL<br>NAME                                  | TYPET | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| <del></del>                                                                                                                    | DATA SIGNALS                                    |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| A19<br>A18<br>A17<br>A16<br>A15<br>A14<br>A13<br>A12<br>A11<br>A10<br>A9<br>A8<br>A7<br>A6<br>A5<br>A4<br>A3<br>A2<br>A1<br>A0 | (MSB)                                           | O/Z   | Parallel address bus A19 [most significant bit (MSB)] through A0 [least significant bit (LSB)]. The lower sixteen address pins (A0 to A15) are multiplexed to address all external memory (program, data) or I/O, while the upper four address pins (A16 to A19) are only used to address external program space. These pins are placed in the high-impedance state when the hold mode is enabled, or when OFF is low.                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |  |
| D15 D14 D13 D12 D11 D10 D9 D8 D7 D6 D5 D4 D3 D2 D1 D0                                                                          | (MSB)                                           | I/O/Z | Parallel data bus D15 (MSB) through D0 (LSB). The sixteen data pins (D0 to D15) are multiplexed to transfer data between the core CPU and external data/program memory or I/O devices. The data bus is placed in the high-impedance state when not outputting or when RS or HOLD is asserted. The data bus also goes into the high-impedance state when OFF is low.  The data bus has bus holders to reduce the static power dissipation caused by floating, unused pins. These bus holders also eliminate the need for external bias resistors on unused pins. When the data bus is not being driven by the '5402, the bus holders keep the pins at the previous logic level. The data bus holders on the '5402 are disabled at reset and can be enabled/disabled via the BH bit of the bank-switching control register (BSCR). |  |  |  |
|                                                                                                                                | INITIALIZATION, INTERRUPT, AND RESET OPERATIONS |       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| ĪACK                                                                                                                           |                                                 | O/Z   | Interrupt acknowledge signal. IACK Indicates receipt of an interrupt and that the program counter is fetching the interrupt vector location designated by A15–A0. IACK also goes into the high-impedance state when OFF is low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |
| INTO<br>INT1<br>INT2<br>INT3                                                                                                   |                                                 | 1     | 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).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |  |
| 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |

<sup>†</sup> I = input, O = output, Z = high impedance, S = supply

<sup>‡</sup> All revisions of the '5402 can be operated with an external clock source, provided that the proper voltage levels be driven on the X2/CLKIN pin. It should be noted that the X2/CLKIN pin is referenced to the device 1.8V power supply (CVdd), rather than the 3V I/O supply (DVdd). Refer to the recommended operating conditions section of this document for the allowable voltage levels of the X2/CLKIN pin.



| TERMINAL<br>NAME | TYPET | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  |       | INITIALIZATION, INTERRUPT, AND RESET OPERATIONS (CONTINUED)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| 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.                                                                                                                                                                                                          |
| MP/MC            | _     | Microprocessor/microcomputer mode select. If active low at reset, microcomputer mode is selected, and the internal program ROM is mapped into the upper 4K words of program memory space. If the pin is driven high during reset, microprocessor mode is selected, and the on-chip ROM is removed from program space. This pin is only sampled at reset, and the MP/MC bit of the processor mode status (PMST) register can override the mode that is selected at reset.                                                                           |
|                  |       | MULTIPROCESSING SIGNALS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| BIO              | I     | Branch control. A branch can be conditionally executed when $\overline{\text{BIO}}$ is active. If low, the processor executes the conditional instruction. For the XC instruction, the $\overline{\text{BIO}}$ condition is sampled during the decode phase of the pipeline; all other instructions sample $\overline{\text{BIO}}$ during the read phase of the pipeline.                                                                                                                                                                          |
| XF               | O/Z   | External flag output (latched software-programmable signal). XF is set high by the SSBX XF instruction, set low by the RSBX XF instruction or by loading ST1. XF is used for signaling other processors in multiprocessor configurations or used as a general-purpose output pin. XF goes into the high-impedance state when $\overline{\text{OFF}}$ is low, and is set high at reset.                                                                                                                                                             |
|                  |       | MEMORY CONTROL SIGNALS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| DS<br>PS<br>IS   | O/Z   | Data, program, and I/O space select signals. DS, PS, and IS are always high unless driven low for accessing a particular external memory space. Active period corresponds to valid address information. DS, PS, and IS are placed into the high-impedance state in the hold mode; the signals also go into the high-impedance state when OFF is low.                                                                                                                                                                                               |
| MSTRB            | O/Z   | Memory strobe signal. MSTRB is always high unless low-level asserted to indicate an external bus access to data or program memory. MSTRB is placed in the high-impedance state in the hold mode; it also goes into the high-impedance state when OFF is low.                                                                                                                                                                                                                                                                                       |
| READY            | _     | Data ready. READY indicates that an external device is prepared for a bus transaction to be completed. If the device is not ready (READY is low), the processor waits one cycle and checks READY again. Note that the processor performs ready detection if at least two software wait states are programmed. The READY signal is not sampled until the completion of the software wait states.                                                                                                                                                    |
| R/W              | O/Z   | Read/write 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/\overline{W}$ is placed in the high-impedance state in hold mode; it also goes into the high-impedance state when $\overline{OFF}$ is low.                                                                                                                                                                |
| IOSTRB           | O/Z   | I/O strobe signal. OSTRB is always high unless low-level asserted to indicate an external bus access to an I/O device. IOSTRB is placed in the high-impedance state in the hold mode; it also goes into the high-impedance state when OFF is low.                                                                                                                                                                                                                                                                                                  |
| HOLD             | I     | Hold. HOLD is asserted to request control of the address, data, and control lines. When acknowledged by the 'C54x, these lines go into the high-impedance state.                                                                                                                                                                                                                                                                                                                                                                                   |
| HOLDA            | O/Z   | Hold acknowledge. HOLDA indicates that the '5402 is in a hold state and that the address, data, and control lines are in the high-impedance state, allowing the external memory interface to be accessed by other devices. HOLDA also goes into the high-impedance state when OFF is low.                                                                                                                                                                                                                                                          |
| MSC              | O/Z   | Microstate complete. $\overline{\text{MSC}}$ indicates completion of all software wait states. When two or more software wait states are enabled, the MSC pin goes active at the beginning of the first software wait state and goes inactive high at the beginning of the last software wait state. If connected to the READY input, $\overline{\text{MSC}}$ forces one external wait state after the last internal wait state is completed. $\overline{\text{MSC}}$ also goes into the high-impedance state when $\overline{\text{OFF}}$ is low. |
| ĪAQ              | O/Z   | Instruction acquisition signal. $\overline{\text{IAQ}}$ is asserted (active low) when there is an instruction address on the address bus. $\overline{\text{IAQ}}$ goes into the high-impedance state when $\overline{\text{OFF}}$ is low.                                                                                                                                                                                                                                                                                                          |

 $<sup>\</sup>dagger$  I = input, O = output, Z = high impedance, S = supply

<sup>‡</sup> All revisions of the '5402 can be operated with an external clock source, provided that the proper voltage levels be driven on the X2/CLKIN pin. It should be noted that the X2/CLKIN pin is referenced to the device 1.8V power supply (CVdd), rather than the 3V I/O supply (DVdd). Refer to the recommended operating conditions section of this document for the allowable voltage levels of the X2/CLKIN pin.



| TERMINAL         | TYPET | DESCRIPTION                                                                                                                                                                                                               |  |
|------------------|-------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| NAME             |       | OSCILLATOR/TIMER SIGNALS                                                                                                                                                                                                  |  |
|                  |       |                                                                                                                                                                                                                           |  |
| CLKOUT           | O/Z   | Master clock output signal. CLKOUT cycles at the machine-cycle rate of the CPU. The internal machine cycle is bounded by rising edges of this signal. CLKOUT also goes into the high-impedance state when OFF is low.     |  |
| CLKMD1           |       | Clock mode select signals. These inputs select the mode that the clock generator is initialized to after reset. The                                                                                                       |  |
| CLKMD2           | 1     | logic levels of CLKMD1–CLKMD3 are latched when the reset pin is low, and the clock mode register is initialized                                                                                                           |  |
| CLKMD3           |       | to the selected mode. After reset, the clock mode can be changed through software, but the clock mode select                                                                                                              |  |
|                  |       | signals have no effect until the device is reset again.                                                                                                                                                                   |  |
|                  |       | Oscillator input. This is the input to the on-chip oscillator.                                                                                                                                                            |  |
| X2/CLKIN         | I     | If the internal oscillator is not used, X2/CLKIN functions as the clock input, and can be driven by an external clock source.‡                                                                                            |  |
|                  |       | Output pin from the internal oscillator for the crystal.                                                                                                                                                                  |  |
| X1               | 0     | If the internal equillator is not used. V4 should be left unconnected. V4 does not go into the high immediance state.                                                                                                     |  |
|                  |       | If the internal oscillator is not used, X1 should be left unconnected. X1 does not go into the high-impedance state when OFF is low.‡                                                                                     |  |
| TOUT0            | O/Z   | Timer0 output. TOUT0 signals a pulse when the on-chip timer 0 counts down past zero. The pulse is a CLKOUT cycle wide. TOUT0 also goes into the high-impedance state when OFF is low.                                     |  |
|                  |       | Timer1 output. TOUT1 signals a pulse when the on-chip timer1 counts down past zero. The pulse is one                                                                                                                      |  |
| TOUT1            | O/Z   | CLKOUT cycle wide. The TOUT1 output is multiplexed with the HINT pin of the HPI and is only available when                                                                                                                |  |
|                  |       | the HPI is disabled. TOUT1 also goes into the high-impedance state when OFF is low.                                                                                                                                       |  |
|                  |       | MULTICHANNEL BUFFERED SERIAL PORT SIGNALS                                                                                                                                                                                 |  |
| BCLKR0<br>BCLKR1 | I/O/Z | Receive clock input. BCLKR can be configured as an input or an output; it is configured as an input following reset. BCLKR serves as the serial shift clock for the buffered serial port receiver.                        |  |
| BDR0<br>BDR1     | 1     | Serial data receive input                                                                                                                                                                                                 |  |
| BFSR0<br>BFSR1   | I/O/Z | Frame synchronization pulse for receive input. BFSR can be configured as an input or an output; it is configured as an input following reset. The BFSR pulse initiates the receive data process over BDR.                 |  |
| BCLKX0           |       | Transmit clock. BCLKX serves as the serial shift clock for the McBSP transmitter. BCLKX can be configured as                                                                                                              |  |
| BCLKX1           | I/O/Z | an input or an output; it is configured as an input following reset. BCLKX enters the high-impedance state when OFF goes low.                                                                                             |  |
| DDV/0            |       | <u> </u>                                                                                                                                                                                                                  |  |
| BDX0<br>BDX1     | O/Z   | Serial data transmit output. BDX is placed in the high-impedance state when not transmitting, when RS is asserted, or when OFF is low.                                                                                    |  |
| BFSX0            |       | Frame synchronization pulse for transmit input/output. The BFSX pulse initiates the transmit data process. BFSX                                                                                                           |  |
| BFSX1            | I/O/Z | can be configured as an input or an output; it is configured as an input following reset. BFSX goes into the                                                                                                              |  |
|                  |       | high-impedance state when OFF is low.                                                                                                                                                                                     |  |
|                  |       | MISCELLANEOUS SIGNAL                                                                                                                                                                                                      |  |
| NC               |       | No connection                                                                                                                                                                                                             |  |
|                  |       | HOST-PORT INTERFACE SIGNALS                                                                                                                                                                                               |  |
|                  |       | Parallel bidirectional data bus. The HPI data bus is used by a host device bus to exchange information with the                                                                                                           |  |
| HD0-HD7          |       | HPI registers. These pins can also be used as general-purpose I/O pins. HD0-HD7 is placed in the                                                                                                                          |  |
|                  | I/O/Z | high-impedance state when not outputting data or when OFF is low. The HPI data bus includes bus holders to reduce the static power dissipation caused by floating, unused pins. When the HPI data bus is not being driven |  |
|                  |       | by the '5402, the bus holders keep the pins at the previous logic level. The HPI data bus holders are disabled                                                                                                            |  |
|                  |       | at reset and can be enabled/disabled via the HBH bit of the BSCR.                                                                                                                                                         |  |
| HCNTL0           |       | Control. HCNTL0 and HCNTL1 select a host access to one of the three HPI registers. The control inputs have                                                                                                                |  |
| HCNTL1           | I     | internal pullup resistors that are only enabled when HPIENA = 0.                                                                                                                                                          |  |

 $<sup>\</sup>dagger$  I = input, O = output, Z = high impedance, S = supply

<sup>‡</sup> All revisions of the '5402 can be operated with an external clock source, provided that the proper voltage levels be driven on the X2/CLKIN pin. It should be noted that the X2/CLKIN pin is referenced to the device 1.8V power supply (CVdd), rather than the 3V I/O supply (DVdd). Refer to the recommended operating conditions section of this document for the allowable voltage levels of the X2/CLKIN pin.



| TERMINAL<br>NAME | TYPET                                                                                                                                                                                                                                                                                                      | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                              |  |  |  |  |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
|                  | HOST-PORT INTERFACE SIGNALS (CONTINUED)                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |
| HBIL I           |                                                                                                                                                                                                                                                                                                            | Byte identification. HBIL identifies the first or second byte of transfer. The HBIL input has an internal pullup resistor that is only enabled when HPIENA = 0.                                                                                                                                                                                                          |  |  |  |  |
| HCS              | I                                                                                                                                                                                                                                                                                                          | Chip select. HCS is the select input for the HPI and must be driven low during accesses. The chip-select input has an internal pullup resistor that is only enabled when HPIENA = 0.                                                                                                                                                                                     |  |  |  |  |
| HDS1<br>HDS2     | 1                                                                                                                                                                                                                                                                                                          | Data strobe. HDS1 and HDS2 are driven by the host read and write strobes to control transfers. The strobe inputs have internal pullup resistors that are only enabled when HPIENA = 0.                                                                                                                                                                                   |  |  |  |  |
| HAS              | 1                                                                                                                                                                                                                                                                                                          | Address strobe. Hosts with multiplexed address and data pins require HAS to latch the address in the HPIA register. HAS has an internal pullup resistor that is only enabled when HPIENA = 0.                                                                                                                                                                            |  |  |  |  |
| HR/W             | 1                                                                                                                                                                                                                                                                                                          | Read/write. HR/ $\overline{W}$ controls the direction of an HPI transfer. R/ $\overline{W}$ has an internal pullup resistor that is only enabled when HPIENA = 0.                                                                                                                                                                                                        |  |  |  |  |
| HRDY             | O/Z                                                                                                                                                                                                                                                                                                        | Ready. The ready output informs the host when the HPI is ready for the next transfer. HRDY goes into the high-impedance state when $\overline{\text{OFF}}$ is low.                                                                                                                                                                                                       |  |  |  |  |
| HINT             | O/Z                                                                                                                                                                                                                                                                                                        | Host interrupt. This output is used to interrupt the host. When the DSP is in reset, HINT is driven high. HINT can also be configured as the timer 1 output (TOUT1), when the HPI is disabled. The signal goes into the high-impedance state when OFF is low.                                                                                                            |  |  |  |  |
| HPIENA           | I                                                                                                                                                                                                                                                                                                          | HPI module select. HPIENA must be driven high during reset to enable the HPI. An internal pulldown resistor is always active and the HPIENA pin is sampled on the rising edge of RS. If HPIENA is left open or is driven low during reset, the HPI module is disabled. Once the HPI is disabled, the HPIENA pin has no effect until the '5402 is reset.                  |  |  |  |  |
|                  |                                                                                                                                                                                                                                                                                                            | SUPPLY PNS                                                                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| CV <sub>DD</sub> | S                                                                                                                                                                                                                                                                                                          | +V <sub>DD</sub> . Dedicated 1.8-V power supply for the core CPU                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| $DV_DD$          | S                                                                                                                                                                                                                                                                                                          | +V <sub>DD</sub> . Dedicated 3.3-V power supply for the I/O pins                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| V <sub>SS</sub>  | S                                                                                                                                                                                                                                                                                                          | Ground                                                                                                                                                                                                                                                                                                                                                                   |  |  |  |  |
|                  |                                                                                                                                                                                                                                                                                                            | TEST PINS                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
| тск              | I                                                                                                                                                                                                                                                                                                          | IEEE standard 1149.1 test clock. TCK is normally a free-running clock signal with a 50% duty cycle. The 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              | 1                                                                                                                                                                                                                                                                                                          | IEEE standard 1149.1 test data input pin with internal pullup device. TDI is clocked into the selected register (instruction or data) on a rising edge of TCK.                                                                                                                                                                                                           |  |  |  |  |
| TDO              | O/Z                                                                                                                                                                                                                                                                                                        | IEEE standard 1149.1 test data output. The contents of the selected register (instruction or data) are shifted out of TDO on the falling edge of TCK. TDO is in the high-impedance state except when the scanning of data is in progress. TDO also goes into the high-impedance state when OFF is low.                                                                   |  |  |  |  |
| TMS              | I                                                                                                                                                                                                                                                                                                          | IEEE standard 1149.1 test mode select. Pin with internal pullup device. This serial control input is clocked into the TAP controller on the rising edge of TCK.                                                                                                                                                                                                          |  |  |  |  |
| TRST             | IEEE standard 1149.1 test reset. TRST, when high, gives the IEEE standard 1149.1 scan system control of operations of the device. If TRST is not connected or is driven low, the device operates in its functional monand the IEEE standard 1149.1 signals are ignored. Pin with internal pulldown device. |                                                                                                                                                                                                                                                                                                                                                                          |  |  |  |  |

 $<sup>\</sup>dagger$  I = input, O = output, Z = high impedance, S = supply



<sup>‡</sup> All revisions of the '5402 can be operated with an external clock source, provided that the proper voltage levels be driven on the X2/CLKIN pin. It should be noted that the X2/CLKIN pin is referenced to the device 1.8V power supply (CVdd), rather than the 3V I/O supply (DVdd). Refer to the recommended operating conditions section of this document for the allowable voltage levels of the X2/CLKIN pin.

| TERMINAL<br>NAME | TYPET | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
|------------------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                  |       | TEST PINS (CONTINUED)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |
| EMU0             | I/O/Z | Emulator 0 pin. When TRST is driven low, EMU0 must be high for activation of the OFF condition. When TRST is driven high, EMU0 is used as an interrupt to or from the emulator system and is defined as input/output by way of the IEEE standard 1149.1 scan system.                                                                                                                                                                                                                                                                                                                 |  |  |
| EMU1/OFF         | I/O/Z | Emulator 1 pin/disable all outputs. When TRST is driven high, EMU1/OFF is used as an interrupt to or from the emulator system and is defined as input/output by way of the IEEE standard 1149.1 scan system. When TRST is driven low, EMU1/OFF is configured as OFF. The EMU1/OFF signal, when active low, puts all output drivers into the high-impedance state. Note that OFF is used exclusively for testing and emulation purposes (not for multiprocessing applications). The OFF feature is selected by the following pin combinations:  TRST = low EMU0 = high EMU1/OFF = low |  |  |

 $<sup>\</sup>dagger$  I = input, O = output, Z = high impedance, S = supply

<sup>‡</sup> All revisions of the '5402 can be operated with an external clock source, provided that the proper voltage levels be driven on the X2/CLKIN pin. It should be noted that the X2/CLKIN pin is referenced to the device 1.8V power supply (CVdd), rather than the 3V I/O supply (DVdd). Refer to the recommended operating conditions section of this document for the allowable voltage levels of the X2/CLKIN pin.

#### memory

The '5402 device provides both on-chip ROM and RAM memories to aid in system performance and integration.

#### on-chip ROM with bootloader

The '5402 features a 4K-word  $\times$  16-bit on-chip maskable ROM. Customers can arrange to have the ROM of the '5402 programmed with contents unique to any particular application. A security option is available to protect a custom ROM. This security option is described in the *TMS320C54x DSP CPU and Peripherals Reference Set, Volume 1* (literature number SPRU131). Note that only the ROM security option, and not the ROM/RAM option, is available on the '5402 .

A bootloader is available in the standard '5402 on-chip ROM. This bootloader can be used to automatically transfer user code from an external source to anywhere in the program memory at power up. If the MP/MC pin is sampled low during a hardware reset, execution begins at location FF80h of the on-chip ROM. This location contains a branch instruction to the start of the bootloader program. The standard '5402 bootloader provides different ways to download the code to accommodate various system requirements:

- Parallel from 8-bit or 16-bit-wide EPROM
- Parallel from I/O space 8-bit or 16-bit mode
- Serial boot from serial ports 8-bit or 16-bit mode
- Host-port interface boot

The standard on-chip ROM layout is shown in Table 1.

Table 1. Standard On-Chip ROM Layout<sup>†</sup>

| ADDRESS RANGE | DESCRIPTION            |
|---------------|------------------------|
| F000h – F7FFh | Reserved               |
| F800h – FBFFh | Bootloader             |
| FC00h - FCFFh | μ-law expansion table  |
| FD00h – FDFFh | A-law expansion table  |
| FE00h - FEFFh | Sine look-up table     |
| FF00h – FF7Fh | Reserved               |
| FF80h – FFFFh | Interrupt vector table |

<sup>†</sup> In the 'VC5402 ROM, 128 words are reserved for factory device-testing purposes. Application code to be implemented in on-chip ROM must reserve these 128 words at addresses FF00h–FF7Fh in program space.

#### on-chip RAM

The '5402 device contains  $16K \times 16$ -bit of on-chip dual-access RAM (DARAM). The DARAM is composed of two blocks of 8K words each. Each block in the DARAM can support two reads in one cycle, or a read and a write in one cycle. The DARAM is located in the address range 0060h-3FFFh in data space, and can be mapped into program/data space by setting the OVLY bit to one.



#### memory map



Figure 1. Memory Map

#### relocatable interrupt vector table

The reset, interrupt, and trap vectors are addressed in program space. These vectors are soft — meaning that the processor, when taking the trap, loads the program counter (PC) with the trap address and executes the code at the vector location. Four words are reserved at each vector location to accommodate a delayed branch instruction, either two 1-word instructions or one 2-word instruction, which allows branching to the appropriate interrupt service routine with minimal overhead.

At device reset, the reset, interrupt, and trap vectors are mapped to address FF80h in program space. However, these vectors can be remapped to the beginning of any 128-word page in program space after device reset. This is done by loading the interrupt vector pointer (IPTR) bits in the PMST register with the appropriate 128-word page boundary address. After loading IPTR, any user interrupt or trap vector is mapped to the new 128-word page.

NOTE: The hardware reset  $(\overline{RS})$  vector cannot be remapped because a hardware reset loads the IPTR with 1s. Therefore, the reset vector is always fetched at location FF80h in program space.



#### extended program memory

The '5402 uses a paged extended memory scheme in program space to allow access of up to 1024K program memory locations. In order to implement this scheme, the '5402 includes several features that are also present on the '548/'549 devices:

- Twenty address lines, instead of sixteen
- An extra memory-mapped register, the XPC register, defines the page selection. This register is memory-mapped into data space to address 001Eh. At a hardware reset, the XPC is initialized to 0.
- Six extra instructions for addressing extended program space. These six instructions affect the XPC.
  - FB[D] pmad (20 bits) Far branch
  - FBACC[D] Accu[19:0] Far branch to the location specified by the value in accumulator A or accumulator B
  - FCALL[D] pmad (20 bits) Far call
  - FCALA[D] Accu[19:0] Far call to the location specified by the value in accumulator A or accumulator B
  - FRET[D] Far return
  - FRETE[D] Far return with interrupts enabled
- In addition to these new instructions, two '54x instructions are extended to use 20 bits in the '5402:
  - READA data\_memory (using 20-bit accumulator address)
  - WRITA data\_memory (using 20-bit accumulator address)

All other instructions, software interrupts and hardware interrupts do not modify the XPC register and access only memory within the current page.

Program memory in the '5402 is organized into 16 pages that are each 64K in length, as shown in Figure 2.



<sup>†</sup> See Figure 1

Figure 2. Extended Program Memory



<sup>&</sup>lt;sup>‡</sup> The lower 16K words of pages 1 through 15 are available only when the OVLY bit is cleared to 0. If the OVLY bit is set to 1, the on-chip RAM is mapped to the lower 16K words of all program space pages.

#### on-chip peripherals

The '5402 device has the following peripherals:

- Software-programmable wait-state generator with programmable bank-switching wait states
- An enhanced 8-bit host-port interface (HPI8)
- Two multichannel buffered serial ports (McBSPs)
- Two hardware timers
- A clock generator with a phase-locked loop (PLL)
- A direct memory access (DMA) controller

#### software-programmable wait-state generator

The software wait-state generator of the '5402 can extend external bus cycles by up to fourteen machine cycles. Devices that require more than fourteen wait states can be interfaced using the hardware READY line. When all external accesses are configured for zero wait states, the internal clocks to the wait-state generator are automatically disabled. Disabling the wait-state generator clocks reduces the power comsumption of the '5402.

The software wait-state register (SWWSR) controls the operation of the wait-state generator. 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.



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

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

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

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

|           | BIT        |       | 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:                                                                                               |  |  |
| 5–3       | Program    | 1     | ☐ XPA = 0: x8000 – xFFFFh                                                                                                                                                                                                                                  |  |  |
|           | rrogram    | '     | ☐ XPA = 1: The upper program space bit field has no effect on wait states.                                                                                                                                                                                 |  |  |
|           |            |       | The SWSM bit of the SWCR defines a multiplication factor of 1 or 2 for the base number of wait states.                                                                                                                                                     |  |  |
| 2–0 Progr |            | 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:                                                                                                     |  |  |
|           | Program    |       | ☐ XPA = 0: x0000-x7FFFh                                                                                                                                                                                                                                    |  |  |
|           | i iogiaiii |       | ☐ XPA = 1: 00000-FFFFFh                                                                                                                                                                                                                                    |  |  |
|           |            |       | The SWSM bit of the SWCR defines a multiplication factor of 1 or 2 for the base number of wait states.                                                                                                                                                     |  |  |

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.



**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                                                                                                               |  |  |
|------|----------|-------|------------------------------------------------------------------------------------------------------------------------|--|--|
| NO.  | NAME     | VALUE | FUNCTION                                                                                                               |  |  |
| 15–1 | Reserved | 0     | These bits are reserved and are unaffected by writes.                                                                  |  |  |
| _    |          |       | Software wait-state multiplier. Used to multiply the number of wait states defined in the SWWSR by a factor of 1 or 2. |  |  |
| 0    | 0 SWSM   | 0     | 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 wait states

The programmable bank-switching logic of the '5402 is functionally equivalent to that of the '548/'549 devices. This feature automatically inserts one cycle when accesses cross memory-bank boundaries within program or data memory space. A bank-switching wait state can also be automatically inserted when accesses cross the data space boundary into program space.

The bank-switching control register (BSCR) defines the bank size for bank-switching wait states. Figure 5 shows the BSCR and its bits are described in Table 4.



Figure 5. Bank-Switching Control Register (BSCR), MMR Address 0029h

Table 4. Bank-Switching Control Register (BSCR) Fields

| NO.   | BIT<br>NAME | RESET<br>VALUE | FUNCTION                                                                                                                                                                                                                                                                                                                                                                                   |  |  |
|-------|-------------|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 15–12 | BNKCMP      | 1111           | Bank compare. 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. Inserts an extra cycle between consecutive accesses of program read and data read or data read and program read.  PS-DS = 0 No extra cycles are inserted by this feature.  PS-DS = 1 One extra cycle is inserted between consecutive data and program reads.                                                                                              |  |  |
| 10–3  | Reserved    | 0              | These bits are reserved and are unaffected by writes.                                                                                                                                                                                                                                                                                                                                      |  |  |
| 2     | НВН         | 0              | HPI Bus holder. Controls the HPI bus holder feature. HBH is cleared to 0 at reset.  HBH = 0  The bus holder is disabled.  HBH = 1  The bus holder is enabled. When not driven, the HPI data bus (HD[7:0]) is held in the previous logic level.                                                                                                                                             |  |  |
| 1     | ВН          | 0              | Bus holder. 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 (D[15:0]) is held in the previous logic level.                                                                                                                                                         |  |  |
| 0     | EXIO        | 0              | External bus interface off. The EXIO bit controls the external bus-off function.  EXIO = 0  EXIO = 1  The external bus interface functions as usual.  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. |  |  |

## TMS320VC5402 FIXED-POINT DIGITAL SIGNAL PROCESSOR

SPRS079D - OCTOBER 1998 - REVISED JANUARY 2000

#### parallel I/O ports

The '5402 has a total of 64K I/O ports. These ports can be addressed by the PORTR instruction or the PORTW instruction. The  $\overline{\text{IS}}$  signal indicates a read/write operation through an I/O port. The '5402 can interface easily with external devices through the I/O ports while requiring minimal off-chip address-decoding circuits.

#### enhanced 8-bit host-port interface

The '5402 host-port interface, also referred to as the HPI8, is an enhanced version of the standard 8-bit HPI found on earlier '54x DSPs ('542, '545, '548, and '549). The HPI8 is an 8-bit parallel port for interprocessor communication. The features of the HPI8 include:

#### Standard features:

- Sequential transfers (with autoincrement) or random-access transfers
- Host interrupt and '54x interrupt capability
- Multiple data strobes and control pins for interface flexibility

#### Enhanced features of the '5402 HPI8:

- Access to entire on-chip RAM through DMA bus
- Capability to continue transferring during emulation stop

The HPI8 functions as a slave and enables the host processor to access the on-chip memory of the '5402. A major enhancement to the '5402 HPI over previous versions is that it allows host access to the entire on-chip memory range of the DSP. The HPI8 memory map is identical to that of the DMA controller shown in Figure 6. The host and the DSP both have access to the on-chip RAM at all times and host accesses are always synchronized to the DSP clock. If the host and the DSP contend for access to the same location, the host has priority, and the DSP waits for one HPI8 cycle. Note that since host accesses are always synchronized to the '5402 clock, an active input clock (CLKIN) is required for HPI8 accesses during IDLE states, and host accesses are not allowed while the '5402 reset pin is asserted.

The HPI8 interface consists of an 8-bit bidirectional data bus and various control signals. Sixteen-bit transfers are accomplished in two parts with the HBIL input designating high or low byte. The host communicates with the HPI8 through three dedicated registers — HPI address register (HPIA), HPI data register (HPID), and an HPI control register (HPIC). The HPIA and HPID registers are only accessible by the host, and the HPIC register is accessible by both the host and the '5402.



#### multichannel buffered serial ports

The '5402 device includes two high-speed, full-duplex multichannel buffered serial ports (McBSPs) that allow direct interface to other 'C54x/'LC54x devices, codecs, and other devices in a system. The McBSPs are based on the standard serial port interface found on other '54x devices. Like its predecessors, the McBSP provides:

- Full-duplex communication
- Double-buffered 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 devices
  - 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 McBSPs consist of separate transmit and receive channels that operate independently. The external interface of each McBSP consists of the following pins:

BCLKX Transmit reference clock

BDX Transmit data

BFSX Transmit frame synchronization

BCLKR Receive reference clock

BDR Receive data

BFSR Receive frame synchronization

The six pins listed are functionally equivalent to previous serial port interface pins in the 'C5000 family of DSPs. On the transmitter, transmit frame synchronization and clocking are indicated by the BFSX and BCLKX pins, respectively. The CPU or DMA can initiate transmission of data by writing to the data transmit register (DXR). Data written to DXR is shifted out on the BDX pin through a transmit shift register (XSR). This structure allows DXR to be loaded with the next word to be sent while the transmission of the current word is in progress.

## TMS320VC5402 FIXED-POINT DIGITAL SIGNAL PROCESSOR

SPRS079D - OCTOBER 1998 - REVISED JANUARY 2000

#### multichannel buffered serial ports (continued)

On the receiver, receive frame synchronization and clocking are indicated by the BFSR and BCLKR pins, respectively. The CPU or DMA can read received data from the data receive register (DRR). Data received on the BDR pin is shifted into a receive shift register (RSR) and then buffered in the receive buffer register (RBR). If the DRR is empty, the RBR contents are copied into the DRR. If not, the RBR holds the data until the DRR is available. This structure allows storage of the two previous words while the reception of the current word is in progress.

The CPU and DMA can move data to and from the McBSPs and can synchronize transfers based on McBSP interrupts, event signals, and status flags. The DMA is capable of handling data movement between the McBSPs and memory with no intervention from the CPU.

In addition to the standard serial port functions, the McBSP provides programmable clock and frame synchronization signals. The programmable functions include:

- Frame synchronization pulse width
- Frame period
- Frame synchronization delay
- Clock reference (internal vs. external)
- Clock division
- Clock and frame synchronization polarity

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

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 TDM 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 stream of up to 128 channels can be enabled.

The clock-stop mode (CLKSTP) in the McBSP provides compatibility with the serial peripheral interface (SPI) protocol. 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.

The McBSP is fully static and operates at arbitrarily low clock frequencies. The maximum frequency is CPU clock frequency divided by 2.

#### hardware timer

The '5402 device features two 16-bit timing circuits with 4-bit prescalers. The main counter of each timer is decremented by one every CLKOUT cycle. Each time the counter decrements to 0, a timer interrupt is generated. The timers can be stopped, restarted, reset, or disabled by specific control bits.

#### clock generator

The clock generator provides clocks to the '5402 device, and consists of an internal oscillator and a phase-locked loop (PLL) circuit. The clock generator requires a reference clock input, which can be provided by using a crystal resonator with the internal oscillator, or from an external clock source.

**NOTE:** All revisions of the '5402 can be operated with an external clock source, provided that the proper voltage levels be driven on the X2/CLKIN pin. It should be noted that the X2/CLKIN pin is referenced to the device 1.8V power supply (CVdd), rather than the 3V I/O supply (DVdd). Refer to the recommended operating conditions section of this document for the allowable voltage levels of the X2/CLKIN pin.



#### clock generator (continued)

The reference clock input is then divided by two (DIV mode) to generate clocks for the '5402 device, or 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 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. Then, other internal clock circuitry allows the synthesis of new clock frequencies for use as master clock for the '5402 device.

This clock generator allows system designers to select the clock source. The sources that drive the clock generator are:

- A crystal resonator circuit. The crystal resonator circuit is connected across the X1 and X2/CLKIN pins of the '5402 to enable the internal oscillator.
- An external clock. The external clock source is directly connected to the X2/CLKIN pin, and X1 is left unconnected.

**NOTE:** All revisions of the '5402 can be operated with an external clock source, provided that the proper voltage levels be driven on the X2/CLKIN pin. It should be noted that the X2/CLKIN pin is referenced to the device 1.8V power supply (CVdd), rather than the 3V I/O supply (DVdd). Refer to the recommended operating conditions section of this document for the allowable voltage levels of the X2/CLKIN pin.

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 (X2/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 using the 16-bit memory-mapped (address 0058h) clock mode register (CLKMD). The CLKMD register is used to define the configuration of the PLL clock module. Upon reset, the CLKMD register is initialized with a predetermined value dependent only upon the state of the CLKMD1 – CLKMD3 pins as shown in Table 5.

| OLIGIDA. | 011/11/02 | 01.1/1100 | CLKMD       | OL COLL MODE           |
|----------|-----------|-----------|-------------|------------------------|
| CLKMD1   | CLKMD2    | CLKMD3    | RESET VALUE | CLOCK MODE             |
| 0        | 0         | 0         | E007h       | PLL x 15               |
| 0        | 0         | 1         | 9007h       | PLL x 10               |
| 0        | 1         | 0         | 4007h       | PLL x 5                |
| 1        | 0         | 0         | 1007h       | PLL x 2                |
| 1        | 1         | 0         | F007h       | PLL x 1                |
| 1        | 1         | 1         | 0000h       | 1/2 (PLL disabled)     |
| 1        | 0         | 1         | F000h       | 1/4 (PLL disabled)     |
| 0        | 1         | 1         | _           | Reserved (bypass mode) |

Table 5. Clock Mode Settings at Reset

#### DMA controller

The '5402 direct memory access (DMA) controller transfers data between points in the memory map without intervention by the CPU. The DMA controller allows movements of data to and from internal program/data memory or internal peripherals (such as the McBSPs) to occur in the background of CPU operation. The DMA has six independent programmable channels allowing six different contexts for DMA operation.

#### features

The 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 may remain constant, be post-incremented,
  post-decremented, or be adjusted by a programmable value.
- Each read or write transfer may be initialized by selected events.
- Upon completion of a half-block or an entire-block transfer, each DMA channel may send an interrupt to the CPU.
- The DMA can perform double-word transfers (a 32-bit transfer of two 16-bit words).

#### DMA memory map

The DMA memory map is shown in Figure 6 to allow DMA transfers to be unaffected by the status of the MPMC, DROM, and OVLY bits.



Figure 6. '5402 DMA Memory Map



#### DMA priority level

Each DMA channel can be independently assigned high priority or low priority relative to each other. Multiple DMA channels that are assigned to the same priority level are handled in a round-robin manner.

#### DMA source/destination address modification

The DMA provides flexible address-indexing modes for easy implementation of data management schemes such as autobuffering and circular buffers. Source and destination addresses can be indexed separately and can be post-incremented, post-decremented, or post-incremented with a specified index offset.

#### DMA in autoinitialization mode

The DMA can automatically reinitialize itself after completion of a block transfer. Some of the DMA registers can be preloaded for the next block transfer through the DMA global reload registers (DMGSA, DMGDA, and DMGCR). Autoinitialization allows:

- Continuous operation: Normally, the CPU would have to reinitialize the DMA immediately after the
  completion of the current block transfer; but with the global reload registers, it can reinitialize these values
  for the next block transfer any time after the current block transfer begins.
- Repetitive operation: The CPU does not preload the global reload register with new values for each block transfer but only loads them on the first block transfer.

#### DMA transfer counting

The DMA channel element count register (DMCTRx) and the frame count register (DMSFCx) contain bit fields that represent the number of frames and the number of elements per frame to be transferred.

- Frame count. This 8-bit value defines the total number of frames in the block transfer. The maximum number of frames per block transfer is 128 (FRAME COUNT= 0ffh). The counter is decremented upon the last read transfer in a frame transfer. Once the last frame is transferred, the selected 8-bit counter is reloaded with the DMA global frame reload register (DMGFR) if the AUTOINIT bit is set to 1. A frame count of 0 (default value) means the block transfer contains a single frame.
- Element count. This 16-bit value defines the number of elements per frame. This counter is decremented after the read transfer of each element. The maximum number of elements per frame is 65536 (DMCTRn = 0FFFFh). In autoinitialization mode, once the last frame is transferred, the counter is reloaded with the DMA global count reload register (DMGCR).

#### DMA transfers in double-word mode

Double-word mode allows the DMA to transfer 32-bit words in any index mode. In double-word mode, two consecutive 16-bit transfers are initiated and the source and destination addresses are automatically updated following each transfer. In this mode, each 32-bit word is considered to be one element.

#### DMA channel index registers

The particular DMA channel index register is selected by way of the SIND and DIND field in the DMA mode control register (DMMCRx). Unlike basic address adjustment, in conjunction with the frame index DMFRI0 and DMFRI1, the DMA allows different adjustment amounts depending on whether or not the element transfer is the last in the current frame. The normal adjustment value (element index) is contained in the element index registers DMIDX0 and DMIDX1. The adjustment value (frame index) for the end of the frame, is determined by the selected DMA frame index register, either DMFRI0 or DMFRI1.



#### DMA channel index registers (continued)

The element index and the frame index affect address adjustment as follows:

- Element index: For all except the last transfer in the frame, the element index determines the amount to be added to the DMA channel for the source/destination address register (DMSRCx/DMDSTx) as selected by the SIND/DIND bits.
- Frame index: If the transfer is the last in a frame, the frame index is used for address adjustment as selected by the SIND/DIND bits. This occurs in both single-frame and multi-frame transfer.

#### DMA interrupts

The ability of the DMA to interrupt the CPU based on the status of the data transfer is configurable and is determined by the IMOD and DINM bits in the DMA channel mode control register (DMMCRn). The available modes are shown in Table 6.

**Table 6. DMA Interrupts** 

| MODE                | DINM | IMOD | INTERRUPT                                              |
|---------------------|------|------|--------------------------------------------------------|
| ABU (non-decrement) | 1    | 0    | At full buffer only                                    |
| ABU (non-decrement) | 1    | 1    | At half buffer and full buffer                         |
| Multi-Frame         | 1    | 0    | At block transfer complete (DMCTRn = DMSEFCn[7:0] = 0) |
| Multi-Frame         | 1    | 1    | At end of frame and end of block (DMCTRn = 0)          |
| Either              | 0    | Х    | No interrupt generated                                 |
| Either              | 0    | Х    | No interrupt generated                                 |

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

**Table 7. DMA Synchronization Events** 

| DSYN VALUE  | DMA SYNCHRONIZATION EVENT |
|-------------|---------------------------|
| 0000b       | No synchronization used   |
| 0001b       | McBSP0 receive event      |
| 0010b       | McBSP0 transmit event     |
| 0011-0100b  | Reserved                  |
| 0101b       | McBSP1 receive event      |
| 0110b       | McBSP1 transmit event     |
| 0111b-0110b | Reserved                  |
| 1101b       | Timer0 interrupt          |
| 1110b       | External interrupt 3      |
| 1111b       | Timer1 interrupt          |

#### DMA channel interrupt selection

The DMA controller can generate a CPU interrupt for each of the six channels. However, the interrupt sources for channels 0,1, 2, and 3 are multiplexed with other interrupt sources. DMA channels 2 and 3 share an interrupt line with the receive and transmit portions of McBSP1 (IMR/IFR bits 10 and 11), and DMA channel 1 shares an interrupt line with timer 1 (IMR/IFR bit 7). The interrupt source for DMA channel 0 is shared with a reserved interrupt source. 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 8.

**Table 8. DMA Channel Interrupt Selection** 

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

## memory-mapped registers

The '5402 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 '5402. The device also has a set of memory-mapped registers associated with peripherals. Table 10, Table 11, and Table 12 show additional peripheral MMRs associated with the '5402.

**Table 9. CPU Memory-Mapped Registers** 

|      | ADD | RESS |                                       |  |
|------|-----|------|---------------------------------------|--|
| NAME | DEC | 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 register                |  |
| BK   | 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 (PMST) register |  |
| XPC  | 30  | 1E   | Extended program page register        |  |
| _    | 31  | 1F   | Reserved                              |  |

## memory-mapped registers (continued)

## **Table 10. Peripheral Memory-Mapped Registers**

| NAME   | ADDRESS | DESCRIPTION                                               | TYPE         |
|--------|---------|-----------------------------------------------------------|--------------|
| DRR20  | 20h     | McBSP0 data receive register 2                            | McBSP #0     |
| DRR10  | 21h     | McBSP0 data receive register 1                            | McBSP #0     |
| DXR20  | 22h     | McBSP0 data transmit register 2                           | McBSP #0     |
| DXR10  | 23h     | McBSP0 data transmit register 1                           | McBSP #0     |
| TIM    | 24h     | Timer0 register                                           | Timer0       |
| PRD    | 25h     | Timer0 period counter                                     | Timer0       |
| TCR    | 26h     | Timer0 control register                                   | Timer0       |
| _      | 27h     | Reserved                                                  |              |
| SWWSR  | 28h     | Software wait-state register                              | External Bus |
| BSCR   | 29h     | Bank-switching control register                           | External Bus |
| _      | 2Ah     | Reserved                                                  |              |
| SWCR   | 2Bh     | Software wait-state control register                      | External Bus |
| HPIC   | 2Ch     | HPI control register                                      | HPI          |
| _      | 2Dh-2Fh | Reserved                                                  |              |
| TIM1   | 30h     | Timer1 register                                           | Timer1       |
| PRD1   | 31h     | Timer1 period counter                                     | Timer1       |
| TCR1   | 32h     | Timer1 control register                                   | Timer1       |
| _      | 33h-37h | Reserved                                                  |              |
| SPSA0  | 38h     | McBSP0 subbank address register†                          | McBSP #0     |
| SPSD0  | 39h     | McBSP0 subbank data register <sup>†</sup>                 | McBSP #0     |
| _      | 3Ah-3Bh | Reserved                                                  |              |
| GPIOCR | 3Ch     | General-purpose I/O pins control register                 | GPIO         |
| GPIOSR | 3Dh     | General-purpose I/O pins status register                  | GPIO         |
| _      | 3Eh-3Fh | Reserved                                                  |              |
| DRR21  | 40h     | McBSP1 data receive register 2                            | McBSP #1     |
| DRR11  | 41h     | McBSP1 data receive register 1                            | McBSP #1     |
| DXR21  | 42h     | McBSP1 data transmit register 2                           | McBSP #1     |
| DXR11  | 43h     | McBSP1 data transmit register 1                           | McBSP #1     |
| -      | 44h–47h | Reserved                                                  |              |
| SPSA1  | 48h     | McBSP1 subbank address register†                          | McBSP #1     |
| SPSD1  | 49h     | McBSP1 subbank data register <sup>†</sup>                 | McBSP #1     |
| _      | 4Ah-53h | Reserved                                                  |              |
| DMPREC | 54h     | DMA channel priority and enable control register          | DMA          |
| DMSA   | 55h     | DMA subbank address register‡                             | DMA          |
| DMSDI  | 56h     | DMA subbank data register with autoincrement <sup>‡</sup> | DMA          |
| DMSDN  | 57h     | DMA subbank data register‡                                | DMA          |
| CLKMD  | 58h     | Clock mode register                                       | PLL          |
| _      | 59h-5Fh | Reserved                                                  |              |

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



<sup>‡</sup> See Table 12 for a detailed description of the DMA subbank 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 serial port subbank address (SPSA) register is used as a pointer to select a particular register within the subbank. The serial port subbank data (SPSD) register is used to access (read or write) the selected register. Table 11 shows the McBSP control registers and their corresponding sub-addresses.

**Table 11. McBSP Control Registers and Subaddresses** 

| McB    | SP0     | McB    | SP1     |                 |                                              |
|--------|---------|--------|---------|-----------------|----------------------------------------------|
| NAME   | ADDRESS | NAME   | ADDRESS | SUB-<br>ADDRESS | DESCRIPTION                                  |
| SPCR10 | 39h     | SPCR11 | 49h     | 00h             | Serial port control register 1               |
| SPCR20 | 39h     | SPCR21 | 49h     | 01h             | Serial port control register 2               |
| RCR10  | 39h     | RCR11  | 49h     | 02h             | Receive control register 1                   |
| RCR20  | 39h     | RCR21  | 49h     | 03h             | Receive control register 2                   |
| XCR10  | 39h     | XCR11  | 49h     | 04h             | Transmit control register 1                  |
| XCR20  | 39h     | XCR21  | 49h     | 05h             | Transmit control register 2                  |
| SRGR10 | 39h     | SRGR11 | 49h     | 06h             | Sample rate generator register 1             |
| SRGR20 | 39h     | SRGR21 | 49h     | 07h             | Sample rate generator register 2             |
| MCR10  | 39h     | MCR11  | 49h     | 08h             | Multichannel register 1                      |
| MCR20  | 39h     | MCR21  | 49h     | 09h             | Multichannel register 2                      |
| RCERA0 | 39h     | RCERA1 | 49h     | 0Ah             | Receive channel enable register partition A  |
| RCERB0 | 39h     | RCERB1 | 49h     | 0Bh             | Receive channel enable register partition B  |
| XCERA0 | 39h     | XCERA1 | 49h     | 0Ch             | Transmit channel enable register partition A |
| XCERB0 | 39h     | XCERB1 | 49h     | 0Dh             | Transmit channel enable register partition B |
| PCR0   | 39h     | PCR1   | 49h     | 0Eh             | Pin control register                         |

#### 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 (DMSDN) 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 post-incremented 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.

## **DMA** subbank addressed registers (continued)

Table 12. DMA Subbank Addressed Registers

| DMA    |         |                 | Ī                                                     |
|--------|---------|-----------------|-------------------------------------------------------|
| 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                |



## interrupts

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

**Table 13. Interrupt Locations and Priorities** 

| NAME                   | LOCA<br>DECIMAL | TION HEX | PRIORITY | FUNCTION                                                                                                        |
|------------------------|-----------------|----------|----------|-----------------------------------------------------------------------------------------------------------------|
| RS, SINTR              | 0               | 00       | 1        | Reset (hardware and software reset)                                                                             |
| NMI, SINT16            | 4               | 00       | 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                                                                                          |
| ĪNTO, SINTO            | 64              | 40       | 3        | External user interrupt #0                                                                                      |
| ĪNT1, SINT1            | 68              | 44       | 4        | External user interrupt #1                                                                                      |
| ĪNT2, SINT2            | 72              | 48       | 5        | External user interrupt #2                                                                                      |
| TINT0, SINT3           | 76              | 4C       | 6        | Timer0 interrupt                                                                                                |
| BRINTO, SINT4          | 80              | 50       | 7        | McBSP #0 receive interrupt                                                                                      |
| BXINT0, SINT5          | 84              | 54       | 8        | McBSP #0 transmit interrupt                                                                                     |
| Reserved(DMAC0), SINT6 | 88              | 58       | 9        | Reserved (default) or DMA channel 0 interrupt. The selection is made in the DMPREC register.                    |
| TINT1(DMAC1), SINT7    | 92              | 5C       | 10       | Timer1 interrupt (default) or DMA channel 1 interrupt. The selection is made in the DMPREC register.            |
| ĪNT3, SINT8            | 96              | 60       | 11       | External user interrupt #3                                                                                      |
| HPINT, SINT9           | 100             | 64       | 12       | HPI interrupt                                                                                                   |
| BRINT1(DMAC2), SINT10  | 104             | 68       | 13       | McBSP #1 receive interrupt (default) or DMA channel 2 interrupt. The selection is made in the DMPREC register.  |
| BXINT1(DMAC3), 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 interrupt                                                                                         |
| DMAC5,SINT13           | 116             | 74       | 16       | DMA channel 5 interrupt                                                                                         |
| Reserved               | 120–127         | 78–7F    | _        | Reserved                                                                                                        |

## interrupts (continued)

The bits of the interrupt flag register (IFR) and interrupt mask register (IMR) are arranged as shown in Figure 7.



Figure 7. IFR and IMR Registers

## Table 14. IFR and IMR Register Bit Fields

|        | BIT          |                                                                                                                                                                               |  |  |
|--------|--------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| NUMBER | NAME         | FUNCTION                                                                                                                                                                      |  |  |
| 15–14  | -            | Reserved for future expansion                                                                                                                                                 |  |  |
| 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      | INT3         | External interrupt 3 flag/mask                                                                                                                                                |  |  |
| 7      | TINT1/DMAC1  | This bit can be configured as either the timer1 interrupt flag/mask bit, or the DMA channel 1 interrupt flag/mask bit. The selection is made in the DMPREC register.          |  |  |
| 6      | DMAC0        | This bit can be configured as either reserved, 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      | TINT0        | Timer 0 interrupt flag/mask bit                                                                                                                                               |  |  |
| 2      | INT2         | External interrupt 2 flag/mask bit                                                                                                                                            |  |  |
| 1      | INT1         | External interrupt 1 flag/mask bit                                                                                                                                            |  |  |
| 0      | INT0         | External interrupt 0 flag/mask bit                                                                                                                                            |  |  |

## TMS320VC5402 FIXED-POINT DIGITAL SIGNAL PROCESSOR

SPRS079D - OCTOBER 1998 - REVISED JANUARY 2000

#### documentation support

Extensive documentation supports all TMS320 family generations of devices from product announcement through applications development. The following types of documentation are available to support the design and use of the 'C5000 family of DSPs:

- TMS320C5000 DSP Family Functional Overview (literature number SPRU307)
- Silicon Updates for the TMS320VC5402/TMS320UC5402 DSP (literature number SPRZ155)
- Device-specific data sheets (such as this document)
- 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 '54x TMS320 products currently available and the hardware and software applications, including algorithms, for fixed-point TMS320 devices.

For general background information on DSPs and Texas Instruments (TI<sup>™</sup>) devices, see the three-volume publication *Digital Signal Processing Applications with the TMS320 Family* (literature numbers SPRA012, SPRA016, and SPRA017).

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

Information regarding TI DSP products is also available on the Worldwide Web at <a href="http://www.ti.com">http://www.ti.com</a> uniform resource locator (URL).

TI is a trademark of Texas Instruments Incorporated.



## absolute maximum ratings over specified temperature range (unless otherwise noted)†

| Supply voltage I/O range, DV <sub>DD</sub> ‡             |                       |
|----------------------------------------------------------|-----------------------|
| Supply voltage core range, CV <sub>DD</sub> <sup>‡</sup> | . $-0.3$ V to $2.4$ V |
| Input voltage range, V <sub>I</sub>                      |                       |
| Output voltage range, VO                                 | . $-0.3$ V to $4.5$ V |
| Operating case temperature range, T <sub>C</sub>         | -40°C to 100°C        |
| Storage temperature range, T <sub>sto</sub>              | –55°C to 150°C        |

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

## recommended operating conditions

|                  |                                                                                       |                                                                                             | MIN  | NOM                    | MAX                    | UNIT |
|------------------|---------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|------|------------------------|------------------------|------|
| $DV_{DD}$        | Device supply voltage, I/O§                                                           |                                                                                             | 3    | 3.3                    | 3.6                    | V    |
| CV <sub>DD</sub> | Device supply voltage, core                                                           | evice supply voltage, core§                                                                 |      |                        | 1.98                   | V    |
| VSS              | Supply voltage, GND                                                                   | Supply voltage, GND                                                                         |      |                        |                        | V    |
|                  | RS, INTn, NMI, BIO, BCLKR0, BCLKR1, BCLKX0, BCLKX1, HCS, HDS1, HDS2, TDI, TMS, CLKMDn | 2.2                                                                                         |      | DV <sub>DD</sub> + 0.3 |                        |      |
| VIH              | High-level input voltage $DV_{DD} = 3.3 \pm 0.3 \text{ V}$                            | X2/CLKIN¶                                                                                   | 1.35 |                        | CV <sub>DD</sub> +0.3  | V    |
|                  |                                                                                       | TCK, TRST                                                                                   | 2.5  |                        | DV <sub>DD</sub> + 0.3 |      |
|                  |                                                                                       | All other inputs                                                                            | 2.0  |                        | DV <sub>DD</sub> + 0.3 |      |
| VIL              | Low-level input voltage<br>DVDD = 3.3±0.3 V                                           | RS, INTn, NMI, X2/CLKIN¶, BIO, BCLKR0, BCLKR1, BCLKX0, BCLKX1, HCS, HDS1, HDS2, TCK, CLKMDn | -0.3 |                        | 0.6                    | V    |
|                  |                                                                                       | All other inputs                                                                            | -0.3 | -0.3 0.8               |                        |      |
| loн              | High-level output current                                                             |                                                                                             |      |                        | -300                   | μΑ   |
| l <sub>OL</sub>  | Low-level output current                                                              |                                                                                             |      |                        | 1.5                    | mA   |
| T <sub>C</sub>   | Operating case temperature                                                            |                                                                                             | -40  |                        | 100                    | °C   |

<sup>§</sup> Texas Instrument DSPs do not require specific power sequencing between the core supply and the I/O supply. However, systems should be designed to ensure that neither supply is powered up for extended periods of time if the other supply is below the proper operating voltage. Excessive exposure to these conditions can adversely affect the long term reliability of the devices. System-level concerns such as bus contention may require supply sequencing to be implemented. In this case, the core supply should be powered up at the same time as or prior to the I/O buffers and then powered down after the I/O buffers.

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

<sup>¶</sup> All revisions of the '5402 can be operated with an external clock source, provided that the proper voltage levels be driven on the X2/CLKIN pin. It should be noted that the X2/CLKIN pin is referenced to the device 1.8V power supply (CVdd), rather than the 3V I/O supply (DVdd). Refer to the recommended operating conditions section of this document for the allowable voltage levels of the X2/CLKIN pin.

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

|                 | PARAME                            | TER                       | TEST CONDITION                                                          | ONS                                    | MIN  | TYP <sup>†</sup> | MAX | UNIT |
|-----------------|-----------------------------------|---------------------------|-------------------------------------------------------------------------|----------------------------------------|------|------------------|-----|------|
| Vон             | H High-level output voltage       |                           | I <sub>OH</sub> = MAX                                                   | I <sub>OH</sub> = MAX                  |      |                  |     | V    |
| VOL             | Low-level output volt             | age                       | I <sub>OL</sub> = MAX                                                   |                                        |      |                  | 0.4 | V    |
| l <sub>IZ</sub> | Input current for outputs in high | D[15:0], HD[7:0]          | Bus holders enabled, $DV_{DD} = MAX$ ,<br>$V_{I} = V_{SS}$ to $DV_{DD}$ |                                        | -175 |                  | 175 | μА   |
|                 | impedance                         | All other inputs          | $DV_{DD} = MAX$ , $V_{O} = V_{SS}$ to D                                 | VDD                                    | -5   |                  | 5   |      |
|                 |                                   | X2/CLKIN <sup>‡</sup>     |                                                                         |                                        | -40  |                  | 40  | μΑ   |
|                 | Input current                     | TRST                      | With internal pulldown                                                  |                                        | -5   |                  | 300 |      |
| l <sub>l</sub>  |                                   | HPIENA                    | With internal pulldown                                                  | (VI = VSS                              | -5   |                  | 300 |      |
| '1              |                                   | TMS, TCK, TDI, HPI§       | With internal pullups,<br>HPIENA = 0                                    | to DV <sub>DD</sub> )                  | -300 |                  | 5   |      |
|                 |                                   | All other input-only pins |                                                                         |                                        | -5   |                  | 5   |      |
| IDDC            | Supply current, core              | CPU                       | CV <sub>DD</sub> = 1.8 V, f <sub>clock</sub> = 100 M                    | $Hz^{\P}$ , $T_{C} = 25^{\circ}C^{\#}$ |      | 45               |     | mA   |
| IDDP            | Supply current, pins              |                           | DV <sub>DD</sub> = 3.3 V, f <sub>clock</sub> = 100 M                    | Hz¶, T <sub>C</sub> = 25°C             |      | 30               |     | mA   |
|                 | Supply current,                   | IDLE2                     | PLL × 1 mode, 100 MHz inp                                               |                                        |      | 2                |     | mA   |
| DD standby      |                                   | IDLE3                     | Divide-by-two mode, CLKIN stopped                                       |                                        |      | 5                |     | μΑ   |
| Ci              | Input capacitance                 |                           |                                                                         |                                        |      | 5                |     | pF   |
| Со              | Output capacitance                |                           |                                                                         |                                        |      | 5                |     | pF   |

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

#### PARAMETER MEASUREMENT INFORMATION



Where:  $I_{OL}$  = 1.5 mA (all outputs)

 $I_{OH} = 300 \,\mu\text{A} \text{ (all outputs)}$ 

 $V_{Load} = 1.5 V$ 

C<sub>T</sub> = 40 pF typical load circuit capacitance

Figure 8. 3.3-V Test Load Circuit



<sup>‡</sup> All revisions of the '5402 can be operated with an external clock source, provided that the proper voltage levels be driven on the X2/CLKIN pin. It should be noted that the X2/CLKIN pin is referenced to the device 1.8V power supply (CVdd), rather than the 3V I/O supply (DVdd). Refer to the recommended operating conditions section of this document for the allowable voltage levels of the X2/CLKIN pin.

<sup>§</sup> HPI input signals except for HPIENA.

<sup>¶</sup> Clock mode: PLL × 1 with external source

<sup>#</sup> 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 McBSP0 and McBSP1 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).

### internal oscillator with external crystal

The internal oscillator is enabled by connecting a crystal across X1 and X2/CLKIN. The frequency of CLKOUT is a multiple of the oscillator frequency. The multiply ratio is determined by the bit settings in the CLKMD register. The crystal should be in fundamental-mode operation, and parallel resonant, with an effective series resistance of 30  $\Omega$  and power dissipation of 1 mW.

The connection of the required circuit, consisting of the crystal and two load capacitors, is shown in Figure 9. The load capacitors,  $C_1$  and  $C_2$ , should be chosen such that the equation below is satisfied.  $C_L$  in the equation is the load specified for the crystal.

$$C_L = \frac{C_1 C_2}{(C_1 + C_2)}$$

#### recommended operating conditions of internal oscillator with external crystal (see Figure 9)

|                                          | MIN | NOM | MAX | UNIT |
|------------------------------------------|-----|-----|-----|------|
| f <sub>clock</sub> Input clock frequency | 10  |     | 20  | MHz  |



Figure 9. Internal Oscillator With External Crystal

#### divide-by-two clock option (PLL disabled)

The frequency of the reference clock provided at the X2/CLKIN pin can be divided by a factor of two to generate the internal machine cycle. The selection of the clock mode is described in the clock generator section.

When an external clock source is used, the frequency injected must conform to specifications listed in the timing requirements table.

**NOTE:** All revisions of the '5402 can be operated with an external clock source, provided that the proper voltage levels be driven on the X2/CLKIN pin. It should be noted that the X2/CLKIN pin is referenced to the device 1.8V power supply (CVdd), rather than the 3V I/O supply (DVdd). Refer to the recommended operating conditions section of this document for the allowable voltage levels of the X2/CLKIN pin.

# switching characteristics over recommended operating conditions [H = $0.5t_{c(CO)}$ ]<sup>†</sup> (see Figure 9, Figure 10, and the recommended operating conditions table)

|                     | PARAMETER                                    | MIN | TYP                  | MAX | UNIT |
|---------------------|----------------------------------------------|-----|----------------------|-----|------|
| t <sub>C</sub> (CO) | Cycle time, CLKOUT                           | 10‡ | 2t <sub>C</sub> (CI) | †   | ns   |
| td(CIH-CO)          | Delay time, X2/CLKIN high to CLKOUT high/low | 4   | 10                   | 17  | ns   |
| t <sub>f</sub> (CO) | Fall time, CLKOUT                            |     | 2                    |     | ns   |
| t <sub>r</sub> (CO) | Rise time, CLKOUT                            |     | 2                    |     | ns   |
| tw(COL)             | Pulse duration, CLKOUT low                   | H-2 |                      | Н   | ns   |
| tw(COH)             | Pulse duration, CLKOUT high                  | H-2 |                      | Н   | ns   |

<sup>&</sup>lt;sup>†</sup> This device utilizes a fully static design and therefore can operate with t<sub>C(CI)</sub> approaching ∞. The device is characterized at frequencies approaching 0 Hz.

## timing requirements (see Figure 10)

|                     |                      | MIN | MAX | UNIT |
|---------------------|----------------------|-----|-----|------|
| t <sub>C</sub> (CI) | Cycle time, X2/CLKIN | 20  | †   | ns   |
| t <sub>f</sub> (CI) | Fall time, X2/CLKIN  |     | 8   | ns   |
| tr(CI)              | Rise time, X2/CLKIN  |     | 8   | ns   |

<sup>&</sup>lt;sup>†</sup> This device utilizes a fully static design and therefore can operate with t<sub>C(CI)</sub> approaching ∞. The device is characterized at frequencies approaching 0 Hz.



Figure 10. External Divide-by-Two Clock Timing

<sup>‡</sup> It is recommended that the PLL clocking option be used for maximum frequency operation.

### multiply-by-N clock option

The frequency of the reference clock provided at the X2/CLKIN pin can be multiplied by a factor of N to generate the internal machine cycle. The selection of the clock mode and the value of N is described in the clock generator section.

When an external clock source is used, the external frequency injected must conform to specifications listed in the timing requirements table.

**NOTE:** All revisions of the '5402 can be operated with an external clock source, provided that the proper voltage levels be driven on the X2/CLKIN pin. It should be noted that the X2/CLKIN pin is referenced to the device 1.8V power supply (CVdd), rather than the 3V I/O supply (DVdd). Refer to the recommended operating conditions section of this document for the allowable voltage levels of the X2/CLKIN pin.

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

|                     | PARAMETER                                        | MIN | TYP                    | MAX | UNIT |
|---------------------|--------------------------------------------------|-----|------------------------|-----|------|
| t <sub>C</sub> (CO) | Cycle time, CLKOUT                               | 10  | t <sub>c(CI)/N</sub> † |     | ns   |
| td(CI-CO)           | Delay time, X2/CLKIN high/low to CLKOUT high/low | 4   | 10                     | 17  | ns   |
| t <sub>f</sub> (CO) | Fall time, CLKOUT                                |     | 2                      |     | ns   |
| tr(CO)              | Rise time, CLKOUT                                |     | 2                      |     | ns   |
| tw(COL)             | Pulse duration, CLKOUT low                       | H-2 |                        | Н   | ns   |
| tw(COH)             | Pulse duration, CLKOUT high                      | H-2 |                        | Н   | ns   |
| tp                  | Transitory phase, PLL lock up time               |     |                        | 30  | μS   |

<sup>†</sup> N = Multiplication factor

## timing requirements (see Figure 11)†

|                     |                                        | MIN                                 | MAX | UNIT |    |
|---------------------|----------------------------------------|-------------------------------------|-----|------|----|
|                     |                                        | Integer PLL multiplier N (N = 1–15) | 20‡ | 200  |    |
| t <sub>C</sub> (CI) | Cycle time, X2/CLKIN                   | PLL multiplier N = x.5              | 20‡ | 100  | ns |
|                     |                                        | PLL multiplier N = x.25, x.75       | 20‡ | 50   |    |
| t <sub>f</sub> (CI) | t <sub>f(CI)</sub> Fall time, X2/CLKIN |                                     |     | 8    | ns |
| tr(CI)              | $t_{r(CI)}$ Rise time, X2/CLKIN        |                                     |     | 8    | ns |

<sup>†</sup> N = Multiplication factor

<sup>&</sup>lt;sup>‡</sup> The multiplication factor and minimum X2/CLKIN cycle time should be chosen such that the resulting CLKOUT cycle time is within the specified range (tc(CO))



Figure 11. External Multiply-by-One Clock Timing

## TMS320VC5402 FIXED-POINT DIGITAL SIGNAL PROCESSOR

SPRS079D - OCTOBER 1998 - REVISED JANUARY 2000

## memory and parallel I/O interface timing

# <u>switching</u> characteristics over recommended operating conditions for a *memory read* $(MSTRB = 0)^{\dagger}$ (see Figure 12)

|              | PARAMETER                                              | MIN | MAX | UNIT |
|--------------|--------------------------------------------------------|-----|-----|------|
| td(CLKL-A)   | Delay time, CLKOUT low to address valid <sup>‡</sup>   | -2  | 3   | ns   |
| td(CLKH-A)   | Delay time, CLKOUT high (transition) to address valid§ | -2  | 3   | ns   |
| td(CLKL-MSL) | Delay time, CLKOUT low to MSTRB low                    | -1  | 3   | ns   |
| td(CLKL-MSH) | Delay time, CLKOUT low to MSTRB high                   | -1  | 3   | ns   |
| th(CLKL-A)R  | Hold time, address valid after CLKOUT low <sup>‡</sup> | -2  | 3   | ns   |
| th(CLKH-A)R  | Hold time, address valid after CLKOUT high§            | -2  | 3   | ns   |

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

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

|                     |                                                  | MIN | MAX  | UNIT |
|---------------------|--------------------------------------------------|-----|------|------|
| ta(A)M              | Access time, read data access from address valid |     | 2H-7 | ns   |
| ta(MSTRBL)          | Access time, read data access from MSTRB low     |     | 2H–8 | ns   |
| t <sub>su(D)R</sub> | Setup time, read data before CLKOUT low          | 6   |      | ns   |
| th(D)R              | Hold time, read data after CLKOUT low            | -2  |      | ns   |
| th(A-D)R            | Hold time, read data after address invalid       | 0   |      | ns   |
| th(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.

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

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



NOTE A: A[19:16] are always driven low during accesses to external data space.

Figure 12. Memory Read ( $\overline{MSTRB} = 0$ )

SPRS079D - OCTOBER 1998 - REVISED JANUARY 2000

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

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

|                       | PARAMETER                                                      | MIN   | MAX   | UNIT |
|-----------------------|----------------------------------------------------------------|-------|-------|------|
| td(CLKH-A)            | Delay time, CLKOUT high to address valid <sup>‡</sup>          | -2    | 3     | ns   |
| td(CLKL-A)            | Delay time, CLKOUT low to address valid§                       | -2    | 3     | ns   |
| td(CLKL-MSL)          | Delay time, CLKOUT low to MSTRB low                            | -1    | 3     | ns   |
| td(CLKL-D)W           | Delay time, CLKOUT low to data valid                           | 0     | 6     | ns   |
| td(CLKL-MSH)          | Delay time, CLKOUT low to MSTRB high                           | -1    | 3     | ns   |
| td(CLKH-RWL)          | Delay time, CLKOUT high to R/W low                             | -1    | 3     | ns   |
| td(CLKH-RWH)          | Delay time, CLKOUT high to R/W high                            | -1    | 3     | ns   |
| td(RWL-MSTRBL)        | Delay time, R/W low to MSTRB low                               | H – 2 | H + 1 | ns   |
| <sup>t</sup> h(A)W    | Hold time, address valid after CLKOUT high <sup>‡</sup>        | 1     | 3     | ns   |
| th(D)MSH              | Hold time, write data valid after MSTRB high                   | H–3   | H+6§  | ns   |
| tw(SL)MS              | Pulse duration, MSTRB low                                      | 2H-2  |       | ns   |
| t <sub>su(A)W</sub>   | Setup time, address valid before MSTRB low                     | 2H–2  |       | ns   |
| t <sub>su(D)MSH</sub> | Setup time, write data valid before MSTRB high                 | 2H-6  | 2H+5§ | ns   |
| ten(D-RWL)            | Enable time, data bus driven after R/W low                     | H–5   |       | ns   |
| tdis(RWH-D)           | Disable time, $R\overline{/W}$ high to data bus high impedance |       | 0     | 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

<sup>§</sup> In the case of a memory write preceded by an I/O cycle



NOTE A: A[19:16] are always driven low during accesses to external data space.

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

## switching characteristics over recommended operating conditions for a parallel I/O port read $(\overline{IOSTRB} = 0)^{\dagger}$ (see Figure 14)

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

<sup>&</sup>lt;sup>†</sup> Address and <del>IS</del> 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 14)

|                       |                                                  | MIN | MAX  | UNIT |
|-----------------------|--------------------------------------------------|-----|------|------|
| ta(A)IO               | Access time, read data access from address valid |     | 3H-7 | ns   |
| ta(ISTRBL)IO          | Access time, read data access from IOSTRB low    |     | 2H-7 | ns   |
| t <sub>su(D)IOR</sub> | Setup time, read data before CLKOUT high         | 6   |      | ns   |
| th(D)IOR              | Hold time, read data after CLKOUT high           | 0   |      | ns   |
| th(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.



NOTE A: A[19:16] are always driven low during accesses to I/O space.

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



### 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 15)

|                           | PARAMETER                                   | MIN | MAX | UNIT |
|---------------------------|---------------------------------------------|-----|-----|------|
| td(CLKL-A)                | Delay time, CLKOUT low to address valid     | -2  | 3   | ns   |
| td(CLKH-ISTRBL)           | Delay time, CLKOUT high to IOSTRB low       | -2  | 3   | ns   |
| td(CLKH-D)IOW             | Delay time, CLKOUT high to write data valid | H–5 | H+8 | ns   |
| td(CLKH-ISTRBH)           | Delay time, CLKOUT high to IOSTRB high      | -2  | 3   | ns   |
| td(CLKL-RWL)              | Delay time, CLKOUT low to R/W low           | -1  | 3   | ns   |
| td(CLKL-RWH)              | Delay time, CLKOUT low to R/W high          | -1  | 3   | ns   |
| th(A)IOW                  | Hold time, address valid after CLKOUT low   | 0   | 3   | ns   |
| th(D)IOW                  | Hold time, write data after IOSTRB high     | H-3 | H+7 | ns   |
| t <sub>su(D)IOSTRBH</sub> | Setup time, write data before OSTRB high    | H–7 | H+1 | ns   |
| t <sub>su(A)IOSTRBL</sub> | Setup time, address valid before IOSTRB low | H-2 | H+2 | ns   |

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



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

#### ready timing for externally generated wait states

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

|                            |                                                | MIN | MAX  | UNIT |
|----------------------------|------------------------------------------------|-----|------|------|
| tsu(RDY)                   | Setup time, READY before CLKOUT low            | 6   |      | ns   |
| <sup>t</sup> h(RDY)        | Hold time, READY after CLKOUT low              | 0   |      | ns   |
| t <sub>V</sub> (RDY)MSTRB  | Valid time, READY after MSTRB low <sup>‡</sup> |     | 4H–8 | ns   |
| th(RDY)MSTRB               | Hold time, READY after MSTRB low <sup>‡</sup>  | 4H  |      | ns   |
| t <sub>V</sub> (RDY)IOSTRB | Valid time, READY after IOSTRB low‡            |     | 5H-8 | ns   |
| th(RDY)IOSTRB              | Hold time, READY after IOSTRB low‡             | 5H  |      | ns   |
| t <sub>V</sub> (MSCL)      | Valid time, MSC low after CLKOUT low           | -1  | 3    | ns   |
| t <sub>V</sub> (MSCH)      | Valid time, MSC high after CLKOUT low          | -1  | 3    | 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.



NOTE A: A[19:16] are always driven low during accesses to external data space.

Figure 16. Memory Read With Externally Generated Wait States

### ready timing for externally generated wait states (continued)



NOTE A: A[19:16] are always driven low during accesses to external data space.

Figure 17. Memory Write With Externally Generated Wait States

### ready timing for externally generated wait states (continued)



NOTE A: A[19:16] are always driven low during accesses to I/O space.

Figure 18. I/O Read With Externally Generated Wait States

### ready timing for externally generated wait states (continued)



NOTE A: A[19:16] are always driven low during accesses to I/O space.

Figure 19. I/O Write With Externally Generated Wait States

### **HOLD** and **HOLDA** timings

# switching characteristics over recommended operating conditions for memory control signals and $\overline{HOLDA}$ , [H = 0.5 $t_{c(CO)}$ ] (see Figure 20)

|                       | PARAMETER                                                                                                                      | MIN  | MAX  | UNIT |
|-----------------------|--------------------------------------------------------------------------------------------------------------------------------|------|------|------|
| tdis(CLKL-A)          | Disable time, address, $\overline{\text{PS}}$ , $\overline{\text{DS}}$ , $\overline{\text{IS}}$ high impedance from CLKOUT low |      | 5    | ns   |
| tdis(CLKL-RW)         | Disable time, $R\overline{W}$ high impedance from CLKOUT low                                                                   |      | 5    | ns   |
| tdis(CLKL-S)          | Disable time, MSTRB, IOSTRB high impedance from CLKOUT low                                                                     |      | 5    | ns   |
| ten(CLKL-A)           | Enable time, address, PS, DS, IS from CLKOUT low                                                                               |      | 2H+5 | ns   |
| ten(CLKL-RW)          | Enable time, $R/\overline{W}$ enabled from CLKOUT low                                                                          |      | 2H+5 | ns   |
| ten(CLKL-S)           | Enable time, MSTRB, IOSTRB enabled from CLKOUT low                                                                             | 2    | 2H+5 | ns   |
|                       | Valid time, HOLDA low after CLKOUT low                                                                                         | -1   | 2    | ns   |
| <sup>t</sup> v(HOLDA) | Valid time, HOLDA high after CLKOUT low                                                                                        | -1   | 2    | ns   |
| tw(HOLDA)             | Pulse duration, HOLDA low duration                                                                                             | 2H-1 |      | ns   |

### timing requirements for memory control signals and $\overline{HOLDA}$ , [H = 0.5 $t_{c(CO)}$ ] (see Figure 20)

|           |                                             | MIN MAX | UNIT |
|-----------|---------------------------------------------|---------|------|
| tw(HOLD)  | Pulse duration, HOLD low                    | 4H+7    | ns   |
| tsu(HOLD) | Setup time, HOLD low/high before CLKOUT low | 7       | ns   |



Figure 20.  $\overline{\text{HOLD}}$  and  $\overline{\text{HOLDA}}$  Timings (HM = 1)

### reset, BIO, interrupt, and MP/MC timings

# timing requirements for reset, $\overline{BIO}$ , interrupt, and MP/ $\overline{MC}$ [H = 0.5 $t_{c(CO)}$ ] (see Figure 21, Figure 22, and Figure 23)

|                      |                                                      | MIN  | MAX | UNIT |
|----------------------|------------------------------------------------------|------|-----|------|
| th(RS)               | Hold time, RS after CLKOUT low                       | 0    |     | ns   |
| th(BIO)              | Hold time, BIO after CLKOUT low                      | 0    |     | ns   |
| th(INT)              | Hold time, INTn, NMI, after CLKOUT low <sup>†</sup>  | 0    |     | ns   |
| th(MPMC)             | Hold time, MP/MC after CLKOUT low                    | 0    |     | ns   |
| tw(RSL)              | Pulse duration, RS low‡§                             | 4H+5 |     | ns   |
| tw(BIO)S             | Pulse duration, BIO low, synchronous                 | 2H+2 |     | ns   |
| tw(BIO)A             | Pulse duration, BIO low, asynchronous                | 4H   |     | ns   |
| tw(INTH)S            | Pulse duration, INTn, NMI high (synchronous)         | 2H   |     | ns   |
| tw(INTH)A            | Pulse duration, INTn, NMI high (asynchronous)        | 4H   |     | ns   |
| tw(INTL)S            | Pulse duration, INTn, NMI low (synchronous)          | 2H+2 |     | ns   |
| tw(INTL)A            | Pulse duration, INTn, NMI low (asynchronous)         | 4H   |     | ns   |
| tw(INTL)WKP          | Pulse duration, INTn, NMI low for IDLE2/IDLE3 wakeup | 10   |     | ns   |
| t <sub>su(RS)</sub>  | Setup time, RS before X2/CLKIN low¶                  | 5    |     | ns   |
| t <sub>su(BIO)</sub> | Setup time, BIO before CLKOUT low                    | 7    | 10  | ns   |
| t <sub>su(INT)</sub> | Setup time, INTn, NMI, RS before CLKOUT low          | 7    | 10  | ns   |
| tsu(MPMC)            | Setup time, MP/MC before CLKOUT low                  | 5    |     | ns   |

The external interrupts (INTO-INT3, 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 three CLKOUT sampling sequences.

 $<sup>\</sup>ddagger$  If the PLL mode is selected, then at power-on sequence, or at wakeup from IDLE3,  $\overline{\text{RS}}$  must be held low for at least 50  $\mu$ s to ensure synchronization and lock-in of the PLL.

<sup>§</sup> Note that RS may cause a change in clock frequency, therefore changing the value of H.

<sup>¶</sup> Divide-by-two mode

### reset, BIO, interrupt, and MP/MC timings (continued)



Figure 21. Reset and BIO Timings



Figure 22. Interrupt Timing



Figure 23. MP/MC Timing



instruction acquisition (IAQ), interrupt acknowledge (IACK), external flag (XF), and TOUT timings

# switching characteristics over recommended operating conditions for $\overline{\text{IAQ}}$ and $\overline{\text{IACK}}$ [H = 0.5 $t_{\text{c(CO)}}$ ] (see Figure 24)

|                | PARAMETER                                  | MIN  | MAX | UNIT |
|----------------|--------------------------------------------|------|-----|------|
| td(CLKL-IAQL)  | Delay time, CLKOUT low to IAQ low          | -1   | 3   | ns   |
| td(CLKL-IAQH)  | Delay time, CLKOUT low to IAQ high         | -1   | 3   | ns   |
| td(A)IAQ       | Delay time, address valid to IAQ low       |      | 1   | ns   |
| td(CLKL-IACKL) | Delay time, CLKOUT low to IACK low         | -1   | 3   | ns   |
| td(CLKL-IACKH) | Delay time , CLKOUT low to IACK high       | -1   | 3   | ns   |
| td(A)IACK      | Delay time, address valid to IACK low      |      | 3   | ns   |
| th(A)IAQ       | Hold time, IAQ high after address invalid  | -2   |     | ns   |
| th(A)IACK      | Hold time, IACK high after address invalid | -2   |     | ns   |
| tw(IAQL)       | Pulse duration, IAQ low                    | 2H-2 |     | ns   |
| tw(IACKL)      | Pulse duration, IACK low                   | 2H-2 |     | ns   |



Figure 24. IAQ and IACK Timings

instruction acquisition ( $\overline{IAQ}$ ), interrupt acknowledge ( $\overline{IACK}$ ), external flag (XF), and TOUT timings (continued)

switching characteristics over recommended operating conditions for XF and TOUT [H = 0.5  $t_{\rm c(CO)}$ ] (see Figure 25 and Figure 26)

|                    | PARAMETER                           |    | MAX | UNIT |  |
|--------------------|-------------------------------------|----|-----|------|--|
|                    | Delay time, CLKOUT low to XF high   | -1 | 3   |      |  |
| <sup>t</sup> d(XF) | Delay time, CLKOUT low to XF low    | -1 | 3   | ns   |  |
| td(TOUTH)          | Delay time, CLKOUT low to TOUT high | 0  | 4   | ns   |  |
| td(TOUTL)          | Delay time, CLKOUT low to TOUT low  | 0  | 4   | ns   |  |
| tw(TOUT)           | Pulse duration, TOUT                | 2H |     | ns   |  |



Figure 25. XF Timing



Figure 26. TOUT Timing

### multichannel buffered serial port timing

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

|                              |                                                  |             | MIN  | MAX | UNIT |
|------------------------------|--------------------------------------------------|-------------|------|-----|------|
| t <sub>C</sub> (BCKRX)       | Cycle time, BCLKR/X                              | BCLKR/X ext | 4H   |     | ns   |
| tw(BCKRX)                    | Pulse duration, BCLKR/X high or BCLKR/X low      | BCLKR/X ext | 2H-2 |     | ns   |
|                              | Output fine and and DEOD bight before DOLKD been | BCLKR int   | 8    |     |      |
| t <sub>su</sub> (BFRH-BCKRL) | Setup time, external BFSR high before BCLKR low  | BCLKR ext   | 1    |     | ns   |
| th(BCKRL-BFRH)               | Held the end on a DEOD blake (top DOLKD less     | BCLKR int   | 0    |     |      |
|                              | Hold time, external BFSR high after BCLKR low    | BCLKR ext   | 3    |     | ns   |
|                              | Setup time, BDR valid before BCLKR low           | BCLKR int   | 5    |     |      |
| tsu(BDRV-BCKRL)              |                                                  | BCLKR ext   | 0    |     | ns   |
|                              | Hold time, BDR valid after BCLKR low             | BCLKR int   | 0    |     |      |
| th(BCKRL-BDRV)               |                                                  | BCLKR ext   | 4    |     | ns   |
|                              | O to the LDEOVICE LA DOLLAND                     | BCLKX int   | 7    |     |      |
| tsu(BFXH-BCKXL)              | Setup time, external BFSX high before BCLKX low  | BCLKX ext   | 0    |     | ns   |
|                              | THE POLICE                                       | BCLKX int   | 0    |     |      |
| th(BCKXL-BFXH)               | Hold time, external BFSX high after BCLKX low    | BCLKX ext   | 3    |     | ns   |
| tr(BCKRX)                    | Rise time, BCKR/X                                | BCLKR/X ext |      | 8   | ns   |
| tf(BCKRX)                    | Fall time, BCKR/X                                | BCLKR/X ext |      | 8   | ns   |

<sup>†</sup> 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.

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

|                               | PARAMETER                                                          |             |             | MIN                | MAX    | UNIT |
|-------------------------------|--------------------------------------------------------------------|-------------|-------------|--------------------|--------|------|
| t <sub>c</sub> (BCKRX)        | Cycle time, BCLKR/X                                                |             | BCLKR/X int | 4H                 |        | ns   |
| tw(BCKRXH)                    | Pulse duration, BCLKR/X high                                       |             | BCLKR/X int | D – 2 <sup>‡</sup> | D + 2‡ | ns   |
| tw(BCKRXL)                    | Pulse duration, BCLKR/X low                                        |             | BCLKR/X int | C – 2 <sup>‡</sup> | C + 2‡ | ns   |
|                               | Deleviting DOLKD high to internal DEOD will                        |             | BCLKR int   | -2                 | 2      | ns   |
| <sup>t</sup> d(BCKRH-BFRV)    | Delay time, BCLKR high to internal BFSR valid                      |             | BCLKR ext   | 3                  | 9      | ns   |
|                               | Delay time, BCLKX high to internal BFSX valid                      |             | BCLKX int   | 0                  | 4      | ns   |
| <sup>t</sup> d(BCKXH-BFXV)    |                                                                    |             | BCLKX ext   | 8                  | 11     |      |
|                               | Disable time, BCLKX high to BDX high impedance following last data |             | BCLKX int   | -1                 | 4      |      |
| <sup>t</sup> dis(BCKXH-BDXHZ) | bit of transfer                                                    |             | BCLKX ext   | 3                  | 9      | ns   |
|                               | D. L. C. DOLLOVIII L. DDV. C.                                      | 20201       | BCLKX int   | 0¶                 | 7      |      |
| <sup>t</sup> d(BCKXH-BDXV)    | Delay time, BCLKX high to BDX valid                                | DXENA = 0\$ | BCLKX ext   | 3                  | 11     | ns   |
|                               | Delay time, BFSX high to BDX valid                                 |             | BFSX int    | -1¶                | 3      |      |
| <sup>t</sup> d(BFXH-BDXV)     | ONLY applies when in data delay 0 (XDATDLY = 00b) m                | node        | BFSX ext    | 3                  | 13     | ns   |

<sup>†</sup>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

<sup>§</sup> The transmit delay enable (DXENA) and A-bis mode (ABIS) features of the McBSP are not implemented on the TMS320VC5402.

<sup>¶</sup> Minimum delay times also represent minimum output hold times.



Figure 27. McBSP Receive Timings



Figure 28. McBSP Transmit Timings

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

|                             |                                                               | MIN | MAX | UNIT |
|-----------------------------|---------------------------------------------------------------|-----|-----|------|
| t <sub>su</sub> (BGPIO-COH) | Setup time, BGPIOx input mode before CLKOUT high <sup>†</sup> | 9   |     | ns   |
| th(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 29)

|                            | PARAMETER                                                  | MIN | MAX | UNIT |
|----------------------------|------------------------------------------------------------|-----|-----|------|
| t <sub>d</sub> (COH-BGPIO) | Delay time, CLKOUT high to BGPIOx output mode <sup>‡</sup> | 0   | 5   | 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.

Figure 29. McBSP General-Purpose I/O Timings

<sup>\$</sup> BGPIOx refers to BCLKRx, BFSRx, BCLKXx, BFSXx, or BDXx when configured as a general-purpose output.

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

|                       |                                        | MASTER |     | MASTER SLAVE |     | UNIT |
|-----------------------|----------------------------------------|--------|-----|--------------|-----|------|
|                       |                                        | MIN    | MAX | MIN          | MAX | UNII |
| tsu(BDRV-BCKXL)       | Setup time, BDR valid before BCLKX low | 9      |     | – 12H        |     | ns   |
| th(BCKXL-BDRV)        | Hold time, BDR valid after BCLKX low   | 0      |     | 5 + 12H      |     | ns   |
| tsu(BFXL-BCKXH)       | Setup time, BFSX low before BCLKX high |        |     | 10           |     | ns   |
| t <sub>c</sub> (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.5 $t_{c(CO)}$ ] CLKSTP = 10b, CLKXP = 0<sup>†</sup> (see Figure 30)

|                   | PARAMETER                                                               | MAST  | rer‡  | SL     | AVE      | UNIT |
|-------------------|-------------------------------------------------------------------------|-------|-------|--------|----------|------|
|                   | PARAMETER                                                               | MIN   | MAX   | MIN    | MAX      | UNIT |
| th(BCKXL-BFXL)    | Hold time, BFSX low after BCLKX low§                                    | T-3   | T + 4 |        |          | ns   |
| td(BFXL-BCKXH)    | Delay time, BFSX low to BCLKX high <sup>¶</sup>                         | C – 5 | C + 3 |        |          | ns   |
| td(BCKXH-BDXV)    | Delay time, BCLKX high to BDX valid                                     | -2    | 6     | 6H + 5 | 10H + 15 | ns   |
| tdis(BCKXL-BDXHZ) | Disable time, BDX high impedance following last data bit from BCLKX low | C – 2 | C + 3 |        |          | ns   |
| tdis(BFXH-BDXHZ)  | Disable time, BDX high impedance following last data bit from BFSX high |       |       | 2H+ 4  | 6H + 17  | ns   |
| td(BFXL-BDXV)     | Delay time, BFSX low to BDX valid                                       |       |       | 4H – 2 | 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>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 30. McBSP Timing as SPI Master or Slave: CLKSTP = 10b, CLKXP = 0



<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

<sup>§</sup> 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

## timing requirements for McBSP as SPI master or slave: $[H=0.5t_{C(CO)}]$ CLKSTP = 11b, CLKXP = $0^{\dagger}$ (see Figure 31)

|                       |                                         | MASTER |     | MASTER SLAVE |     | UNIT |
|-----------------------|-----------------------------------------|--------|-----|--------------|-----|------|
|                       |                                         | MIN    | MAX | MIN          | MAX | UNIT |
| tsu(BDRV-BCKXH)       | Setup time, BDR valid before BCLKX high | 12     |     | 2 – 12H      |     | ns   |
| th(BCKXH-BDRV)        | Hold time, BDR valid after BCLKX high   | 4      |     | 5 + 12H      |     | ns   |
| tsu(BFXL-BCKXH)       | Setup time, BFSX low before BCLKX high  |        |     | 10           |     | ns   |
| t <sub>c</sub> (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^{+}$ (see Figure 31)

|                           | DADAMETER                                                               | MAST  | rer‡  | SL     | AVE      | LINUT |
|---------------------------|-------------------------------------------------------------------------|-------|-------|--------|----------|-------|
|                           | PARAMETER                                                               | MIN   | MAX   | MIN    | MAX      | UNIT  |
| th(BCKXL-BFXL)            | Hold time, BFSX low after BCLKX low§                                    | C – 3 | C + 4 |        |          | ns    |
| td(BFXL-BCKXH)            | Delay time, BFSX low to BCLKX high¶                                     | T-5   | T + 3 |        |          | ns    |
| td(BCKXL-BDXV)            | Delay time, BCLKX low to BDX valid                                      | -2    | 6     | 6H + 5 | 10H + 15 | ns    |
| tdis(BCKXL-BDXHZ)         | Disable time, BDX high impedance following last data bit from BCLKX low | -2    | 4     | 6H + 3 | 10H + 17 | ns    |
| <sup>t</sup> d(BFXL-BDXV) | Delay time, BFSX low to BDX valid                                       | D-2   | D + 4 | 4H – 2 | 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>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 = 11b, CLKXP = 0

<sup>&</sup>lt;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

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

<sup>§</sup> 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

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

|                              |                                         | MASTER |     | MASTER SLAVE |     |      |
|------------------------------|-----------------------------------------|--------|-----|--------------|-----|------|
|                              |                                         | MIN    | MAX | MIN          | MAX | UNIT |
| t <sub>su</sub> (BDRV-BCKXH) | Setup time, BDR valid before BCLKX high | 12     |     | 2 – 12H      |     | ns   |
| th(BCKXH-BDRV)               | Hold time, BDR valid after BCLKX high   | 4      |     | 5 + 12H      |     | ns   |
| tsu(BFXL-BCKXL)              | Setup time, BFSX low before BCLKX low   |        |     | 10           |     | ns   |
| t <sub>c</sub> (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.5 $t_{c(CO)}$ ] CLKSTP = 10b, CLKXP = 1<sup>†‡</sup> (see Figure 32)

|                   | PARAMETER                                                                | MAS   | TER   | SL     | AVE      | UNIT |
|-------------------|--------------------------------------------------------------------------|-------|-------|--------|----------|------|
|                   | PARAMETER                                                                | MIN   | MAX   | MIN    | MAX      | UNIT |
| th(BCKXH-BFXL)    | Hold time, BFSX low after BCLKX high§                                    | T-3   | T + 4 |        |          | ns   |
| td(BFXL-BCKXL)    | Delay time, BFSX low to BCLKX low¶                                       | D – 5 | D + 3 |        |          | ns   |
| td(BCKXL-BDXV)    | Delay time, BCLKX low to BDX valid                                       | -2    | 6     | 6H + 5 | 10H + 15 | ns   |
| tdis(BCKXH-BDXHZ) | Disable time, BDX high impedance following last data bit from BCLKX high | D – 2 | D + 3 |        |          | ns   |
| tdis(BFXH-BDXHZ)  | Disable time, BDX high impedance following last data bit from BFSX high  |       |       | 2H + 3 | 6H + 17  | ns   |
| td(BFXL-BDXV)     | Delay time, BFSX low to BDX valid                                        |       |       | 4H – 2 | 8H + 17  | ns   |

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

<sup>¶</sup>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 = 10b, CLKXP = 1



<sup>&</sup>lt;sup>‡</sup>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

<sup>§</sup> 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

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

|                              |                                        | MASTER |     | MASTER SLAVE |     | UNIT |
|------------------------------|----------------------------------------|--------|-----|--------------|-----|------|
|                              |                                        | MIN    | MAX | MIN          | MAX | UNII |
| tsu(BDRV-BCKXL)              | Setup time, BDR valid before BCLKX low | 9      |     | – 12H        |     | ns   |
| th(BCKXL-BDRV)               | Hold time, BDR valid after BCLKX low   | 0      |     | 5 + 12H      |     | ns   |
| t <sub>su</sub> (BFXL-BCKXL) | Setup time, BFSX low before BCLKX low  |        |     | 10           |     | ns   |
| t <sub>C</sub> (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.5 $t_{c(CO)}$ ] CLKSTP = 11b, CLKXP = 1<sup>†‡</sup> (see Figure 33)

|                   | DADAMETED                                                                | MAST  | rer‡  | SL     | AVE      | LINUT |
|-------------------|--------------------------------------------------------------------------|-------|-------|--------|----------|-------|
|                   | PARAMETER                                                                | MIN   | MAX   | MIN    | MAX      | UNIT  |
| th(BCKXH-BFXL)    | Hold time, BFSX low after BCLKX high§                                    | D-3   | D + 4 |        |          | ns    |
| td(BFXL-BCKXL)    | Delay time, BFSX low to BCLKX low¶                                       | T – 5 | T + 3 |        |          | ns    |
| td(BCKXH-BDXV)    | Delay time, BCLKX high to BDX valid                                      | -2    | 6     | 6H + 5 | 10H + 15 | ns    |
| tdis(BCKXH-BDXHZ) | Disable time, BDX high impedance following last data bit from BCLKX high | -2    | 4     | 6H + 3 | 10H + 17 | ns    |
| td(BFXL-BDXV)     | Delay time, BFSX low to BDX valid                                        | C-2   | C + 4 | 4H – 2 | 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.

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

<sup>¶</sup>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 = 11b, CLKXP = 1

<sup>&</sup>lt;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

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

<sup>§</sup> 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.

#### **HPI8** timing

## switching characteristics over recommended operating conditions†‡§¶ [H = $0.5t_{c(CO)}$ ] (see Figure 34, Figure 35, Figure 36, and Figure 37)

|                                                                                                                | PARAMETER                                                 |                                                                                    | MIN MAX                       | UNIT |
|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------|------------------------------------------------------------------------------------|-------------------------------|------|
| ten(DSL-HD)                                                                                                    | Enable time, HD driven from DS low                        |                                                                                    | 2 16                          | ns   |
|                                                                                                                |                                                           | Case 1a: Memory accesses when DMAC is active in 16-bit mode and $t_W(DSH) < 18H$   | 18H+16 - t <sub>W(DSH)</sub>  |      |
|                                                                                                                |                                                           | Case 1b: Memory accesses when DMAC is active in 16-bit mode and $t_W(DSH) \ge 18H$ | 16                            |      |
| † 1/2 01 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 1 1 2 | Delay time, DS low to HDx valid for                       | Case 1c: Memory access when DMAC is active in 32-bit mode and $t_W(DSH) < 26H$     | 26H+16 - t <sub>w(DSH)</sub>  | ns   |
| <sup>t</sup> d(DSL-HDV1)                                                                                       | first byte of an HPI read                                 | Case 1d: Memory access when DMAC is active in 32-bit mode and $t_W(DSH) \ge 26H$   | 16                            | 113  |
|                                                                                                                |                                                           | Case 2a: Memory accesses when DMAC is inactive and t <sub>w(DSH)</sub> < 10H       | 10H+16 - t <sub>W</sub> (DSH) |      |
|                                                                                                                |                                                           | Case 2b: Memory accesses when DMAC is inactive and t <sub>W</sub> (DSH) ≥ 10H      | 16                            |      |
|                                                                                                                |                                                           | Case 3: Register accesses                                                          | 16                            | ]    |
| td(DSL-HDV2)                                                                                                   | Delay time, DS low to HDx valid for se                    | cond byte of an HPI read                                                           | 16                            | ns   |
| th(DSH-HDV)R                                                                                                   | Hold time, HDx valid after DS high, for                   | a HPI read                                                                         | 3 5                           | ns   |
| t <sub>V</sub> (HYH-HDV)                                                                                       | Valid time, HDx valid after HRDY high                     |                                                                                    | 9                             |      |
| td(DSH-HYL)                                                                                                    | Delay time, DS high to HRDY low (see                      | e Note 1)                                                                          | 16                            | ns   |
|                                                                                                                |                                                           | Case 1a: Memory accesses when DMAC is active in 16-bit mode                        | 18H+16                        | ns   |
|                                                                                                                | D. 1                                                      | Case 1b: Memory accesses when DMAC is active in 32-bit mode                        | 26H+16                        | ns   |
| <sup>t</sup> d(DSH-HYH)                                                                                        | Delay time, DS high to HRDY high                          | Case 2: Memory accesses when DMAC is inactive                                      | 10H+16                        |      |
|                                                                                                                |                                                           | Case 3: Write accesses to HPIC register (see Note 2)                               | 6H+16                         | ns   |
| td(HCS-HRDY)                                                                                                   | Delay time, HCS low/high to HRDY low                      | w/high                                                                             | 16                            | ns   |
| td(COH-HYH)                                                                                                    | Delay time, CLKOUT high to HRDY high                      | gh                                                                                 | 3                             | ns   |
| td(COH-HTX)                                                                                                    | Delay time, CLKOUT high to HINT cha                       | ange                                                                               | 5                             | ns   |
| td(COH-GPIO)                                                                                                   | Delay time, CLKOUT high to HDx of general-purpose output. | output change. HDx is configured as a                                              | 6                             | ns   |

NOTES: 1. The HRDY output is always high when the HCS input is high, regardless of DS timings.



<sup>2.</sup> This timing applies when writing a one to the DSPINT bit or HINT bit of the HPIC register. All other writes to the HPIC occur asynchronoulsy, and do not cause HRDY to be deasserted.

<sup>†</sup> DS refers to the logical OR of HCS, HDS1, and HDS2.

<sup>&</sup>lt;sup>‡</sup> HDx refers to any of the HPI data bus pins (HD0, HD1, HD2, etc.).

<sup>§</sup> DMAC stands for direct memory access (DMA) controller. The HPI8 shares the internal DMA bus with the DMAC, thus HPI8 access times are affected by DMAC activity.

 $<sup>\</sup>P$  GPIO refers to the HD pins when they are configured as general-purpose input/outputs.

### **HPI8 timing (continued)**

### timing requirements†‡§ (see Figure 34, Figure 35, Figure 36, and Figure 37)

|                          |                                                                                         | MIN | MAX | UNIT |
|--------------------------|-----------------------------------------------------------------------------------------|-----|-----|------|
| t <sub>su(HBV-DSL)</sub> | Setup time, HBIL and HAD valid before DS low or before HAS low¶#                        | 5   |     | ns   |
| th(DSL-HBV)              | Hold time, HBIL and HAD valid after DS low or after HAS low¶#                           | 5   |     | ns   |
| tsu(HSL-DSL)             | Setup time, HAS low before DS low                                                       | 10  |     | ns   |
| tw(DSL)                  | Pulse duration, DS low                                                                  | 20  |     | ns   |
| tw(DSH)                  | Pulse duration, DS high                                                                 | 10  |     | ns   |
| t <sub>su(HDV-DSH)</sub> | Setup time, HDx valid before DS high, HPI write                                         | 2   |     | ns   |
| th(DSH-HDV)W             | Hold time, HDx valid after DS high, HPI write                                           | 3   |     | ns   |
| tsu(GPIO-COH)            | Setup time, HDx input valid before CLKOUT high, HDx configured as general-purpose input | 6   |     | ns   |
| th(GPIO-COH)             | Hold time, HDx input valid after CLKOUT high, HDx configured as general-purpose input   | 0   |     | ns   |

<sup>†</sup>DS refers to the logical OR of HCS, HDS1, and HDS2.

<sup>‡</sup> HDx refers to any of the HPI data bus pins (HD0, HD1, HD2, etc.).

<sup>§</sup> GPIO refers to the HD pins when they are configured as general-purpose input/outputs.  $\P$  HAD refers to HCNTL0, HCNTL1, and H/RW.

<sup>#</sup> When the HAS signal is used to latch the control signals, this timing refers to the falling edge of the HAS signal. Otherwise, when HAS is not used (always high), this timing refers to the falling edge of DS.

### **HPI8 timing (continued) Second Byte** First Byte **Second Byte** HAS tsu(HBV-DSL) t<sub>su(HSL-DSL)</sub> <mark>↑ t</mark>h(DSL-HBV) HAD† Valid Valid tsu(HBV-DSL)‡ th(DSL-HBV) **HBIL** HCS tw(DSH) tw(DSL) HDS td(DSH-HYH) td(DSH-HYL) **HRDY** ten(DSL-HD) td(DSL-HDV2) td(DSL-HDV1) th(DSH-HDV)R **HD READ** Valid Valid Valid tsu(HDV-DSH) t<sub>V</sub>(HYH-HDV) - th(DSH-HDV)W HD WRITE -Valid Valid Valid td(COH-HYH) **CLKOUT**

Figure 34. Using HDS to Control Accesses (HCS Always Low)

† HAD refers to HCNTL0, HCNTL1, and HR/W. ‡ When HAS is not used (HAS always high)



Figure 37. GPIOx<sup>†</sup> Timings

SPRS079D - OCTOBER 1998 - REVISED JANUARY 2000

#### **MECHANICAL DATA**

### 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 MO-136

#### **Thermal Resistance Characteristics**

| PARAMETER       | °C/W |
|-----------------|------|
| $R_{\ThetaJA}$  | 56   |
| $R_{\Theta JC}$ | 5    |



#### **MECHANICAL DATA**

#### GGU (S-PBGA-N144)

#### PLASTIC BALL GRID ARRAY PACKAGE



NOTES: A. All linear dimensions are in millimeters.

B. This drawing is subject to change without notice.

C. MicroStar BGA™ configuration

### **Thermal Resistance Characteristics**

| PARAMETER       | °C/W |
|-----------------|------|
| $R_{\ThetaJA}$  | 38   |
| $R_{\Theta JC}$ | 5    |

MicroStar BGA is a trademark of Texas Instruments Incorporated.

#### **IMPORTANT NOTICE**

Texas Instruments and its subsidiaries (TI) reserve the right to make changes to their products or to discontinue any product or service without notice, and advise customers to obtain the latest version of relevant information to verify, before placing orders, that information being relied on is current and complete. All products are sold subject to the terms and conditions of sale supplied at the time of order acknowledgement, including those pertaining to warranty, patent infringement, and limitation of liability.

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

CERTAIN APPLICATIONS USING SEMICONDUCTOR PRODUCTS MAY INVOLVE POTENTIAL RISKS OF DEATH, PERSONAL INJURY, OR SEVERE PROPERTY OR ENVIRONMENTAL DAMAGE ("CRITICAL APPLICATIONS"). TI SEMICONDUCTOR PRODUCTS ARE NOT DESIGNED, AUTHORIZED, OR WARRANTED TO BE SUITABLE FOR USE IN LIFE-SUPPORT DEVICES OR SYSTEMS OR OTHER CRITICAL APPLICATIONS. INCLUSION OF TI PRODUCTS IN SUCH APPLICATIONS IS UNDERSTOOD TO BE FULLY AT THE CUSTOMER'S RISK.

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

TI assumes no liability for applications assistance or customer product design. TI does not warrant or represent that any license, either express or implied, is granted under any patent right, copyright, mask work right, or other intellectual property right of TI covering or relating to any combination, machine, or process in which such semiconductor products or services might be or are used. TI's publication of information regarding any third party's products or services does not constitute TI's approval, warranty or endorsement thereof.

Copyright © 2000, Texas Instruments Incorporated