# SM320VC5421-EP Fixed-Point Digital Signal Processor

Data Manual

Literature Number: SGUS047 July 2003

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







# Contents

| Se | Section Page            |                                           |                                             |          |  |  |  |
|----|-------------------------|-------------------------------------------|---------------------------------------------|----------|--|--|--|
| 1  | SM320                   | VC5421-                                   | EP Features                                 | 1        |  |  |  |
| 2  | Introd                  | uction                                    |                                             | 2        |  |  |  |
|    | 2.1                     | Descrip                                   | tion                                        | 2        |  |  |  |
|    | 2.2                     |                                           | on From the 5420 to the 5421                | 2        |  |  |  |
|    | 2.3                     | Pin Ass                                   | ignments                                    | 3        |  |  |  |
|    |                         | 2.3.1                                     | Pin Assignments for the PGE Package         | 3        |  |  |  |
|    | 2.4                     | Signal [                                  | Descriptions                                | 6        |  |  |  |
| 3  | Functi                  | onal Ove                                  | erview                                      | 14       |  |  |  |
|    | 3.1                     | Memory                                    | /                                           | 15       |  |  |  |
|    |                         | 3.1.1                                     | On-Chip Dual-Access RAM (DARAM)             | 15       |  |  |  |
|    |                         | 3.1.2                                     | On-Chip Single-Access RAM (SARAM)           | 16       |  |  |  |
|    |                         | 3.1.3                                     | On-Chip Two-Way Shared RAM (DARAM)          | 16       |  |  |  |
|    |                         | 3.1.4                                     | On-Chip Boot ROM                            | 16       |  |  |  |
|    |                         | 3.1.5                                     | Extended Program Memory                     | 16       |  |  |  |
|    |                         | 3.1.6                                     | Program Memory                              | 17       |  |  |  |
|    |                         | 3.1.7                                     | Data Memory                                 | 17       |  |  |  |
|    |                         | 3.1.8                                     | I/O Memory                                  | 17       |  |  |  |
|    | 3.2                     | Multicor                                  | re Reset Signals                            | 17       |  |  |  |
|    | 3.3                     |                                           |                                             |          |  |  |  |
|    | 3.4                     | Externa                                   | I Interface (XIO)                           | 18<br>18 |  |  |  |
|    | 3.5 On-Chip Peripherals |                                           |                                             |          |  |  |  |
|    |                         | 3.5.1                                     | Software-Programmable Wait-State Generators | 19       |  |  |  |
|    |                         | 3.5.2                                     | Programmable Bank-Switching                 | 20       |  |  |  |
|    |                         | 3.5.3                                     | Parallel I/O Ports                          | 21       |  |  |  |
|    | 3.6                     | Bidirectional Host-Port Interface (HPI16) | 22                                          |          |  |  |  |
|    |                         | 3.6.1                                     | HPI16 Memory Map                            | 22       |  |  |  |
|    |                         | 3.6.2                                     | HPI Features                                | 23       |  |  |  |
|    |                         | 3.6.3                                     | HPI Multiplexed Mode                        | 23       |  |  |  |
|    |                         | 3.6.4                                     | Host/DSP Interrupts                         | 23       |  |  |  |
|    |                         | 3.6.5                                     | Emulation Considerations                    | 23       |  |  |  |
|    |                         | 3.6.6                                     | HPI Nonmultiplexed Mode                     | 23       |  |  |  |
|    |                         | 3.6.7                                     | Other HPI16 System Considerations           | 24       |  |  |  |
|    | 3.7                     | Multicha                                  | annel Buffered Serial Port (McBSP)          | 25       |  |  |  |
|    |                         | 3.7.1                                     | Emulation Considerations                    | 28       |  |  |  |
|    | 3.8                     |                                           | Iemory Access (DMA) Controller              | 29       |  |  |  |
|    |                         | 3.8.1                                     | DMA Controller Features                     | 31       |  |  |  |
|    |                         | 3.8.2                                     | DMA Accesses to External Memory             | 31       |  |  |  |
|    |                         | 3.8.3                                     | DMA Controller Synchronization Events       | 33       |  |  |  |
|    |                         | 3.8.4                                     | DMA Channel Interrupt Selection             | 33       |  |  |  |
|    |                         | 3.8.5                                     | DMA in Autoinitialization Mode              | 34       |  |  |  |
|    |                         | 3.8.6                                     | Subsystem Communications                    | 34       |  |  |  |
|    |                         | 3.8.7                                     | Chip Subsystem ID Register                  | 35       |  |  |  |

| 3.9       General-Purpose I/O       35         3.9.1       Hardware Timer       36         3.9.2       Software-Programmable Phase-Locked Loop (PLL)       36         3.9.3       PLL Clock Programmable Timer       38         3.10       Memory-Mapped Registers and Subaddresses       39         3.11       McBSP Control Registers and Subaddresses       41         3.12       DMA Subbank Addressed Registers       42         3.13       Interrupts       44         3.14       McBSP Control Registers and Subaddresses       46         3.15       Emulating the 5421 Device       46         4       Documentation Support       47         5       Electrical Specifications       48         5.1       Absolute Maximum Ratings       48         5.2       Recommended Operating Conditions       48         5.3       Electrical Characteristics       50         5.4       Package Thermal Resistance Characteristics       50         5.5       Timing Parameter Symbology       50         5.6       Clock Options       51         5.6.1       Divide-By-Two, Divide-By-Four, and Bypass Clock Option (PLL Disabled)       51         5.6.2       Multiply-By-N Clock Option (PLL Enabled)                                                                                               | Se | ection      |            |                                                                                                            | Page |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-------------|------------|------------------------------------------------------------------------------------------------------------|------|
| 3.9.1       Hardware Timer       36         3.9.2       Software-Programmable Timer       36         3.0       Memory-Mapped Registers       39         3.11       McBSP Control Registers and Subaddresses       41         3.12       DMA Subbank Addressed Registers       42         3.13       Interrupts       44         3.14       IDLE3 Power-Down Mode       46         3.15       Emulating the 5421 Device       46         4       Documentation Support       47         5       Electrical Specifications       48         5.1       Absolute Maximum Ratings       48         5.2       Recommended Operating Conditions       48         5.3       Electrical Characteristics       50         5.4       Package Thermal Resistance Characteristics       50         5.5       Timing Parameter Symbology       50         5.6       Multipt/By-N Clock Option (PLL Enabled)       51         5.6.1       Divide-By-Two, Divide-By-Four, and Bypass Clock Option (PLL Disabled)       52         5.7       Memory Interface Timing       53       57.1         5.7       Memory Nutriface Timing       53       53         5.7       Memory Interface Timing       53<                                                                                                                    |    | 3.9         | General-I  | Purpose I/O                                                                                                | 35   |
| 3.9.2         Software-Programmable Phase-Locked Loop (PLL)         36           3.9.3         PLL Clock Programmable Timer         38           3.10         Memory-Mapped Registers         39           3.11         McBSP Control Registers and Subaddresses         31           3.12         DMA Subbank Addressed Registers         42           3.13         Interrupts         44           3.14         IDLE3 Power-Down Mode         46           3.15         Emulating the 5421 Device         46           4         Documentation Support         47           5         Electrical Specifications         48           5.1         Absolute Maximum Ratings         48           5.2         Recommended Operating Conditions         48           5.3         Electrical Characteristics         50           5.4         Package Thermal Resistance Characteristics         50           5.6         Clock Options         51           5.6.1         Divide-By-Two, Divide-By-Four, and Bypass Clock Option (PLL Disabled)         51           5.6.2         Multiply-By-N Clock Option (PLL Enabled)         52           5.7         External Memory Interface Timing         53           5.7.1         Memory Meed         53                                                      |    |             |            | •                                                                                                          |      |
| 3.9.3       PLL Clock Programmable Timer.       38         3.10       Memory-Mapped Registers       39         3.11       McBSP Control Registers and Subaddresses       41         3.12       DMA Subbank Addressed Registers       42         3.13       Interrupts       44         3.14       DLE3P rower-Down Mode       46         3.15       Emulating the 5421 Device       46         4       Documentation Support       47         5       Electrical Specifications       48         5.1       Absolute Maximum Ratings       48         5.2       Recommended Operating Conditions       48         5.3       Electrical Characteristics       50         5.4       Package Thermal Resistance Characteristics       50         5.5       Timing Parameter Symbology       50         5.6       Clock Options       51         5.6.1       Divide-By-Four, and Bypass Clock Option (PLL Disabled)       52         5.6.2       Multiply-By-N Clock Option (PLL Enabled)       52         5.7       External Memory Interface Timing       53         5.7.1       Memory Write       55         5.8       Ready Timing For Externally Generated Wait States       56                                                                                                                           |    |             |            |                                                                                                            |      |
| 3.10       Memory-Mapped Registers       39         3.11       McBSP Control Registers and Subaddressee       41         3.12       DMA Subbank Addressed Registers       42         3.13       Interrupts       44         3.14       IDLE3 Power-Down Mode       46         3.15       Emulating the 5421 Device       46         4       Documentation Support       47         5       Electrical Specifications       48         5.1       Absolute Maximum Ratings       48         5.2       Recommended Operating Conditions       48         5.3       Electrical Characteristics       50         5.4       Package Thermal Resistance Characteristics       50         5.5       Timing Parameter Symbology       50         5.6       Clock Options       51         5.6.1       Divide-By-Four, and Bypass Clock Option (PLL Disabled)         5.6.2       Multiply-By-N Clock Option (PLL Enabled)       52         5.7       External Memory Interface Timing       53         5.7.1       Memory Write       55         5.8       Ready Timing For Externally Generated Wait States       56         5.9       Parallel I/O Dort Read       59.         5.10                                                                                                                               |    |             |            |                                                                                                            |      |
| 3.11       McBSP Control Registers and Subaddresses       41         3.12       DMA Subbank Addressed Registers       42         3.13       Interrupts       44         3.14       IDLE3 Power-Down Mode       46         3.15       Emulating the 5421 Device       46         4       Documentation Support       47         5       Electrical Specifications       48         5.1       Absolute Maximum Ratings       48         5.2       Recommended Operating Conditions       48         5.3       Electrical Characteristics       49         5.4       Package Thermal Resistance Characteristics       50         5.5       Timing Parameter Symbology       50         5.6       Clock Options       51         5.6.1       Divide-By-Two, Divide-By-Four, and Bypass Clock Option (PLL Disabled)       51         5.6.2       Multiply-By-N Clock Option (PLL Enabled)       52         5.7       External Memory Interface Timing       53         5.7.1       Memory Read       53         5.7.2       Memory Read       53         5.8       Ready Timing For Externally Generated Wait States       56         5.9       Parallel I/O Port Read       53                                                                                                                                 |    | 3.10        |            |                                                                                                            |      |
| 3.12       DMA Subbank Addressed Registers       42         3.13       Interrupts       44         3.14       IDLE3 Power-Down Mode       46         3.15       Emulating the 5421 Device       46         4       Documentation Support       47         5       Electrical Specifications       48         5.1       Absolute Maximum Ratings       48         5.2       Recommended Operating Conditions       48         5.3       Electrical Characteristics       50         5.4       Package Thermal Resistance Characteristics       50         5.5       Timing Parameter Symbology       50         5.6       Clock Options       51         5.6.1       Divide-By-Two, Divide-By-Four, and Bypass Clock Option (PLL Disabled)       51         5.6.2       Multiply-By-N Clock Option (PLL Enabled)       52         5.7       External Memory Interface Timing       53         5.8       Ready Timing For Externally Generated Wait States       56         5.9       Parallel I/O Interface Timing       58         5.10       External Memory Interface Timing       58         5.11       Parallel I/O Port Read       58         5.9.1       Parallel I/O Port Read       58     <                                                                                                       |    |             | -          |                                                                                                            |      |
| 3.13       Interrupts       44         3.14       IDLE3 Power-Down Mode       46         3.15       Emulating the 5421 Device       46         4       Documentation Support       47         5       Electrical Specifications       48         5.1       Absolute Maximum Ratings       48         5.2       Recommended Operating Conditions       48         5.3       Electrical Characteristics       49         5.4       Package Thermal Resistance Characteristics       50         5.5       Timing Parameter Symbology       50         5.6       Clock Options       51         5.6.1       Divide-By-Two, Divide-By-Four, and Bypass Clock Option (PLL Disabled)       51         5.6.2       Multiply-By-N Clock Option (PLL Enabled)       52         5.7       External Memory Interface Timing       53         5.7.2       Memory Read       53         5.7.2       Memory Read       53         5.7.2       Memory Read       58         5.9       Parallel I/O Port Read       58         5.9.1       Parallel I/O Port Read       58         5.9.2       Parallel I/O Port Read       59         5.10       External Ragi (K) and TOUT Timings <td></td> <td></td> <td></td> <td>-</td> <td></td>                                                                                     |    |             |            | -                                                                                                          |      |
| 3.14       IDLE3 Power-Down Mode       46         3.15       Emulating the 5421 Device       46         4       Documentation Support       47         5       Electrical Specifications       48         5.1       Absolute Maximum Ratings       48         5.2       Recommended Operating Conditions       48         5.3       Electrical Characteristics       49         5.4       Package Thermal Resistance Characteristics       50         5.5       Timing Parameter Symbology       50         5.6       Clock Options       51         5.6.1       Divide-By-Two, Divide-By-Four, and Bypass Clock Option (PLL Disabled)       51         5.6.2       Multiply-By-N Clock Option (PLL Enabled)       52         5.7       External Memory Interface Timing       53         5.7.1       Memory Read       53         5.7.2       Memory Write       55         5.8       Ready Timing For Externally Generated Wait States       56         5.9       Parallel I/O Port Read       58         5.9.1       Parallel I/O Port Read and Write With Externally Generated Wait States       60         5.10       Externally Generated Wait States       60         5.11       IOD and HOLDA Timings                                                                                              |    |             |            | -                                                                                                          |      |
| 3.15       Emulating the 5421 Device       46         4       Documentation Support       47         5       Electrical Specifications       48         5.1       Absolute Maximum Ratings       48         5.2       Recommended Operating Conditions       48         5.3       Electrical Characteristics       49         5.4       Package Thermal Resistance Characteristics       50         5.5       Timing Parameter Symbology       50         5.6       Clock Options       51         5.6.2       Multiply-By-Nuo, Divide-By-Four, and Bypass Clock Option (PLL Disabled)       52         5.7       External Memory Interface Timing       53         5.7.1       Memory Write       55         5.8       Ready Timing For Externally Generated Wait States       56         5.9       Parallel I/O Interface Timing       58         5.10       Externally Generated Wait States       56         5.10       Externally Generated Wait States       56         5.11       Interrupt, and MP/MC Timings       62         5.12       HOLD And HOLDA Timings       62         5.11       Reset, BIO, Interrupt, and MP/MC Timings       64         5.13       External Flag (XF) and TOUT Timings                                                                                              |    |             |            |                                                                                                            |      |
| 5       Electrical Specifications       48         5.1       Absolute Maximum Ratings       48         5.2       Recommended Operating Conditions       48         5.3       Electrical Characteristics       49         5.4       Package Thermal Resistance Characteristics       50         5.5       Timing Parameter Symbology       50         5.6       Clock Options       51         5.6.1       Divide-By-Two, Divide-By-Four, and Bypass Clock Option (PLL Disabled)       51         5.6.2       Multiply-By-N Clock Option (PLL Enabled)       52         5.7       External Memory Interface Timing       53         5.7.2       Memory Read       53         5.7.2       Memory Write       55         5.8       Ready Timing For Externally Generated Wait States       56         5.9       Parallel I/O Port Read       58         5.9.1       Parallel I/O Port Read       58         5.9.2       Parallel I/O Port Read       58         5.10.1       J/O Port Read and Write With Externally Generated Wait States       60         5.10.1       J/O Port Read and Write With Externally Generated Wait States       60         5.11       McBSP Transmit and Receive Timings       64         5.12 <td></td> <td></td> <td></td> <td></td> <td>-</td>                                |    |             |            |                                                                                                            | -    |
| 5.1       Absolute Maximum Ratings       48         5.2       Recommended Operating Conditions       48         5.3       Electrical Characteristics       49         5.4       Package Thermal Resistance Characteristics       50         5.5       Timing Parameter Symbology       50         5.6       Clock Options       51         5.6.1       Divide-By-Two, Divide-By-Four, and Bypass Clock Option (PLL Disabled)       51         5.6.2       Multiply-By-N Clock Option (PLL Enabled)       52         5.7       External Memory Interface Timing       53         5.7.1       Memory Write       55         5.8       Ready Timing For Externally Generated Wait States       56         5.9       Parallel I/O Interface Timing       58         5.9.1       Parallel I/O Port Read       58         5.9.2       Parallel I/O Port Write       59         5.10       Externally Generated Wait States       60         5.10.1       I/O Port Read and Write With Externally Generated Wait States       60         5.11       Reset, BIO, Interrupt, and MP/MC Timings       64         5.13       External Flag (XF) and TOUT Timings       64         5.14       General-Purpose I/O Timing       67         <                                                                            | 4  | Docun       | nentation  | Support                                                                                                    | 47   |
| 5.1       Absolute Maximum Ratings       48         5.2       Recommended Operating Conditions       48         5.3       Electrical Characteristics       49         5.4       Package Thermal Resistance Characteristics       50         5.5       Timing Parameter Symbology       50         5.6       Clock Options       51         5.6.1       Divide-By-Two, Divide-By-Four, and Bypass Clock Option (PLL Disabled)       51         5.6.2       Multiply-By-N Clock Option (PLL Enabled)       52         5.7       External Memory Interface Timing       53         5.7.1       Memory Write       55         5.8       Ready Timing For Externally Generated Wait States       56         5.9       Parallel I/O Interface Timing       58         5.9.1       Parallel I/O Port Read       58         5.9.2       Parallel I/O Port Write       59         5.10       Externally Generated Wait States       60         5.10.1       I/O Port Read and Write With Externally Generated Wait States       60         5.11       Reset, BIO, Interrupt, and MP/MC Timings       64         5.12       HOLD and HOLDA Timings       64         5.13       External Flag (XF) and TOUT Timings       64         5                                                                                | 5  | Electri     | cal Specif | fications                                                                                                  | 48   |
| 5.2       Recommended Operating Conditions       48         5.3       Electrical Characteristics       49         5.4       Package Thermal Resistance Characteristics       50         5.5       Timing Parameter Symbology       50         5.6       Clock Options       51         5.6.1       Divide-By-Two, Divide-By-Four, and Bypass Clock Option (PLL Disabled)       51         5.6.2       Multiply-By-N Clock Option (PLL Enabled)       52         5.7       External Memory Interface Timing       53         5.7.2       Memory Read       53         5.7.2       Memory Write       55         5.8       Ready Timing For Externally Generated Wait States       56         5.9       Parallel I/O Port Read       58         5.9.1       Parallel I/O Port Read       58         5.9.2       Parallel I/O Port Write       59         5.10       Externally Generated Wait States       60         5.11       I/O Port Read and Write With Externally Generated Wait States       60         5.12       HOLD and HOLDA Timings       62         5.13       Kester, BIO, Interrupt, and MP/MC Timings       64         5.14       General-Purpose I/O Timing       67         5.15.1       McBSP T                                                                                         | Ŭ  |             | -          |                                                                                                            | -    |
| 5.3       Electrical Characteristics       49         5.4       Package Thermal Resistance Characteristics       50         5.5       Timing Parameter Symbology       50         5.6       Clock Options       51         5.6.1       Divide-By-Two, Divide-By-Four, and Bypass Clock Option (PLL Disabled)       51         5.6.2       Multiply-By-N Clock Option (PLL Enabled)       52         5.7       External Memory Interface Timing       53         5.7.1       Memory Read       53         5.7.2       Memory Write       55         5.8       Ready Timing For Externally Generated Wait States       56         5.9       Parallel I/O Interface Timing       58         5.9.1       Parallel I/O Port Read       58         5.9.2       Parallel I/O Port Read       58         5.10       Externally Generated Wait States       60         5.11       Reset, BIO, Interrupt, and MP/MC Timings       62         5.12       HOLD and HOLDA Timings       64         5.13       External Flag (XF) and TOUT Timings       64         5.14       General-Purpose I/O Timing       68         5.15.1       McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to the Sample Rate Generator (SRGR)       71                                                              |    |             |            |                                                                                                            | -    |
| 5.4       Package Thermal Resistance Characteristics       50         5.5       Timing Parameter Symbology       50         5.6       Clock Options       51         5.6.1       Divide-By-Two, Divide-By-Four, and Bypass Clock Option (PLL Disabled)       51         5.6.2       Multiply-By-N Clock Option (PLL Enabled)       52         5.7       External Memory Interface Timing       53         5.7.1       Memory Read       53         5.7.2       Memory Write       55         5.8       Ready Timing For Externally Generated Wait States       56         5.9       Parallel I/O Interface Timing       58         5.9.1       Parallel I/O Port Read       58         5.9.2       Parallel I/O Port Write       59         5.10       Externally Generated Wait States       60         5.11       Reset, BIO, Interrupt, and MP/MC Timings       62         5.12       HOLD and HOLDA Timings       64         5.13       External Flag (XF) and TOUT Timings       64         5.14       General-Purpose I/O Timing       67         5.15.1       McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to the Sample Rate Generator (SRGR)       71         5.15.2       McBSP as SPI Master or Slave Timing       <                                                  |    |             |            |                                                                                                            |      |
| 5.5       Timing Parameter Symbology       50         5.6       Clock Options       51         5.6.1       Divide-By-Two, Divide-By-Four, and Bypass Clock Option (PLL Disabled)       51         5.6.2       Multiply-By-N Clock Option (PLL Enabled)       52         5.7       External Memory Interface Timing       53         5.7.1       Memory Read       53         5.7.2       Memory Write       55         5.8       Ready Timing For Externally Generated Wait States       56         5.9       Parallel I/O Interface Timing       58         5.9.1       Parallel I/O Port Read       58         5.9.2       Parallel I/O Port Write       59         5.10       Externally Generated Wait States       60         5.10.1       I/O Port Read and Write With Externally Generated Wait States       60         5.11       Reset, BIO, Interrupt, and MP/MC Timings       62         5.12       HOLD and HOLDA Timings       64         5.13       External Flag (XF) and TOUT Timings       66         5.14       General-Purpose I/O Timing       67         5.15.1       McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to the Sample Rate Generator (SRGR)       71         5.15.2       McBSP Transmit and Receive                                             |    |             |            |                                                                                                            | -    |
| 5.6       Clock Options       51         5.6.1       Divide-By-Two, Divide-By-Four, and Bypass Clock Option (PLL Disabled)       51         5.6.2       Multiply-By-N Clock Option (PLL Enabled)       52         5.7       External Memory Interface Timing       53         5.7.1       Memory Read       53         5.7.2       Memory Write       55         5.8       Ready Timing For Externally Generated Wait States       56         5.9       Parallel I/O Interface Timing       58         5.9.1       Parallel I/O Port Read       58         5.9.2       Parallel I/O Port Write       59         5.10       Externally Generated Wait States       60         5.11       I/O Port Read and Write With Externally Generated Wait States       60         5.11       Reset, BIO, Interrupt, and MP/MC Timings       62         5.12       HOLD and HOLDA Timings       64         5.13       External Flag (XF) and TOUT Timings       66         5.14       General-Purpose I/O Timing       68         5.15.1       McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to the Sample Rate Generator (SRGR)       71         5.15.3       McBSP General-Purpose I/O Timing       73         5.15.4       McBSP General-Purpo                                             |    |             | -          |                                                                                                            |      |
| 5.6.1       Divide-By-Two, Divide-By-Four, and Bypass Clock Option (PLL Disabled)       51         5.6.2       Multiply-By-N Clock Option (PLL Enabled)       52         5.7       External Memory Interface Timing       53         5.7.1       Memory Write       53         5.7.2       Memory Write       55         5.8       Ready Timing For Externally Generated Wait States       56         5.9       Parallel I/O Interface Timing       58         5.9.1       Parallel I/O Port Read       58         5.9.2       Parallel I/O Port Write       59         5.10       Externally Generated Wait States       60         5.10.1       I/O Port Read and Write With Externally Generated Wait States       60         5.11.1       Reset, BIO, Interrupt, and MP/MC Timings       62         5.12       HOLD and HOLDA Timings       64         5.13       External Flag (XF) and TOUT Timings       66         5.14       General-Purpose I/O Timing       68         5.15.1       McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to the Sample Rate Generator (SRGR)       71         5.15.2       McBSP Transmit and Receive Timing       73         5.15.3       McBSP General-Purpose I/O Timing       73         5.15.4                                           |    |             | •          |                                                                                                            |      |
| 5.6.2       Multiply-By-N Clock Option (PLL Enabled)       52         5.7       External Memory Interface Timing       53         5.7.1       Memory Read       53         5.7.2       Memory Write       55         5.8       Ready Timing For Externally Generated Wait States       56         5.9       Parallel I/O Interface Timing       58         5.9.1       Parallel I/O Port Read       58         5.9.2       Parallel I/O Port Write       59         5.10.1       I/O Port Read and Write With Externally Generated Wait States       60         5.10.1       I/O Port Read and Write With Externally Generated Wait States       60         5.10.1       I/O Port Read and Write With Externally Generated Wait States       60         5.10.1       I/O Port Read and Write With Externally Generated Wait States       60         5.11       I/O Port Read and Write With Externally Generated Wait States       60         5.12       HOLD and HOLDA Timings       62         5.13       External Flag (XF) and TOUT Timings       62         5.14       General-Purpose I/O Timing       67         5.15.1       McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to the Sample Rate Generator (SRGR)       71         5.15.3       McBSP General-Purpose I/O Ti |    | 5.0         | •          |                                                                                                            |      |
| 5.7       External Memory Interface Timing       53         5.7.1       Memory Read       53         5.7.2       Memory Write       55         5.8       Ready Timing For Externally Generated Wait States       56         5.9       Parallel I/O Interface Timing       58         5.9.1       Parallel I/O Port Read       58         5.9.2       Parallel I/O Port Write       59         5.10       Externally Generated Wait States       60         5.10.1       I/O Port Read and Write With Externally Generated Wait States       60         5.10.1       I/O Port Read and Write With Externally Generated Wait States       60         5.11       Reset, BIO, Interrupt, and MP/MC Timings       62         5.12       HOLD and HOLDA Timings       64         5.13       External Flag (XF) and TOUT Timings       66         5.14       General-Purpose I/O Timing       67         5.15       Multichannel Buffered Serial Port (McBSP) Timing       68         5.15.2       McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to the Sample Rate Generator (SRGR)       71         5.15.3       McBSP General-Purpose I/O Timing       73         5.15.4       McBSP as SPI Master or Slave Timing       74         5.16                                              |    |             |            |                                                                                                            |      |
| 5.7.1       Memory Read       53         5.7.2       Memory Write       55         5.8       Ready Timing For Externally Generated Wait States       56         5.9       Parallel I/O Interface Timing       58         5.9.1       Parallel I/O Port Read       58         5.9.2       Parallel I/O Port Write       59         5.10       Externally Generated Wait States       60         5.10.1       I/O Port Read and Write With Externally Generated Wait States       60         5.11       Reset, BIO, Interrupt, and MP/MC Timings       62         5.12       HOLD and HOLDA Timings       62         5.14       General-Purpose I/O Timing       66         5.15       Multichannel Buffered Serial Port (McBSP) Timing       66         5.15.1       McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to the Sample Rate Generator (SRGR)       71         5.15.3       McBSP General-Purpose I/O Timing       73         5.15.4       McBSP as SPI Master or Slave Timing       74         5.16       Host-Port Interface Timing       78         6       Mechanical Data       85                                                                                                                                                                                   |    | 57          |            |                                                                                                            |      |
| 5.7.2       Memory Write       55         5.8       Ready Timing For Externally Generated Wait States       56         5.9       Parallel I/O Interface Timing       58         5.9       Parallel I/O Port Read       58         5.9.1       Parallel I/O Port Read       58         5.9.2       Parallel I/O Port Write       59         5.10       Externally Generated Wait States       60         5.10.1       I/O Port Read and Write With Externally Generated Wait States       60         5.11       Reset, BIO, Interrupt, and MP/MC Timings       62         5.12       HOLD and HOLDA Timings       62         5.13       External Flag (XF) and TOUT Timings       64         5.14       General-Purpose I/O Timing       67         5.15       Multichannel Buffered Serial Port (McBSP) Timing       67         5.15.1       McBSP Transmit and Receive Timings       68         5.15.2       McBSP Transmit and Receive Timings       68         5.15.3       McBSP General-Purpose I/O Timing       73         5.15.3       McBSP General-Purpose I/O Timing       73         5.15.4       McBSP as SPI Master or Slave Timing       74         5.16       Host-Port Interface Timing       78         6<                                                                                |    | 5.7         |            |                                                                                                            |      |
| 5.8       Ready Timing For Externally Generated Wait States       56         5.9       Parallel I/O Interface Timing       58         5.9.1       Parallel I/O Port Read       58         5.9.2       Parallel I/O Port Write       59         5.10       Externally Generated Wait States       60         5.10.1       I/O Port Read and Write With Externally Generated Wait States       60         5.11       Reset, BIO, Interrupt, and MP/MC Timings       62         5.12       HOLD and HOLDA Timings       62         5.13       External Flag (XF) and TOUT Timings       64         5.14       General-Purpose I/O Timing       66         5.15       Multichannel Buffered Serial Port (McBSP) Timing       68         5.15.1       McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to the Sample Rate Generator (SRGR)       71         5.15.3       McBSP General-Purpose I/O Timing       73         5.15.4       McBSP as SPI Master or Slave Timing       74         5.16       Host-Port Interface Timing       78         6       Mechanical Data       85                                                                                                                                                                                                      |    |             | -          | •                                                                                                          |      |
| 5.9       Parallel I/O Interface Timing       58         5.9.1       Parallel I/O Port Read       58         5.9.2       Parallel I/O Port Write       59         5.10       Externally Generated Wait States       60         5.10.1       I/O Port Read and Write With Externally Generated Wait States       60         5.11       Reset, BIO, Interrupt, and MP/MC Timings       62         5.12       HOLD and HOLDA Timings       64         5.13       External Flag (XF) and TOUT Timings       66         5.14       General-Purpose I/O Timing       67         5.15       Multichannel Buffered Serial Port (McBSP) Timing       68         5.15.1       McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to the Sample Rate Generator (SRGR)       71         5.15.3       McBSP General-Purpose I/O Timing       73         5.15.4       McBSP as SPI Master or Slave Timing       74         5.16       Host-Port Interface Timing       78         6       Mechanical Data       85                                                                                                                                                                                                                                                                                   |    | E 0         |            |                                                                                                            |      |
| 5.9.1       Parallel I/O Port Read       58         5.9.2       Parallel I/O Port Write       59         5.10       Externally Generated Wait States       60         5.11.       I/O Port Read and Write With Externally Generated Wait States       60         5.11       Reset, BIO, Interrupt, and MP/MC Timings       62         5.12       HOLD and HOLDA Timings       64         5.13       External Flag (XF) and TOUT Timings       66         5.14       General-Purpose I/O Timing       67         5.15       Multichannel Buffered Serial Port (McBSP) Timing       68         5.15.1       McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to the Sample Rate Generator (SRGR)       71         5.15.3       McBSP General-Purpose I/O Timing       73         5.15.4       McBSP as SPI Master or Slave Timing       74         5.16       Host-Port Interface Timing       78         6       Mechanical Data       85                                                                                                                                                                                                                                                                                                                                             |    |             |            | • •                                                                                                        |      |
| 5.9.2Parallel I/O Port Write595.10Externally Generated Wait States605.10.1I/O Port Read and Write With Externally Generated Wait States605.11Reset, BIO, Interrupt, and MP/MC Timings625.12HOLD and HOLDA Timings645.13External Flag (XF) and TOUT Timings665.14General-Purpose I/O Timing675.15Multichannel Buffered Serial Port (McBSP) Timing685.15.1McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to<br>the Sample Rate Generator (SRGR)715.15.3McBSP General-Purpose I/O Timing735.15.4McBSP as SPI Master or Slave Timing745.16Host-Port Interface Timing786Mechanical Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |    | 5.9         |            |                                                                                                            |      |
| 5.10       Externally Generated Wait States       60         5.10.1       I/O Port Read and Write With Externally Generated Wait States       60         5.11       Reset, BIO, Interrupt, and MP/MC Timings       62         5.12       HOLD and HOLDA Timings       64         5.13       External Flag (XF) and TOUT Timings       66         5.14       General-Purpose I/O Timing       66         5.15       Multichannel Buffered Serial Port (McBSP) Timing       68         5.15.1       McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to the Sample Rate Generator (SRGR)       71         5.15.3       McBSP General-Purpose I/O Timing       73         5.15.4       McBSP as SPI Master or Slave Timing       74         5.16       Host-Port Interface Timing       78         6       Mechanical Data       85                                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |             |            |                                                                                                            |      |
| 5.10.1       I/O Port Read and Write With Externally Generated Wait States       60         5.11       Reset, BIO, Interrupt, and MP/MC Timings       62         5.12       HOLD and HOLDA Timings       64         5.13       External Flag (XF) and TOUT Timings       66         5.14       General-Purpose I/O Timing       66         5.15       Multichannel Buffered Serial Port (McBSP) Timing       68         5.15.1       McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to the Sample Rate Generator (SRGR)       71         5.15.3       McBSP General-Purpose I/O Timing       73         5.15.4       McBSP as SPI Master or Slave Timing       74         5.16       Host-Port Interface Timing       78         6       Mechanical Data       85                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |    | E 10        |            |                                                                                                            |      |
| 5.11       Reset, BIO, Interrupt, and MP/MC Timings       62         5.12       HOLD and HOLDA Timings       64         5.13       External Flag (XF) and TOUT Timings       66         5.14       General-Purpose I/O Timing       67         5.15       Multichannel Buffered Serial Port (McBSP) Timing       68         5.15.1       McBSP Transmit and Receive Timings       68         5.15.2       McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to the Sample Rate Generator (SRGR)       71         5.15.3       McBSP General-Purpose I/O Timing       73         5.15.4       McBSP as SPI Master or Slave Timing       74         5.16       Host-Port Interface Timing       78         6       Mechanical Data       85                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |    | 5.10        |            |                                                                                                            |      |
| 5.12HOLD and HOLDA Timings645.13External Flag (XF) and TOUT Timings665.14General-Purpose I/O Timing675.15Multichannel Buffered Serial Port (McBSP) Timing685.15.1McBSP Transmit and Receive Timings685.15.2McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to<br>the Sample Rate Generator (SRGR)715.15.3McBSP General-Purpose I/O Timing735.15.4McBSP as SPI Master or Slave Timing745.16Host-Port Interface Timing786Mechanical Data85                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |    | <b>E</b> 44 |            |                                                                                                            |      |
| 5.13External Flag (XF) and TOUT Timings665.14General-Purpose I/O Timing675.15Multichannel Buffered Serial Port (McBSP) Timing685.15.1McBSP Transmit and Receive Timings685.15.2McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to<br>the Sample Rate Generator (SRGR)715.15.3McBSP General-Purpose I/O Timing735.15.4McBSP as SPI Master or Slave Timing745.16Host-Port Interface Timing7885                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |    |             |            |                                                                                                            |      |
| 5.14General-Purpose I/O Timing675.15Multichannel Buffered Serial Port (McBSP) Timing685.15.1McBSP Transmit and Receive Timings685.15.2McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to<br>the Sample Rate Generator (SRGR)715.15.3McBSP General-Purpose I/O Timing735.15.4McBSP as SPI Master or Slave Timing745.16Host-Port Interface Timing7885                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |    |             |            |                                                                                                            |      |
| 5.15       Multichannel Buffered Serial Port (McBSP) Timing       68         5.15.1       McBSP Transmit and Receive Timings       68         5.15.2       McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to the Sample Rate Generator (SRGR)       71         5.15.3       McBSP General-Purpose I/O Timing       73         5.15.4       McBSP as SPI Master or Slave Timing       74         5.16       Host-Port Interface Timing       78         85                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |    |             |            |                                                                                                            |      |
| 5.15.1McBSP Transmit and Receive Timings685.15.2McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to<br>the Sample Rate Generator (SRGR)715.15.3McBSP General-Purpose I/O Timing735.15.4McBSP as SPI Master or Slave Timing745.16Host-Port Interface Timing786Mechanical Data85                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |             |            |                                                                                                            |      |
| 5.15.2McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to<br>the Sample Rate Generator (SRGR)715.15.3McBSP General-Purpose I/O Timing735.15.4McBSP as SPI Master or Slave Timing745.16Host-Port Interface Timing7885                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |    | 5.15        |            |                                                                                                            |      |
| the Sample Rate Generator (SRGR)715.15.3McBSP General-Purpose I/O Timing735.15.4McBSP as SPI Master or Slave Timing745.16Host-Port Interface Timing786Mechanical Data85                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |    |             |            |                                                                                                            | 68   |
| 5.15.4       McBSP as SPI Master or Slave Timing       74         5.16       Host-Port Interface Timing       78         6       Mechanical Data       85                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |    |             | 5.15.2     | McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to the Sample Rate Generator (SRGR) | 71   |
| 5.16       Host-Port Interface Timing       78         6       Mechanical Data       85                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |    |             | 5.15.3     |                                                                                                            | 73   |
| 6 Mechanical Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |    |             | 5.15.4     | McBSP as SPI Master or Slave Timing                                                                        | 74   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |    | 5.16        | Host-Port  | t Interface Timing                                                                                         | 78   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 6  | Mecha       | nical Data |                                                                                                            | 85   |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | -  |             |            |                                                                                                            |      |

# List of Figures

| Figure |                                                                                   | Page |
|--------|-----------------------------------------------------------------------------------|------|
| 2–1    | 144-Pin Low-Profile Flatpack Pin Assignments (PGE – Top View)                     | 3    |
| 3–1    | 320VC5421 Functional Block Diagram                                                | 14   |
| 3–2    | Memory Map Relative to CPU Subsystems A and B                                     | 15   |
| 3–3    | Software Wait-State Register (SWWSR) [Memory-Mapped Register (MMR) Address 0028h] | 19   |
| 3–4    | Software Wait-State Control Register (SWCR) [MMR Address 002Bh]                   | 20   |
| 3–5    | BSCR Register Bit Layout for Each DSP Subsystem                                   | 20   |
| 3–6    | Memory Map Relative to Host-Port Interface HPI16                                  | 22   |
| 3–7    | Interfacing to the HPI-16 in Non-Multiplexed Mode                                 | 24   |
| 3–8    | Pin Control Register (PCR)                                                        | 26   |
| 3–9    | Multichannel Control Register 2x (MCR2x)                                          | 26   |
| 3–10   | Multichannel Control Register 1x (MCR1x)                                          | 27   |
| 3–11   | Receive Channel Enable Registers Bit Layout for Partitions A to H                 | 27   |
| 3–12   | Transmit Channel Enable Registers Bit Layout for Partitions A to H                | 27   |
| 3–13   | On-Chip Memory Map Relative to DMA (DLAXS/SLAXS = 0)                              | 29   |
| 3–14   | DMA External Program Memory Map                                                   | 30   |
| 3–15   | Arbitration Between XIO and xDMA for External Access                              | 32   |
| 3–16   | DMA Transfer Mode Control Register (DMMCRn)                                       | 32   |
| 3–17   | DMPREC Register                                                                   | 34   |
| 3–18   | Chip Subsystem ID Register                                                        | 35   |
| 3–19   | General-Purpose I/O Control Register                                              | 35   |
| 3–20   | Clock Mode Register (CLKMD)                                                       | 37   |
| 3–21   | Bit Layout of the IMR and IFR Registers for Subsystems A and B                    | 45   |
| 5–1    | 3.3-V Test Load Circuit                                                           | 49   |
| 5–2    | External Divide-by-Two Clock Timing                                               | 51   |
| 5–3    | External Multiply-by-One Clock Timing                                             | 52   |
| 5–4    | Memory Read (MSTRB = 0)                                                           | 54   |
| 5–5    | Memory Write (MSTRB = 0)                                                          | 55   |
| 5–6    | Memory Read With Externally Generated Wait States                                 | 56   |
| 5–7    | Memory Write With Externally Generated Wait States                                | 57   |
| 5–8    | Parallel I/O Port Read (IOSTRB=0)                                                 | 58   |
| 5–9    | Parallel I/O Port Write (IOSTRB=0)                                                | 59   |
| 5–10   | I/O Port Read With Externally Generated Wait States                               | 60   |
| 5–11   | I/O Port Write With Externally Generated Wait States                              | 61   |
| 5–12   | Reset and BIO Timings                                                             | 62   |
| 5–13   | Interrupt Timing                                                                  | 63   |
| 5–14   | XIO Timing                                                                        | 63   |
| 5–15   | $\overline{\text{HOLD}}$ and $\overline{\text{HOLDA}}$ Timings (HM = 1)           | 65   |
| 5–16   | External Flag (XF) Timing                                                         | 66   |

#### Figures

| -    |                                                              | -  |
|------|--------------------------------------------------------------|----|
| 5–17 | Timer (TOUT) Timing                                          | 66 |
| 5–18 | GPIO Timings                                                 | 77 |
| 5–19 | McBSP Receive Timings                                        | 70 |
| 5–20 | McBSP Transmit Timings                                       | 70 |
| 5–21 | McBSP Sample Rate Generator Timings                          | 72 |
| 5–22 | McBSP General-Purpose I/O Timings                            | 73 |
| 5–23 | McBSP Timing as SPI Master or Slave: CLKSTP = 10b, CLKXP = 0 | 74 |
| 5–24 | McBSP Timing as SPI Master or Slave: CLKSTP = 11b, CLKXP = 0 | 75 |
| 5–25 | McBSP Timing as SPI Master or Slave: CLKSTP = 10b, CLKXP = 1 | 76 |
| 5–26 | McBSP Timing as SPI Master or Slave: CLKSTP = 11b, CLKXP = 1 | 77 |
| 5–27 | Multiplexed Read Timings Using HAS                           | 80 |
| 5–28 | Multiplexed Read Timings With HAS Held High                  | 81 |
| 5–29 | Multiplexed Write Timings Using HAS                          | 82 |
| 5–30 | Multiplexed Write Timings With HAS Held High                 | 83 |
| 5–31 | Nonmultiplexed Read Timings                                  | 83 |
| 5–32 | Nonmultiplexed Write Timings                                 | 84 |
| 5–33 | HRDY and HINT Relative to CLKOUT                             | 84 |
| 5–34 | SELA/B Timing                                                | 84 |
| 6–1  | Low-Profile Quad Flatpack                                    | 85 |
|      |                                                              |    |

# **List of Tables**

| Table      |                                                                     | Page   |
|------------|---------------------------------------------------------------------|--------|
| 2–1<br>2–2 | Pin Assignments for the 144-Pin Low-Profile Quad Flatpack           | 4<br>6 |
| 3–1        | XIO/ROMEN Modes                                                     | 16     |
| 3–2        | Bootloader Operating Modes                                          | 17     |
| 3–3        | XIO/HPI Modes                                                       | 18     |
| 3-4        | Software Wait-State Register (SWWSR) Bit Fields                     | 19     |
| 3–5        | Software Wait-State Control Register (SWCR) Bit Fields              | 20     |
| 3–6        | BSCR Register Bit Functions for Each DSP Subsystem                  | 21     |
| 3–7        | Sample Rate Generator Clock Source Selection                        | 26     |
| 3–8        | Receive Channel Enable Registers for Partitions A to H              | 27     |
| 3–9        | Transmit Channel Enable Registers for Partitions A to H             | 28     |
| 3–10       | DMA Synchronization Events                                          | 33     |
| 3–11       | DMA Channel Interrupt Selection                                     | 33     |
| 3–12       | DMA Global Reload Register Selection                                | 34     |
| 3–13       | Chip Subsystem ID Register Bit Functions                            | 35     |
| 3–14       | General-Purpose I/O Control Register Bit Functions                  | 36     |
| 3–15       | Clock Mode Register (CLKMD) Bit Functions                           | 37     |
| 3–16       | Multiplier Related to PLLNDIV, PLLDIV, and PLLMUL                   | 38     |
| 3–17       | VCO Truth Table                                                     | 38     |
| 3–18       | VCO Lockup Time                                                     | 38     |
| 3–19       | Processor Memory-Mapped Registers for Each DSP Subsystem            | 39     |
| 3–20       | Peripheral Memory-Mapped Registers for Each DSP Subsystem           | 40     |
| 3–21       | McBSP Control Registers and Subaddresses                            | 41     |
| 3–22       | DMA Subbank Addressed Registers                                     | 42     |
| 3–23       | 5421 Interrupt Locations and Priorities for Each DSP Subsystem      | 44     |
| 3–24       | Bit Functions for IMR and IFR Registers for Each DSP Subsystem      | 45     |
| 5–1        | Recommended Operating Conditions                                    | 48     |
| 5–2        | Electrical Characteristics                                          | 49     |
| 5–3        | Thermal Resistance Characteristics                                  | 50     |
| 5–4        | Divide-By-2 and Divide-by-4 Clock Options Timing Requirements       | 51     |
| 5–5        | Divide-By-2 and Divide-by-4 Clock Options Switching Characteristics | 51     |
| 5–6        | Multiply-By-N Clock Option Timing Requirements                      | 52     |
| 5–7        | Multiply-By-N Clock Option Switching Characteristics                | 52     |
| 5–8        | Memory Read Timing Requirements                                     | 53     |
| 5–9        | Memory Read Switching Characteristics                               | 53     |
| 5–10       | Memory Write Switching Characteristics                              | 55     |
| 5–11       | Ready Timing Requirements for Externally Generated Wait States      | 56     |
| 5–12       | Parallel I/O Port Read Timing Requirements                          | 58     |
| 5–13       | Parallel I/O Port Read Switching Characteristics                    | 58     |
| 5–14       | Parallel I/O Port Write Switching Characteristics                   | 59     |
| 5-15       | Externally Generated Wait States Timing Requirements                | 60     |
| 5–16       | Reset, BIO, Interrupt, and MP/MC Timing Requirements                | 62     |

#### Tables

| Table |                                                                                  | Page |
|-------|----------------------------------------------------------------------------------|------|
| 5–17  | HOLD and HOLDA Timing Requirements                                               | 64   |
| 5–18  | HOLD and HOLDA Switching Characteristics                                         | 64   |
| 5–19  | External Flag (XF) and TOUT Switching Characteristics                            | 66   |
| 5–20  | General-Purpose I/O Timing Requirements                                          | 67   |
| 5–21  | General-Purpose I/O Switching Characteristics                                    | 67   |
| 5–22  | McBSP Transmit and Receive Timing Requirements                                   | 68   |
| 5–23  | McBSP Transmit and Receive Switching Characteristics                             | 69   |
| 5–24  | McBSP Sample Rate Generator Timing Requirements                                  | 71   |
| 5–25  | McBSP Sample Rate Generator Switching Characteristics                            | 71   |
| 5–26  | McBSP General-Purpose I/O Timing Requirements                                    | 73   |
| 5–27  | McBSP General-Purpose I/O Switching Characteristics                              | 73   |
| 5–28  | McBSP as SPI Master or Slave Timing Requirements (CLKSTP = 10b, CLKXP = 0)       | 74   |
| 5–29  | McBSP as SPI Master or Slave Switching Characteristics (CLKSTP = 10b, CLKXP = 0) | 74   |
| 5–30  | McBSP as SPI Master or Slave Timing Requirements (CLKSTP = 11b, CLKXP = 0)       | 75   |
| 5–31  | McBSP as SPI Master or Slave Switching Characteristics (CLKSTP = 11b, CLKXP = 0) | 75   |
| 5–32  | McBSP as SPI Master or Slave Timing Requirements (CLKSTP = 10b, CLKXP = 1)       | 76   |
| 5–33  | McBSP as SPI Master or Slave Switching Characteristics (CLKSTP = 10b, CLKXP = 1) | 76   |
| 5–34  | McBSP as SPI Master or Slave Timing Requirements (CLKSTP = 11b, CLKXP = 1)       | 77   |
| 5–35  | McBSP as SPI Master or Slave Switching Characteristics (CLKSTP = 11b, CLKXP = 1) | 77   |
| 5–36  | HPI16 Mode Timing Requirements                                                   | 78   |
| 5–37  | HPI16 Mode Switching Characteristics                                             | 79   |

# 1 SM320VC5421-EP Features

- Controlled Baseline

   One Assembly/Test Site, One Fabrication Site
- Extended Temperature Performance of -40°C to 85°C
- Enhanced Diminishing Manufacturing Sources (DMS) Support
- Enhanced Product-Change Notification
- Qualification Pedigree<sup>†</sup>
- 200-MIPS Dual-Core DSP Consisting of Two Independent Subsystems
- Each Core Has an Advanced Multibus Architecture With Three Separate 16-Bit Data Memory Buses and One Program Bus
- 40-Bit Arithmetic Logic Unit (ALU) Including a 40-Bit Barrel-Shifter and Two 40-Bit Accumulators Per Core
- Each Core Has a 17-Bit × 17-Bit Parallel Multiplier Coupled to a 40-Bit Adder for Non-Pipelined Single-Cycle Multiply/ Accumulate (MAC) Operations
- Each Core Has a Compare, Select, and Store Unit (CSSU) for the Add/Compare Selection of the Viterbi Operator
- Each Core Has an Exponent Encoder to Compute an Exponent Value of a 40-Bit Accumulator Value in a Single Cycle
- Each Core Has Two Address Generators With Eight Auxiliary Registers and Two Auxiliary Register Arithmetic Units (ARAUs)
- 16-Bit Data Bus With Data Bus Holder Feature
- 512K-Word × 16-Bit Extended Program Address Space
- Total of 256K-Word × 16-Bit Dual- and Single-Access On-Chip RAM (128K-Word x 16-Bit Two-Way Shared Memory)
- Single-Instruction Repeat and Block-Repeat Operations

- Instructions With 32-Bit-Long Word Operands
- Instructions With Two or Three Operand Reads
- Fast Return From Interrupts
- Arithmetic Instructions With Parallel Store and Parallel Load
- Conditional Store Instructions
- Output Control of CLKOUT
- Output Control of TOUT
- Power Consumption Control With IDLE1, IDLE2, and IDLE3 Instructions
- Dual 1.8-V (Core) and 3.3-V (I/O) Power Supplies for Low-Power, Fast Operations
- 10-ns Single-Cycle Fixed-Point Instruction
- Interprocessor Communication via Two Internal 8-Element FIFOs
- Twelve Channels of Direct Memory Access (DMA) for Data Transfers With No CPU Loading (Six Channels Per Subsystem With External Access)
- Six Multichannel Buffered Serial Ports (McBSPs) With 128-Channel Selection Capability (Three McBSPs per Subsystem)
- 16-Bit Host-Port Interface (HPI) Multiplexed With External Memory Interface Pins
- Software-Programmable Phase-Locked Loop (APLL) Provides Several Clocking Options (Requires External Oscillator)
- On-Chip Scan-Based Emulation Logic, IEEE Standard 1149-1<sup>‡</sup> (JTAG) Boundary-Scan Logic
- Two Software-Programmable Timers (One Per Subsystem)
- Software-Programmable Wait-State Generator (14 Wait States Maximum)
- Provided in 144-pin Low-Profile Quad Flatpack (LQFP) (PGE Suffix) Package



<sup>&</sup>lt;sup>†</sup> Component qualification in accordance with JEDEC and industry standards to ensure reliable operation over an extended temperature range. This includes, but is not limited to, Highly Accelerated Stress Test (HAST) or biased 85/85, temperature cycle, autoclave or unbiased HAST, electromigration, bond intermetallic life, and mold compound life. Such qualification testing should not be viewed as justifying use of this component beyond specified performance and environmental limits.

<sup>&</sup>lt;sup>‡</sup>IEEE Standard 1149.1-1990 Standard-Test-Access Port and Boundary Scan Architecture.

# 2 Introduction

This section describes the main features, gives a brief functional overview of the SM320VC5421-EP, lists the pin assignments, and provides a signal description table. This data manual also provides a detailed description section, electrical specifications, parameter measurement information, and mechanical data about the available packaging.

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

### 2.1 Description

The 320VC5421 fixed-point digital signal processor (DSP) is a dual-core solution running at 200-MIPS performance. The 5421 consists of two DSP subsystems capable of core-to-core communications and a 128K-word zero-wait-state on-chip program memory shared by the two DSP subsystems. Each subsystem consists of one 54x DSP core, 32K-word program/data DARAM, 32K-word data SARAM, 2K-word ROM, three multichannel serial interfaces, xDMA logic, one timer, one APLL, and other miscellaneous circuitry.

The 5421 also contains a host-port interface (HPI) that allows the 5421 to be viewed as a memory-mapped peripheral to a host processor. The 5421 is pin-compatible with the TMS320VC5420.

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

The 5421 is intended as a high-performance, low-cost, high-density DSP for remote data access or voice-over IP subsystems. It is designed to maintain the current modem architecture with minimal hardware and software impacts, thus maximizing reuse of existing modem technologies and development efforts.

# 2.2 Migration From the 5420 to the 5421

Customers migrating from the 5420 to the 5421 need to take into account the following:

- The memory structure of the 5421 has been changed to incorporate 128K x 16-bit words of two-way shared memory.
- The DMA of the 5421 has been enhanced to provide access to external, as well as internal memory.
- The HPI and DMA memory maps have been changed to incorporate the new memory 5421.
- 2K x 16-bit words of ROM have been added to the 5421 for bootloading purposes only.
- The VCO pin on the 5420 has been replaced with the HOLDA pin on the 5421 and the HOLD pin was added to the 5421 at a previously unused pin location.
- The McBSPs have been updated with a new mode that allows 128-channel selection capability.
- McBSP CLKX/R pins can be used as inputs to internal clock rate generator for CLKS-like function without the penalty of extra pins.
- The SELA/B pin on 5421 is changed to type I/O/Z for added functionality.

#### NOTE:

For additional information, see *TMS320VC5420 to TMS320VC5421 DSP Migration* (literature number SPRA621).

TMS320C54x is a trademark of Texas Instruments.

# 2.3 Pin Assignments

Figure 2–1 provides the pin assignments for the 144-pin low-profile quad flatpack (LQFP) package.

### 2.3.1 Pin Assignments for the PGE Package

The SM320VC5421PGE-EP 144-pin low-profile quad flatpack (LQFP) is footprint- and pin-compatible with the 5420. Table 2–1 lists the pin number and associated signal name for both the multiplexed mode and the nonmultiplexed mode.



NOTES: A. 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.

B. Pin configuration shown for nonmultiplexed mode only. See the pin assignments table for the 320VC5421PGE for multiplexed functions of specific pins and for specific pin numbers.

#### Figure 2–1. 144-Pin Low-Profile Flatpack Pin Assignments (PGE – Top View)

| SIGNAL NAME<br>(NONMULTIPLEXED) | SIGNAL NAME<br>(MULTIPLEXED) | PIN<br>NO. | SIGNAL NAME<br>(NONMULTIPLEXED) | SIGNAL NAME<br>(MULTIPLEXED) | PIN<br>NO. |
|---------------------------------|------------------------------|------------|---------------------------------|------------------------------|------------|
| PPD7                            | HD7                          | 1          | PPA8                            | HA8                          | 2          |
| PPA0                            | A_HINT/HA0                   | 3          | DVDD                            |                              | 4          |
| PPA9                            | HA9                          | 5          | PPD1                            | HD1                          | 6          |
| A_INT1                          |                              | 7          | A_NMI                           |                              | 8          |
| IOSTRB                          | A_GPIO3/A_TOUT               | 9          | A_GPIO2/BIO                     |                              | 10         |
| A_GPIO1                         |                              | 11         | A_RS                            |                              | 12         |
| A_GPIO0                         | A_ROMEN                      | 13         | V <sub>SS</sub>                 |                              | 14         |
| V <sub>SS</sub>                 |                              | 15         | CV <sub>DD</sub>                |                              | 16         |
| A_BFSR1                         |                              | 17         | A_BDR1                          |                              | 18         |
| A_BCLKR1                        |                              | 19         | A_BFSX1                         |                              | 20         |
| CV <sub>DD</sub>                |                              | 21         | V <sub>SS</sub>                 |                              | 22         |
| A_BDX1                          |                              | 23         | A_BCLKX1                        |                              | 24         |
| A_XF                            |                              | 25         | A_CLKOUT                        |                              | 26         |
| HOLDA                           |                              | 27         | тск                             |                              | 28         |
| TMS                             |                              | 29         | TDI                             |                              | 30         |
| TRST                            |                              | 31         | EMU1/OFF                        |                              | 32         |
| DV <sub>DD</sub>                |                              | 33         | A_INT0                          |                              | 34         |
| EMU0                            |                              | 35         | TDO                             |                              | 36         |
| V <sub>SS</sub>                 |                              | 37         | PPD15                           | HD15                         | 38         |
| PPD14                           | HD14                         | 39         | V <sub>SS</sub>                 |                              | 40         |
| PPD13                           | HD13                         | 41         | PPD12                           | HD12                         | 42         |
| A_BFSR0                         |                              | 43         | A_BDR0                          |                              | 44         |
| A_BCLKR0                        |                              | 45         | A_BFSX0                         |                              | 46         |
| V <sub>SS</sub>                 |                              | 47         | CV <sub>DD</sub>                |                              | 48         |
| A_BDX0                          |                              | 49         | A_BCLKX0                        |                              | 50         |
| MSTRB                           | HCS                          | 51         | DS                              | HDS2                         | 52         |
| PS                              | HDS1                         | 53         | B_BCLKX0                        |                              | 54         |
| B_BDX0                          |                              | 55         | DV <sub>DD</sub>                |                              | 56         |
| V <sub>SS</sub>                 |                              | 57         | B_BFSX0                         |                              | 58         |
| B_BCLKR0                        |                              | 59         | B_BDR0                          |                              | 60         |
| CV <sub>DD</sub>                |                              | 61         | V <sub>SS</sub>                 |                              | 62         |
| B_BFSR0                         |                              | 63         | R/W                             | HR/W                         | 64         |
| PPA2                            | HCNTL1/HA2                   | 65         | PPA3                            | HCNTL0/HA3                   | 66         |
| SELA/B                          | PPA18                        | 67         | PPD8                            | HD8                          | 68         |
| PPD9                            | HD9                          | 69         | PPD10                           | HD10                         | 70         |
| PPD11                           | HD11                         | 71         | V <sub>SS</sub>                 |                              | 72         |
| PPA10                           | HA10                         | 73         | PPA11                           | HA11                         | 74         |
| DV <sub>DD</sub>                |                              | 75         | V <sub>SS</sub>                 |                              | 76         |
| PPA12                           | HA12                         | 77         | PPA13                           | HA13                         | 78         |
| HPIRS                           |                              | 79         | HMODE                           |                              | 80         |
| B_CLKOUT                        |                              | 81         | B_XF                            |                              | 82         |
| B_RS                            |                              | 83         | XIO                             |                              | 84         |
| TEST                            |                              | 85         | V <sub>SS</sub>                 |                              | 86         |

### Table 2–1. Pin Assignments for the 144-Pin Low-Profile Quad Flatpack

| SIGNAL NAME<br>(NONMULTIPLEXED) | SIGNAL NAME<br>(MULTIPLEXED) | PIN<br>NO. | SIGNAL NAME<br>(NONMULTIPLEXED) | SIGNAL NAME<br>(MULTIPLEXED) | PIN<br>NO. |
|---------------------------------|------------------------------|------------|---------------------------------|------------------------------|------------|
| CV <sub>DD</sub>                |                              | 87         | B_BCLKX1                        |                              | 88         |
| B_BDX1                          |                              | 89         | V <sub>SS</sub>                 |                              | 90         |
| B_BFSX1                         |                              | 91         | B_BCLKR1                        |                              | 92         |
| V <sub>SS</sub>                 |                              | 93         | CV <sub>DD</sub>                |                              | 94         |
| B_BDR1                          |                              | 95         | B_BFSR1                         |                              | 96         |
| B_GPIO0                         | B_ROMEN                      | 97         | B_GPIO1                         |                              | 98         |
| B_GPIO2/BIO                     |                              | 99         | IS                              | B_GPIO3/B_TOUT               | 100        |
| B_NMI                           |                              | 101        | B_INT1                          |                              | 102        |
| B_INT0                          |                              | 103        | PPA17                           | HA17                         | 104        |
| PPA16                           | HA16                         | 105        | V <sub>SS</sub>                 |                              | 106        |
| PPA15                           | HA15                         | 107        | PPA14                           | HA14                         | 108        |
| PPA7                            | HA7                          | 109        | PPA6                            | HA6                          | 110        |
| PPA4                            | HAS/HA4                      | 111        | DVDD                            |                              | 112        |
| PPA5                            | HA5                          | 113        | PPA1                            | B_HINT/HA1                   | 114        |
| PPD3                            | HD3                          | 115        | PPD2                            | HD2                          | 116        |
| B_BFSR2                         |                              | 117        | B_BDR2                          |                              | 118        |
| VSS                             |                              | 119        | CVDD                            |                              | 120        |
| B_BCLKR2                        |                              | 121        | B_BFSX2                         |                              | 122        |
| B_BDX2                          |                              | 123        | B_BCLKX2                        |                              | 124        |
| VSS                             |                              | 125        | AV <sub>DD</sub>                |                              | 126        |
| V <sub>SSA</sub>                |                              | 127        | HOLD                            |                              | 128        |
| CLKIN                           |                              | 129        | DV <sub>DD</sub>                |                              | 130        |
| READY                           | HRDY                         | 131        | A_BCLKX2                        |                              | 132        |
| CVDD                            |                              | 133        | V <sub>SS</sub>                 |                              | 134        |
| A_BCLKR2                        |                              | 135        | A_BDR2                          |                              | 136        |
| A_BFSR2                         |                              | 137        | A_BDX2                          |                              | 138        |
| A_BFSX2                         |                              | 139        | PPD6                            | HD6                          | 140        |
| PPD4                            | HD4                          | 141        | PPD5                            | HD5                          | 142        |
| PPD0                            | HD0                          | 143        | V <sub>SS</sub>                 |                              | 144        |

# Table 2–1. Pin Assignments for the 144-Pin Low-Profile Quad Flatpack (Continued)

# 2.4 Signal Descriptions

Table 2–2 lists each signal, function, and operating mode(s) grouped by function. See pin assignments section for exact pin locations based on package type.

| PIN NAME    | TYPE <sup>†</sup> | DESCRIPTION                                                                                                                                                                                                         |
|-------------|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|             |                   | DATA SIGNALS                                                                                                                                                                                                        |
| PPA18 (MSB) |                   | Parallel port address bus. The DSP can access the external memory locations by way of the external                                                                                                                  |
| PPA17       |                   | memory interface using PPA[18:0] in external memory interface (EMIF) mode when the XIO pin is logic                                                                                                                 |
| PPA16       |                   | high. PPA18 is a secondary output function of the SELA/B pin.                                                                                                                                                       |
| PPA15       |                   | The DDM/47 QLains are also as liteland with the UDList starters to UDLands (VIO air is low), the estimate                                                                                                           |
| PPA14       |                   | The PPA[17:0] pins are also multiplexed with the HPI interface. In HPI mode (XIO pin is low), the external address pins PPA[17:0] are used by a host processor for access to the memory map by way of the on-chip   |
| PPA13       |                   | HPI. Refer to the Host-Port Interface (HPI) Signals section of this table for details on the secondary                                                                                                              |
| PPA12       |                   | functions of these pins.                                                                                                                                                                                            |
| PPA11       |                   | These pins are placed into the high-impedance state when OFF is low.                                                                                                                                                |
| PPA10       |                   |                                                                                                                                                                                                                     |
| PPA9        | I/O/Z             |                                                                                                                                                                                                                     |
| PPA8        |                   |                                                                                                                                                                                                                     |
| PPA7        |                   |                                                                                                                                                                                                                     |
| PPA6        |                   |                                                                                                                                                                                                                     |
| PPA5        |                   |                                                                                                                                                                                                                     |
| PPA4‡§      |                   |                                                                                                                                                                                                                     |
| PPA3        |                   |                                                                                                                                                                                                                     |
| PPA2        |                   |                                                                                                                                                                                                                     |
| PPA1        |                   |                                                                                                                                                                                                                     |
| PPA0 (LSB)  |                   |                                                                                                                                                                                                                     |
| PPD15 (MSB) |                   | Parallel port data bus. The DSP uses this bidirectional data bus to access external memory when the                                                                                                                 |
| PPD14       |                   | device is in external memory interface (EMIF) mode (the XIO pin is logic high).                                                                                                                                     |
| PPD13       |                   |                                                                                                                                                                                                                     |
| PPD12       |                   | This data bus is also multiplexed with the 16-bit HPI data bus. When in HPI mode, the bus is used to transfer data between the host processor and internal DSP memory via the HPI. Refer to the HPI section of this |
| PPD11       |                   | table for details on the secondary functions of these pins.                                                                                                                                                         |
| PPD10       |                   |                                                                                                                                                                                                                     |
| PPD9        |                   | The data bus includes bus holders to reduce power dissipation caused by floating, unused pins. The bus                                                                                                              |
| PPD8        | I/O/Z¶            | holders also eliminate the need for external pullup resistors on unused pins. When the data bus is not being                                                                                                        |
| PPD7        |                   | driven by the 5421, the bus holders keep data pins at the last driven logic level. The data bus keepers are disabled at reset and can be enabled/disabled via the BH bit of the BSCR register.                      |
| PPD6        |                   |                                                                                                                                                                                                                     |
| PPD5        |                   | These pins are placed into high-impedance state when OFF is low.                                                                                                                                                    |
| PPD4        |                   | These pine are placed into high impedance state when of this low.                                                                                                                                                   |
| PPD3        |                   |                                                                                                                                                                                                                     |
| PPD2        |                   |                                                                                                                                                                                                                     |
| PPD1        |                   |                                                                                                                                                                                                                     |
| PPD0 (LSB)  |                   | 7 Ulah Impedance                                                                                                                                                                                                    |

#### Table 2–2. Signal Descriptions

 $^{\dagger}$ I = Input, O = Output, S = Supply, Z = High Impedance

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

§ These pins are Schmitt triggered inputs.

This pin has an internal bus holder controlled by way of the BSCR register in 54x cLEAD core of DSP subsystem A .

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

| PIN NAME                                           | TYPE <sup>†</sup> | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|----------------------------------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| DATA SIGNALS (CONTINUED)                           |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| A_INT0<br>B_INT0<br>A_INT1<br>B_INT1<br>\$         | I                 | External user interrupts. $\overline{A_{INT0}}$ - $\overline{B_{INT0}}$ are prioritized and are maskable by the interrupt mask registe (IMR) and the interrupt mode bit. $\overline{A_{INT1}}$ - $\overline{B_{INT1}}$ can be polled and reset by way of the interrupt flag register (IFR).                                                                                                                                                                                                                                                                                 |                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|                                                    |                   | INITIALIZATION,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | INTERRUPT, AND RESET OPERATIONS                                                                                                                                                                                                                                                                                                        |  |  |  |
| A_NMI\$<br>B_NMI\$                                 | I                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | pt. $\overline{\rm NMI}$ is an external interrupt that cannot be masked by way of the INTM or the IMR. ed, the processor traps to the appropriate vector location.                                                                                                                                                                     |  |  |  |
| A_RS§<br>B_RS§                                     | I                 | of the CPU and perip                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | e digital signal processor (DSP) to terminate execution and causes a reinitialization observation. When RS is brought to a high level, execution begins at location 0FF80h of S affects various registers and status bits.                                                                                                             |  |  |  |
| XIO                                                | I                 | <ul> <li>The XIO pin is used to configure the parallel port as a host-port interface (HPI mode when XIO pin is low), or as an asynchronous memory interface (EMIF mode when XIO pin is high).</li> <li>NOTE: Because the XIO signal is asynchronous, caution must be taken when changing the state of the XIO pin to ensure the current cycle is properly ended.</li> <li>At device reset, the XIO pin level determines the initialization value of the MP/MC bit (a bit in the processor mode status (PMST) register). Refer to the memory section for details.</li> </ul> |                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| GENERAL-PURPOSE I/O PINS                           |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| A_XF<br>B_XF                                       | O/Z               | External flag output<br>B_XF are placed into                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | (latched software-programmable output-only signal). Bit-addressable. A_XF and the high-impedance state when OFF is low.                                                                                                                                                                                                                |  |  |  |
| A_GPIO0<br>B_GPIO0                                 | 1/0/Z             | A_ROMEN I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | General-purpose I/O pins. The secondary function of these pins. In XIO mode, the ROM enable (ROMEN) pins are used to enable the applicable on-chip ROM after reset.                                                                                                                                                                    |  |  |  |
| A_GPIO1<br>B_GPIO1                                 | I/O/Z             | General-purpose I/O pins (software-programmable I/O signal). Values can be latched (output) by writ-<br>ing into the GPIO register. The states of GPIO pins (inputs) can be read by reading the GPIO register.<br>The GPIO direction is also programmable by way of the DIRn field in the GPIO register.                                                                                                                                                                                                                                                                    |                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| A_GPIO2/ <mark>BIO</mark><br>B_GPIO2/BIO           | I/O/Z             | General-purpose I/O. These pins can be configured like GPIO0–GPIO1; however, as an input, the pins operate as the traditional branch control bit (BIO). If application code does not perform BIO-conditional instructions, these pins operate as general inputs.                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                                                                                                                                                                        |  |  |  |
|                                                    |                   | PRIMARY                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                        |  |  |  |
| A_GPIO3 <i>(A_TOUT)</i><br>B_GPIO3 <i>(B_TOUT)</i> | 1/0/Z             | IOSTRB<br>O<br>IS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | When the device is in HPI mode and HMODE = 0 (multiplexed), these pins act according to the general-purpose I/O control register. TOUT bit must be set to "1" to drive the timer output on the pin. IF TOUT = 0, then these pins are general-purpose I/Os. In EMIF mode (XIO = 1), these signals are active during I/O space accesses. |  |  |  |

#### Table 2–2. Signal Descriptions (Continued)

† I = Input, O = Output, S = Supply, Z = High Impedance
‡ This pin has an internal pullup resistor.
§ These pins are Schmitt triggered inputs.
¶ This pin has an internal bus holder controlled by way of the BSCR register in 54x cLEAD core of DSP subsystem A .

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

| PIN NAME             | TYPE <sup>†</sup> | DESCRIPTION                                                                                                                                                                                                                                                                                                        |  |  |  |
|----------------------|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                      | -                 | MEMORY CONTROL SIGNALS                                                                                                                                                                                                                                                                                             |  |  |  |
|                      |                   | Program space select signal. The $\overline{\text{PS}}$ signal is asserted during external program space accesses. This pin is placed into the high-impedance state when $\overline{\text{OFF}}$ is low.                                                                                                           |  |  |  |
|                      |                   | This pin is also multiplexed with the HPI, and functions as the $\overline{\text{HDS1}}$ data strobe input signal in HPI mode.<br>Refer to the HPI section of this table for details on the secondary function of this pin.                                                                                        |  |  |  |
| PS <sup>‡</sup> §    |                   | Data space select signal. The $\overline{\text{DS}}$ signal is asserted during external data space accesses. This pin is placed into the high-impedance state when $\overline{\text{OFF}}$ is low.                                                                                                                 |  |  |  |
| DS‡§<br>īs           | O/Z               | This pin is also multiplexed with the HPI, and functions as the $\overline{HDS2}$ data strobe input signal in HPI mode.<br>Refer to the HPI section of this table for details on the secondary function of this pin.                                                                                               |  |  |  |
|                      |                   | I/O space select signal. The IS signal is asserted during external I/O space accesses. This pin is placed into the high-impedance state when OFF is low.                                                                                                                                                           |  |  |  |
|                      |                   | This pin is also multiplexed with the general-purpose I/O feature, and functions as the B_GPIO3 (B_TOUT) input/output signal in HPI mode. Refer to the General-Purpose I/O section of this table for details on the secondary function of this pin.                                                                |  |  |  |
| MSTRB <sup>‡</sup> § | O/Z               | Program and data memory strobe (active in EMIF mode). This pin is placed into the high-impedance state when $\overline{OFF}$ is low.                                                                                                                                                                               |  |  |  |
| READY                | I                 | Data-ready input signal. READY indicates that the external device is prepared for a bus transaction to be completed. If the device is not ready (READY = 0), the processor waits one cycle and checks READY again. The processor performs the READY detection if at least two software wait states are programmed. |  |  |  |
|                      |                   | This pin is also multiplexed with the HPI, and functions as the host-port data ready (output) in HPI mode. Refer to the HPI section of this table for details on the secondary function of this pin.                                                                                                               |  |  |  |
|                      |                   | Read/write output signal. R/ $\overline{W}$ indicates transfer direction during communication to an external device. R/ $\overline{W}$ is normally in the read mode (high), unless it is asserted low when the DSP performs a write operation.                                                                     |  |  |  |
| R/W                  | O/Z               | This pin is also multiplexed with the HPI, and functions as the host-port read/write input in HPI mode. Refer to the HPI section of this table for details on the secondary function of this pin.                                                                                                                  |  |  |  |
|                      |                   | This pin is placed into the high-impedance state when $\overline{OFF}$ is low.                                                                                                                                                                                                                                     |  |  |  |
|                      |                   | I/O space memory strobe. External I/O space is accessible by the CPU and not the direct memory access (DMA) controller. The DMA has its own dedicated I/O space that is not accessible by the CPU.                                                                                                                 |  |  |  |
| IOSTRB               | O/Z               | This pin is also multiplexed with the general-purpose I/O feature, and functions as the A_GPIO3 (A_TOUT) signal in HPI mode. Refer to the General Purpose I/O section of this table for details on the secondary function of this pin.                                                                             |  |  |  |
|                      |                   | This pin is placed into the high-impedance state when $\overline{OFF}$ is low.                                                                                                                                                                                                                                     |  |  |  |

#### Table 2–2. Signal Descriptions (Continued)

<sup>†</sup> I = Input, O = Output, S = Supply, Z = High Impedance <sup>‡</sup> This pin has an internal pullup resistor.

§ These pins are Schmitt triggered inputs.

This pin has an internal bus holder controlled by way of the BSCR register in 54x cLEAD core of DSP subsystem A . "This pin is used by Texas Instruments for device testing and should be left unconnected.

| PIN NAME                                                                                                                            | TYPE <sup>†</sup>                  | DESCRIPTION                                                                      |                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                   |  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|----------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                                                                                                                                     | MEMORY CONTROL SIGNALS (CONTINUED) |                                                                                  |                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                   |  |  |  |
|                                                                                                                                     |                                    | PRIMAR                                                                           | Y                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                   |  |  |  |
|                                                                                                                                     |                                    |                                                                                  |                                                                                                                                                                                                                                                                                                                                                          | For HPI access (XIO=0), SELA/B is an input.                                                                                                                                                                                                       |  |  |  |
|                                                                                                                                     |                                    |                                                                                  |                                                                                                                                                                                                                                                                                                                                                          | See Table 3–3 for a truth table of SELA/B, HMODE, and XIO pins and functionality.                                                                                                                                                                 |  |  |  |
| PPA18                                                                                                                               | O/Z                                | SELA/B                                                                           | I                                                                                                                                                                                                                                                                                                                                                        | For external memory accesses (XIO=1), SELA/B is multiplexed as output PPA18.<br>See the PPA signal descriptions. These pins are placed into the high-impedance state when OFF is low.                                                             |  |  |  |
| HOLD <sup>‡</sup>                                                                                                                   | I                                  |                                                                                  |                                                                                                                                                                                                                                                                                                                                                          | ted to request control of the address, data, and control lines. When acknowledged,<br>e high-impedance state.                                                                                                                                     |  |  |  |
| HOLDA                                                                                                                               | O/Z                                | the address,                                                                     | data <u>, ar</u>                                                                                                                                                                                                                                                                                                                                         | OLDA indicates to the external circuitry that the processor is in a hold state and that<br>ad control lines are in the high-impedance state, allowing them to be available to the<br>DDA also goes into the high-impedance state when OFF is low. |  |  |  |
|                                                                                                                                     | L                                  |                                                                                  |                                                                                                                                                                                                                                                                                                                                                          | CLOCKING SIGNALS                                                                                                                                                                                                                                  |  |  |  |
| A_CLKOUT<br>B_CLKOUT                                                                                                                | O/Z                                | cycle is bound                                                                   | Master clock output signal. CLKOUT cycles at the machine-cycle rate of the CPU. The internal machine cycle is bounded by the falling edges of this signal. The CLKOUT pin can be turned off by writing <u>a "1"</u> to the CLKOFF bit of the PMST register. CLKOUT goes into the high-impedance state when EMU1/OFF is low.                              |                                                                                                                                                                                                                                                   |  |  |  |
| CLKIN§                                                                                                                              | I                                  | Input clock to the device. CLKIN connects to an oscillator circuit/device (PLL). |                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                   |  |  |  |
|                                                                                                                                     | ľ                                  | ULTICHANNI                                                                       | EL BUF                                                                                                                                                                                                                                                                                                                                                   | FERED SERIAL PORT 0, 1, AND 2 SIGNALS                                                                                                                                                                                                             |  |  |  |
| A_BCLKR0 <sup>‡</sup> §<br>B_BCLKR0 <sup>‡</sup> §<br>A_BCLKR1 <sup>‡</sup> §<br>B_BCLKR1 <sup>‡</sup> §                            | I/O/Z                              | external clock                                                                   | Receive clocks. BCLKR serves as the serial shift clock for the buffered serial-port receiver. Input from an external clock source for clocking data into the McBSP. When not being used as a clock, these pins can be used as general-purpose I/O by setting RIOEN = 1.                                                                                  |                                                                                                                                                                                                                                                   |  |  |  |
| A_BCLKR2‡§<br>B_BCLKR2 <sup>‡§</sup>                                                                                                |                                    |                                                                                  |                                                                                                                                                                                                                                                                                                                                                          | gured as an output by the way of the CLKRM bit in the PCR register.<br>ad into the high-impedance state when $\overline{OFF}$ is low.                                                                                                             |  |  |  |
| A_BCLKX0 <sup>‡</sup> §<br>B_BCLKX0 <sup>‡</sup> §<br>A_BCLKX1 <sup>‡</sup> §<br>B_BCLKX1 <sup>‡</sup> §<br>A_BCLKX2 <sup>‡</sup> § | I/O/Z                              | as an input by the IN1 bit in t                                                  | Transmit clocks. Clock signal used to clock data from the transmit register. This pin can also be configured as an input by setting the CLKXM = 0 in the PCR register. BCLKX can be sampled as an input by way of the IN1 bit in the SPC register. When not being used as a clock, these pins can be used as general-purpose $I/O$ by setting XIOEN = 1. |                                                                                                                                                                                                                                                   |  |  |  |
| B_BCLKX2‡§                                                                                                                          |                                    | These pins a                                                                     | re place                                                                                                                                                                                                                                                                                                                                                 | ed into the high-impedance state when $\overline{OFF}$ is low.                                                                                                                                                                                    |  |  |  |
| A_BDR0<br>B_BDR0<br>A_BDR1<br>B_BDR1<br>A_BDR2<br>B_BDR2                                                                            | I                                  |                                                                                  | Buffered serial data receive (input) pin. When not being used as data-receive pins, these pins can be used as general-purpose I/O by setting RIOEN = 1.                                                                                                                                                                                                  |                                                                                                                                                                                                                                                   |  |  |  |

† I = Input, O = Output, S = Supply, Z = High Impedance
‡ This pin has an internal pullup resistor.
§ These pins are Schmitt triggered inputs.
¶ This pin has an internal bus holder controlled by way of the BSCR register in 54x cLEAD core of DSP subsystem A .
# This pin is used by Texas Instruments for device testing and should be left unconnected.

| PIN NAME                                                       | TYPE <sup>†</sup> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |        | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
|----------------------------------------------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
|                                                                | MULTIC            | HANNEL BUF                                                                                                                                                                                                                                                                                                                                                                                                                                                      | FERED  | SERIAL PORT 0, 1, AND 2 SIGNALS (CONTINUED)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |
| A_BDX0<br>B_BDX0<br>A_BDX1<br>B_BDX1<br>A_BDX2<br>B_BDX2       | O/Z               | Buffered serial-port transmit (output) pin. When not being used as data-transmit pins, these pins can be used as general-purpose I/O by setting XIOEN = 1. These pins are placed into the high-impedance state when OFF is low.                                                                                                                                                                                                                                 |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| A_BFSR0<br>B_BFSR0<br>A_BFSR1<br>B_BFSR1<br>A_BFSR2<br>B_BFSR2 | I/O/Z             | Frame synchronization pin for buffered serial-port input data. The BFSR pulse initiates the receive-data process over the BDR pin. When not being used as data-receive synchronization pins, these pins can be used as general-purpose I/O by setting RIOEN = 1. These pins are placed into the high-impedance state when OFF is low.                                                                                                                           |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| A_BFSX0<br>B_BFSX0<br>A_BFSX1<br>B_BFSX1<br>A_BFSX2<br>B_BFSX2 | I/O/Z             | Buffered serial-port frame synchronization pin for transmitting data. The BFSX pulse initiates the transmit-data process over the BDX pin. If RS is asserted when BFSX is configured as output, then BFSX is turned into input mode by the reset operation. When not being used as data-transmit synchronization pins, these pins can be used as general-purpose I/O by setting XIOEN = 1. These pins are placed into the high-impedance state when OFF is low. |        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
|                                                                |                   | H                                                                                                                                                                                                                                                                                                                                                                                                                                                               | OST-PC | RT INTERFACE (HPI) SIGNALS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|                                                                |                   | PRIMAR                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RY     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| HA[17:0]                                                       | I                 | PPA[17:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                       | O/Z    | These pins are multiplexed with the external interface pins and are used by the HPI when the subsystem is in HPI mode (XIO = 0, MP/MC = 0).<br>See the PPA signal descriptions. These pins are placed into the high-impedance state when OFF is low.<br>NOTE: HA4 has a pullup and a Schmitt trigger buffer.                                                                                                                                                                                                                                                                                                                                                    |  |  |
|                                                                |                   | PRIMAR                                                                                                                                                                                                                                                                                                                                                                                                                                                          | RY     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |  |
| HD[15:0]                                                       | I/O/Z             | PPD[15:0]                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1/0/Z  | Parallel bidirectional data bus. These pins are multiplexed with the external interface pins and are used as an HPI interface when XIO = 0.<br>These pins include bus holders to reduce power dissipation caused by floating, unused inputs. The bus holders also eliminate the need for external pullup resistors on unused inputs. In multiplexed address/data mode (HMODE = 0), when the data bus is not being driven by the 5421, the bus holders keep the multiplexed address inputs on these pins at the last logic level driven by the host. The data bus holders are disabled at reset and can be enabled/disabled via the BH bit of the BSCR register. |  |  |
|                                                                |                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |        | See the PPD signal descriptions. These pins are placed into the high-impedance state when OFF is low.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |  |  |

#### Table 2–2. Signal Descriptions (Continued)

<sup>†</sup>I = Input, O = Output, S = Supply, Z = High Impedance <sup>‡</sup>This pin has an internal pullup resistor. § These pins are Schmitt triggered inputs.

This pin has an internal bus holder controlled by way of the BSCR register in 54x cLEAD core of DSP subsystem A.

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

| PIN NAME            | TYPE <sup>†</sup>                             | DESCRIPTION       |           |                                                                                                                                                                                                                                                                                                             |  |  |  |
|---------------------|-----------------------------------------------|-------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|                     | HOST-PORT INTERFACE (HPI) SIGNALS (CONTINUED) |                   |           |                                                                                                                                                                                                                                                                                                             |  |  |  |
| HCNTL0              | 1                                             | PPA3              | O/Z       | HPI control inputs. Use PPA3 and PPA2 for the HCNTL0 and HCNTL1 values during the HPI HPIC, HPIA, and HPID reads/writes. Only used in multiplexed address/data mode (HMODE = 0).                                                                                                                            |  |  |  |
| HCNTL1              |                                               | PPA2              | 0,2       | These pins are shared with the external memory interface and are only used by the HPI when the interface is in HPI mode (XIO pin is low). These pins are placed into the high-impedance state when OFF is low.                                                                                              |  |  |  |
| HAS <sup>‡</sup> §  |                                               | PPA4‡§            | O/Z       | Address strobe input. Hosts with multiplexed address and data pins require HAS to latch the address in the HPIA register. This signal is only used in HPI multiplexed address/data mode (HMODE pin is low).                                                                                                 |  |  |  |
| HAS+3               | -                                             | PPA4+3            | 0/2       | This pin is shared with the external memory interface and is only used by the HPI when the interface is in HPI mode (XIO pin is low). This pin is placed into the high-impedance state when OFF is low.                                                                                                     |  |  |  |
|                     |                                               |                   |           | HPI chip-select signal. This signal must be active during HPI transfers, and can remain active between concurrent transfers.                                                                                                                                                                                |  |  |  |
| HCS‡§               | I                                             | MSTRB‡§           | O/Z       | This pin is shared with the external memory interface and is only used by the HPI when the interface is in HPI mode (XIO pin is low). This pin is placed into the high-impedance state when OFF is low.                                                                                                     |  |  |  |
| HDS1 <sup>‡§</sup>  |                                               | <u>₽S</u> ‡§      |           | HPI data strobes. HDS1 and HDS2 are driven by the host read and write strobes to control HPI transfers.                                                                                                                                                                                                     |  |  |  |
| HDS2 <sup>‡</sup> § | I                                             | DS <sup>‡</sup> § | O/Z       | These pins are shared with the external memory interface and are only used by the HPI when the interface is in HPI mode (XIO pin is low).                                                                                                                                                                   |  |  |  |
|                     |                                               |                   |           | These pins are placed into the high-impedance state when $\overline{OFF}$ is low.                                                                                                                                                                                                                           |  |  |  |
|                     |                                               |                   | O/Z       | HPI read/write signal. This signal is used by the host to control the direction of an HPI transfer.                                                                                                                                                                                                         |  |  |  |
| HR/W                | I                                             | R/W               |           | This pin is shared with the external memory interface and is only used by the HPI when the interface is in HPI mode (XIO pin is low).                                                                                                                                                                       |  |  |  |
|                     |                                               |                   |           | This pin is placed into the high-impedance state when $\overline{OFF}$ is low.                                                                                                                                                                                                                              |  |  |  |
|                     |                                               |                   | ADY I     | HPI data-ready output. The ready output informs the host when the HPI is ready for the next transfer.                                                                                                                                                                                                       |  |  |  |
| HRDY                | O/Z READY                                     | READY             |           | This pin is shared with the external memory interface and is only used by the HPI when the interface is in HPI mode (XIO pin is low). HRDY is placed into the high-impedance state when OFF is low.                                                                                                         |  |  |  |
|                     |                                               | PRIMARY           |           |                                                                                                                                                                                                                                                                                                             |  |  |  |
| A_HINT<br>B_HINT    | O/Z                                           | PPA0<br>PPA1      | O/Z       | Host interrupt pin. HPI can interrupt the host by asserting this low. The host can clear this interrupt by writing a "1" to the HINT bit of the HPIC register. Only supported in HPI multiplexed address/data mode (HMODE pin is low). These pins are placed into the high-impedance state when OFF is low. |  |  |  |
| HPIRS§              | I                                             | Host-port inte    | erface (I | HPI) reset pin. This signal resets the host port interface and both subsystems.                                                                                                                                                                                                                             |  |  |  |

| Table 2–2. | <b>Signal Descriptions</b> | (Continued) |
|------------|----------------------------|-------------|
|------------|----------------------------|-------------|

† I = Input, O = Output, S = Supply, Z = High Impedance
‡ This pin has an internal pullup resistor.
§ These pins are Schmitt triggered inputs.
¶ This pin has an internal bus holder controlled by way of the BSCR register in 54x cLEAD core of DSP subsystem A .

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

| PIN NAME         | TYPE <sup>†</sup> | DESCRIPTION                                                                                                                                                                                                                                                                                                                                               |
|------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                  | -                 | HOST-PORT INTERFACE (HPI) SIGNALS (CONTINUED)                                                                                                                                                                                                                                                                                                             |
|                  |                   | Host mode select. When this pin is low, it selects the HPI multiplexed address/data mode. The multiplexed address/data mode allows hosts with multiplexed address/data lines access to the HPI registers HPIC, HPIA, and HPID. Host-to-DSP and DSP-to-host interrupts are supported in this mode.                                                         |
| HMODE            | I                 | When HMODE is high, it selects the HPI nonmultiplexed mode. HPI nonmultiplexed mode allows hosts with separate address/data buses to access the HPI address range by way of the 18-bit address bus and the HPI data (HPID) register via the 16-bit data bus. Host-to-DSP and DSP-to-host interrupts are not supported in this mode.                       |
|                  |                   | SUPPLY PINS                                                                                                                                                                                                                                                                                                                                               |
| AV <sub>DD</sub> | S                 | Dedicated power supply that powers the PLL. $AV_{DD}$ = 1.8 V. $AV_{DD}$ can be connected to $CV_{DD}$ .                                                                                                                                                                                                                                                  |
| CVDD             | S                 | Dedicated "clean" power supply that powers the core CPUs. $CV_{DD} = 1.8 V$                                                                                                                                                                                                                                                                               |
| DV <sub>DD</sub> | S                 | Dedicated "dirty" power supply that powers the I/O pins. $DV_{DD}$ = 3.3 V                                                                                                                                                                                                                                                                                |
| V <sub>SS</sub>  | S                 | Digital ground. Dedicated ground plane for the device.                                                                                                                                                                                                                                                                                                    |
| VSSA             | S                 | Analog ground. Dedicated ground for the PLL. $V_{\mbox{SSA}}$ can be connected to $V_{\mbox{SS}}$ if digital and analog grounds are not separated.                                                                                                                                                                                                        |
|                  |                   | TEST PIN                                                                                                                                                                                                                                                                                                                                                  |
| TEST#            |                   | No connection                                                                                                                                                                                                                                                                                                                                             |
|                  |                   | EMULATION/TEST PINS                                                                                                                                                                                                                                                                                                                                       |
| тсꇧ              | I                 | Standard test clock. This is normally a free-running clock signal with a 50% duty cycle. Changes on the test access port (TAP) of input signals TMS and TDI are clocked into the TAP controller, instruction register, or selected test-data register on the rising edge of TCK. Changes at the TAP output signal (TDO) occur on the falling edge of TCK. |
| ты‡              | I                 | Test data input. Pin with an internal pullup device. TDI is clocked into the selected register (instruction or data) on a rising edge of TCK.                                                                                                                                                                                                             |
| TDO              | O/Z               | Test data output. The contents of the selected register is shifted out of TDO on the falling edge of TCK. TDO is in high-impedance state except when the scanning of data is in progress. These pins are placed into high-impedance state when OFF is low.                                                                                                |
| тмs‡             | I                 | Test mode select. Pin with internal pullup device. This serial control input is clocked into the TAP controller on the rising edge of TCK.                                                                                                                                                                                                                |
| TRSTII           | I                 | Test reset. When high, TRST gives the scan system control of the operations of the device. If TRST is driven low, the device operates in its functional mode and the IEEE 1149.1 signals are ignored. Pin with internal pulldown device.                                                                                                                  |

#### Table 2–2. Signal Descriptions (Continued)

<sup>†</sup> I = Input, O = Output, S = Supply, Z = High Impedance <sup>‡</sup> This pin has an internal pullup resistor.

§ These pins are Schmitt triggered inputs.

This pin has an internal bus holder controlled by way of the BSCR register in 54x cLEAD core of DSP subsystem A .

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

| PIN NAME                        | TYPE <sup>†</sup> | DESCRIPTION                                                                                                                                                                                                                                                                                                                                                                             |  |  |  |  |
|---------------------------------|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| EMULATION/TEST PINS (CONTINUED) |                   |                                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |
| EMU0                            | I/O/Z             | Emulator interrupt 0 pin. When TRST is driven low, EMU0 must be high for the activation of the EMU1/OFF condition. When TRST is driven high, EMU0 is used as an interrupt to or from the emulator system and is defined as I/O.                                                                                                                                                         |  |  |  |  |
|                                 |                   | Emulator interrupt 1 pin. When $\overline{\text{TRST}}$ is driven high, EMU1/ $\overline{\text{OFF}}$ is used as an interrupt to or from the emulator system and is defined as I/O. When $\overline{\text{TRST}}$ transitions from high to low, then EMU1 operates as $\overline{\text{OFF}}$ . EMU/ $\overline{\text{OFF}}$ = 0 puts all output drivers into the high-impedance state. |  |  |  |  |
| EMU1/OFF                        | I/O/Z             | Note that OFF is used exclusively for testing and emulation purposes (and not for multiprocessing applications). Therefore, for the OFF condition, the following conditions apply:                                                                                                                                                                                                      |  |  |  |  |
|                                 |                   | TRST = 0, EMU0 = 1, EMU1 = 0                                                                                                                                                                                                                                                                                                                                                            |  |  |  |  |

#### Table 2–2. Signal Descriptions (Continued)

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

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

§ These pins are Schmitt triggered inputs.

This pin has an internal bus holder controlled by way of the BSCR register in 54x cLEAD core of DSP subsystem A .

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

# **3** Functional Overview



Figure 3–1. 320VC5421 Functional Block Diagram

# 3.1 Memory

Each 5421 DSP subsystem maintains the peripheral register memory map and interrupt location/priorities of the standard 5420. Figure 3–2 shows the size of the required memory blocks and their link map within the program and data space of the cLEAD core. The total on-chip memory for the 5421 devices is 256K-word data/program.

| Hex                | Data                                                                                 | Hex                                      | Program Page 0                                                                                    | Hex                | Program Page 1                                                                        | Hex                | Program Page 2                                                                                    | Hex                | Program Page 3                                                                                    | Hex                | Program Page n        |
|--------------------|--------------------------------------------------------------------------------------|------------------------------------------|---------------------------------------------------------------------------------------------------|--------------------|---------------------------------------------------------------------------------------|--------------------|---------------------------------------------------------------------------------------------------|--------------------|---------------------------------------------------------------------------------------------------|--------------------|-----------------------|
| 00 0000            | Memory-<br>Mapped<br>Registers                                                       | 00 0000<br>00 005F                       | Reserved                                                                                          | 01 0000<br>01 005F | Reserved                                                                              | 02 0000<br>02 005F | Reserved                                                                                          | 03 0000<br>03 005F | Reserved                                                                                          | 0n 0000            | Reserved              |
| 00 0060            | On-Chip<br>DARAM A/B <sup>§</sup><br>(32K Words)<br>Prog/Data                        | 00 0060                                  | On-Chip<br>DARAM A/B <sup>§</sup><br>(32K Words)<br>Prog/Data<br>(OVLY=1)<br>External<br>(OVLY=0) | 01 0060            | On-Chip<br>DARAM A/B§<br>(32K Words)<br>Prog/Data<br>(OVLY=1)<br>External<br>(OVLY=0) | 02 0060            | On-Chip<br>DARAM A/B <sup>§</sup><br>(32K Words)<br>Prog/Data<br>(OVLY=1)<br>External<br>(OVLY=0) | 03 0060 -          | On-Chip<br>DARAM A/B <sup>S</sup><br>(32K Words)<br>Prog/Data<br>(OVLY=1)<br>External<br>(OVLY=0) | 0n 0060            | External <sup>‡</sup> |
| 00 7FFF<br>00 8000 |                                                                                      | 00 7FFF<br>00 8000                       |                                                                                                   | 01 7FFF<br>01 8000 |                                                                                       | 02 7FFF<br>02 8000 |                                                                                                   | 03 7FFF<br>03 8000 |                                                                                                   | 0n 7FFF<br>0n 8000 |                       |
|                    | On-Chip<br>SARAM A/B<br>(32K Words)<br>Data Only<br>(DROM=1)<br>External<br>(DROM=0) | 00 DFFF                                  | On-Chip<br>two-way<br>shared<br>DARAM 0¶<br>(24K Words)<br>Prog Only<br>Shared 0                  |                    | On-Chip<br>two-way<br>shared<br>DARAM 1¶<br>(32K Words)<br>Prog Only                  |                    | On-Chip<br>two-way<br>shared<br>DARAM 2 <sup>#</sup><br>(32K Words)<br>Prog Only                  |                    | On-Chip<br>two-way<br>shared<br>DARAM 3 <sup>##</sup><br>(32K Words)<br>Prog Only                 |                    | External‡             |
| 00 FFFF            |                                                                                      | 00 E000<br>00 F7FF<br>00 F800<br>00 FFFF | Reserved<br>ROM<br>(ROMEN=1) <sup>†</sup>                                                         | 01 FFFF            | Shared 1                                                                              | 02 FFFF            | Shared 2                                                                                          | 03 FFFF            | Shared 3                                                                                          | 0n FFFF            |                       |
|                    |                                                                                      |                                          |                                                                                                   |                    | (extended)                                                                            |                    | (extended)                                                                                        |                    | (extended)                                                                                        |                    | (n = 4 – 127)         |

<sup>†</sup>ROM enabled after reset.

<sup>‡</sup>When CPU PMST register bit MP/MC=0 and an address is generated outside the on-chip memory bound or the address reach, i.e., XPC > 3h, access is always external, if XIO = 1. Pages 8–127 are mapped over pages 4–7. When XIO = 1 and MP/MC = 1, program pages 0, 1, 2, and 3 are external. Pages 4–127 are mapped over pages 0–3.

§ On-chip DARAM A and SARAM A are for subsystem A. Likewise, on-chip DARAM B and SARAM B are for subsystem B.

¶ On-chip DRAM 0 and DRAM 1 are owned by subsystem A and shared with subsystem B.

<sup>#</sup>On-chip DRAM 2 and DRAM 3 are owned by subsystem B and shared with subsystem A.

NOTES: A. Clearing the ROMEN bit (GPIO[7]) enables an 8K-word block (0E000h - 0FFFh) of DARAM .

- B. All external accesses require the XIO pin to be high.
- C. CPU I/O space is a single page of 64K words. Access is always external.
  - D. All internal memory is divided into 8K blocks.

#### Figure 3–2. Memory Map Relative to CPU Subsystems A and B

# 3.1.1 On-Chip Dual-Access RAM (DARAM)

The 5421 subsystems A and B each have 32K 16-bit words of on-chip DARAM (4 blocks of 8K words). Each of these DARAM blocks can be accessed twice per machine cycle. This memory is intended primarily to store data values; however, it can be used to store program as well. At reset, the DARAM is mapped into data memory space. The DARAM can be mapped into program/data memory space by setting the OVLY bit in the processor-mode status (PMST) register of the 54x CPU in each DSP subsystem.

# 3.1.2 On-Chip Single-Access RAM (SARAM)

The 5421 subsystems A and B each have 32K 16-bit words of on-chip SARAM (4 blocks of 8K words). Each of these SARAM blocks can be accessed once per machine cycle. This memory is intended to store data values only. At reset, the SARAM is disabled. The SARAM can be enabled in data memory space by setting the DROM bit in the PMST register.

# 3.1.3 On-Chip Two-Way Shared RAM (DARAM)

The 5421 has 128K 16-bit words of on-chip DARAM (16 blocks of 8K words) that is shared between the two DSP subsystems. This memory is intended to store program only. Each subsystem is able to make one instruction fetch from any location in two-way shared memory each cycle. Neither subsystem CPU can write to the two-way shared memory as only the DMA can write to two-way shared memory.

### 3.1.4 On-Chip Boot ROM

The 5421 subsystems A and B each have 2K 16-bit words of on-chip ROM. This ROM is used for bootloading functions only. Enabling the ROM maps out one 8K-word block of the shared program memory. The ROM can be disabled by clearing bit 7 (ROMEN) of the general-purpose I/O (GPIO) register. Table 3–1 shows the XIO/ROMEN modes. The ROM is enabled or disabled at reset for each subsystem depending on the state of the GPIO0 pin for that subsystem.

| XIO | ROMEN/GPIO0 | MODE                    |
|-----|-------------|-------------------------|
| 0   | х           | Fetch internal from RAM |
| 1   | 0           | Fetch external          |
| 1   | 1           | ROM enabled             |

| Table 3–1. | XIO/ROMEN Modes |
|------------|-----------------|
|------------|-----------------|

# 3.1.5 Extended Program Memory

The program memory space on the 5421 device addresses up to 512K 16-bit words. The 5421 device uses a paged extended memory scheme in program space to allow access of up to 512K of program memory . This extended program memory (each subsystem) is organized into eight pages (0–7), pages 0–3 are internal, pages 4–7 are external, each 64K in length. (Pages 8–127 as defined by the program counter extension register (XPC) are aliases for pages 4–7.) Access to the extended program memory is similar to the 5420. To implement the extended program memory scheme, the 5421 device includes the following feature:

- Two 54x instructions are extended to use the additional two bits in the 5421 device.
  - READA Read program memory addressed by accumulator A and store in data memory
  - WRITA Write data to program memory addressed by accumulator A (Writes not allowed for CPUs to shared program memory)

# 3.1.6 Program Memory

The program memory is accessible on multiple pages, depending on the XPC value. Within these pages, memory is accessible, depending on the address range.

- Access in the lower 32K of each page is dependent on the state of OVLY.
  - OVLY = 0 Program memory is accessed externally for all values of XPC.
  - OVLY = 1 Program memory is accessed from local data/program DARAM for all values of XPC.
- Access in the upper 32K of each page is dependent on the state of MP/MC and the value of XPC.
  - $MP/\overline{MC} = 0$  Program memory is accessed internally from two-way shared DARAM for XPC = 0-3. Program memory is accessed externally for XPC = 4-127.
  - $MP/\overline{MC} = 1 Program memory is accessed externally for all values of XPC.$

#### 3.1.7 Data Memory

The data memory space is a single page of 64K. Access is dependent on the address range. Access in the lower 32K of data memory is always from local DARAM.

Access in the upper 32K of data memory is dependent on the state of DROM.

- DROM = 0 Data memory is accessed externally
- DROM = 1 Data memory is accessed internally from local SARAM

# 3.1.8 I/O Memory

The I/O space is a single page of 64K. Access is always external.

When XIO = 0 and an access to external memory is attempted, any write is ignored and any read is an unknown value.

### 3.2 Multicore Reset Signals

The 5421 device includes three reset signals: A\_RS, B\_RS, and HPIRS. The A\_RS and B\_RS pins function as the CPU reset signal for subsystem A and subsystem B, respectively. These signals reset the state of the CPU registers and upon release, initiate the reset function. Additionally, the A\_RS signal resets the on-chip PLL and initializes the CLKMD register to bypass mode.

The HPI reset signal (HPIRS) places the HPI peripheral into a reset state. It is necessary to wait three clock cycles after the rising edge of HPIRS before performing an HPI access. The HPIRS signal also resets the PLL by turning off the PLL and initializing the CLKMD register to bypass mode.

#### 3.3 Bootloader

The on-chip bootloader is used to automatically transfer user code from an external source to anywhere in program memory after reset. The XIO pin is sampled during a hardware reset and the results indicate the operating mode as shown in Table 3–2.

| XIO | AFTER RESET                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|     | HPI mode, bootload is controlled by host. The external host holds the 5421 in reset while it loads the on-chip memory of one or both subsystems as determined by the SELA/B pin.                                                                                                                                                                                                                                                                |
|     | The host can release the 5421 from reset by either of the following methods:                                                                                                                                                                                                                                                                                                                                                                    |
| 0   | 1. If the A_RS/B_RS pins are held low while HPIRS transitions from low to high, the subsystem cores reset will be controlled by the A_RS/B_RS pins. When the host has finished downloading code, it drives A_RS/B_RS high to release the cores from reset.                                                                                                                                                                                      |
|     | 2. If the A_RS/B_RS pins are held high while HPIRS transitions from low to high, the subsystems stay in reset until a HPI data write to address 0x2F occurs. This means the host can download code to subsystem A and then release core A from reset by writing any data to core A address 0x2F via the HPI. The host can then repeat the sequence for core B. This mode allows the host to control the 5421 reset without additional hardware. |
| 1   | XIO mode. ROM is mapped in, if ROMEN pin = 1 during reset.                                                                                                                                                                                                                                                                                                                                                                                      |

Table 3–2. Bootloader Operating Modes

The 5421 bootloader provides the following options for the source of code to download:

- Parallel from 8-bit or 16-bit-wide EPROM
- Serial boot from McBSPs, 8-bit mode

GPIO register bit 7 (ROMEN) is used to enable/disable the ROM after reset. The ROMEN bit reflects the status of the ROMEN/GPIO0 pin for each core. ROMEN = 1 indicates that the ROM and the 8K-word program memory block (00 E000h–00 FFFFh) are not available for a CPU write. When ROMEN = 0, this 8K-word program memory is available and the ROM is disabled.

A combination of interrupt flags and the bit values of an external memory location determine the selection of the various boot options.

# 3.4 External Interface (XIO)

The external interface (XIO) supports the 5421 master boot modes and other external accesses. Its features include:

- Multiplexed with the HPI pins
- Selection of XIO or HPI mode is determined by a dedicated pin (XIO)
- Provides 512K words of external program space, 64K words of external data space, and 64K words of external I/O space.
- Different boot modes are selectable by the XIO, HMODE, and A\_RS/B\_RS pins.
- After reset, the control register bit ROMEN is always preset to 1.

While XIO = 0 during reset, host HPI mode is on, the host sees all RAM, and ROM is disabled. A host write to 002Fh releases the CPUs from reset; the 002Fh write by the host clears the ROMEN bit in the GPIO register.

While XIO = 1 and ROMEN = 1 during reset, the CPU starts from ROM (0FF80h) to do boot selection. After branching to non-ROM area, the code changes the ROMEN bit to enable the RAM area occupied by ROM. While XIO = 1 and ROMEN = 0 during reset, the CPU starts from external (0FF80h) to do boot selection.

Table 3–3 provides a complete description of HMODE, SELA/B, and XIO pin functionality.

| HMODE | SELA/B | HPI MODES (XIO = 0)                                  | XIO MODES (XIO = 1)                        |
|-------|--------|------------------------------------------------------|--------------------------------------------|
| 0     | 0      | HPI muxed address/data subsystem A slave to host     | SELA/B pin is multiplexed as PPA18 output. |
| 0     | 1      | HPI muxed address/data subsystem B slave to host     | SELA/B pin is multiplexed as PPA18 output. |
| 1     | 0      | HPI non-muxed address/data subsystem A slave to host | SELA/B pin is multiplexed as PPA18 output. |
| 1     | 1      | HPI non-muxed address/data subsystem B slave to host | SELA/B pin is multiplexed as PPA18 output. |

#### Table 3–3. XIO/HPI Modes

#### 3.5 On-Chip Peripherals

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

- Software-programmable wait-state generator
- Programmable bank-switching
- Parallel I/O ports
- Multichannel buffered serial ports (McBSPs)
- A hardware timer
- A software-programmable clock generator using a phase-locked loop (PLL)

# 3.5.1 Software-Programmable Wait-State Generators

The software-programmable wait-state generator can be used to extend external bus cycles up to fourteen machine cycles to interface with slower off-chip memory and I/O devices. The software wait-state register (SWWSR) controls the operation of the wait-state generator. The SWWSR of a particular DSP subsystem (A or B) is used for the external memory interface, depending on the state of the xDMA/XIO arbitration logic (see Direct Memory Access (DMA) Controller section 3.8 and Table 3–4. The 14 least significant bits (LSBs) of the SWWSR specify the number of wait states (0–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–3 and described in Table 3–4.

| 15    | 14      | 13 | 12 | 11   | 10      | 9 | 8    | 7       | 6 | 5       | 4       | 3 | 2       | 1 | 0 |
|-------|---------|----|----|------|---------|---|------|---------|---|---------|---------|---|---------|---|---|
| XPA   | I/O     |    |    | Data |         |   | Data |         |   | Program |         |   | Program |   |   |
| R/W=0 | R/W=111 |    |    |      | R/W=111 |   |      | R/W=111 |   |         | R/W=111 |   | R/W=111 |   |   |

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

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

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

Table 3–4. Software Wait-State Register (SWWSR) Bit Fields

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



LEGEND: R = Read, W = Write

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

|      | PIN      | RESET | FUNCTION                                                                                                               |  |  |  |  |  |  |  |  |
|------|----------|-------|------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|--|
| NO.  | NAME     | VALUE | FUNCTION                                                                                                               |  |  |  |  |  |  |  |  |
| 15–1 | Reserved | 0     | nese 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    | SWSM     | 0     | SWSM = 0: wait-state base values are unchanged (multiplied by 1).                                                      |  |  |  |  |  |  |  |  |
|      |          |       | SWSM = 1: wait-state base values are multiplied by 2 for a maximum of 14 wait states.                                  |  |  |  |  |  |  |  |  |

# 3.5.2 Programmable Bank-Switching

Programmable bank-switching can be used to insert one cycle automatically when crossing memory-bank boundaries inside program memory or data memory space. One cycle can also be inserted when crossing from program-memory space to data-memory space (54x) or one program memory page to another program memory page. This extra cycle allows memory devices to release the bus before other devices start driving the bus, thereby avoiding bus contention. The size of the memory bank for the bank-switching is defined by the bank-switching control register (BSCR), as shown in Figure 3–5. The BSCR of a particular DSP subsystem (A or B) is used for the external memory interface based on the xDMA/XIO arbitration logic. The BSCR bit fields are described in Table 3–6.

| 15 | 14  | 13  | 12 | 11    | 10   | 9    | 8     | 7        | 6 | 5 | 4 | 3  | 2        | 1    | 0   |
|----|-----|-----|----|-------|------|------|-------|----------|---|---|---|----|----------|------|-----|
|    | BNK | СМР |    | PS-DS | Rese | rved | IPIRQ | Reserved |   |   |   | BH | Reserved | EXIO |     |
|    | R/  | W   |    | R/W   | R/   | W    | R/W   |          |   |   |   |    | R/W      |      | R/W |
|    |     |     |    |       |      |      |       |          |   |   |   |    |          |      |     |

LEGEND: R = Read, W = Write

Figure 3–5. BSCR Register Bit Layout for Each DSP Subsystem

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

 Table 3–6. BSCR Register Bit Functions for Each DSP Subsystem

# 3.5.3 Parallel I/O Ports

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

# 3.6 16-Bit Bidirectional Host-Port Interface (HPI16)

The HPI16 is an enhanced 16-bit version of the TMS320C54x<sup>™</sup> DSP 8-bit host-port interface (HPI). The HPI16 is designed to allow a 16-bit host to access the DSP on-chip memory, with the host acting as the master of the interface.

### 3.6.1 HPI16 Memory Map

Figure 3–6 illustrates the available memory accessible by the HPI. Neither the CPU nor DMA I/O spaces can be accessed using the host-port interface.

| Hex                | Page 0 Hex Page 1                              |                    | Page 1                                                                 | Hex     | Page 2                                         | Hex     | Page 3                                                                 |
|--------------------|------------------------------------------------|--------------------|------------------------------------------------------------------------|---------|------------------------------------------------|---------|------------------------------------------------------------------------|
| 00 0000            | Reserved                                       | 01 0000            |                                                                        | 02 0000 | Deserved                                       | 03 0000 |                                                                        |
| 00 001F            | Reserved                                       |                    |                                                                        | 02 001F | Reserved                                       |         |                                                                        |
| 00 0020            | McBSP<br>DXR/DRR                               |                    |                                                                        | 02 0020 | McBSP<br>DXR/DRR                               |         |                                                                        |
| 00 005F            | MMRegs Only                                    |                    |                                                                        | 02 005F | MMRegs Only                                    |         |                                                                        |
| 00 0060            | On-Chip<br>DARAM A<br>(32K Words)<br>Prog/Data |                    | On-Chip<br>Two-Way<br>Shared<br>DARAM 0<br>(32K Words)<br>Program Only | 02 0060 | On-Chip<br>DARAM B<br>(32K Words)<br>Prog/Data |         | On-Chip<br>Two-Way<br>Shared<br>DARAM 2<br>(32K Words)<br>Program Only |
| 00 7FFF            | Subsystem A                                    | 01 7FFF<br>01 8000 | Shared 0                                                               | 02 7FFF | Subsystem B                                    | 03 7FFF | Shared 2                                                               |
| 00 7FFF<br>00 8000 | On-Chip<br>SARAM A<br>(32K Words)<br>Data Only |                    | On-Chip<br>Two-Way<br>Shared<br>DARAM 1<br>(32K Words)<br>Program Only | 02 8000 | On-Chip<br>SARAM B<br>(32K Words)<br>Data Only | 03 8000 | On-Chip<br>Two-Way<br>Shared<br>DARAM 3<br>(32K Words)<br>Program Only |
| 00 FFFF            | Subsystem A                                    | 01 FFFF            | Shared 1                                                               | 02 FFFF | Subsystem B                                    | 03 FFFF | Shared 3                                                               |

NOTES: A. All local memory is available to the HPI

B. The encoder maps CPU A Data Page 0 into the HPI Page 0. CPU B Data Page 0 is mapped into the HPI Page 2. Pages 1 and 3 are the on-chip shared program memory.

C. In pages 00 and 02, in the range of 0020–005F, only the following memory mapped registers are accessible: 20,21,30,31,40,41 (read only), 22,23,32,33,42,43 (write only).

#### Figure 3–6. Memory Map Relative to Host-Port Interface HPI16

# 3.6.2 HPI Features

Some of the features of the HPI16 include:

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

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

# 3.6.3 HPI Multiplexed Mode

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

# 3.6.4 Host/DSP Interrupts

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

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

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

# 3.6.5 Emulation Considerations

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

#### 3.6.6 HPI Nonmultiplexed Mode

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

C54x is a trademark of Texas Instruments.





# 3.6.7 Other HPI16 System Considerations

#### 3.6.7.1 Operation During IDLE

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

#### 3.6.7.2 Downloading Code During Reset

The HPI16 can download code while the DSP is in reset. However, the system provides a pin (HPIRS) that provides a way to take the HPI16 module out of reset while leaving the DSP in reset. The maximum HPI16 data rate is 33 MBps assuming no other DMA activity (100-MIPS DSP subsystem).

#### 3.6.7.3 Performance Issues

On the 5421, the use of SELA/B is optional for access to all on-chip memory. However, with both the 5420 and 5421 implementation using two separate subsystems (subchips), the SELA/B pin is used to select the specific HPI16 used to access memory.

| SELA/B PIN | SUBSYSTEM |
|------------|-----------|
| 0          | А         |
| 1          | В         |

Accesses to memory contained inside the same subsystem as the selected HPI16 will be faster. For accesses to an HPI16 in a subsystem different than the memory being addressed, reads take an additional six cycles and writes an extra five cycles. Therefore, for performance reasons, it is best to additionally decode SELA/B.

# 3.7 Multichannel Buffered Serial Port (McBSP)

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

The McBSP provides:

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

In addition, the McBSP has the following capabilities:

- Direct interface to:
  - T1/E1 framers
  - MVIP switching-compatible and ST-BUS compliant devices
  - IOM-2 compliant device
  - AC97-compliant device
  - Serial peripheral interface (SPI)
- 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 5421 McBSPs have been enhanced to provide more flexibility in the choice of the sample rate generator input clock source. On previous TMS320C5000<sup>™</sup> DSP platform devices, the McBSP sample rate input clock can be driven from one of two possible choices: the internal CPU clock , or the external CLKS pin. However, most C5000<sup>™</sup> DSP devices have only the internal CPU clock as a possible source because the CLKS pin is not implemented on most device packages.

To accommodate applications that require an external reference clock for the sample rate generator, the 5421 McBSPs allow either the receive clock pin (BCLKR) or the transmit clock pin (BCLKX) to be configured as the input clock to the sample rate generator. This enhancement is enabled through two register bits: pin control register (PCR) bit 7 – enhanced sample clock mode (SCLKME), and sample rate generator register 2 (SRGR2) bit 13 – McBSP sample rate generator clock mode (CLKSM). SCLKME is an addition to the PCR contained in the McBSPs on previous C5000 devices. The new bit layout of the PCR is shown in Figure 3–8. For a description of the remaining bits, see *TMS320C54x DSP Reference Set, Volume 5: Enhanced Peripherals* (literature number SPRU302).

TMS320C5000 and C5000 are trademarks of Texas Instruments.

| 15     | 14    | 13    | 12      | 11    | 10    | 9     | 8     |
|--------|-------|-------|---------|-------|-------|-------|-------|
| Res    | erved | XIOEN | RIOEN   | FSXM  | FSRM  | CLKXM | CLKRM |
| R      | ,+0   | RW,+0 | RW,+0   | RW,+0 | RW,+0 | RW,+0 | RW,+0 |
| 7      | 6     | 5     | 4       | 3     | 2     | 1     | 0     |
| SCLKME |       |       | DR_STAT | FSXP  | FSRP  | CLKXP | CLKRP |
| RW,+0  |       |       | R,+0    | RW,+0 | RW,+0 | RW,+0 | RW,+0 |

Note: R = Read, W = Write, +0 = Value at reset

#### Figure 3–8. Pin Control Register (PCR)

The selection of the sample rate generator (SRG) clock input source is made by the combination of the CLKSM and SCLKME bit values as shown in Table 3–7.

| SCLKME | CLKSM | SRG Clock Source                      |  |  |  |  |  |
|--------|-------|---------------------------------------|--|--|--|--|--|
| 0      | 0     | CLKS (not available as a pin on 5421) |  |  |  |  |  |
| 0      | 1     | CPU clock                             |  |  |  |  |  |
| 1      | 0     | BCLKR pin                             |  |  |  |  |  |
| 1      | 1     | BCLKX pin                             |  |  |  |  |  |

Table 3–7. Sample Rate Generator Clock Source Selection

When either of the bidirectional pins, BCLKR or BCLKX, is configured as the clock input, its output buffer is automatically disabled. For example, with SCLKME = 1 and CLKSM = 0, the BCLKR pin is configured as the SRG input. In this case, both the transmitter and receiver circuits can be synchronized to the SRG output by setting the PCR bits (9:8) for CLKXM = 1 and CLKRM = 1. However, the SRG output is only driven onto the BCLKX pin because the BCLKR output is automatically disabled.

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

The 5421 McBSPs have two working modes that are selected by setting the RMCME and XMCME bits in the multichannel control registers (MCR1x and MCR2x, respectively). See Figure 3–9 and Figure 3–10. For a description of the remaining bits, see *TMS320C54x DSP Reference Set, Volume 5: Enhanced Peripherals* (literature number SPRU302).

• In the first mode, when RMCME = 0 and XMCME = 0, there are two partitions (A and B), with each containing 16 channels as shown in Figure 3–9 and Figure 3–10. This is compatible with the McBSPs used in the 5420, where only 32-channel selection is enabled (default).

|   | 15       | 14 | 13 | 12    | 11    | 10          | 9  | 8      | 7 | 6            | 5     | 4 | 3    | 2 | 1 | 0 |
|---|----------|----|----|-------|-------|-------------|----|--------|---|--------------|-------|---|------|---|---|---|
|   | Reserved |    |    |       | XMCME | XPBBLK      |    | XPABLK |   | XCBLK        |       |   | ХМСМ |   |   |   |
| - | R,+0     |    |    | RW,+0 | RW    | , <b>+0</b> | RW | ,+0    |   | R, <b>+0</b> | RW,+0 |   |      |   |   |   |

Note: R = Read, W = Write, +0 = Value at reset; x = McBSP 0,1, or 2

#### Figure 3–9. Multichannel Control Register 2x (MCR2x)

| 15 | 14       | 13 | 12 | 11    | 10   | 9   | 8   | 7   | 6 | 5     | 4 | 3  | 2    | 1 | 0 |
|----|----------|----|----|-------|------|-----|-----|-----|---|-------|---|----|------|---|---|
|    | Reserved |    |    | RMCME | RPBI | BLK | RPA | BLK |   | RCBLK |   | RM | СМ   |   |   |
|    | R,+0     |    |    | RW,+0 | RW   | ,+0 | RW  | ,+0 |   | R,+0  |   | RW | /,+0 |   |   |
|    |          |    |    |       |      |     |     |     |   |       |   |    |      |   |   |

Note: R = Read, W = Write, +0 = Value at reset; x = McBSP 0,1, or 2

#### Figure 3–10. Multichannel Control Register 1x (MCR1x)

In the second mode, with RMCME = 1 and XMCME = 1, the McBSPs have 128 channel selection capability. Twelve new registers (RCERCx-RCERHx and XCERCx-XCERHx) are used to enable the 128 channel selection. The subaddresses of the new registers are shown in Table 3–21. These new registers, functionally equivalent to the RCERA0-RCERB1 and XCERA0-XCERB1 registers in the 5420, are used to enable/disable the transmit and receive of additional channel partitions (C,D,E,F,G, and H) in the 128 channel stream. For example, XCERH1 is the transmit enable for channel partition H (channels 112 to 127) of MCBSP1 for each DSP subsystem. See Figure 3–11, Table 3–8, Figure 3–12, and Table 3–9 for bit layout and function of the receive and transmit registers.

| 15       | 14       | 13       | 12       | 11       | 10       | 9       | 8       |
|----------|----------|----------|----------|----------|----------|---------|---------|
| RCERyz15 | RCERyz14 | RCERyz13 | RCERyz12 | RCERyz11 | RCERyz10 | RCERyz9 | RCERyz8 |
| RW,+0    | RW,+0    | RW,+0    | RW,+0    | RW,+0    | RW,+0    | RW,+0   | RW,+0   |
| 7        | 6        | 5        | 4        | 3        | 2        | 1       | 0       |
| RCERyz7  | RCERyz6  | RCERyz5  | RCERy4   | RCERyz3  | RCERyz2  | RCERyz1 | RCERyz0 |
| RW,+0    | RW,+0    | RW,+0    | RW,+0    | RW,+0    | RW,+0    | RW,+0   | RW,+0   |

Note: R = Read, W = Write, +0 = Value at reset; y = Partition A,B,C,D,E,F,G, or H; z = McBSP 0,1, or 2

#### Figure 3–11. Receive Channel Enable Registers Bit Layout for Partitions A to H

#### Table 3–8. Receive Channel Enable Registers for Partitions A to H

| Bit  | Name         | Function        |                                                           |  |  |  |  |  |
|------|--------------|-----------------|-----------------------------------------------------------|--|--|--|--|--|
| 15–0 | RCERyz(15:0) | Receive Channel | Receive Channel Enable Register                           |  |  |  |  |  |
|      |              | RCERyz n = 0    | Disables reception of <i>n</i> th channel in partition y. |  |  |  |  |  |
|      |              | RCERyz n = 1    | Enables reception of <i>n</i> th channel in partition y.  |  |  |  |  |  |

Note: y = Partition A,B,C,D,E,F,G, or H; z = McBSP 0,1, or 2; n = bit 15-0

| 15       | 14       | 13       | 12       | 11       | 10       | 9       | 8       |
|----------|----------|----------|----------|----------|----------|---------|---------|
| XCERyz15 | XCERyz14 | XCERyz13 | XCERyz12 | XCERyz11 | XCERyz10 | XCERyz9 | XCERyz8 |
| RW,+0    | RW,+0    | RW,+0    | RW,+0    | RW,+0    | RW,+0    | RW,+0   | RW,+0   |
| 7        | 6        | 5        | 4        | 3        | 2        | 1       | 0       |
|          |          |          |          |          |          |         |         |
| XCERyz7  | XCERyz6  | XCERyz5  | XCERy4   | XCERyz3  | XCERyz2  | XCERyz1 | XCERyz0 |

Note: R = Read, W = Write, +0 = Value at reset; y = Partition A,B,C,D,E,F,G, or H; z = McBSP 0,1, or 2

#### Figure 3–12. Transmit Channel Enable Registers Bit Layout for Partitions A to H

| Bit  | Name         | Function        |                                                          |  |  |  |  |  |
|------|--------------|-----------------|----------------------------------------------------------|--|--|--|--|--|
| 15–0 | XCERyz(15:0) | Transmit Channe | Transmit Channel Enable Register                         |  |  |  |  |  |
|      |              | XCERyz n = 0    | Disables transmit of <i>n</i> th channel in partition y. |  |  |  |  |  |
|      |              | XCERyz n = 1    | Enables transmit of <i>n</i> th channel in partition y.  |  |  |  |  |  |

| Table 2 0  | Tronomit Channe | I Enchle Devicte | ne fen Deutitien |          |
|------------|-----------------|------------------|------------------|----------|
| Table 3-9. | Transmit Channe | i Enable Registe | rs for Partition | S A to H |

**Note:** y = Partition A,B,C,D,E,F,G, or H; z = McBSP 0,1, or 2; n = bit 15-0

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

The McBSP is fully static and operates at arbitrarily low clock frequencies. The maximum McBSP multichannel operating frequency on the 5421 is 9 MBps. Nonmultichannel operation is limited to 38 MBps.

### 3.7.1 Emulation Considerations

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

# 3.8 Direct Memory Access (DMA) Controller

The 5421 includes two 6-channel direct memory access (DMA) controllers for performing data transfers independent of the CPU, one for each subsystem. The DMA controller controls accesses to off-chip program/data/IO and internal data/program memory. The primary function of the 5421 DMA controller is to provide code overlays and manage data transfers between on-chip memory, the peripherals, and off-chip memory.

In the background of CPU operation, the 5421 DMA allows movement of data between internal and external program/data memory, and internal peripherals, such as the McBSPs and the HPI. Each subsystem has its own independent DMA with six programmable channels, which allows for six different contexts for DMA operation. The HPI has a dedicated auxiliary DMA channel. Figure 3–13 illustrates the memory map accessible by the DMA.

| Hex                | Data <sup>†</sup>                                | Hex P              | rogram Page 0‡                                 | Hex P   | rogram Page 1                                                             | <sup>∓</sup> Hex P | rogram Page 2                                  | F <sub>Hex</sub> P | rogram Page 3 <sup>‡</sup>                                                |
|--------------------|--------------------------------------------------|--------------------|------------------------------------------------|---------|---------------------------------------------------------------------------|--------------------|------------------------------------------------|--------------------|---------------------------------------------------------------------------|
| 00 0000            | Reserved                                         | 00 0000            | Reserved                                       | 01 0000 |                                                                           | 02 0000<br>02 001F | Reserved                                       | 03 0000            |                                                                           |
| 00 001F<br>00 0020 | McBSP<br>DXR/DRR                                 | 00 001F<br>00 0020 | McBSP<br>DXR/DRR                               |         |                                                                           | 02 0020            | McBSP<br>DXR/DRR                               |                    |                                                                           |
| 00 005F<br>00 0060 | MMRegs Only                                      | 00 005F<br>00 0060 | MMRegs Only                                    |         | On-Chip                                                                   | 02 005F<br>02 0060 | MMRegs Only                                    |                    | On-Chip<br>Two-Way                                                        |
|                    | On-Chip<br>DARAM A/B<br>(32K Words)<br>Prog/Data |                    | On-Chip<br>DARAM A<br>(32K Words)<br>Prog/Data |         | Two-Way<br>Shared<br>DARAM 0<br>(32K Words)<br>Program<br>Only            |                    | On-Chip<br>DARAM B<br>(32K Words)<br>Prog/Data |                    | Shared<br>DARAM 2<br>(32K Words)<br>Program<br>Only                       |
| 00 7FFF            |                                                  | 00 7FFF            | Subsystem A                                    | 01 7FFF | Shared 0                                                                  | 02 7FFF            | Subsystem B                                    | 03 7FFF            | Shared 2                                                                  |
| 00 8000            | On-Chip<br>SARAM A/B<br>(32K Words)<br>Data Only | 00 8000            | On-Chip<br>SARAM A<br>(32K Words)<br>Data Only | 01 8000 | On-Chip<br>Two-Way<br>Shared<br>DARAM 1<br>(32K Words)<br>Program<br>Only | 02 8000            | On-Chip<br>SARAM B<br>(32K Words)<br>Data Only | 03 8000            | On-Chip<br>Two-Way<br>Shared<br>DARAM 3<br>(32K Words)<br>Program<br>Only |
| 00 FFFF            |                                                  | 00 FFFF            | Subsystem A                                    | 01 FFFF | Shared 1                                                                  | 02 FFFF            | Subsystem B                                    | 03 FFFF            | Shared 3                                                                  |

† DMD/DMS = 01

 $\ddagger DMD/DMS = 00$ 

NOTES: A. All local memory is available to the DMA.

B. All I/O memory accesses by the DMA (DMD/DMS = 10) are mapped to the core-to-core FIFO.

C. In pages 00 and 02, in the range of 0020–005F, only the following memory mapped registers are accessible: 20,21,30,31,40,41 (read only), 22,23,32,33,42,43 (write only).

#### Figure 3–13. On-Chip Memory Map Relative to DMA (DLAXS/SLAXS = 0)



xDMA External Program Memory Map<sup>†</sup>

<sup>†</sup> Pages 8 – 127 are overlaid over pages 0 – 7.



## 3.8.1 DMA Controller Features

The 5421 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.
- Two DMA channels are available for external accesses: one for reads and one for writes.
- 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 include configurable indexing modes. The address can be held constant, postincremented, postdecremented, or adjusted by a programmable value.
- For internal accesses, each read or write transfer can be initialized by selected events.
- Supports 32-bit transfers for internal accesses only.
- Single-word (16-bit) transfers are supported for external accesses.
- The DMA does not support transfers from peripherals to external memory.
- The DMA does not support transfers from external memory to the peripherals.
- The DMA does not support external to external transfers.

A 16-bit DMA transfer requires four CPU clock cycles to complete — two cycles for reads and two cycles for writes. This gives a maximum DMA throughput of 50 MBps. Since the DMA controller shares the DMA bus with the HPI module, the DMA access rate is reduced when the HPI is active.

### 3.8.2 DMA Accesses to External Memory

The 5421 DMAs supports external accesses to extended program, extended data, and extended I/O memory. These overlay pages are only visible to the DMA controller. A maximum of two channels (one for reads, one for writes) per DMA can be used for external memory accesses. The DMA external accesses require 9 cycles (minimum) for external writes and 13 cycles (minimum) for external reads.

The control of the bus is arbitrated between the two CPUs and the two DMAs. While one DMA or CPU is in control of the external bus, the other three components will be held off (via wait-states) until the current transfer is complete. The DMA takes precedence over XIO requests. The HOLD/HOLDA feature of the 5421 affects external CPU transfers, as well as external DMA transfers. When an external processor asserts the HOLD pin to gain control of the memory interface, the HOLDA signal is not asserted until all pending DMA transfers are completed. To prevent a DMA from blocking out the CPUs or HOLD/HOLDA feature from accessing the external bus, uninterrupted burst transfers are **not** supported by the DMAs. Subsequently, CPU and DMA arbitration testing is performed for each external bus cycle, regardless of the bus activity. With the completion of each block, the highest priority will be swapped.

For arbitration at the DSP subsystem level, the DMA requests (DMA\_REQ\_A or DMA\_REQ\_B) from either DMA will be sent to both CPUs as shown in Figure 3–15. Regardless of which CPU controls the external pin interface (XIO), both CPUs must send a grant (GRANT\_A, GRANT\_B) for control of the bus to be released to the DMAs.

Arbitration between CPUs is done using a request/grant scheme. Prior to accessing XIO of one of the CPUs, software is responsible for asserting a request for access to the device pins and polling grant status until the pins are granted to the requestor. If both CPUs request the bus simultaneously, subsystem A is granted priority. For details on memory-mapped register bits pertaining to CPU XIO arbitration, see the general-purpose I/O control register bits [6:4] (CORE SEL, XIO GRANT, XIO REQ) in Table 3–14.

At reset, the default is that subsystem A has access to the device pins. Accesses without a grant will be allowed, but do not show up on the device pins.



Figure 3–15. Arbitration Between XIO and xDMA for External Access

The HM bit in the ST1 indicates whether the processor continues internal execution when acknowledging an active HOLD signal.

- HM = 0, the processor continues execution from internal program memory but places its external interface in the high-impedance state.
- When HM = 1, the processor halts internal execution.

To ensure that proper arbitration occurs, the HM bit should be set to 0 in the memory-mapped ST1 registers for both CPUs.

To allow the DMA access to extended data pages, the SLAXS and DLAXS bits are added to the DMMCRn registers. For a description of the remaining bits, see *TMS320C54x DSP Reference Set, Volume 5: Enhanced Peripherals* (literature number SPRU302).

| 15           | 14   | 13   | 12        | 11    | 10 | 9    | 8 | 7  | 6  | 5     | 4 | 3    | 2 | 1  | 0  |
|--------------|------|------|-----------|-------|----|------|---|----|----|-------|---|------|---|----|----|
| AUTC<br>INIT | DINM | IMOD | CT<br>MOD | SLAXS |    | SIND |   | DI | MS | DLAXS |   | DIND |   | DI | ND |

| Eigure 2 16  | DMA Tropofo   | Mada Cantral   | Deviator |  |
|--------------|---------------|----------------|----------|--|
| Figure 3-10. | DIMA ITALISIE | r Mode Control | Register |  |

These new bit fields were created to allow the user to define the space-select for the DMA (internal/external). Also, a new extended destination data page (XDSTDP[6:0], subaddress 029h) and extended source data page (XSRCDP[6:0], subaddress 028h) have been created.

| DLAXS(DMMCRn[5])  | 0 = No external access (default internal) |
|-------------------|-------------------------------------------|
| Destination       | 1 = External access                       |
| SLAXS(DMMCRn[11]) | 0 = No external access (default internal) |
| Source            | 1 = External access                       |

For the CPU external access, software can configure the memory cells to reside inside or outside the program address map. When the cells are mapped into program space, the device automatically accesses them when their addresses are within bounds. When the program address generation (PAGEN) logic generates an address outside its bounds, the device automatically generates an external access. All DMA I/O space accesses are mapped to the core-to-core FIFO.

### 3.8.3 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 3–10.

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

Table 3–10. DMA Synchronization Events

## 3.8.4 DMA Channel Interrupt Selection

The DMA controller can generate a CPU interrupt for each of the six channels. However, channels 0, 1, 2, and 3 are multiplexed with other interrupt sources. DMA channels 0 and 1 share an interrupt line with the receive and transmit portions of McBSP2 (IMR/IFR bits 6 and 7), and DMA channels 2 and 3 share an interrupt line with the receive and transmit portions of McBSP1 (IMR/IFR bits 10 and 11). When the 5421 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 3–11.

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

Table 3–11. DMA Channel Interrupt Selection

### 3.8.5 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, DMGCR, and DMGFR). Autoinitialization allows:

- Continuous operation: Normally, the CPU would have to reinitialize the DMA immediately after the completion of the current block transfers, 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.

The 5421 DMA has been enhanced to expand the DMA global reload register sets. Each DMA channel now has its own DMA global reload register set. For example, the DMA global reload register set for channel 0 has DMGSA0, DMGDA0, DMGCR0, and DMGFR0 while DMA channel 1 has DMGSA1, DMGDA1, DMGCR1, and DMGFR1, etc.

To utilize the additional DMA global reload registers, the AUTOIX bit is added to the DMPREC register as shown in Figure 3–17.

| 15   | 14     | 13 | 12        | 11 | 10 | 9 | 8 | 7 | 6  | 5 | 4 | 3   | 2    | 1 | 0 |
|------|--------|----|-----------|----|----|---|---|---|----|---|---|-----|------|---|---|
| FREE | AUTOIX |    | DPRC[5:0] |    |    |   |   |   | EL |   |   | DE[ | 5:0] |   |   |

### Figure 3–17. DMPREC Register

| AUTOIX      | DMA GLOBAL RELOAD REGISTER USAGE IN AUTO INIT MODE           |
|-------------|--------------------------------------------------------------|
| 0 (default) | All DMA channels use DMGSA0, DMGDA0, DMGCR0 and DMGFR0       |
| 1           | Each DMA channel uses its own set of global reload registers |

### 3.8.6 Subsystem Communications

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

- Core-to-core FIFO communications
- DMA global memory transfer

### 3.8.6.1 FIFO Data Communications

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

### 3.8.6.2 DMA Global Memory Transfers

The 5421 enables each subsystem to transfer data directly between the memories that are CPU local via DMA global memory transfers. The DMA global memory map is shown in Figure 3–13.

## 3.8.7 Chip Subsystem ID Register

The chip subsystem ID Register (CSIDR) is a read-only memory-mapped register located at 3Eh within each DSP subsystem. This register contains three elements for electrically readable device identification. The ChipID bits identify the type of 54x device (21h for 5421). The ChipRev bits contain the revision number of the device. Lastly, the SubSysID contains a unique subsystem identifier.

| 15 | 14 | 13 | 12   | 11   | 10 | 9 | 8 | 7 | 6    | 5   | 4 | 3 | 2    | 1 | 0 |
|----|----|----|------|------|----|---|---|---|------|-----|---|---|------|---|---|
|    |    |    | Chij | o ID |    |   |   |   | Chip | Rev |   |   | SubS |   |   |

#### Figure 3–18. Chip Subsystem ID Register

| BIT<br>NO. | BIT FIELD<br>NAME | FUNCTION                                             |  |  |  |  |  |  |  |  |  |
|------------|-------------------|------------------------------------------------------|--|--|--|--|--|--|--|--|--|
| 15–8       | Chip ID           | 54x device type. Contains 21h for 5421.              |  |  |  |  |  |  |  |  |  |
| 7–4        | Chip Rev          | Revision number of device (i.e., 0h for revision 0). |  |  |  |  |  |  |  |  |  |
| 3–0        | SubSvsID          | Identifier for DSP subsystem: A = 0h. B = 1h.        |  |  |  |  |  |  |  |  |  |

#### Table 3–13. Chip Subsystem ID Register Bit Functions

### 3.9 General-Purpose I/O

In addition to the A\_XF and B\_XF pins, the 5421 has eight general-purpose I/O pins. These pins are:

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

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

Four general-purpose I/O pins are available to each core. Each GPIO pin can be individually selected as either an input or an output. Additionally, the timer output is selectable on GPIO pin 3. At core reset, all GPIO pins are configured as inputs. GPIO data and control bits are accessible through a memory-mapped register at 3Ch with the format shown in Figure 3–19.

| 15    | 14       | 13 | 12           | 11           | 10           | 9            | 8         | 7           | 6            | 5          | 4            | 3            | 2            | 1            | 0     |
|-------|----------|----|--------------|--------------|--------------|--------------|-----------|-------------|--------------|------------|--------------|--------------|--------------|--------------|-------|
| тоит  | Reserved |    | GPIO<br>DIR3 | GPIO<br>DIR2 | GPIO<br>DIR1 | GPIO<br>DIR0 | ROM<br>EN | CORE<br>SEL | XIO<br>GRANT | XIO<br>REQ | GPIO<br>DAT3 | GPIO<br>DAT2 | GPIO<br>DAT1 | GPIO<br>DAT0 |       |
| R/W+0 |          |    |              | R/W+0        | R/W+0        | R/W+0        | R/W+0     | r/w†        | R            | R+0        | R/W+0        | R/W+0        | R/W+0        | R/W+0        | R/W+0 |

<sup>†</sup> 1 denotes XIO = 1, 0 denotes XIO = 0**Note:** R = Read, W = Write, +0 = Value at reset

Figure 3–19. General-Purpose I/O Control Register

| BIT<br>NO. | BIT<br>NAME          | BIT<br>VALUE | FUNCTION                                                                                        |  |  |  |  |  |  |
|------------|----------------------|--------------|-------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 45         | TOUT                 | 0            | Timer output disable. Uses GPIO3 as general-purpose I/O.                                        |  |  |  |  |  |  |
| 15         | TOUT                 | 1            | Timer output enable. Overrides DIR3. Timer output is driven on GPIO3 and readable in DAT3.      |  |  |  |  |  |  |
| 14-12      | Reserved             | Х            | Register bit is reserved. Read 0, write has no effect.                                          |  |  |  |  |  |  |
|            | GPIO                 | 0            | GPIOn pin is used as an input.                                                                  |  |  |  |  |  |  |
| 11–8       | DIRn†                | 1            | GPIOn pin is used as an output.                                                                 |  |  |  |  |  |  |
| _          | 7 ROMEN <sup>‡</sup> | 0            | ROM is mapped out (value at reset if XIO = 0)                                                   |  |  |  |  |  |  |
| 7          | ROMEN+               | 1            | ROM is mapped in (value at reset if XIO = 1)                                                    |  |  |  |  |  |  |
|            | CORE                 | 0            | cLEAD core A is selected for XIO REQ bit. DSP subsystem A is tied low internally for this bit.  |  |  |  |  |  |  |
| 6          | SEL                  | 1            | cLEAD core B is selected for XIO REQ bit. DSP subsystem B is tied high internally for this bit. |  |  |  |  |  |  |
| _          | XIO                  | 0            | EMIF is not available to the cLEAD core determined by the CORE SEL bit.                         |  |  |  |  |  |  |
| 5          | GRANT                | 1            | EMIF is granted to the cLEAD core determined by the CORE SEL bit.                               |  |  |  |  |  |  |
|            | XIO                  | 0            | EMIF is not requested for the cLEAD core indicated by the CORE SEL bit.                         |  |  |  |  |  |  |
| 4          | REQ                  | 1            | Request EMIF for the cLEAD core indicated by the CORE SEL bit.                                  |  |  |  |  |  |  |
|            | GPIO                 | 0            | GPIOn is driven with a 0 (DIRn = 1). GPIOn is read as 0 (DIRn = 0).                             |  |  |  |  |  |  |
| 3–0        | DATn†                | 1            | GPIOn is driven with a 1 (DIRn = 1). GPIOn is read as 1 (DIRn = 0).                             |  |  |  |  |  |  |

Table 3–14. General-Purpose I/O Control Register Bit Functions

† n = 3, 2, 1, or 0

<sup>‡</sup>1 denotes XIO = 1, 0 denotes XIO = 0

Register bit 7 is used as ROMEN to enable and disable ROM space. In XIO mode, ROM enable (ROMEN) reflects the state of the A\_GPIO0 and B\_GPIO0 pins (GPIODAT0 input) to enable the applicable on-chip ROM after reset. Register bits (6:4) are used for XIO arbitration of external memory interface (EMIF) control between DSP subsystems. The timer out (TOUT) bit is used to multiplex the output of the timer and GPIO3. All GPIO pins are programmable as an input or output by the direction bit (DIRn). Data is either driven or read from the data bit field (DATn). DIR3 has no affect when TOUT = 1.

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

## 3.9.1 Hardware Timer

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

## 3.9.2 Software-Programmable Phase-Locked Loop (PLL)

The clock generator provides clocks to the 5421 device, and consists of a phase-locked loop (PLL) circuit. The clock generator requires a reference clock input, which must be provided by using an external clock source. The reference clock input is then divided by two (DIV mode) to generate clocks for the 5421 device. Alternately, the PLL circuit can be used (PLL mode) to generate the device clock by multiplying the reference clock frequency by a scale factor, allowing use of a clock source with a lower frequency than that of the CPU. Bypass (multiply by 1) is the default mode at reset. 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 5421 device. Only subsystem A controls the PLL. Subsystem B cannot access the PLL registers.

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

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

The software-programmable PLL is controlled using the 16-bit memory-mapped (address 0058h) clock mode register (CLKMD). The CLKMD register is used to define the clock configuration of the PLL clock module. Figure 3–20 shows the bit layout of the clock mode register and Table 3–15 describes the bit functions.

| _ | 15 |                     | 12 | 11                  | 10      | 3  | 2                      | 1       | 0      |
|---|----|---------------------|----|---------------------|---------|----|------------------------|---------|--------|
|   |    | PLLMUL <sup>†</sup> |    | PLLDIV <sup>†</sup> | PLLCOUN | r† | PLLON/OFF <sup>†</sup> | PLLNDIV | STATUS |
|   |    | R/W                 |    | R/W                 | R/W     |    | R/W                    | R/W     | R/W    |

<sup>†</sup>When in DIV mode (PLLSTATUS is low), PLLMUL, PLLDIV, PLLCOUNT, and PLLON/OFF are don't cares, and their contents are indeterminate. **LEGEND:** R = Read, W = Write

| BIT BIT<br>NO. NAME |                        | FUNCTION                                                                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|---------------------|------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| 15–12               | PLLMULT                | PLL multiplier. PLLMUL defines the frequency multiplier in conjunction with PLLDIV and PLLNDIV. Set Table 3–16.                                                                                                                                                                                                                                                          |  |  |  |  |
|                     |                        | PLL divider. PLLDIV defines the frequency multiplier in conjunction with PLLMUL and PLLNDIV. See Table 3–16.                                                                                                                                                                                                                                                             |  |  |  |  |
| 11                  | PLLDIV <sup>†</sup>    | PLLDIV = 0 Means that an integer multiply factor is used                                                                                                                                                                                                                                                                                                                 |  |  |  |  |
|                     |                        | PLLDIV = 1 Means that a noninteger multiply factor is used                                                                                                                                                                                                                                                                                                               |  |  |  |  |
| 10–3                | PLLCOUNT               | PLL counter value. PLLCOUNT specifies the number of input clock cycles (in increments of 16 cycles) for the PLL lock timer to count before the PLL begins clocking the processor after the PLL is started. The PLL counter is a down-counter, which is driven by the input clock divided by 16; therefore, for every 16 input clocks, the PLL counter decrements by one. |  |  |  |  |
|                     |                        | The PLL counter can be used to ensure that the processor is not clocked until the PLL is locked, so that only valid clock signals are sent to the device.                                                                                                                                                                                                                |  |  |  |  |
| 2                   | PLLON/OFF <sup>†</sup> | PLL on/off. PLLON/OFF enables or disables the PLL part of the clock generator in conjunction with the PLLNDIV bit (see Table 3–17). Note that PLLON/OFF and PLLNDIV can both force the PLL to run; when PLLON/OFF is high, the PLL runs independently of the state of PLLNDIV.                                                                                           |  |  |  |  |
| 1                   | PLLNDIV                | PLLNDIV configures PLL mode when high or DIV mode when low. PLLNDIV defines the frequency multiplier in conjunction with PLLDIV and PLLMUL. See Table 3–16.                                                                                                                                                                                                              |  |  |  |  |
| 0                   | STATUS                 | Indicates the PLL mode.<br>STATUS = 0 Indicates DIV mode<br>STATUS = 1 Indicates PLL mode                                                                                                                                                                                                                                                                                |  |  |  |  |

#### Table 3–15. Clock Mode Register (CLKMD) Bit Functions

<sup>†</sup>When in DIV mode (PLLSTATUS is low), PLLMUL, PLLDIV, PLLCOUNT, and PLLON/OFF are don't cares, and their contents are indeterminate.

| PLLNDIV | PLLDIV | PLLMUL    | MULTIPLIER <sup>†</sup>           |
|---------|--------|-----------|-----------------------------------|
| 0       | х      | 0–14      | 0.5                               |
| 0       | х      | 15        | 0.25                              |
| 1       | 0      | 0–14      | PLLMUL + 1                        |
| 1       | 0      | 15        | bypass (multiply by 1) $\ddagger$ |
| 1       | 1      | 0 or even | (PLLMUL + 1)/2                    |
| 1       | 1      | odd       | PLLMUL/4                          |

| Table 3–16. Multiplier Related to PLLNDIV, PLLDIV, and PLLM |
|-------------------------------------------------------------|
|-------------------------------------------------------------|

<sup>†</sup> CLKOUT = CLKIN \* Multiplier

‡ Indicates the default clock mode after reset

| PLLON/OFF | PLLNDIV | VCO STATE |  |  |  |  |  |
|-----------|---------|-----------|--|--|--|--|--|
| 0         | 0       | off       |  |  |  |  |  |
| 1         | 0       | on        |  |  |  |  |  |
| 0         | 1       | on        |  |  |  |  |  |
| 1         | 1       | on        |  |  |  |  |  |

| Table 2 17 | VCO Truth Ta | abla |
|------------|--------------|------|
|            |              | apie |

## 3.9.3 PLL Clock Programmable Timer

During the lockup period, the PLL should not be used to clock the 5421. The PLLCOUNT programmable lock timer provides a convenient method of automatically delaying clocking of the device by the PLL until lock is achieved.

The PLL lock timer is a counter, loaded from the PLLCOUNT field in the CLKMD register, that decrements from its preset value to 0. The timer can be preset to any value from 0 to 255, and its input clock is CLKIN divided by 16. The resulting lockup delay can therefore be set from 0 to  $255 \times 16$  CLKIN cycles.

The lock timer is activated when the operating mode of the clock generator is switched from DIV to PLL. During the lockup period, the clock generator continues to operate in DIV mode; after the PLL lock timer decrements to zero, the PLL begins clocking the 5421.

Accordingly, the value loaded into PLLCOUNT is chosen based on the following formula:

$$PLLCOUNT = \frac{Lockup Time}{16 \times T_{CLKIN}}$$

where  $T_{CLKIN}$  is the input reference clock period and lockup time is the required VCO lockup time, as shown in Table 3–18.

| CLKOUT FREQUENCY (MHz) | LOCKUP TIME (µs) |
|------------------------|------------------|
| 5                      | 23               |
| 10                     | 17               |
| 20                     | 16               |
| 40                     | 19               |
| 60                     | 24               |
| 80                     | 29               |
| 100                    | 35               |

## 3.10 Memory-Mapped Registers

The 5421 has 27 memory-mapped CPU registers, which are mapped in data memory space address 0h to 1Fh. Each 5421 device also has a set of memory-mapped registers associated with peripherals. Table 3–19 gives a list of CPU memory-mapped registers (MMRs) available. Table 3–20 shows additional peripheral MMRs associated with the 5421.

| NAME      | ADDF<br>DEC | RESS<br>HEX | DESCRIPTION                      |  |  |
|-----------|-------------|-------------|----------------------------------|--|--|
| IMR       | 0           | 0           | Interrupt Mask Register          |  |  |
| IFR       | 1           | 1           | Interrupt Flag Register          |  |  |
| —         | 2–5         | 2–5         | Reserved for testing             |  |  |
| ST0       | 6           | 6           | Status Register 0                |  |  |
| ST1       | 7           | 7           | Status Register 1                |  |  |
| AL        | 8           | 8           | Accumulator A Low Word (15–0)    |  |  |
| AH        | 9           | 9           | Accumulator A High Word (31–16)  |  |  |
| AG        | 10          | А           | Accumulator A Guard Bits (39–32) |  |  |
| BL        | 11          | В           | Accumulator B Low Word (15–0)    |  |  |
| ВН        | 12          | С           | Accumulator B High Word (31–16)  |  |  |
| BG        | 13          | D           | Accumulator B Guard Bits (39–32) |  |  |
| TREG      | 14          | E           | Temporary Register               |  |  |
| TRN       | 15          | F           | Transition Register              |  |  |
| AR0       | 16          | 10          | Auxiliary Register 0             |  |  |
| AR1       | 17          | 11          | Auxiliary Register 1             |  |  |
| AR2       | 18          | 12          | Auxiliary Register 2             |  |  |
| AR3       | 19          | 13          | Auxiliary Register 3             |  |  |
| AR4       | 20          | 14          | Auxiliary Register 4             |  |  |
| AR5       | 21          | 15          | Auxiliary Register 5             |  |  |
| AR6       | 22          | 16          | Auxiliary Register 6             |  |  |
| AR7       | 23          | 17          | Auxiliary Register 7             |  |  |
| SP        | 24          | 18          | Stack Pointer                    |  |  |
| 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 Register   |  |  |
| XPC 30 1E |             | 1E          | Extended Program Counter         |  |  |
| — 31 1F I |             | 1F          | Reserved                         |  |  |

 Table 3–19. Processor Memory-Mapped Registers for Each DSP Subsystem

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

Table 3–20. Peripheral Memory-Mapped Registers for Each DSP Subsystem

<sup>†</sup> See Table 3–21 for a detailed description of the McBSP control registers and their subaddresses. <sup>‡</sup> See Table 3–22 for a detailed description of the DMA subbank addressed registers.

## 3.11 McBSP Control Registers and Subaddresses

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

| McBSP0 |         | McBSP1 |         | McBSP2 |         |                 |                                              |  |
|--------|---------|--------|---------|--------|---------|-----------------|----------------------------------------------|--|
| NAME   | ADDRESS | NAME   | ADDRESS | NAME   | ADDRESS | SUB-<br>ADDRESS | DESCRIPTION                                  |  |
| SPCR10 | 39h     | SPCR11 | 49h     | SPCR12 | 35h     | 00h             | Serial port control register 1               |  |
| SPCR20 | 39h     | SPCR21 | 49h     | SPCR22 | 35h     | 01h             | Serial port control register 2               |  |
| RCR10  | 39h     | RCR11  | 49h     | RCR12  | 35h     | 02h             | Receive control register 1                   |  |
| RCR20  | 39h     | RCR21  | 49h     | RCR22  | 35h     | 03h             | Receive control register 2                   |  |
| XCR10  | 39h     | XCR11  | 49h     | XCR12  | 35h     | 04h             | Transmit control register 1                  |  |
| XCR20  | 39h     | XCR21  | 49h     | XCR22  | 35h     | 05h             | Transmit control register 2                  |  |
| SRGR10 | 39h     | SRGR11 | 49h     | SRGR12 | 35h     | 06h             | Sample rate generator register 1             |  |
| SRGR20 | 39h     | SRGR21 | 49h     | SRGR22 | 35h     | 07h             | Sample rate generator register 2             |  |
| MCR10  | 39h     | MCR11  | 49h     | MCR12  | 35h     | 08h             | Multichannel register 1                      |  |
| MCR20  | 39h     | MCR21  | 49h     | MCR22  | 35h     | 09h             | Multichannel register 2                      |  |
| RCERA0 | 39h     | RCERA1 | 49h     | RCERA2 | 35h     | 0Ah             | Receive channel enable register partition A  |  |
| RCERB0 | 39h     | RCERB1 | 49h     | RCERB2 | 35h     | 0Bh             | Receive channel enable register partition B  |  |
| XCERA0 | 39h     | XCERA1 | 49h     | XCERA2 | 35h     | 0Ch             | Transmit channel enable register partition A |  |
| XCERB0 | 39h     | XCERB1 | 49h     | XCERB2 | 35h     | 0Dh             | Transmit channel enable register partition B |  |
| PCR0   | 39h     | PCR1   | 49h     | PCR2   | 35h     | 0Eh             | Pin control register                         |  |
| RCERC0 | 39h     | RCERC1 | 49h     | RCERC2 | 35h     | 010h            | Receive channel enable register partition C  |  |
| RCERD0 | 39h     | RCERD1 | 49h     | RCERD2 | 35h     | 011h            | Receive channel enable register partition D  |  |
| XCERC0 | 39h     | XCERC1 | 49h     | XCERC2 | 35h     | 012h            | Transmit channel enable register partition C |  |
| XCERD0 | 39h     | XCERD1 | 49h     | XCERD2 | 35h     | 013h            | Transmit channel enable register partition D |  |
| RCERE0 | 39h     | RCERE1 | 49h     | RCERE2 | 35h     | 014h            | Receive channel enable register partition E  |  |
| RCERF0 | 39h     | RCERF1 | 49h     | RCERF2 | 35h     | 015h            | Receive channel enable register partition F  |  |
| XCERE0 | 39h     | XCERE1 | 49h     | XCERE2 | 35h     | 016h            | Transmit channel enable register partition E |  |
| XCERF0 | 39h     | XCERF1 | 49h     | XCERF2 | 35h     | 017h            | Transmit channel enable register partition F |  |
| RCERG0 | 39h     | RCERG1 | 49h     | RCERG2 | 35h     | 018h            | Receive channel enable register partition G  |  |
| RCERH0 | 39h     | RCERH1 | 49h     | RCERH2 | 35h     | 019h            | Receive channel enable register partition H  |  |
| XCERG0 | 39h     | XCERG1 | 49h     | XCERG2 | 35h     | 01Ah            | Transmit channel enable register partition G |  |
| XCERH0 | 39h     | XCERH1 | 49h     | XCERH2 | 35h     | 01Bh            | Transmit channel enable register partition H |  |

 Table 3–21. McBSP Control Registers and Subaddresses

## 3.12 DMA Subbank Addressed Registers

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

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

| 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 event 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 event 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 event 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 event 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 event 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 event 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)  |  |

#### Table 3–22. DMA Subbank Addressed Registers

| NAME   | ADDRESS | SUB-<br>ADDRESS | DESCRIPTION                                              |  |
|--------|---------|-----------------|----------------------------------------------------------|--|
| 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                               |  |
| DMGSA0 | 56h/57h | 24h             | DMA channel 0 global source address reload register      |  |
| DMGDA0 | 56h/57h | 25h             | DMA channel 0 global destination address reload register |  |
| DMGCR0 | 56h/57h | 26h             | DMA channel 0 global count reload register               |  |
| DMGFR0 | 56h/57h | 27h             | DMA channel 0 global frame count reload register         |  |
| XSRCDP | 56h/57h | 28h             | DMA extended source data page                            |  |
| XDSTDP | 56h/57h | 29h             | DMA extended destination data page                       |  |
| DMGSA1 | 56h/57h | 2Ah             | DMA channel 1 global source address reload register      |  |
| DMGDA1 | 56h/57h | 2Bh             | DMA channel 1 global destination address reload register |  |
| DMGCR1 | 56h/57h | 2Ch             | DMA channel 1 global count reload register               |  |
| DMGFR1 | 56h/57h | 2Dh             | DMA channel 1 global frame count reload register         |  |
| DMGSA2 | 56h/57h | 2Eh             | DMA channel 2 global source address reload register      |  |
| DMGDA2 | 56h/57h | 2Fh             | DMA channel 2 global destination address reload register |  |
| DMGCR2 | 56h/57h | 30h             | DMA channel 2 global count reload register               |  |
| DMGFR2 | 56h/57h | 31h             | DMA channel 2 global frame count reload register         |  |
| DMGSA3 | 56h/57h | 32h             | DMA channel 3 global source address reload register      |  |
| DMGDA3 | 56h/57h | 33h             | DMA channel 3 global destination address reload register |  |
| DMGCR3 | 56h/57h | 34h             | DMA channel 3 global count reload register               |  |
| DMGFR3 | 56h/57h | 35h             | DMA channel 3 global frame count reload register         |  |
| DMGSA4 | 56h/57h | 36h             | DMA channel 4 global source address reload register      |  |
| DMGDA4 | 56h/57h | 37h             | DMA channel 4 global destination address reload register |  |
| DMGCR4 | 56h/57h | 38h             | DMA channel 4 global count reload register               |  |
| DMGFR4 | 56h/57h | 39h             | DMA channel 4 global frame count reload register         |  |
| DMGSA5 | 56h/57h | 3Ah             | DMA channel 5 global source address reload register      |  |
| DMGDA5 | 56h/57h | 3Bh             | DMA channel 5 global destination address reload register |  |
| DMGCR5 | 56h/57h | 3Ch             | DMA channel 5 global count reload register               |  |
| DMGFR5 | 56h/57h | 3Dh             | DMA channel 5 global frame count reload register         |  |

Table 3–22. DMA Subbank Addressed Registers (Continued)

## 3.13 Interrupts

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

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

### Table 3–23. 5421 Interrupt Locations and Priorities for Each DSP Subsystem

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

For example, if subsystem A is required to notify subsystem B of a completed task, subsystem A must write a "1" to the IPIRQ field to generate a IPINT interrupt on subsystem B. On subsystem B, the IPINT interrupt is latched in IFR.14. Figure 5 shows the bit layout of the BSCR and Table 6 describes the bit functions.

| 15                | 14                | 13    | 12    | 11                | 10                | 9     | 8        |
|-------------------|-------------------|-------|-------|-------------------|-------------------|-------|----------|
| Reserved          | IPINT             | DMAC5 | DMAC4 | XINT1 or<br>DMAC3 | RINT1 or<br>DMAC2 | HPINT | Reserved |
|                   | R/                | W     | R/W   | R/W               | R/W               | R/W   |          |
| 7                 | 6                 | 5     | 4     | 3                 | 2                 | 1     | 0        |
| XINT2 or<br>DMAC1 | RINT2 or<br>DMAC0 | XINTO | RINT0 | TINT              | Reserved          | INT1  | INTO     |
| R/W               | R/W               | R/W   | R/W   | R/W               |                   | R/W   | R/W      |

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

## Figure 3–21. Bit Layout of the IMR and IFR Registers for Subsystems A and B

| BIT | BIT       | BIT   | FUNCTIONS FOR IMR and IFR REGISTERS FOR Each DSP Subsystem                         |  |  |  |
|-----|-----------|-------|------------------------------------------------------------------------------------|--|--|--|
| NO. | NAME      | VALUE |                                                                                    |  |  |  |
| 15  | Reserved  | Х     | Register bit is reserved.                                                          |  |  |  |
| 14  |           | 0     | IFR/IMR: Interprocessor IRQ has no interrupt pending/is disabled (masked).         |  |  |  |
| 14  | 4 IPINT 1 |       | IFR/IMR: Interprocessor IRQ has an interrupt pending/is enabled.                   |  |  |  |
| 40  | DMAGE     | 0     | IFR/IMR: DMA Channel 5 has no interrupt pending/is disabled (masked).              |  |  |  |
| 13  | DMAC5 0   |       | IFR/IMR: DMA Channel 5 has an interrupt pending/is enabled.                        |  |  |  |
| 40  | 0         |       | IFR/IMR: DMA Channel 4 has no interrupt pending/is disabled (masked).              |  |  |  |
| 12  | DMAC4     | 1     | IFR/IMR: DMA Channel 4 has an interrupt pending/is enabled.                        |  |  |  |
|     |           | 0     | IFR/IMR: McBSP_1 has no transmit interrupt pending/is disabled (masked).           |  |  |  |
|     | XINT1     | 1     | IFR/IMR: McBSP_1 has a transmit interrupt pending/is enabled.                      |  |  |  |
| 11  |           | 0     | IFR/IMR: DMA Channel 3 has no interrupt pending/is disabled (masked).              |  |  |  |
|     | DMAC3 1   |       | IFR/IMR: DMA Channel 3 has an interrupt pending/is enabled.                        |  |  |  |
|     |           | 0     | IFR/IMR: McBSP_1 has no receive interrupt pending/is disabled (masked).            |  |  |  |
|     | RINT1     | 1     | IFR/IMR: McBSP_1 has a receive interrupt pending/is enabled.                       |  |  |  |
| 10  |           | 0     | IFR/IMR: DMA Channel 2 has no interrupt pending/is disabled (masked).              |  |  |  |
|     | DMAC2 1   |       | IFR/IMR: DMA Channel 2 has an interrupt pending/is enabled.                        |  |  |  |
| -   |           | 0     | IFR/IMR: Host-port interface has no DSPINT interrupt pending/is disabled (masked). |  |  |  |
| 9   | HPINT     | 1     | IFR/IMR: Host-port interface has an DSPINT interrupt pending/is enabled.           |  |  |  |
| 8   | Reserved  | Х     | Register bit is reserved.                                                          |  |  |  |
|     |           | 0     | IFR/IMR: McBSP_2 has no transmit interrupt pending/is disabled (masked).           |  |  |  |
| _   | XINT2     | 1     | IFR/IMR: McBSP_2 has a transmit interrupt pending/is enabled.                      |  |  |  |
| 7   |           | 0     | IFR/IMR: DMA Channel 1 has no interrupt pending/is disabled (masked).              |  |  |  |
|     | DMAC1     | 1     | IFR/IMR: DMA Channel 1 has an interrupt pending/is enabled.                        |  |  |  |
|     |           | 0     | IFR/IMR: McBSP_2 has no receive interrupt pending/is disabled (masked).            |  |  |  |
| _   | RINT2 1   |       | IFR/IMR: McBSP_2 has a receive interrupt pending/is enabled.                       |  |  |  |
| 6   |           | 0     | IFR/IMR: DMA Channel 0 has no interrupt pending/is disabled (masked).              |  |  |  |
|     | DMAC0     |       | IFR/IMR: DMA Channel 0 has an interrupt pending/is enabled.                        |  |  |  |
| _   |           | 0     | IFR/IMR: McBSP_0 has no receive interrupt pending/is disabled (masked).            |  |  |  |
| 5   | XINT0     | 1     | IFR/IMR: McBSP_0 has a receive interrupt pending/is enabled.                       |  |  |  |
|     |           | 0     | IFR/IMR: McBSP_0 has no receive interrupt pending/is disabled (masked).            |  |  |  |
| 4   | RINT0     | 1     | IFR/IMR: McBSP_0 has a receive interrupt pending/is enabled.                       |  |  |  |

| Table 3–24. | Bit Functions | for IMR | and IFR | <b>Registers</b> f | or Each I | OSP Subsystem |
|-------------|---------------|---------|---------|--------------------|-----------|---------------|
|             |               |         |         |                    |           |               |

| BIT<br>NO. | BIT<br>NAME | BIT<br>VALUE | FUNCTION                                                                         |  |
|------------|-------------|--------------|----------------------------------------------------------------------------------|--|
| 2          |             | 0            | IFR/IMR: Timer has no interrupt pending/is disabled (masked).                    |  |
| 3          | TINT        | 1            | IFR/IMR: Timer has an interrupt pending/is enabled.                              |  |
| 2          | Reserved    | Х            | Register bit is reserved.                                                        |  |
|            | INITA       | 0            | IFR/IMR: Ext user interrupt pin 1 has no interrupt pending/is disabled (masked). |  |
|            | 1 INT1 1    |              | IFR/IMR: Ext user interrupt pin 1 has an interrupt pending/is enabled.           |  |
|            | 0           |              | IFR/IMR: Ext user interrupt pin 0 has no interrupt pending/is disabled (masked). |  |
| 0          | INT0        | 1            | IFR/IMR: Ext user interrupt pin 0 has an interrupt pending/is enabled.           |  |

#### Table 3–24. Bit Functions for IMR and IFR Registers for Each DSP Subsystem (Continued)

## 3.14 IDLE3 Power-Down Mode

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

## 3.15 Emulating the 5421 Device

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

"CPU\_B" TI320C5xx

"CPU\_A" TI320C5xx

Use Code Composer Studio to convert this file into a binary file (**board.dat**), readable by the emulation tools. Place the board.dat file in the directory that contains the emulator software.

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

# 4 **Documentation Support**

Extensive documentation supports all TMS320<sup>™</sup> DSP 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 TMS320C5000<sup>™</sup> family of DSPs:

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

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

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

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

A series of DSP textbooks is published by Prentice-Hall and John Wiley & Sons to support digital signal processing research and education. The TMS320<sup>™</sup> DSP family 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 *http://www.ti.com* uniform resource locator (URL).

# 5 Electrical Specifications

This section provides the absolute maximum ratings and the recommended operating conditions for the 320VC5421 DSP.

## 5.1 Absolute Maximum Ratings

The list of absolute maximum ratings are specified over operating case temperature. 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. All voltage values are with respect to V<sub>SS</sub>.

| Supply voltage I/O range, DV <sub>DD</sub>        | $\ldots$ — 0.5 V to 4.0 V           |
|---------------------------------------------------|-------------------------------------|
| Supply voltage core range, CV <sub>DD</sub>       | $\ldots$ — 0.5 V to 2.4 V           |
| Supply voltage analog PLL range, AV <sub>DD</sub> | $\ldots$ — 0.5 V to 2.4 V           |
| Input voltage range, V <sub>I</sub>               | – 0.5 V to DV <sub>DD</sub> + 0.5 V |
| Output voltage range, Vo                          | – 0.5 V to DV <sub>DD</sub> + 0.5 V |
| Operating case temperature range, T <sub>C</sub>  | –40°C to 85°C                       |
| Storage temperature range T <sub>stg</sub>        | – 65°C to 150°C                     |

## 5.2 Recommended Operating Conditions

The device recommended operating conditions are supplied in Table 5–1 and the electrical characteristics over recommended operating case temperature range (unless otherwise noted) are listed in Table 5–2. Figure 5–1 provides the test load circuit values for a 3.3-V device.

|      |                               |                                                    | MIN                 | NOM  | MAX                 | UNIT |
|------|-------------------------------|----------------------------------------------------|---------------------|------|---------------------|------|
| DVDD | Device supply voltage, I/O    |                                                    | 3                   | 3.3  | 3.6                 | V    |
| CVDD | Device supply voltage, core   |                                                    | 1.75                | 1.80 | 1.98                | V    |
| AVDD | Device supply voltage, PLL    |                                                    | 1.75                | 1.80 | 1.98                | V    |
| VSS  | Supply voltage, GND           |                                                    |                     | 0    |                     | V    |
| VIH  | High-level input voltage, I/O | Schmitt triggered inputs $DV_{DD} = 3.3 \pm 0.3 V$ | 0.7DV <sub>DD</sub> |      | DVDD                | V    |
|      |                               | All other inputs                                   | 2                   |      | DVDD                |      |
| VIL  | Low-level input voltage, I/O  | Schmitt triggered inputs $DV_{DD} = 3.3 \pm 0.3 V$ | 0                   |      | 0.3DV <sub>DD</sub> | V    |
|      |                               | All other inputs                                   | 0                   |      | 0.8                 |      |
| ЮН   | High-level output current     |                                                    |                     |      | -300                | μΑ   |
| IOL  | Low-level output current      |                                                    |                     |      | 1.5                 | mA   |
| ТС   | Operating case temperature    |                                                    | -40                 |      | 85                  | °C   |

#### Table 5–1. Recommended Operating Conditions

## 5.3 Electrical Characteristics

Table 5–2 describes the electrical characteristics over recommended operating case temperature range (unless otherwise noted).

| PARAMETER                        |                                      | TEST CONDITIONS <sup>†</sup> | MIN                                                                                    | TYP‡ | MAX | UNIT |    |  |
|----------------------------------|--------------------------------------|------------------------------|----------------------------------------------------------------------------------------|------|-----|------|----|--|
| VOH                              | High-level output voltage§           |                              | $DV_{DD}$ = 3.3 $\pm$ 0.3 V, I_{OH} = MAX                                              | 2.4  |     |      | V  |  |
| VOL                              | Low-level output voltage§            |                              | I <sub>OL</sub> = MAX                                                                  |      |     | 0.4  | V  |  |
| IIZ                              | Input current in high imped          | ance                         | $DV_{DD} = MAX, V_I = V_{SS} \text{ to } DV_{DD}$                                      | -10  |     | 10   | μA |  |
|                                  |                                      |                              | With internal pulldown                                                                 | -10  |     | 35   |    |  |
|                                  | Input current                        | See pin descriptions         | With internal pullups                                                                  | -35  |     | 10   |    |  |
| 1                                | $(V_I = V_{SS} \text{ to } DV_{DD})$ | PPD[15:0]                    | Bus holders enabled, $DV_{DD} = MAX^{\ddagger}$                                        | -200 |     | 200  | μA |  |
|                                  |                                      | All other input-only pins    |                                                                                        | -10  |     | 10   |    |  |
| IDDC                             | C Supply current, both core CPUs     |                              | $CV_{DD} = 1.8 \text{ V}, \text{ f}_{X} = 100 \text{ MHz}$ ¶,<br>T <sub>C</sub> = 25°C |      | 90# |      | mA |  |
| I <sub>DDP</sub>                 | Supply current, pins                 |                              |                                                                                        |      | 54  |      | mA |  |
| IDDA                             | Supply current, PLL                  |                              |                                                                                        |      | 5   |      | mA |  |
|                                  |                                      | IDLE2                        | PLL $\times$ n mode, 20 MHz input                                                      |      | 2   |      | mA |  |
| IDDC                             | Supply current, standby              | IDLE3                        | PLL x n mode, 20 MHz input                                                             |      | 600 |      | μA |  |
| C <sub>i</sub> Input capacitance |                                      |                              |                                                                                        | 10   |     | pF   |    |  |
| Co                               | Output capacitance                   |                              |                                                                                        |      | 10  |      | pF |  |

| Table 5–2. | Electrical | Characteristics |
|------------|------------|-----------------|
|------------|------------|-----------------|

<sup>†</sup> For test conditions shown as MIN, MAX, or NOM, use the appropriate value specified in the recommended operating conditions table.

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

§ All input and output voltage levels except RS, INTO, INT1, NMI, CLKIN, BCLKX, BCLKR, HAS, HCS, HDS1, HDS2, and HPIRS are LVTTL-compatible.

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

# This value is based on 50% usage of MAC and 50% usage of NOP instructions. Actual operating current varies with the program being executed.
 I This value was obtained using the following conditions: external memory writes at a rate of 20 million writes per second, CLKOFF = 0, full-duplex operation of all six McBSPs at a rate of 10 million bits per second each, and 15-pF loads on all outputs. For more details on how this calculation

is performed, refer to the Calculation of TMS320LC54x Power Dissipation Application Report (literature number SPRA164).



Figure 5–1. 3.3-V Test Load Circuit

## 5.4 Package Thermal Resistance Characteristics

Table 5–3 provides the thermal resistance characteristics for the recommended package types used on the 320VC5421 DSP.

| PARAMETER        | PGE PACKAGE | UNIT |
|------------------|-------------|------|
| $R_{\Theta JA}$  | 56          | °C/W |
| R <sub>OJC</sub> | 5           | °C/W |

### Table 5–3. Thermal Resistance Characteristics

## 5.5 Timing Parameter Symbology

Timing parameter symbols used in the timing requirements and switching characteristics tables are created in accordance with JEDEC Standard 100. To shorten the symbols, some of the pin names and other related terminology have been abbreviated as follows:

Lowercase subscripts and their meanings:

| а   | access time                            |
|-----|----------------------------------------|
| С   | cycle time (period)                    |
| d   | delay time                             |
| dis | disable time                           |
| en  | enable time                            |
| f   | fall time                              |
| h   | hold time                              |
| r   | rise time                              |
| su  | setup time                             |
| t   | transition time                        |
| V   | valid time                             |
| W   | pulse duration (width)                 |
| Х   | Unknown, changing, or don't care level |
|     |                                        |

Letters and symbols and their meanings:

- H High
- L Low
- V Valid
- Z High impedance

## 5.6 Clock Options

The frequency of the reference clock provided at the CLKIN pin can be divided by a factor of two or four to generate the internal machine cycle. The selection of the clock mode is described in the software-programmable phase-locked loop (PLL) section.

## 5.6.1 Divide-By-Two, Divide-By-Four, and Bypass Clock Option (PLL Disabled)

The frequency of the reference clock provided at the CLKIN pin can be divided by a factor of two or four to generate the internal machine cycle. The selection of the clock mode is described in the software-programmable phase-locked loop (PLL) section.

The following timing requirements and switching characteristics tables assume testing over recommended operating conditions and  $H = 0.5t_{c(CO)}$  (see Figure 5–2).

### Table 5–4. Divide-By-2 and Divide-by-4 Clock Options Timing Requirements

|                     |                            | MIN | МАХ | UNIT |
|---------------------|----------------------------|-----|-----|------|
| tc(CI)              | Cycle time, CLKIN          | 20  | †   | ns   |
| <sup>t</sup> f(CI)  | Fall time, CLKIN           |     | 8   | ns   |
| <sup>t</sup> r(CI)  | Rise time, CLKIN           |     | 8   | ns   |
| <sup>t</sup> w(CIL) | Pulse duration, CLKIN low  | 5   |     | ns   |
| <sup>t</sup> w(CIH) | Pulse duration, CLKIN high | 5   |     | ns   |

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

| Table 5–5. Divide-By-2 and Divide-by-4 Clock Options Switching Ch | naracteristics |
|-------------------------------------------------------------------|----------------|
| Table of 0. Diffac by 2 and Diffac by 4 clock options ownoning on | laraotoristios |

|                        | PARAMETER                                 | MIN | TYP                 | MAX | UNIT |
|------------------------|-------------------------------------------|-----|---------------------|-----|------|
| <sup>t</sup> c(CO)     | Cycle time, CLKOUT                        | 40  | 2t <sub>c(CI)</sub> | †   | ns   |
| tc(CO)                 | Cycle time, CLKOUT – bypass mode          | 40  | 2t <sub>c(CI)</sub> | †   | ns   |
| <sup>t</sup> d(CIH-CO) | Delay time, CLKIN high to CLKOUT high/low | 3   | 6                   | 10  | ns   |
| <sup>t</sup> f(CO)     | Fall time, CLKOUT                         |     | 2                   |     | ns   |
| <sup>t</sup> r(CO)     | Rise time, CLKOUT                         |     | 2                   |     | ns   |
| tw(COL)                | Pulse duration, CLKOUT low                | H–2 | H–1                 | H+2 | ns   |
| <sup>t</sup> w(COH)    | Pulse duration, CLKOUT high               | H–2 | H–1                 | H+2 | ns   |

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





## 5.6.2 Multiply-By-N Clock Option (PLL Enabled)

The frequency of the reference clock provided at the 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 software-programmable phase-locked loop (PLL) section.

The following timing requirements and switching characteristics tables assume testing over recommended operating conditions and  $H = 0.5t_{C(CO)}$  (see Figure 5–3).

|                     |                                                                                                        |                                                     | MIN | MAX | UNIT |
|---------------------|--------------------------------------------------------------------------------------------------------|-----------------------------------------------------|-----|-----|------|
|                     |                                                                                                        | Integer PLL multiplier N (N = $1-15$ ) <sup>†</sup> | 20‡ | 200 |      |
| <sup>t</sup> c(CI)  | Cycle time, CLKIN<br>PLL multiplier N = x.5 <sup>†</sup><br>PLL multiplier N = x.25, x.75 <sup>†</sup> | PLL multiplier N = $x.5^{\dagger}$                  | 20‡ | 100 | ns   |
| , ,                 |                                                                                                        | 20‡                                                 | 50  |     |      |
| <sup>t</sup> f(CI)  | Fall time, CLKIN                                                                                       |                                                     |     | 8   | ns   |
| <sup>t</sup> r(CI)  |                                                                                                        |                                                     |     | 8   | ns   |
| <sup>t</sup> w(CIL) | Pulse duration, CLKIN low                                                                              |                                                     | 5   |     | ns   |
| <sup>t</sup> w(CIH) | Pulse duration, CLKIN high                                                                             |                                                     | 5   |     | ns   |

#### Table 5–6. Multiply-By-N Clock Option Timing Requirements

 $^{\dagger}N =$  Multiplication factor

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

Table 5–7. Multiply-By-N Clock Option Switching Characteristics

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

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



Figure 5–3. External Multiply-by-One Clock Timing

# 5.7 External Memory Interface Timing

## 5.7.1 Memory Read

External memory reads can be performed in consecutive or nonconsecutive mode under control of the  $\overline{\text{CONSEC}}$  bit in the BSCR. The following timing requirements and switching characteristics tables assume testing over recommended operating conditions with  $\overline{\text{MSTRB}} = 0$  and  $H = 0.5t_{c(CO)}$  (see Figure 5–4).

|                                                               | MIN                                                                                                                                                                            | MAX                                                                                                                                                                                                                                                                                 | UNIT                                                                                                                                                                                                                                                                                                          |
|---------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Access time, read data access from address valid <sup>†</sup> |                                                                                                                                                                                | 2H–12                                                                                                                                                                                                                                                                               | ns                                                                                                                                                                                                                                                                                                            |
| Access time, read data access from MSTRB low                  |                                                                                                                                                                                | 2H–11                                                                                                                                                                                                                                                                               | ns                                                                                                                                                                                                                                                                                                            |
| Setup time, read data before CLKOUT low                       | 9                                                                                                                                                                              |                                                                                                                                                                                                                                                                                     | ns                                                                                                                                                                                                                                                                                                            |
| Hold time, read data after CLKOUT low                         | 0                                                                                                                                                                              |                                                                                                                                                                                                                                                                                     | ns                                                                                                                                                                                                                                                                                                            |
| Hold time, read data after address invalid                    | 0                                                                                                                                                                              |                                                                                                                                                                                                                                                                                     | ns                                                                                                                                                                                                                                                                                                            |
| Hold time, read data after MSTRB high                         | 0                                                                                                                                                                              |                                                                                                                                                                                                                                                                                     | ns                                                                                                                                                                                                                                                                                                            |
|                                                               | Access time, read data access from MSTRB low<br>Setup time, read data before CLKOUT low<br>Hold time, read data after CLKOUT low<br>Hold time, read data after address invalid | Access time, read data access from address valid <sup>†</sup> Access time, read data access from MSTRB low         Setup time, read data before CLKOUT low       9         Hold time, read data after CLKOUT low       0         Hold time, read data after address invalid       0 | Access time, read data access from address valid <sup>†</sup> 2H–12         Access time, read data access from MSTRB low       2H–11         Setup time, read data before CLKOUT low       9         Hold time, read data after CLKOUT low       0         Hold time, read data after address invalid       0 |

### Table 5–8. Memory Read Timing Requirements

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

### Table 5–9. Memory Read Switching Characteristics

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

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

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

§ In the case of a memory read preceded by a memory write





## 5.7.2 Memory Write

The following switching characteristics table assumes testing over recommended operating conditions with MSTRB = 0 and  $H = 0.5t_{c(CO)}$  (see Figure 5–5).

|                            | PARAMETER                                                | MIN   | MAX   | UNIT |
|----------------------------|----------------------------------------------------------|-------|-------|------|
| <sup>t</sup> d(CLKH-A)     | Delay time, CLKOUT high to address valid <sup>†‡</sup>   | – 1   | 6     | ns   |
| <sup>t</sup> d(CLKL-A)     | Delay time, CLKOUT low to address valid $^{ m \$}$       | -1    | 5     | ns   |
| <sup>t</sup> d(CLKL-MSL)   | Delay time, CLKOUT low to MSTRB low                      | -1    | 4     | ns   |
| <sup>t</sup> d(CLKL-D)W    | Delay time, CLKOUT low to data valid                     | 0     | 7     | ns   |
| <sup>t</sup> d(CLKL-MSH)   | Delay time, CLKOUT low to MSTRB high                     | – 1   | 4     | ns   |
| <sup>t</sup> d(CLKH-RWL)   | Delay time, CLKOUT high to $R/\overline{W}$ low          | 0     | 4     | ns   |
| <sup>t</sup> d(CLKH-RWH)   | Delay time, CLKOUT high to R/W high                      | 0     | 4     | ns   |
| <sup>t</sup> d(RWL-MSTRBL) | Delay time, R/W low to MSTRB low                         | H – 2 | H + 2 | ns   |
| <sup>t</sup> h(A)W         | Hold time, address valid after CLKOUT high <sup>†‡</sup> | -1    | 6     | ns   |
| <sup>t</sup> h(D)MSH       | Hold time, write data valid after MSTRB high             | H – 3 | H +3§ | ns   |
| <sup>t</sup> w(SL)MS       | Pulse duration, MSTRB low§                               | 2H–4  |       | ns   |
| <sup>t</sup> su(A)W        | Setup time, address valid before MSTRB low <sup>†</sup>  | 2H–4  |       | ns   |
| <sup>t</sup> su(D)MSH      | Setup time, write data valid before MSTRB high           | 2H–5  | 2H+5§ | ns   |
|                            |                                                          |       |       |      |

| Table F 40 | Manaam | 10/1:40 | Curitals in a | Characteristics |
|------------|--------|---------|---------------|-----------------|
|            | wemory | write   | Switching     | Characteristics |

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

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

 $\$  In the case of a memory write preceded by an I/O cycle





## 5.8 Ready Timing For Externally Generated Wait States

The following timing requirements table assumes testing over recommended operating conditions and  $H = 0.5t_{c(CO)}$  (see Figure 5–6 and Figure 5–7).

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

#### Table 5–11. Ready Timing Requirements for Externally Generated Wait States<sup>†</sup>

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



Figure 5–6. Memory Read With Externally Generated Wait States



Figure 5–7. Memory Write With Externally Generated Wait States

## 5.9 Parallel I/O Interface Timing

### 5.9.1 Parallel I/O Port Read

The following timing requirements and switching characteristics tables assume testing over recommended operating conditions with  $\overline{\text{IOSTRB}} = 0$  and  $\text{H} = 0.5t_{C(CO)}$  (see Figure 5–8).

|                           |                                                               | MIN | MAX   | UNIT |
|---------------------------|---------------------------------------------------------------|-----|-------|------|
| <sup>t</sup> a(A)IO       | Access time, read data access from address valid <sup>†</sup> |     | 3H–12 | ns   |
| <sup>t</sup> a(ISTRBL)IO  | Access time, read data access from IOSTRB low                 |     | 2H–11 | ns   |
| <sup>t</sup> su(D)IOR     | Setup time, read data before CLKOUT high                      | 9   |       | ns   |
| <sup>t</sup> h(D)IOR      | Hold time, read data after CLKOUT high                        | 0   |       | ns   |
| <sup>t</sup> h(ISTRBH-D)R | Hold time, read data after IOSTRB high                        | 0   |       | ns   |

| Table 5–12. | Parallel I/O | Port Read | Timing | Requirements |
|-------------|--------------|-----------|--------|--------------|
|-------------|--------------|-----------|--------|--------------|

 $^\dagger$  Address and  $\overline{\rm IS}$  timings are included in timings referenced as address.

### Table 5–13. Parallel I/O Port Read Switching Characteristics

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

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





## 5.9.2 Parallel I/O Port Write

The following switching characteristics table assumes testing over recommended operating conditions with  $\overline{\text{IOSTRB}} = 0$  and  $H = 0.5t_{c(CO)}$  (see Figure 5–9).

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

| Table 5–14 | Parallel I/O | Port Write | Switching | Characteristics |
|------------|--------------|------------|-----------|-----------------|
|------------|--------------|------------|-----------|-----------------|

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



Figure 5–9. Parallel I/O Port Write (IOSTRB=0)

## 5.10 Externally Generated Wait States

### 5.10.1 I/O Port Read and Write With Externally Generated Wait States

The following timing requirements table assumes testing over recommended operating conditions and  $H = 0.5t_{c(CO)}$  (see Figure 5–10 and Figure 5–11).

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

#### Table 5–15. Externally Generated Wait States Timing Requirements<sup>†</sup>

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

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



Figure 5–10. I/O Port Read With Externally Generated Wait States



Figure 5–11. I/O Port Write With Externally Generated Wait States

# 5.11 Reset, BIO, Interrupt, and MP/MC Timings

The following timing requirements table assumes testing over recommended operating conditions and  $H = 0.5t_{c(CO)}$  (see Figure 5–12, Figure 5–13, and Figure 5–14).

|                         |                                                                   | MIN  | MAX   | UNIT |
|-------------------------|-------------------------------------------------------------------|------|-------|------|
| <sup>t</sup> h(RS)      | Hold time, RS after CLKOUT low                                    | 0    |       | ns   |
| <sup>t</sup> h(BIO)     | Hold time, BIO after CLKOUT low                                   | 0    |       | ns   |
| <sup>t</sup> h(INT)     | Hold time, INTn, NMI, after CLKOUT low <sup>†</sup>               | 0    |       | ns   |
| <sup>t</sup> w(RSL)     | Pulse duration, RS low <sup>‡</sup> §                             | 4H+5 |       | ns   |
| <sup>t</sup> w(BIO)A    | Pulse duration, BIO low, asynchronous <sup>†</sup>                | 5H   |       | ns   |
| <sup>t</sup> w(INTH)A   | Pulse duration, INTn, NMI high (asynchronous) <sup>†</sup>        | 4H   |       | ns   |
| <sup>t</sup> w(INTL)A   | Pulse duration, INTn, NMI low (asynchronous) <sup>†</sup>         | 4H   |       | ns   |
| <sup>t</sup> w(INTL)WKP | Pulse duration, INTn, NMI low for IDLE2/IDLE3 wakeup <sup>†</sup> | 8    |       | ns   |
| <sup>t</sup> w(XIO)     | Pulse duration, XIO switched                                      | 4H   |       | ns   |
| ten(XIO)                | Enable time, after XIO switched                                   |      | 4H+10 | ns   |
| t <sub>su(RS)</sub>     | Setup time, RS before CLKIN low§                                  | 5    |       | ns   |
| t <sub>su</sub> (BIO)   | Setup time, BIO before CLKOUT low                                 | 9    | 12    | ns   |
| <sup>t</sup> su(INT)    | Setup time, INTn, NMI, RS before CLKOUT low                       | 9    | 13    | ns   |

#### Table 5–16. Reset, BIO, Interrupt, and MP/MC Timing Requirements

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

<sup>‡</sup> If the PLL mode is selected, then at power-on sequence, or at wakeup from IDLE3, RS must be held low for at least 50 μs to ensure synchronization and lock-in of the PLL.

§ RS can cause a change in clock frequency, changing the value of H (see the software-programmable phase-locked loop (PLL) section).



Figure 5–12. Reset and BIO Timings





# 5.12 HOLD and HOLDA Timings

The following timing requirements and switching characteristics tables assume testing over recommended operating conditions and  $H = 0.5t_{C(CO)}$  (see Figure 5–15).

## Table 5–17. HOLD and HOLDA Timing Requirements

|                       |                                             | MIN   | MAX | UNIT |
|-----------------------|---------------------------------------------|-------|-----|------|
| <sup>t</sup> w(HOLD)  | Pulse duration, HOLD low                    | 4H+10 |     | ns   |
| <sup>t</sup> su(HOLD) | Setup time, HOLD low/high before CLKOUT low | 8     |     | ns   |

## Table 5–18. HOLD and HOLDA Switching Characteristics

|                           | PARAMETER                                                         | MIN  | MAX   | UNIT |
|---------------------------|-------------------------------------------------------------------|------|-------|------|
| <sup>t</sup> dis(CLKL-A)  | Disable time, address, PS, DS, IS high impedance from CLKOUT high |      | 5     | ns   |
| <sup>t</sup> dis(CLKL-RW) | Disable time, R/W high impedance from CLKOUT high                 |      | 5     | ns   |
| <sup>t</sup> dis(CLKL-S)  | Disable time, MSTRB, IOSTRB high impedance from CLKOUT high       |      | 5     | ns   |
| <sup>t</sup> dis(CLKL-D)  | Disable time, Data from CLKOUT high                               |      | 5     | ns   |
| <sup>t</sup> en(CLKL-A)   | Enable time, address, PS, DS, IS from CLKOUT high                 |      | 2H+5  | ns   |
| <sup>t</sup> en(CLKL-D)   | Enable time, Data from CLKOUT high                                |      | 2H+5  | ns   |
| <sup>t</sup> en(CLKL-RW)  | Enable time, R/W enabled from CLKOUT high                         |      | 2H+5  | ns   |
| <sup>t</sup> en(CLKL-S)   | Enable time, MSTRB, IOSTRB enabled from CLKOUT high               | 1    | 2H+5  | ns   |
| <sup>t</sup> d(HOLDAL)    | Delay time, HOLDA low after CLKOUT high                           | 0    | 11H+5 | ns   |
| <sup>t</sup> d(HOLDAH)    | Delay time, HOLDA high after CLKOUT high                          | 0    | 5     | ns   |
| <sup>t</sup> w(HOLDA)     | Pulse duration, HOLDA low duration                                | 2H–3 |       | ns   |



NOTE A: A[17:16] apply to DMA accesses to extended DATA and PROGRAM memory. The CPU has access to **only** extended PROGRAM memory.

Figure 5–15. HOLD and HOLDA Timings (HM = 1)

# 5.13 External Flag (XF) and TOUT Timings

The following switching characteristics table assumes testing over recommended operating conditions and

```
H = 0.5t_{C(CO)} (see Figure 5–16 and Figure 5–17).
```

#### Table 5–19. External Flag (XF) and TOUT Switching Characteristics

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



Figure 5–16. External Flag (XF) Timing



Figure 5–17. Timer (TOUT) Timing

# 5.14 General-Purpose I/O Timing

The following timing requirements and switching characteristics tables assume testing over recommended operating conditions (see Figure 5–18).

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

#### Table 5–20. General-Purpose I/O Timing Requirements

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



## Figure 5–18. GPIO Timings

# 5.15 Multichannel Buffered Serial Port (McBSP) Timing

# 5.15.1 McBSP Transmit and Receive Timings

The following timing requirements and switching characteristics tables assume testing over recommended operating conditions and  $H = 0.5t_{C(CO)}$  (see Figure 5–19 and Figure 5–20).

|                             |                                                 |             | MIN | MAX | UNIT |
|-----------------------------|-------------------------------------------------|-------------|-----|-----|------|
| <sup>t</sup> c(BCKRX)       | Cycle time, BCLKR/X                             | BCLKR/X ext | 4H  |     | ns   |
| tw(BCKRX)                   | Pulse duration, BCLKR/X low or BCLKR/X high     | BCLKR/X ext | 6   |     | ns   |
|                             |                                                 | BCLKR int   | 0   |     |      |
| <sup>t</sup> h(BCKRL-BFRH)  | Hold time, external BFSR high after BCLKR low   | BCLKR ext   | 4   |     | ns   |
|                             |                                                 | BCLKR int   | 0   |     |      |
| <sup>t</sup> h(BCKRL-BDRV)  | Hold time, BDR valid after BCLKR low            | BCLKR ext   | 5   |     | ns   |
| <sup>t</sup> h(BCKXL-BFXH)  |                                                 | BCLKX int   | 0   |     |      |
|                             | Hold time, external BFSX high after BCLKX low   | BCLKX ext   | 4   |     | ns   |
|                             |                                                 | BCLKR int   | 10  |     |      |
| <sup>t</sup> su(BFRH-BCKRL) | Setup time, external BFSR high before BCLKR low | BCLKR ext   | 4   |     | ns   |
|                             |                                                 | BCLKR int   | 10  |     |      |
| <sup>t</sup> su(BDRV-BCKRL) | Setup time, BDR valid before BCLKR low          | BCLKR ext   | 3   |     | ns   |
|                             |                                                 | BCLKX int   | 10  |     |      |
| <sup>t</sup> su(BFXH-BCKXL) | Setup time, external BFSX high before BCLKX low | BCLKX ext   | 6   |     | ns   |
| <sup>t</sup> r(BCKRX)       | Rise time, BCLKR/X                              | BCLKR/X ext |     | 8   | ns   |
| tf(BCKRX)                   | Fall time, BCLKR/X                              | BCLKR/X ext |     | 8   | ns   |

# Table 5–22. McBSP Transmit and Receive Timing Requirements<sup>†</sup>

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

|                               | PARAMETER                                                                                     |                     |             | MIN   | MAX   | UNIT |
|-------------------------------|-----------------------------------------------------------------------------------------------|---------------------|-------------|-------|-------|------|
| <sup>t</sup> c(BCKRX)         | Cycle time, BCLKR/X                                                                           |                     | BCLKR/X int | 4H    |       | ns   |
| <sup>t</sup> w(BCKRXH)        | Pulse duration, BCLKR/X high                                                                  |                     | BCLKR/X int | D-4‡  | D+1‡  | ns   |
| <sup>t</sup> w(BCKRXL)        | BCKRXL) Pulse duration, BCLKR/X low                                                           |                     | BCLKR/X int | C-4‡  | C+1‡  | ns   |
| <sup>t</sup> d(BCKRH-BFRV)    |                                                                                               |                     | BCLKR int   | -3    | 3     | ns   |
| 1,000,000,000,000             | Delay time, BCLKX high to internal BFSX valid                                                 |                     | BCLKX int   | -3    | 8     | 20   |
| <sup>t</sup> d(BCKXH-BFXV)    | B                                                                                             |                     | BCLKX ext   | 2     | 15    | ns   |
|                               | Disable time, BCLKX high to BDX high impedance follow                                         | ing last data hit   | BCLKX int   | -8    | 3     | 20   |
| <sup>t</sup> dis(BCKXH-BDXHZ) | Disable time, BCERA high to BDA high impedance follow                                         | ning last data bit  | BCLKX ext   | 1     | 12    | 115  |
|                               | Delay time, BCLKX high to BDX valid. This applies to all bit                                  | ts except the first | BCLKX int   | -1    | 11    |      |
|                               | bit transmitted.                                                                              |                     | BCLKX ext   | 4     | 20    | ns   |
| <sup>t</sup> d(BCKXH-BDXV)    |                                                                                               | DXENA = 0           | BCLKX int   |       | 11    | 20   |
|                               | Delay time, BCLKX high to BDX valid.§                                                         | DAENA = 0           | BCLKX ext   |       | 20    | 115  |
|                               | Only applies to first bit transmitted when in Data Delay 1<br>or 2 (XDATDLY=01b or 10b) modes | DXENA = 1           | BCLKX int   |       | 4H+6  |      |
|                               |                                                                                               | DAENA = 1           | BCLKX ext   |       | 4H+15 |      |
|                               | 5                                                                                             | DXENA = 0           | BCLKX int   | 5     |       |      |
| * (50)0(1155)0                | Enable time, BCLKX high to BDX driven.§                                                       | DAENA = 0           | BCLKX ext   | 16    |       | 20   |
| <sup>t</sup> en(BCKXH-BDX)    | Only applies to first bit transmitted when in Data Delay 1<br>or 2 (XDATDLY=01b or 10b) modes | DXENA = 1           | BCLKX int   | 4H    |       | 115  |
|                               |                                                                                               | DAENA = 1           | BCLKX ext   | 4H+12 |       |      |
|                               |                                                                                               | DXENA = 0           | BFSX int    |       | 9     |      |
| • · · · · · · · · ·           | Delay time, BFSX high to BDX valid.§                                                          | DAENA = 0           | BFSX ext    |       | 15    | ~~   |
| <sup>t</sup> d(BFXH-BDXV)     | Only applies to first bit transmitted when in Data Delay 0 (XDATDLY=00b) mode.                | DXENA = 1           | BFSX int    |       | 4H    | ns   |
|                               |                                                                                               | DAENA = I           | BFSX ext    |       | 4H+15 |      |
|                               |                                                                                               | DXENA = 0           | BFSX int    | 2     |       |      |
| •                             | Enable time, BFSX high to BDX driven.§                                                        | D = 0               | BFSX ext    | 14    |       | 20   |
| <sup>t</sup> en(BFXH-BDX)     | Only applies to first bit transmitted when in Data Delay 0<br>(XDATDLY=00b) mode              | DXENA = 1           | BFSX int    | 4H–1  |       | ns   |
|                               |                                                                                               | DAENA = I           | BFSX ext    | 2H+5  |       |      |

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

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

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

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

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







Figure 5–20. McBSP Transmit Timings

# 5.15.2 McBSP Transmit and Receive Timing Using CLKR/X as a Clock Source Input to the Sample Rate Generator (SRGR)

The 5421 McBSP has been enhanced to allow the use of an external clock source as an input to the sample rate generator (SRGR). This capability is enabled by reconfiguring either the transmit shift clock (BCLKX), or the receive shift clock (BCLKR) to function as the input clock to the SRGR. When the McBSP is used in this mode, the output of the SRGR is then used as a common shift clock for both the receive and transmit sections of the serial port. This clock is output on the other of these two pins. Therefore, if BCLKX is reconfigured as the SRGR input, then BCLKR is used as the shift clock for both the transmit and receive sections of the McBSP. If BCLKR is reconfigured as the SRGR input, then BCLKX is used as the shift clock for both the transmit and receive sections of the McBSP. The relevant timings for this mode of operation are depicted in Figure 5–21. The other timings for serial port operations are the same as when using an internal clock source as described in the standard McBSP transmit and receive timings presented in section 5.15.1.

The following timing requirements and switching characteristics tables assume testing over recommended operating conditions and  $H = 0.5t_{c(CO)}$  (see Figure 5–21).

|                       |                                       | MIN | MAX | UNIT |
|-----------------------|---------------------------------------|-----|-----|------|
| <sup>t</sup> c(BCKS)  | Cycle time, SRGR clock input          | 2H  |     | ns   |
| <sup>t</sup> w(BCKSH) | Pulse duration, SRGR clock input high | H–4 | H+1 | ns   |
| <sup>t</sup> w(BCKSL) | Pulse duration, SRGR clock input low  | H–4 | H+1 | ns   |
| <sup>t</sup> r(BCKS)  | Rise time, SRGR clock input           |     | 8   | ns   |
| <sup>t</sup> f(BCKS)  | Fall time, SRGR clock input           |     | 8   | ns   |

#### Table 5–24. McBSP Sample Rate Generator Timing Requirements

#### Table 5–25. McBSP Sample Rate Generator Switching Characteristics

| PARAMETER                                                          | MIN | MAX | UNIT |
|--------------------------------------------------------------------|-----|-----|------|
| td(BCKSH-BCLKRXH) Delay time, from SRGR clock input to SRGR output | 3   | 13  | ns   |



# 5.15.3 McBSP General-Purpose I/O Timing

The following timing requirements and switching characteristics tables assume testing over recommended operating conditions (see Figure 5–22).

#### Table 5–26. McBSP General-Purpose I/O Timing Requirements

|                                                                     | MIN                    | MAX | UNIT |
|---------------------------------------------------------------------|------------------------|-----|------|
| t <sub>su(BGPIO-COH)</sub> Setup time, BGPIOx input mode before CLk | KOUT high <sup>†</sup> | )   | ns   |
| th(COH-BGPIO) Hold time, BGPIOx input mode after CLKOU              | JT high <sup>†</sup> ( |     | ns   |

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

#### Table 5–27. McBSP General-Purpose I/O Switching Characteristics

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

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



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

#### Figure 5–22. McBSP General-Purpose I/O Timings

# 5.15.4 McBSP as SPI Master or Slave Timing

The following timing requirements and switching characteristics tables assume testing over recommended operating conditions and H =  $0.5t_{c(CO)}$  (see Figure 5–23, Figure 5–24, Figure 5–25, and Figure 5–26).

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

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

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

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

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

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

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

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

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

I 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 5–23. McBSP Timing as SPI Master or Slave: CLKSTP = 10b, CLKXP = 0

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

## Table 5–30. McBSP as SPI Master or Slave Timing Requirements (CLKSTP = 11b, CLKXP = 0)<sup>†</sup>

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

|  | Table 5–31. McBS | SP as SPI Master or Slave | e Switching Characteristics | $(CLKSTP = 11b, CLKXP = 0)^{\dagger}$ |
|--|------------------|---------------------------|-----------------------------|---------------------------------------|
|--|------------------|---------------------------|-----------------------------|---------------------------------------|

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

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

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

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

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

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

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

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

I 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 5–24. McBSP Timing as SPI Master or Slave: CLKSTP = 11b, CLKXP = 0

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

## Table 5–32. McBSP as SPI Master or Slave Timing Requirements (CLKSTP = 10b, CLKXP = $1)^{\dagger}$

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

#### Table 5–33. McBSP as SPI Master or Slave Switching Characteristics (CLKSTP = 10b, CLKXP = 1)<sup>†</sup>

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

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

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

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

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

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

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

I 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 5–25. McBSP Timing as SPI Master or Slave: CLKSTP = 10b, CLKXP = 1

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

## Table 5–34. McBSP as SPI Master or Slave Timing Requirements (CLKSTP = 11b, CLKXP = 1)<sup>†</sup>

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

| Table 5–35. McB | SP as SPI Master or Slav | e Switching Characteristics | $(CLKSTP = 11b, CLKXP = 1)^{\dagger}$ |
|-----------------|--------------------------|-----------------------------|---------------------------------------|
|                 |                          |                             |                                       |

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

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

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

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

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

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

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

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

I 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 5–26. McBSP Timing as SPI Master or Slave: CLKSTP = 11b, CLKXP = 1

# 5.16 Host-Port Interface Timing

The following timing requirements and switching characteristics tables assume testing over recommended operating conditions and  $H = 0.5t_{c(CO)}$  (see Figure 5–27 through Figure 5–34). In the following tables,  $\overline{DS}$  refers to the logical OR of HCS, HDS1, and HDS2, and HD refers to any of the HPI data bus pins (HD0, HD1, HD2, etc.).

|                                      |                                                                                                                                                 |                                                                                                    |          | MIN       | MAX | UNIT |
|--------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|----------|-----------|-----|------|
| <sup>t</sup> su(HBV-DSL)             | Setup time, HAD valid before DS                                                                                                                 | 5 falling edge <sup>†‡</sup>                                                                       |          | 5         |     | ns   |
| <sup>t</sup> h(DSL-HBV)              | Hold time, HAD valid after DS falling edge <sup>†‡</sup>                                                                                        |                                                                                                    |          | 5         |     | ns   |
| <sup>t</sup> su(HBV-HSL)             | Setup time, HAD valid before HAS falling edge <sup>†</sup>                                                                                      |                                                                                                    |          | 5         |     | ns   |
| <sup>t</sup> h(HSL-HBV)              | Hold time, HAD valid after HAS                                                                                                                  | falling edge <sup>†</sup>                                                                          |          | 5         |     | ns   |
| <sup>t</sup> su(HAV-DSH)             | Setup time, address valid before                                                                                                                | DS rising edge (nonmultiplexed write) <sup>‡</sup>                                                 |          | 5         |     | ns   |
| <sup>t</sup> su(HAV-DSL)             | Setup time, address valid before                                                                                                                | e DS falling edge (nonmultiplexed read)‡                                                           |          | –(4H + 5) |     | ns   |
| <sup>t</sup> h(DSH-HAV)              | Hold time, address valid after DS                                                                                                               | S rising edge (nonmultiplexed mode) $\ddagger$                                                     |          | 1         |     | ns   |
| <sup>t</sup> su(HSL-DSL)             | Setup time, HAS low before DS                                                                                                                   | falling edge‡                                                                                      |          | 5         |     | ns   |
| <sup>t</sup> h(HSL-DSL)              | Hold time, HAS low after DS fall                                                                                                                | ing edge‡                                                                                          |          | 2         |     | ns   |
| <sup>t</sup> w(DSL)                  | Pulse duration, DS low <sup>‡</sup>                                                                                                             |                                                                                                    |          | 30        |     | ns   |
| <sup>t</sup> w(DSH)                  | Pulse duration, DS high‡                                                                                                                        |                                                                                                    |          | 10        |     | ns   |
|                                      | Cycle_time, DS rising edge to next DS rising edge‡                                                                                              | increment) memory accesses (or writes to                                                           | Reads    | 10H + 30  |     |      |
|                                      |                                                                                                                                                 |                                                                                                    | Writes   | 10H + 10  |     | ns   |
|                                      |                                                                                                                                                 | Nonmultiplexed or multiplexed mode (no increment) memory accesses (or writes to                    | Reads    | 16H + 30  |     |      |
|                                      |                                                                                                                                                 |                                                                                                    | Writes   | 16H + 10  |     | ns   |
|                                      |                                                                                                                                                 | Nonmultiplexed or multiplexed mode (no increment) memory accesses (or writes to                    | Reads    | 24H + 30  |     |      |
|                                      |                                                                                                                                                 | the FETCH bit) with 32-bit DMA activity.                                                           |          | 24H + 10  |     | ns   |
| <sup>t</sup> c(DSH-DSH) <sup>§</sup> | Cycle time, DS rising edge to next DS rising edge <sup>‡</sup>                                                                                  | Multiplexed (autoincrement) memory accea<br>writes to the FETCH bit) with no DMA activ             |          |           |     | ns   |
|                                      | (In autoincrement mode,                                                                                                                         | Multiplexed (autoincrement) memory accesses (or writes to the FETCH bit) with 16-bit DMA activity. |          | 16H + 10  |     | ns   |
|                                      | WRITE timings are the same as READ timings.) Multiplexed (autoincrement) memory accesses (or writes to the FETCH bit) with 32-bit DMA activity. |                                                                                                    | 24H + 10 |           | ns  |      |
|                                      | Cycle time, DS rising edge to next DS rising edge for writes to DSPINT and HINT                                                                 |                                                                                                    |          | 8H        |     | ns   |
|                                      | Cycle time, DS rising edge to next DS rising edge for HPIC reads, HPIC XADD bit writes, and address register reads and writes <sup>‡</sup>      |                                                                                                    |          | 40        |     | ns   |
| t <sub>su(HDV-DSH)W</sub>            | Setup time, HD valid before DS rising edge <sup>‡</sup>                                                                                         |                                                                                                    |          | 10        |     | ns   |
| th(DSH-HDV)W                         | Hold time, HD valid after DS rising edge, write <sup>‡</sup>                                                                                    |                                                                                                    |          | 1         |     | ns   |
| t <sub>su</sub> (SELV-DSL)           | Setup time, SELA/B valid before DS falling edge‡                                                                                                |                                                                                                    |          | 5         |     | ns   |
| th(DSH-SELV)                         | Hold time, SELA/B valid after DS                                                                                                                | S rising edge‡                                                                                     |          | 0         |     | ns   |

 $\frac{1}{10}$  HAD stands for HCNTL0, HCNTL1, and HR/W.

<sup>‡</sup> DS refers to either HCS or HDS, whichever is controlling the transfer. Refer to the *TMS320C54x DSP Reference Set, Volume 5: Enhanced Peripherals* (literature number SPRU302) for information regarding logical operation of the HPI16. These timings are shown assuming that HDS is the signal controlling the transfer.

§ These timings are for HPI accesses which do not cross from one subsystem to the other. For accesses which do cross from one subsystem to the other, additional cycles are required. A detailed description of these considerations is provided in the application note *Memory Transfers with TMS320VC5420 and TMS320VC5421 DSPs* (literature number SPRA620).

|                                       |                                                                                               | MIN                                                                                                                                  | MAX | UNIT                          |     |  |  |  |
|---------------------------------------|-----------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|-----|-------------------------------|-----|--|--|--|
| td(DSL-HDD)                           | Delay time, DS lo                                                                             | 3                                                                                                                                    | 20  | ns                            |     |  |  |  |
| <sup>t</sup> d(DSL-HDV1) <sup>#</sup> |                                                                                               | Case 1a: Memory accesses initiated immediately following a write when DMAC is active in 16-bit mode and $t_{W(DSH)}$ was < 18H       |     | 32H+20 - t <sub>w</sub> (DSH) |     |  |  |  |
|                                       | Delay time, DS<br>low to HD valid<br>for first word of<br>an HPI read <sup>†</sup>            | Case 1b: Memory accesses initiated by an autoincrement when DMAC is active in 16-bit mode and $t_{W(DSH)}$ was < 18H                 |     | 16H+20 - t <sub>w(DSH)</sub>  | l)  |  |  |  |
|                                       |                                                                                               | Case 1c: Memory accesses not initiated by an autoincrement (or not immediately following a write) when DMAC is active in 16-bit mode |     | 16H+20                        |     |  |  |  |
|                                       |                                                                                               | Case 1d: Memory accesses initiated by an autoincrement when DMAC is active in 16-bit mode and $t_{W}(\text{DSH})$ was $\geq$ 18H     |     | 20                            | ns  |  |  |  |
|                                       |                                                                                               | Case 1e: Memory accesses initiated immediately following a write when DMAC is active in 32-bit mode and $t_{W(DSH)}$ was < 26H       |     | 48H+20 – t <sub>w(DSH)</sub>  |     |  |  |  |
|                                       |                                                                                               | Case 1f: Memory access initiated by an autoincrement when DMAC is active in 32-bit mode and $t_{W(DSH)}$ was < 26H                   |     | 24H+20 – t <sub>w(DSH)</sub>  |     |  |  |  |
|                                       |                                                                                               | Case 1g: Memory access not initiated by an autoincrement (or not immediately following a write) when DMAC is active in 32-bit mode   |     | 24H+20                        |     |  |  |  |
|                                       |                                                                                               | Case 1h: Memory access initiated by an autoincrement when DMAC is active in 32-bit mode and $t_{W(DSH)}$ was $\geq$ 26H              |     | 20                            |     |  |  |  |
| <sup>t</sup> d(HSL-HDV1) <sup>#</sup> | Delay time,<br>HAS low to HD<br>valid for first<br>word of an HPI<br>read                     | Case 2a: Memory accesses initiated immediately following a write when DMAC is inactive and $t_{W(DSH)}$ was < 10H                    |     | 20H+20 – t <sub>w(DSH)</sub>  |     |  |  |  |
|                                       |                                                                                               | Case 2b: Memory accesses initiated by an autoincrement when DMAC is inactive and $t_{W(DSH)}$ was < 10H                              |     | 10H+20 - tw(DSH)              | ns  |  |  |  |
|                                       |                                                                                               | Case 2c: Memory accesses not initiated by an autoincrement (or not immediately following a write) when DMAC is inactive              |     | 10H+20                        |     |  |  |  |
|                                       |                                                                                               | Case 2d: Memory accesses initiated by an autoincrement when DMAC is inactive and $t_{W}(\text{DSH})$ was $\geq 10\text{H}$           |     | 20                            |     |  |  |  |
|                                       |                                                                                               | Case 3: HPIC/HPIA reads                                                                                                              |     | 20                            |     |  |  |  |
| <sup>t</sup> d(DSL-HDV2)              | Multiplexed read                                                                              | s with autoincrement. Prefetch completed.                                                                                            | 3   | 20                            | ns  |  |  |  |
| <sup>t</sup> d(DSH:HYH) <sup>#</sup>  | Delay time, DS<br>high to HRDY<br>high <sup>§</sup><br>(writes and<br>autoincrement<br>reads) | Memory accesses (or writes to the FETCH bit) when no DMA is active                                                                   |     | 10H+5                         |     |  |  |  |
|                                       |                                                                                               | Memory accesses (or writes to the FETCH bit) with one or more 16-bit DMA channels active                                             |     | 16H+5                         | ns  |  |  |  |
|                                       |                                                                                               | Memory accesses (or writes to the FETCH bit) with one or more 32-bit DMA channels active                                             |     | 24H+5                         | 110 |  |  |  |
|                                       |                                                                                               | Writes to DSPINT and HINT‡                                                                                                           |     | 4H + 5                        |     |  |  |  |
| <sup>t</sup> v(HYH-HDV)               | Valid time, HD va                                                                             | alid after HRDY high                                                                                                                 |     | 7                             | ns  |  |  |  |
| <sup>t</sup> h(DSH-HDV)R              | Hold time, HD valid after DS rising edge, read <sup>‡</sup> 0 10                              |                                                                                                                                      |     |                               |     |  |  |  |
| <sup>t</sup> d(COH-HYH)               | Delay time, CLK                                                                               |                                                                                                                                      | 5   | ns                            |     |  |  |  |
| <sup>t</sup> d(DSL-HYL)               | Delay time, DS lo                                                                             | ow to HRDY low¶                                                                                                                      |     | 12                            | ns  |  |  |  |
| td(DSH-HYL)                           | Delay time, DS h                                                                              |                                                                                                                                      | 12  | ns                            |     |  |  |  |

Table 5–37. HPI16 Mode Switching Characteristics

<sup>†</sup> HAD stands for HCNTL0, HCNTL1, and HR/W.

§ DS refers to either HCS or HDS, whichever is controlling the transfer. Refer to the *TMS320C54x DSP Reference Set, Volume 5: Enhanced Peripherals* (literature number SPRU302) for information regarding logical operation of the HPI16. These timings are shown assuming that HDS is the signal controlling the transfer.

¶ HRDY does not go low for other register accesses.

# These timings are for HPI accesses which do not cross from one subsystem to the other. For accesses which do cross from one subsystem to the other, additional cycles are required. A detailed description of these considerations is provided in the application note *Memory Transfers with TMS320VC5420 and TMS320VC5421 DSPs* (literature number SPRA620).

| PARAMETER                                                             | MIN | MAX | UNIT |
|-----------------------------------------------------------------------|-----|-----|------|
| t <sub>d(HSL-HYL)</sub> Delay time, HAS low to HRDY low, read         |     | 12  | ns   |
| t <sub>d(COH-HTX)</sub> Delay time, CLKOUT rising edge to HINT change |     | 5   | ns   |
|                                                                       |     |     |      |

<sup>†</sup>HAD stands for HCNTL0, HCNTL1, and HR/W.

<sup>‡</sup><u>HDS</u> refers to either <u>HDS1</u> or <u>HDS2</u>.

§ DS refers to either HCS or HDS, whichever is controlling the transfer. Refer to the *TMS320C54x DSP Reference Set, Volume 5: Enhanced Peripherals* (literature number SPRU302) for information regarding logical operation of the HPI16. These timings are shown assuming that HDS is the signal controlling the transfer.

¶ HRDY does not go low for other register accesses.

<sup>#</sup> These timings are for HPI accesses which do not cross from one subsystem to the other. For accesses which do cross from one subsystem to the other, additional cycles are required. A detailed description of these considerations is provided in the application note *Memory Transfers with TMS320VC5420 and TMS320VC5421 DSPs* (literature number SPRA620).



<sup>†</sup>HRDY goes low at these times only after autoincrement reads.

## Figure 5–27. Multiplexed Read Timings Using HAS



 $^{\dagger}\,\text{HRDY}$  goes low at these times only after autoincrement reads.

Figure 5–28. Multiplexed Read Timings With HAS Held High

Electrical Specifications



Figure 5–29. Multiplexed Write Timings Using HAS













# 6 Mechanical Data

# 6.1 Low Profile Quad Flatpack Mechanical Data

# PGE (S-PQFP-G144)

Low-Profile 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





10-Dec-2020

# PACKAGING INFORMATION

| Orderable Device   | Status<br>(1) | Package Type | Package<br>Drawing | Pins | Package<br>Qty | Eco Plan<br>(2) | Lead finish/<br>Ball material | MSL Peak Temp<br>(3) | Op Temp (°C) | Device Marking<br>(4/5) | Samples |
|--------------------|---------------|--------------|--------------------|------|----------------|-----------------|-------------------------------|----------------------|--------------|-------------------------|---------|
| SM320VC5421PGE20EP | ACTIVE        | LQFP         | PGE                | 144  | 60             | RoHS & Green    | NIPDAU                        | Level-1-260C-UNLIM   | -40 to 85    | SM320VC5421<br>PGE20EP  | Samples |
| V62/04607-01XE     | ACTIVE        | LQFP         | PGE                | 144  | 60             | RoHS & Green    | NIPDAU                        | Level-1-260C-UNLIM   | -40 to 85    | SM320VC5421<br>PGE20EP  | Samples |

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

ACTIVE: Product device recommended for new designs.

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

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

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

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

<sup>(2)</sup> RoHS: TI defines "RoHS" to mean semiconductor products that are compliant with the current EU RoHS requirements for all 10 RoHS substances, including the requirement that RoHS substance do not exceed 0.1% by weight in homogeneous materials. Where designed to be soldered at high temperatures, "RoHS" products are suitable for use in specified lead-free processes. TI may reference these types of products as "Pb-Free".

**RoHS Exempt:** TI defines "RoHS Exempt" to mean products that contain lead but are compliant with EU RoHS pursuant to a specific EU RoHS exemption.

Green: TI defines "Green" to mean the content of Chlorine (CI) and Bromine (Br) based flame retardants meet JS709B low halogen requirements of <= 1000ppm threshold. Antimony trioxide based flame retardants must also meet the <= 1000ppm threshold requirement.

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

<sup>(4)</sup> There may be additional marking, which relates to the logo, the lot trace code information, or the environmental category on the device.

(5) Multiple Device Markings will be inside parentheses. Only one Device Marking contained in parentheses and separated by a "~" will appear on a device. If a line is indented then it is a continuation of the previous line and the two combined represent the entire Device Marking for that device.

<sup>(6)</sup> Lead finish/Ball material - Orderable Devices may have multiple material finish options. Finish options are separated by a vertical ruled line. Lead finish/Ball material values may wrap to two lines if the finish value exceeds the maximum column width.

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

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



www.ti.com

# PACKAGE OPTION ADDENDUM

10-Dec-2020

# **MECHANICAL DATA**

MTQF017A - OCTOBER 1994 - REVISED DECEMBER 1996

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

#### PLASTIC QUAD FLATPACK



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



## IMPORTANT NOTICE AND DISCLAIMER

TI PROVIDES TECHNICAL AND RELIABILITY DATA (INCLUDING DATASHEETS), DESIGN RESOURCES (INCLUDING REFERENCE DESIGNS), APPLICATION OR OTHER DESIGN ADVICE, WEB TOOLS, SAFETY INFORMATION, AND OTHER RESOURCES "AS IS" AND WITH ALL FAULTS, AND DISCLAIMS ALL WARRANTIES, EXPRESS AND IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE OR NON-INFRINGEMENT OF THIRD PARTY INTELLECTUAL PROPERTY RIGHTS.

These resources are intended for skilled developers designing with TI products. You are solely responsible for (1) selecting the appropriate TI products for your application, (2) designing, validating and testing your application, and (3) ensuring your application meets applicable standards, and any other safety, security, or other requirements. These resources are subject to change without notice. TI grants you permission to use these resources only for development of an application that uses the TI products described in the resource. Other reproduction and display of these resources is prohibited. No license is granted to any other TI intellectual property right or to any third party intellectual property right. TI disclaims responsibility for, and you will fully indemnify TI and its representatives against, any claims, damages, costs, losses, and liabilities arising out of your use of these resources.

TI's products are provided subject to TI's Terms of Sale (https://www.ti.com/legal/termsofsale.html) or other applicable terms available either on ti.com or provided in conjunction with such TI products. TI's provision of these resources does not expand or otherwise alter TI's applicable warranties or warranty disclaimers for TI products.

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