# **DSP56311 User's Manual**

# 24-Bit Digital Signal Processor

DSP56311UM/D Revision 1.0, October 1999



For More Information On This Product, Go to: www.freescale.com

OnCE<sup>™</sup> and Mfax are trademarks of Motorola, Inc. Intel<sup>®</sup> is a registered trademark of the Intel Corporation. All other trademarks are those of their respective owners.

Motorola reserves the right to make changes without further notice to any products herein to improve reliability, function, or design. Motorola does not assume any liability arising out of the application or use of any product or circuit described herein; neither does it convey any license under its patent rights nor the rights of others. Motorola products are not authorized for use as components in life support devices or systems intended for surgical implant into the body or intended to support or sustain life. Buyer agrees to notify Motorola of any such intended end use whereupon Motorola shall determine availability and suitability of its product or products for the use intended. Motorola and Are registered trademarks of Motorola, Inc. Motorola, Inc. is an Equal Employment Opportunity /Affirmative Action Employer.

How to reach us:

#### USA/Europe/Locations Not Listed:

Motorola Literature Distribution P.O. Box 5405 Denver, Colorado 80217 1 (800) 441-2447 1 (303) 675-2140

#### Motorola Fax Back System (Mfax<sup>™</sup>):

TOUCHTONE (602) 244-6609 1 (800) 774-1848 RMFAX0@email.sps.mot.com

#### Asia/Pacific:

Motorola Semiconductors H.K. Ltd. 8B Tai Ping Industrial Park 51 Ting Kok Road Tai Po, N.T., Hong Kong 852-26629298

#### **Technical Resource Center:**

1 (800) 521-6274

DSP Helpline dsphelp@dsp.sps.mot.com

#### Japan:

Nippon Motorola Ltd SPD, Strategic Planning Office141 4-32-1, Nishi-Gotanda Shinagawa-ku, Japan 81-3-5487-8488

Internet: http://www.motorola-dsp.com/

© MOTOROLA INC., 1999

# Contents

### Chapter 1 Overview

| 1.1     | Manual Organization 1-1             |
|---------|-------------------------------------|
| 1.2     | Manual Conventions 1-2              |
| 1.3     | Features                            |
| 1.4     | DSP56300 Core                       |
| 1.5     | DSP56300 Core Functional Blocks 1-5 |
| 1.5.1   | Data ALU1-6                         |
| 1.5.1.1 | Data ALU Registers1-6               |
| 1.5.1.2 | Multiplier-Accumulator (MAC) 1-6    |
| 1.5.2   | Address Generation Unit (AGU) 1-7   |
| 1.5.3   | Program Control Unit (PCU) 1-7      |
| 1.5.4   | PLL and Clock Oscillator 1-8        |
| 1.5.5   | JTAG TAP and OnCE Module 1-9        |
| 1.5.6   | On-Chip Memory                      |
| 1.5.7   | Off-Chip Memory Expansion           |
| 1.6     | Internal Buses                      |
| 1.7     | Block Diagram                       |
| 1.8     | DMA1-12                             |
| 1.9     | Peripherals 1-12                    |
| 1.9.1   | GPIO Functionality                  |
| 1.9.2   | HI08 1-12                           |
| 1.9.3   | ESSI 1-13                           |
| 1.9.4   | SCI 1-13                            |
| 1.9.5   | Timer Module                        |
| 1.9.6   | EFCOP                               |

### Chapter **2** Signals/Connections

| 2.1   | Power                                       |
|-------|---------------------------------------------|
| 2.2   | Ground                                      |
| 2.3   | Clock                                       |
| 2.4   | PLL                                         |
| 2.5   | External Memory Expansion Port (Port A) 2-6 |
| 2.5.1 | External Address Bus                        |
| 2.5.2 | External Data Bus                           |
| 2.5.3 | External Bus Control                        |
| 2.6   | Interrupt and Mode Control                  |
| 2.7   | HI08                                        |

| 2.8  | Enhanced Synchronous Serial Interface 0 | 2-14 |
|------|-----------------------------------------|------|
| 2.9  | Enhanced Synchronous Serial Interface 1 | 2-17 |
| 2.10 | SCI                                     | 2-19 |
| 2.11 | Timers                                  | 2-19 |
| 2.12 | JTAG and OnCE Interface.                | 2-20 |

### Chapter **3** Memory Configuration

| 3.1   | Program Memory Space                         | 3-1 |
|-------|----------------------------------------------|-----|
| 3.1.1 | Internal Program Memory                      |     |
| 3.1.2 | Memory Switch Modes—Program Memory           | 3-2 |
| 3.1.3 | Instruction Cache                            | 3-3 |
| 3.1.4 | Program Bootstrap ROM                        | 3-3 |
| 3.2   | X Data Memory Space                          |     |
| 3.2.1 | Internal X Data Memory                       | 3-3 |
| 3.2.2 | Memory Switch Modes—X Data Memory            | 3-4 |
| 3.2.3 | Internal X I/O Space                         | 3-5 |
| 3.3   | Y Data Memory Space                          | 3-5 |
| 3.3.1 | Internal Y Data Memory                       | 3-5 |
| 3.3.2 | Memory Switch Modes—Y Data Memory            | 3-6 |
| 3.3.3 | Internal Y I/O Space                         | 3-7 |
| 3.3.4 | External Y I/O Space                         | 3-7 |
| 3.4   | Dynamic Memory Configuration Switching       | 3-7 |
| 3.5   | Sixteen-Bit Compatibility Mode Configuration | 3-8 |
| 3.6   | Memory Maps                                  | 3-8 |

### Chapter **4** Core Configuration

| Operating Modes                               |
|-----------------------------------------------|
| Bootstrap Program                             |
| Interrupt Sources and Priorities              |
| Interrupt Sources                             |
| Interrupt Priority Levels                     |
| Interrupt Source Priorities Within an IPL 4-8 |
| DMA Request Sources 4-10                      |
| Operating Mode Register (OMR) 4-11            |
| Status Register (SR) 4-15                     |
| PLL Control Register (PCTL) 4-21              |
| Device Identification Register (IDR)          |
| Address Attribute Registers (AAR0–AAR3) 4-22  |
| JTAG Identification (ID) Register 4-25        |
| JTAG Boundary Scan Register (BSR)             |
|                                               |

### Chapter 5 Programming the Peripherals

| 5.1   | Peripheral Initialization Steps     | 5-1 |
|-------|-------------------------------------|-----|
| 5.2   | Mapping the Control Registers       | 5-2 |
| 5.3   | Reading Status Registers            | 5-2 |
| 5.4   | Data Transfer Methods               | 5-3 |
| 5.4.1 | Polling                             | 5-3 |
| 5.4.2 | Interrupts                          | 5-3 |
| 5.4.3 | DMA                                 | 5-5 |
| 5.4.4 | Advantages and Disadvantages        | 5-6 |
| 5.5   | General-Purpose Input/Output (GPIO) | 5-6 |
| 5.5.1 | Port B Signals and Registers        | 5-6 |
| 5.5.2 | Port C Signals and Registers        | 5-7 |
| 5.5.3 | Port D Signals and Registers        | 5-8 |
| 5.5.4 | Port E Signals and Registers        | 5-8 |
| 5.5.5 | Triple Timer Signals and Registers  | 5-9 |

### Chapter <mark>6</mark> Host Interface (HI08)

| 6.1   | Features                            | 6-1  |
|-------|-------------------------------------|------|
| 6.1.1 | DSP Core Interface                  | 6-1  |
| 6.1.2 | Host Processor Interface            |      |
| 6.2   | Host Port Signals                   | 6-3  |
| 6.3   | Overview                            |      |
| 6.4   | Operation                           | 6-6  |
| 6.4.1 | Software Polling.                   | 6-7  |
| 6.4.2 | Core Interrupts and Host Commands.  | 6-7  |
| 6.4.3 | Core DMA Access                     |      |
| 6.4.4 | Host Requests                       | 6-9  |
| 6.4.5 | Endian Modes                        | 6-11 |
| 6.5   | Boot-up Using the HI08 Host Port    | 6-12 |
| 6.6   | DSP Core Programming Model          | 6-13 |
| 6.6.1 | Host Control Register (HCR).        | 6-14 |
| 6.6.2 | Host Status Register (HSR)          | 6-15 |
| 6.6.3 | Host Data Direction Register (HDDR) | 6-16 |
| 6.6.4 | Host Data Register (HDR)            | 6-16 |
| 6.6.5 | Host Base Address Register (HBAR)   | 6-17 |
| 6.6.6 | Host Port Control Register (HPCR).  | 6-17 |
| 6.6.7 | Host Transmit Data Register (HTX)   |      |
| 6.6.8 | Host Receive Data Register (HRX)    | 6-22 |
| 6.6.9 | DSP-Side Registers After Reset.     | 6-22 |
| 6.7   | Host Programmer's Model.            | 6-23 |
| 6.7.1 | Interface Control Register (ICR)    | 6-24 |
| 6.7.2 | Command Vector Register (CVR)       | 6-27 |

| 6.7.3 | Interface Status Register (ISR)         | 6-28 |
|-------|-----------------------------------------|------|
| 6.7.4 | Interrupt Vector Register (IVR)         | 6-30 |
| 6.7.5 | Receive Byte Registers (RXH: RXM: RXL). | 6-30 |
| 6.7.6 | Transmit Byte Registers (TXH:TXM:TXL)   | 6-30 |
| 6.7.7 | Host-Side Registers After Reset         | 6-31 |
| 6.8   | Programming Model Quick Reference       | 6-32 |

# Chapter **7** Enhanced Synchronous Serial Interface (ESSI)

| 7.1    | ESSI Enhancements                               |
|--------|-------------------------------------------------|
| 7.2    | ESSI Data and Control Signals                   |
| 7.2.1  | Serial Transmit Data Signal (STD)               |
| 7.2.2  | Serial Receive Data Signal (SRD)                |
| 7.2.3  | Serial Clock (SCK)                              |
| 7.2.4  | Serial Control Signal (SC0)                     |
| 7.2.5  | Serial Control Signal (SC1)                     |
| 7.2.6  | Serial Control Signal (SC2)                     |
| 7.3    | Operation                                       |
| 7.3.1  | ESSI After Reset                                |
| 7.3.2  | Initialization                                  |
| 7.3.3  | Exceptions                                      |
| 7.4    | Operating Modes: Normal, Network, and On-Demand |
| 7.4.1  | Normal/Network/On-Demand Mode Selection         |
| 7.4.2  | Synchronous/Asynchronous Operating Modes        |
| 7.4.3  | Frame Sync Selection                            |
| 7.4.4  | Frame Sync Signal Format                        |
| 7.4.5  | Frame Sync Length for Multiple Devices          |
| 7.4.6  | Word Length Frame Sync and Data Word Timing     |
| 7.4.7  | Frame Sync Polarity                             |
| 7.4.8  | Byte Format (LSB/MSB) for the Transmitter       |
| 7.4.9  | Flags                                           |
| 7.5    | ESSI Programming Model                          |
| 7.5.1  | ESSI Control Register A (CRA)                   |
| 7.5.2  | ESSI Control Register B (CRB)                   |
| 7.5.3  | ESSI Status Register (SSISR)                    |
| 7.5.4  | ESSI Receive Shift Register                     |
| 7.5.5  | ESSI Receive Data Register (RX)                 |
| 7.5.6  | ESSI Transmit Shift Registers                   |
| 7.5.7  | ESSI Transmit Data Registers (TX[2-0]) 7-34     |
| 7.5.8  | ESSI Time Slot Register (TSR)                   |
| 7.5.9  | Transmit Slot Mask Registers (TSMA, TSMB)       |
| 7.5.10 | Receive Slot Mask Registers (RSMA, RSMB)        |
| 7.6    | GPIO Signals and Registers                      |
| 7.6.1  | Port Control Register (PCR)                     |
| 7.6.2  | Port Direction Register (PRR)                   |
| 7.6.3  | Port Data Register (PDR) 7-38                   |

**Freescale Semiconductor, Inc.** 

DSP56311 User's Manual

## Chapter <mark>8</mark> Serial Communication Interface (SCI)

| 8.1     | Operating Modes                                      | . 8-1 |
|---------|------------------------------------------------------|-------|
| 8.1.1   | Synchronous Mode                                     | . 8-2 |
| 8.1.2   | Asynchronous Mode                                    | . 8-2 |
| 8.1.3   | Multidrop Mode                                       | . 8-2 |
| 8.1.3.1 | Transmitting Data and Address Characters             | . 8-3 |
| 8.1.3.2 | Wired-OR Mode                                        |       |
| 8.1.3.3 | Idle Line Wakeup                                     | . 8-3 |
| 8.1.3.4 | Address Mode Wakeup                                  |       |
| 8.2     | I/O Signals                                          |       |
| 8.2.1   | Receive Data (RXD)                                   |       |
| 8.2.2   | Transmit Data (TXD).                                 | . 8-4 |
| 8.2.3   | SCI Serial Clock (SCLK).                             | . 8-4 |
| 8.3     | SCI After Reset                                      | . 8-4 |
| 8.4     | SCI Initialization                                   | . 8-6 |
| 8.4.1   | Preamble, Break, and Data Transmission Priority      | . 8-7 |
| 8.4.2   | Bootstrap Loading Through the SCI (Operating Mode 6) | . 8-7 |
| 8.5     | Exceptions                                           |       |
| 8.6     | SCI Programming Model.                               | . 8-9 |
| 8.6.1   | SCI Control Register (SCR).                          | 8-12  |
| 8.6.2   | SCI Status Register (SSR)                            | 8-17  |
| 8.6.3   | SCI Clock Control Register (SCCR)                    | 8-19  |
| 8.6.4   | SCI Data Registers                                   | 8-22  |
| 8.6.4.1 | SCI Receive Register (SRX).                          | 8-23  |
| 8.6.4.2 | SCI Transmit Register (STX)                          | 8-24  |
| 8.7     | GPIO Signals and Registers                           | 8-25  |
| 8.7.1   | Port E Control Register (PCRE)                       | 8-25  |
| 8.7.2   | Port E Direction Register (PRRE)                     | 8-26  |
| 8.7.3   | Port E Data Register (PDRE)                          | 8-26  |

### Chapter 9 Triple Timer Module

| 9.1     | Overview                      | 9-1  |
|---------|-------------------------------|------|
| 9.2     | Operation                     | 9-2  |
| 9.2.1   | Timer After Reset             | 9-2  |
| 9.2.2   | Timer Initialization          | 9-3  |
| 9.2.3   | Timer Exceptions              | 9-3  |
| 9.3     | Operating Modes               | 9-4  |
| 9.3.1   | Triple Timer Modes            | 9-5  |
| 9.3.1.1 | Timer GPIO (Mode 0).          | 9-5  |
| 9.3.1.2 | Timer Pulse (Mode 1)          | 9-7  |
| 9.3.1.3 | Timer Toggle (Mode 2).        | 9-8  |
| 9.3.1.4 | Timer Event Counter (Mode 3). | 9-10 |

| 9.3.2   | Signal Measurement Modes              | 9-11 |
|---------|---------------------------------------|------|
| 9.3.2.1 | Measurement Input Width (Mode 4)      | 9-12 |
| 9.3.2.2 | Measurement Input Period (Mode 5)     | 9-13 |
| 9.3.2.3 | Measurement Capture (Mode 6)          | 9-15 |
| 9.3.3   | Pulse Width Modulation (PWM, Mode 7). | 9-16 |
| 9.3.4   | Watchdog Modes                        | 9-18 |
| 9.3.4.1 | Watchdog Pulse (Mode 9)               | 9-19 |
| 9.3.4.2 | Watchdog Toggle (Mode 10)             | 9-20 |
| 9.3.4.3 | Reserved Modes                        | 9-21 |
| 9.3.5   | Special Cases                         | 9-21 |
| 9.3.6   | DMA Trigger                           | 9-21 |
| 9.4     | Triple Timer Module Programming Model | 9-21 |
| 9.4.1   | Prescalar Counter                     | 9-21 |
| 9.4.2   | Timer Prescalar Load Register (TPLR)  | 9-23 |
| 9.4.3   | Timer Prescalar Count Register (TPCR) | 9-24 |
| 9.4.4   | Timer Control/Status Register (TCSR)  | 9-24 |
| 9.4.5   | Timer Load Register (TLR)             | 9-29 |
| 9.4.6   | Timer Compare Register (TCPR)         | 9-30 |
| 9.4.7   | Timer Count Register (TCR)            | 9-30 |
|         |                                       |      |

### Chapter 10 Enhanced Filter Coprocessor (EFCOP)

| 10.1      | Features                                   | 10-1 |
|-----------|--------------------------------------------|------|
| 10.2      | Architecture Overview                      | 10-3 |
| 10.2.1    | PMB Interface                              | 10-4 |
| 10.2.2    | EFCOP Memory Banks                         | 10-4 |
| 10.2.3    | Filter Multiplier and Accumulator (FMAC)   | 10-6 |
| 10.3      | EFCOP Programming Model.                   | 10-6 |
| 10.3.1    | Filter Data Input Register (FDIR)          | 10-7 |
| 10.3.2    | Filter Data Output Register (FDOR)         | 10-7 |
| 10.3.3    | Filter K-Constant Input Register (FKIR)    | 10-7 |
| 10.3.4    | Filter Count (FCNT) Register               | 10-7 |
| 10.3.5    | EFCOP Control Status Register (FCSR)       | 10-8 |
| 10.3.6    | EFCOP ALU Control Register (FACR) 1        | 0-11 |
| 10.3.7    | EFCOP Data Base Address (FDBA) 1           | 0-12 |
| 10.3.8    | EFCOP Coefficient Base Address (FCBA) 1    | 0-13 |
| 10.3.9    | Decimation/Channel Count Register (FDCH) 1 | 0-13 |
| 10.3.10   | EFCOP Interrupt Vectors                    | 0-14 |
| 10.4      | EFCOP Programming 1                        | 0-14 |
| 10.5      | Operation Summary 1                        | 0-16 |
| 10.5.1    | FIR Filter Type 1                          | 0-16 |
| 10.5.1.1  | Real Mode                                  | 0-17 |
| 10.5.1.1. | .1 Adaptive Mode                           | 0-17 |
| 10.5.1.1. | 2 Multichannel Mode 1                      | 0-17 |
| 10.5.1.1. | .3 Complex Mode 1                          | 0-18 |

| 10.5.1.1. | .4 Alternating Complex Mode                         | 10-18 |
|-----------|-----------------------------------------------------|-------|
| 10.5.1.1. | .5 Magnitude Mode                                   | 10-19 |
| 10.5.1.1. | .6 Initialization                                   | 10-19 |
| 10.5.1.1. | .7 Decimation                                       | 10-19 |
| 10.5.2    | IIR Filter Type                                     | 10-20 |
| 10.6      | Data Transfer                                       | 10-21 |
| 10.7      | Examples of Use in Different Modes.                 | 10-22 |
| 10.7.1    | Real FIR Filter: Mode 0                             | 10-22 |
| 10.7.1.1  | DMA Input/DMA Output                                | 10-23 |
| 10.7.1.2  | DMA Input/Polling Output                            | 10-26 |
| 10.7.1.3  | DMA Input/Interrupt Output.                         | 10-28 |
| 10.7.2    | Real FIR Filter With Decimation by M                | 10-30 |
| 10.7.3    | Adaptive FIR Filter                                 | 10-31 |
| 10.7.3.1  | Implementation Using Polling                        | 10-33 |
| 10.7.3.2  | Implementation Using DMA Input and Interrupt Output | 10-34 |
| 10.7.3.3  | Updating an FIR Filter                              | 10-34 |
| 10.8      | Verification For All Exercises                      | 10-37 |
| 10.8.1    | Input Sequence (input.asm)                          | 10-37 |
| 10.8.2    | Filter Coefficients (coefs.asm).                    | 10-38 |
| 10.8.3    | Output Sequence for Examples D-1, D-2, and D-3      | 10-39 |
| 10.8.4    | Desired Signal for Example D-4                      | 10-39 |
| 10.8.5    | Output Sequence for Example D-4                     | 10-40 |

### Appendix A Bootstrap Program

| A.1 | Bootstrap Code       | A-1  |
|-----|----------------------|------|
|     | Internal I/O Equates |      |
| A.3 | Interrupt Equates    | A-20 |

### Appendix **B** Programming Reference

| B.1 | Internal I/O Memory Map          | <b>B-2</b> |
|-----|----------------------------------|------------|
| B.2 | Interrupt Sources and Priorities | B-8        |
| B.3 | Programming Sheets I             | B-13       |

### INDEX

# Figures

| Figure1-1.   | DSP56311 Block Diagram                                                  | 1-11 |
|--------------|-------------------------------------------------------------------------|------|
| Figure 2-1.  | Signals Identified by Functional Group                                  | 2-3  |
| Figure 3-1.  | Memory Switch Off, Cache Off, 24-Bit Mode (Default)                     | 3-9  |
| Figure 3-2.  | Memory Switch Off, Cache On, 24-Bit Mode                                | 3-10 |
| Figure 3-3.  | Memory Switch On (MSW = 00), Cache Off, 24-Bit Mode                     | 3-11 |
| Figure 3-4.  | Memory Switch On (MSW = 00), Cache On, 24-Bit Mode                      | 3-12 |
| Figure 3-5.  | Memory Switch On (MSW = 01), Cache Off, 24-Bit Mode $\dots \dots \dots$ | 3-13 |
| Figure 3-6.  | Memory Switch On (MSW = 01), Cache On, 24-Bit Mode                      | 3-14 |
| Figure 3-7.  | Memory Switch On (MSW = 10), Cache Off, 24-Bit Mode                     | 3-15 |
| Figure 3-8.  | Memory Switch On (MSW = 10), Cache On, 24-Bit Mode                      | 3-16 |
| Figure 3-9.  | Memory Switch On (MSW = 11), Cache Off, 24-Bit Mode                     | 3-17 |
| Figure 3-10. | Memory Switch On (MSW = 11), Cache On, 24-Bit Mode                      | 3-18 |
| Figure 3-11. | Memory Switch Off, Cache Off, 16-Bit Mode                               | 3-19 |
| Figure 3-12. | Memory Switch Off, Cache On, 16-Bit Mode                                | 3-20 |
| Figure 3-13. | Memory Switch On (MSW = $00$ ), Cache Off, 16-Bit Mode                  | 3-21 |
| Figure 3-14. | Memory Switch On (MSW = 00), Cache On, 16-Bit Mode                      | 3-22 |
| Figure 3-15. | Memory Switch On (MSW = 01), Cache Off, 16-Bit Mode $\dots \dots \dots$ | 3-23 |
| Figure 3-16. | Memory Switch On (MSW = 01), Cache On, 16-Bit Mode $\ldots$             | 3-24 |
| Figure 3-17. | Memory Switch On (MSW = 10), Cache Off, 16-Bit Mode                     | 3-25 |
| Figure 3-18. | Memory Switch On (MSW = 10), Cache On, 16-Bit Mode                      | 3-26 |
| Figure 3-19. | Memory Switch On (MSW = 11), Cache Off, 16-Bit Mode                     | 3-27 |
| Figure 3-20. | Memory Switch On (MSW = 11), Cache On, 16-Bit Mode                      | 3-28 |
| Figure 4-1.  | Interrupt Priority Register C (IPR-C) (X:\$FFFFFF)                      | 4-7  |
| Figure 4-2.  | Interrupt Priority Register P (IPR-P) (X:\$FFFFFE)                      | 4-7  |
| Figure 4-3.  | DSP56311 Operating Mode Register (OMR) Format                           | 4-11 |
| Figure 4-4.  | Status Register                                                         | 4-16 |
| Figure 4-5.  | PLL Control Register (PCTL)                                             | 4-21 |
| Figure 4-6.  | Identification Register Configuration (Revision 0)                      | 4-22 |
| Figure 4-7.  | Address Attribute Registers (AAR0–AAR3)<br>(X:\$FFFF9–\$FFFF6)          | 4-23 |
| Figure 4-8.  | JTAG Identification Register Configuration (Revision 0)                 | 4-25 |
| Figure 5-1.  | Memory Mapping of Peripherals Control Registers                         | 5-2  |
| Figure 5-2.  | Port B Signals                                                          | 5-7  |
| Figure 5-3.  | Port C Signals                                                          | 5-7  |

| Figure 5-4.  | Port D Signals                                              |
|--------------|-------------------------------------------------------------|
| Figure 5-5.  | Port E Signals                                              |
| Figure 5-6.  | Triple Timer Signals 5-9                                    |
| Figure 6-1.  | HI08 Block Diagram                                          |
| Figure 6-2.  | HI08 Core Interrupt Operation                               |
| Figure 6-3.  | HI08 Host Request Structure                                 |
| Figure 6-4.  | HI08 Read and Write Operations in Little Endian Mode        |
| Figure 6-5.  | HI08 Read and Write Operations in Big Endian Mode           |
| Figure 6-6.  | Host Control Register (HCR) (X:\$FFFFC2)                    |
| Figure 6-7.  | Host Status Register (HSR) (X:\$FFFFC3)                     |
| Figure 6-8.  | Host Data Direction Register (HDDR) (X:\$FFFFC8)6-16        |
| Figure 6-9.  | Host Base Address Register (HBAR) (X:\$FFFFC5)              |
| Figure 6-10. | Self Chip-Select Logic                                      |
| Figure 6-11. | Host Port Control Register (HPCR) (X:\$FFFFC4) 6-18         |
| Figure 6-12. | Single-Strobe Bus                                           |
| Figure 6-13. | Dual-Strobe Bus.         6-21                               |
| Figure 6-14. | Interface Control Register (ICR)                            |
| Figure 6-15. | Command Vector Register (CVR)                               |
| Figure 6-16. | Interface Status Registe (ISR) 6-28                         |
| Figure 6-17. | Interrupt Vector Register (IVR)                             |
| Figure 7-1.  | ESSI Block Diagram                                          |
| Figure 7-2.  | ESSI Control Register A(CRA)                                |
| Figure 7-3.  | ESSI Clock Generator Functional Block Diagram               |
| Figure 7-4.  | ESSI Frame Sync Generator Functional Block Diagram          |
| Figure 7-5.  | ESSI Control Register B (CRB)                               |
| Figure 7-6.  | CRB FSL0 and FSL1 Bit Operation (FSR = 0)                   |
| Figure 7-7.  | CRB SYN Bit Operation                                       |
| Figure 7-8.  | CRB MOD Bit Operation                                       |
| Figure 7-9.  | Normal Mode, External Frame Sync (8 Bit, 1 Word in Frame)   |
| Figure 7-10. | Network Mode, External Frame Sync (8 Bit, 2 Words in Frame) |
| Figure 7-11. | ESSI Status Register (SSISR)                                |
| Figure 7-12. | ESSI Data Path Programming Model (SHFD = 0)                 |
| Figure 7-13. | ESSI Data Path Programming Model (SHFD = 1)                 |
| Figure 7-14. | ESSI Transmit Slot Mask Register A (TSMA)                   |
| Figure 7-15. | ESSI Transmit Slot Mask Register B (TSMB)                   |
| Figure 7-16. | ESSI Receive Slot Mask Register A (RSMA)                    |
| Figure 7-17. | ESSI Receive Slot Mask Register B (RSMB)                    |

| Figure 7-18. | Port Control Register (PCR) (PCRC X:\$FFFFBF)<br>(PCRD X:\$FFFAF) |
|--------------|-------------------------------------------------------------------|
| Figure 7-19. | Port Direction Register (PRR)(PRRC X:\$FFFFBE)                    |
| 0            | (PRRD X: \$FFFFAE)                                                |
| Figure 7-20. | Port Data Register (PDR) (PDRC X:\$FFFFBD)<br>(PDRD X: \$FFFFAD)  |
| Figure 8-1.  | SCI Data Word Formats (SSFTD = 1), 1                              |
| Figure 8-2.  | SCI Data Word Formats (SSFTD = 0), 2                              |
| Figure 8-3.  | SCI Control Register (SCR) 8-12                                   |
| Figure 8-4.  | SCI Status Register                                               |
| Figure 8-5.  | SCI Clock Control Register (SCCR)                                 |
| Figure 8-6.  | 16 x Serial Clock                                                 |
| Figure 8-7.  | SCI Baud Rate Generator                                           |
| Figure 8-8.  | SCI Programming Model - Data Registers                            |
| Figure 8-9.  | Port E Control Register (PCRE) 8-25                               |
| Figure 8-10. | Port E Direction Register (PRRE)                                  |
| Figure 8-11. | Port E Data Register (PDRE) 8-27                                  |
| Figure 9-1.  | Triple Timer Module Block Diagram                                 |
| Figure 9-2.  | Timer Module Block Diagram                                        |
| Figure 9-3.  | Timer Mode (TRM = 1)                                              |
| Figure 9-4.  | Timer Mode (TRM = 0)                                              |
| Figure 9-5.  | Pulse Mode (TRM = 1)                                              |
| Figure 9-6.  | Pulse Mode (TRM = 0)                                              |
| Figure 9-7.  | Toggle Mode, TRM = 1                                              |
| Figure 9-8.  | Toggle Mode, TRM = 0                                              |
| Figure 9-9.  | Event Counter Mode, TRM = 1                                       |
| Figure 9-10. | Event Counter Mode, TRM = 0                                       |
| Figure 9-11. | Pulse Width Measurement Mode, TRM = 1                             |
| Figure 9-12. | Pulse Width Measurement Mode, TRM = 0 9-13                        |
| Figure 9-13. | Period Measurement Mode, TRM = 1                                  |
| Figure 9-14. | Period Measurement Mode, TRM = 0                                  |
| Figure 9-15. | Capture Measurement Mode, TRM = 0                                 |
| Figure 9-16. | Pulse Width Modulation Toggle Mode, TRM = 1                       |
| Figure 9-17. | Pulse Width Modulation Toggle Mode, TRM = 0                       |
| Figure 9-18. | Watchdog Pulse Mode                                               |
| Figure 9-19. | Watchdog Toggle Mode                                              |
| Figure 9-20. | Timer Module Programmer's Model.    9-22                          |
| Figure 9-21. | Timer Prescalar Load Register (TPLR)                              |

| Figure 9-22.         | Timer Prescalar Count Register (TPCR)                    |       |
|----------------------|----------------------------------------------------------|-------|
| Figure 9-23.         | Timer Control/Status Register (TCSR)                     |       |
| Figure 10-1.         | EFCOP Block Diagram                                      | 10-3  |
| Figure 10-2.         | Storage of Filter Coefficients                           | 10-5  |
| Figure 10-3.         | EFCOP Memory Organization                                | 10-5  |
| Figure 10-4.         | Filter Count (FCNT) Register                             | 10-8  |
| Figure 10-5.         | EFCOP ALU Control Register (FACR)                        | 10-11 |
| Figure 10-6.         | Decimation/Channel Count Register (FDCH)                 | 10-13 |
| Figure 10-7.         | FIR Filter Type Processing                               | 10-16 |
| Figure 10-8.         | IIR Filter Type Processing                               | 10-20 |
| Figure 10-9.         | Real FIR Filter Data stream                              | 10-25 |
| Figure 10-11.        | Adaptive FIR Filter                                      | 10-31 |
| <b>Figure 10-10.</b> | Real FIR Filter Data Stream With Decimation by M         | 10-31 |
| <b>Figure 10-12.</b> | Adaptive FIR Filter Using Polling                        | 10-33 |
| <b>Figure 10-13.</b> | Adaptive FIR Filter Using DMA Input and Interrupt Output | 10-34 |
| Figure B-1.          | Status Register (SR)                                     | B-13  |
| Figure B-2.          | Operating Mode Register                                  | B-14  |
| Figure B-3.          | Address Attribute Registers (AAR3 - AAR0)                | B-15  |
| Figure B-4.          | Bus Control Register (BCR)                               | B-16  |
| Figure B-5.          | DMA Control Register (DCR)                               | B-17  |
| Figure B-6.          | Interrupt Priority Register–Core (IPR–C)                 | B-18  |
| Figure B-7.          | Interrupt Priority Register – Peripherals (IPR–P)        | B-19  |
| Figure B-8.          | Phase Lock Loop Control Register (PCTL)                  | B-20  |
| Figure B-9.          | Host Receive and Host Transmit Data Registers            | B-21  |
| Figure B-10.         | Host Control and Host Status Registers                   | B-22  |
| Figure B-11.         | Host Base Address and Host Port Control Registers        | B-23  |
| Figure B-12.         | Interrupt Control and Interrupt Status Registers         | B-24  |
| Figure B-13.         | Interrupt Vector and Command Vector Registers            | B-25  |
| Figure B-14.         | Host Receive and Host Transmit Data Registers            | B-26  |
| Figure B-15.         | ESSI Control Register A (CRA)                            | B-27  |
| Figure B-16.         | ESSI Control Register B (CRB)                            | B-28  |
| Figure B-17.         | ESSI Status Register (SSISR)                             | B-29  |
| Figure B-18.         | ESSR Transmit and Receive Slot Mask Registers (TSM, RSM) | B-30  |
| Figure B-19.         | SCI Control Register (SCR)                               | B-31  |
| Figure B-20.         | SCI Status and Clock Control Registers (SSR, SCCR)       | B-32  |
| Figure B-21.         | SCI Receive and Transmit Data Registers (SRX, TRX)       | B-33  |
| Figure B-22.         | Timer Prescaler Load/Count Register (TPLR, TPCR)         | B-34  |
| Figure B-23.         | Timer Control/Status Register (TCSR)                     | B-35  |

| Figure B-24. | Timer Load, Compare, Count Registers (TLR, TCPR, TCR)B-36         |
|--------------|-------------------------------------------------------------------|
| Figure B-25. | Host Data Direction and Host Data Registers (HDDR, HDR) B-37      |
| Figure B-26. | Port C Registers (PCRC, PRRC, PDRC) B-38                          |
| Figure B-27. | Port D Registers (PCRD, PRRD, PDRD)                               |
| Figure B-28. | Port E Registers (PCRE, PRRE, PDRE) B-40                          |
| Figure B-29. | EFCOP Counter and Control Status Registers<br>(FCNT and FCSR)B-41 |
| Figure B-30. | EFCOP FACR, FDBA, FCBA, and FDCH RegistersB-42                    |
|              |                                                                   |

# Tables

| Table 1-1.         | High True/Low True Signal Conventions1-3                  |
|--------------------|-----------------------------------------------------------|
| <b>Table 1-2.</b>  | DSP56311 Switch Memory Configuration                      |
| Table 4-1.         | DSP56311 Operating Modes                                  |
| <b>Table 4-2.</b>  | Interrupt Sources                                         |
| <b>Table 4-3.</b>  | Interrupt Priority Level Bits                             |
| Table 4-4.         | Interrupt Source Priorities Within an IPL                 |
| Table 4-5.         | DMA Request Sources                                       |
| Table 4-6.         | Operating Mode Register (OMR) Bit Definitions             |
| <b>Table 4-7.</b>  | Status Register Bit Definitions 4-16                      |
| Table 4-8.         | PLL Control Register (PCTL) Bit Definitions 4-21          |
| Table 4-9.         | Address Attribute Registers (AAR0–AAR3) Bit Definitions   |
| Table 5-1.         | DMA-Accessible Registers                                  |
| Table 6-1.         | HI08 Signal Definitions for Operational Modes             |
| <b>Table 6-2.</b>  | HI08 Data Strobe Signals                                  |
| Table 6-3.         | HI08 Host Request Signals                                 |
| Table 6-4.         | DMA Request Sources                                       |
| Table 6-5.         | HREQ Pin Operation In Single Request Mode (ICR[2]=HDRQ=0) |
| Table 6-6.         | HTRQ and HRRQ Pin Operation In Double Request Mode        |
|                    | (ICR[2]=HDRQ=1)                                           |
| Table 6-7.         | Host Control Register (HCR) Bit Definitions               |
| Table 6-8.         | Host Status Register (HSR) Bit Definitions                |
| Table 6-9.         | HDR and HDDR Functionality                                |
| <b>Table 6-10.</b> | Host Base Address Register (HBAR) Bit Definitions         |
| <b>Table 6-11.</b> | Host Port Control Register (HPCR) Bit Definitions         |
| <b>Table 6-12.</b> | DSP-Side Registers After Reset                            |
| <b>Table 6-13.</b> | Host-Side Register Map                                    |
| <b>Table 6-14.</b> | Interface Control Register (ICR) Bit Definitions          |
| <b>Table 6-15.</b> | Command Vector Register (CVR) Bit Definitions             |
| <b>Table 6-16.</b> | Interface Status Register (ISR) Bit Definitions           |
| <b>Table 6-17.</b> | Host-Side Registers After Reset                           |
| <b>Table 6-18.</b> | HI08 Programming Model, DSP Side                          |
| <b>Table 6-19.</b> | HI08 Programming Model: Host Side 6-35                    |
| Table 7-1.         | ESSI Clock Sources                                        |
| <b>Table 7-2.</b>  | Mode and Signal Definitions                               |
| <b>Table 7-3.</b>  | ESSI Control Register A (CRA) Bit Definitions             |
| Table 7-4.         | ESSI Control Register B (CRB) Bit Definitions             |

| Table 7-5.          | ESSI Status Register (SSISR) Bit Definitions           |
|---------------------|--------------------------------------------------------|
| <b>Table 8-1.</b>   | SCI Registers After Reset                              |
| <b>Table 8-2.</b>   | SCI Control Register (SCR) Bit Definitions             |
| <b>Table 8-3.</b>   | SCI Status Register (SSR) Bit Definitions              |
| <b>Table 8-4.</b>   | SCI Clock Control Register (SCCR) Bit Definitions      |
| <b>Table 8-5.</b>   | Port Control Register and Port Direction Register Bits |
| Table 9-1.          | Timer Prescalar Load Register (TPLR) Bit Definitions   |
| <b>Table 9-2.</b>   | Timer Prescalar Count Register (TPCR) Bit Definitions  |
| Table 9-3.          | Timer Control/Status Register (TCSR) Bit Definitions   |
| Table 9-4.          | Inverter (INV) Bit Operation                           |
| <b>Table 10-1.</b>  | EFCOP Registers Accessible Through the PMB 10-4        |
| <b>Table 10-2.</b>  | EFCOP Registers and Base Addresses 10-6                |
| <b>Table 10-3.</b>  | Filter Count FCNT Register Bits 10-8                   |
| <b>Table 10-4.</b>  | FCSR Bits                                              |
| <b>Table 10-5.</b>  | EFCOP ALU Control Register (FACR) Bits 10-12           |
| <b>Table 10-6.</b>  | Decimation/Channel Count Register (FDCH) Bits 10-14    |
| <b>Table 10-7.</b>  | EFCOP Interrupt Vectors                                |
| <b>Table 10-8.</b>  | EFCOP DMA Request Sources. 10-14                       |
| <b>Table 10-9.</b>  | EFCOP Operating Modes 10-15                            |
| <b>Table 10-10.</b> | DMA Channel 0 Regisister Initialization 10-23          |
| <b>Table 10-11.</b> | DMA Channel 1 Register Initialization 10-24            |
| Table B-1.          | Guide to Programming SheetsB-1                         |
| Table B-2.          | Internal X I/O Memory MapB-2                           |
| Table B-3.          | Internal Y I/O Memory MapB-7                           |
| Table B-4.          | Interrupt Sources                                      |
| Table B-5.          | Interrupt Source Priorities Within an IPLB-10          |

# **Chapter 1** Overview

This manual describes the DSP56311 24-bit digital signal processor (DSP), its memory, operating modes, and peripheral modules. The DSP56311 is an implementation of the DSP56300 core with a unique configuration of on-chip memory, cache, and peripherals.

Use this manual in conjunction with the *DSP56300 Family Manual (DSP56300FM/AD)*, which describes the CPU, core programming models, and instruction set. The *DSP56311 Technical Data (DSP56311/D)*—referred to as the data sheet—provides DSP56311 electrical specifications, timing, pinout, and packaging descriptions.

You can obtain these documents—and the Motorola DSP development tools—through a local Motorola Semiconductor Sales Office or authorized distributor. To receive the latest information on this DSP, access the Motorola DSP home page at the address given on the back cover of this document.

# **1.1** Manual Organization

This manual contains the following sections and appendices:

- Chapter 1, *Overview* Features list and block diagram, related documentation, organization of this manual, and the notational conventions used.
- Chapter 2, Signals/Connections DSP56311 signals and their functional groupings.
- Chapter 3, Memory Configuration DSP56311 memory spaces, RAM configuration, memory configuration bit settings, memory configurations, and memory maps.
- Chapter 4, Core Configuration Registers for configuring the DSP56300 core when programming the DSP56311, in particular the interrupt vector locations and the operation of the interrupt priority registers; operating modes and how they affect the processor's program and data memories.
- Chapter 5, *Programming the Peripherals* Guidelines on initializing the DSP56311 peripherals, including mapping control registers, specifying a method of transferring data, and configuring for general-purpose input/output (GPIO).

- **Chapter 6**, *Host Interface (HI08)* Features, signals, architecture, programming model, reset, interrupts, external host programming model, initialization, and a quick reference to the HI08 programming model.
- **Chapter 7,** Enhanced Synchronous Serial Interface (ESSI) Enhancements, data and control signals, programming model, operating modes, initialization, exceptions, and GPIO.
- **Chapter 8,** Serial Communication Interface (SCI) Signals, programming model, operating modes, reset, initialization, and GPIO.
- **Chapter 9,** *Triple Timer Module* Architecture, programming model, and operating modes of three identical timer devices available for use as internals or event counters.
- **Chapter 10,** *Enhanced Filter Coprocessor (EFCOP)* Structure and function of the EFCOP, including features, architecture, and programming model; programming topics such as data transfer to and from the EFCOP, its use in different modes, and examples of usage.
- Appendix A, Bootstrap Code Bootstrap code for the DSP56311.
- Appendix B, *Programming Reference* Peripheral addresses, interrupt addresses, and interrupt priorities for the DSP56311; programming sheets listing the contents of the major DSP56311 registers for programmer's reference.

#### **Manual Conventions** 1.2

This manual uses the following conventions:

- Bits within registers are always listed from most significant bit (MSB) to least significant bit (LSB).
- Bits within a register are indicated AA[n m], n > m, when more than one bit is involved in a description. For purposes of description, the bits are presented as if they are contiguous within a register. However, this is not always the case. Refer to the programming model diagrams or to the programmer's sheets to see the exact location of bits within a register.
- When a bit is described as "set," its value is 1. When a bit is described as "cleared," its value is 0.
- The word "assert" means that a high true (active high) signal is pulled high to  $V_{CC}$ or that a low true (active low) signal is pulled low to ground. The word "deassert" means that a high true signal is pulled low to ground or that a low true signal is pulled high to  $V_{CC}$ . See **Table 1-1**.

| Signal/Symbol | Logic State | Signal State | Voltage                      |
|---------------|-------------|--------------|------------------------------|
| PIN1          | True        | Asserted     | Ground <sup>2</sup>          |
| PIN           | False       | Deasserted   | V <sub>CC</sub> <sup>3</sup> |
| PIN           | True        | Asserted     | V <sub>CC</sub>              |
| PIN           | False       | Deasserted   | Ground                       |

 Table 1-1.
 High True/Low True Signal Conventions

- 1. PIN is a generic term for any pin on the chip.
- 2. Ground is an acceptable low voltage level. See the appropriate data sheet for the range of acceptable low voltage levels (typically a TTL logic low).
- 3. V<sub>CC</sub> is an acceptable high voltage level. See the appropriate data sheet for the range of acceptable high voltage levels (typically a TTL logic high).
- Pins or signals that are asserted low (made active when pulled to ground) are indicated like this in text:
  - In text, they have an overbar: for example,  $\overline{\mathsf{RESET}}$  is asserted low.
  - In code examples, they have a tilde in front of their names. In **Example 1-1**, line 3 refers to the  $\overline{SS0}$  signal (shown as  $\sim SS0$ ).
- Sets of signals are indicated by the first and last signals in the set, for instance HA1–HA8.
- "Input/Output" indicates a bidirectional signal. "Input or Output" indicates a signal that is exclusively one or the other.
- Code examples are displayed in a monospaced font, as shown in **Example 1-1**.

| Example 1-1. | Sample Code Listing |
|--------------|---------------------|
|--------------|---------------------|

| BFSET | #\$0007,X:PCC; Configure:           | line 1 |
|-------|-------------------------------------|--------|
|       | ; MISOO, MOSIO, SCKO for SPI master | line 2 |
|       | ; ~SSO as PC3 for GPIO              | line 3 |

Hex values are indicated with a dollar sign (\$) preceding the hex value, as follows:
 \$FFFFFF is the X memory address for the core interrupt priority register.

- The word "reset" is used in four different contexts in this manual:
  - the reset signal, written as  $\overline{\mathsf{RESET}}$
  - the reset instruction, written as RESET
  - the reset operating state, written as Reset
  - the reset function, written as reset

# **1.3** Features

The Motorola DSP56311, a member of the DSP56300 core family of programmable DSPs, supports wireless infrastructure applications with general filtering operations. The on-chip EFCOP processes filter algorithms in parallel with core operation, thus increasing overall DSP performance and efficiency. Like the other family members, the DSP56311 uses a high-performance, single-clock-cycle-per-instruction engine (code compatible with Motorola's popular DSP56000 core family), a barrel shifter, 24-bit addressing, instruction cache, and DMA controller. The DSP56311 offers 150 million instructions per second (MIPS) performance (255 MIPS using the EFCOP in filtering applications) using an internal 150 MHz clock with 1.8 V core and independent 3.3 V input/output (I/O) power.

All DSP56300 core family members contain the DSP56300 core and additional modules. The modules are chosen from a library of standard predesigned elements, such as memories and peripherals. New modules can be added to the library to meet customer specifications. A standard interface between the DSP56300 core and the on-chip memory and peripherals supports a wide variety of memory and peripheral configurations. In particular, the DSP56311 includes Motorola's JTAG port and OnCE module.

The DSP56311, with its large on-chip memory array of 128K words and its EFCOP, is well suited for high-end multichannel telecommunication applications, such as wireless infrastructure, multi-line voice/data/FAX processing, video conferencing, and general digital signal processing.

# 1.4 DSP56300 Core

Core features are fully described in the *DSP56300 Family Manual*. (This manual, in contrast, documents pinout, memory, and peripheral features.) Core features are as follows:

- 150 MIPS (255 MIPS using the EFCOP in filtering applications) with a 150 MHz clock at 1.8 V
- Object code compatible with the DSP56000 core
- Highly parallel instruction set
- Large on-chip RAM memory of 128K words
- EFCOP running concurrently with the core, capable of executing 100 million filter taps per second at peak performance
- Hardware debugging support
  - JTAG test access port (TAP)
  - OnCE module
  - Address trace mode reflects internal accesses at the external port
- Reduced power dissipation
  - Very low-power CMOS design
  - Wait and stop low-power standby modes
  - Fully-static design specified to operate at 0 Hz (dc)
  - Optimized power-management circuitry (instruction-dependent, peripheral-dependent, and mode-dependent)

# 1.5 DSP56300 Core Functional Blocks

The functional blocks of the DSP56300 core are:

- Data arithmetic logic unit (ALU)
- Address generation unit
- Program control unit
- PLL and clock oscillator
- JTAG TAP and OnCE module
- Memory

In addition, the DSP56311 provides a set of on-chip peripherals, discussed in **Section 1.9**, "Peripherals," on page 1-12.

# 1.5.1 Data ALU

The data ALU performs all the arithmetic and logical operations on data operands in the DSP56300 core. These are the components of the data ALU:

- Fully pipelined  $24 \times 24$ -bit parallel multiplier-accumulator
- Bit field unit, comprising a 56-bit parallel barrel shifter (fast shift and normalization; bit stream generation and parsing)
- Conditional ALU instructions
- Software-controllable 24-bit, 48-bit, or 56-bit arithmetic support
- Four 24-bit or 48-bit input general-purpose registers: X1, X0, Y1, and Y0
- Six data ALU registers (A2, A1, A0, B2, B1, and B0) that are concatenated into two general-purpose, 56-bit accumulators, A and B, accumulator shifters
- Two data bus shifter/limiter circuits

### 1.5.1.1 Data ALU Registers

The data ALU registers are read or written over the X data bus and the Y data bus as 16- or 32-bit operands. The source operands for the data ALU can be 16, 32, or 40 bits and always originate from data ALU registers. The results of all data ALU operations are stored in an accumulator. Data ALU operations are performed in two clock cycles in a pipeline so that a new instruction can be initiated in every clock cycle, yielding an effective execution rate of one instruction per clock cycle. The destination of every arithmetic operation can be a source operand for the immediately following operation without penalty.

### 1.5.1.2 Multiplier-Accumulator (MAC)

The MAC unit comprises the main arithmetic processing unit of the DSP56300 core and performs all of the calculations on data operands. For arithmetic instructions, the unit accepts as many as three input operands and outputs one 56-bit result of the following form: extension:most significant product:least significant product (EXT:MSP:LSP).

The multiplier executes 24-bit × 24-bit parallel, fractional multiplies between twos-complement signed, unsigned, or mixed operands. The 48-bit product is right-justified and added to the 56-bit contents of either the A or B accumulator. A 56-bit result can be stored as a 24-bit operand. The LSP is either truncated or rounded into the MSP. Rounding is performed if specified.

1-6

# 1.5.2 Address Generation Unit (AGU)

The AGU performs the effective address calculations using integer arithmetic necessary to address data operands in memory and contains the registers that generate the addresses. It implements four types of arithmetic: linear, modulo, multiple wrap-around modulo, and reverse-carry. The AGU operates in parallel with other chip resources to minimize address-generation overhead.

The AGU is divided into halves, each with its own identical address ALU. Each address ALU has four sets of register triplets, and each register triplet includes an address register, offset register, and modifier register. Each contains a 24-bit full adder (called an offset adder). A second full adder (called a modulo adder) adds the summed result of the first full adder to a modulo value that is stored in its respective modifier register. A third full adder (called a reverse-carry adder) is also provided. The offset adder and the reverse-carry adder work in parallel and share common inputs. The only difference between them is that the carry propagates in opposite directions. Test logic determines which of the three summed results of the full adders is output.

Each address ALU can update one address register from its own address register file during one instruction cycle. The contents of the associated modifier register specify the type of arithmetic used in the address register update calculation. The modifier value is decoded in the address ALU.

# 1.5.3 Program Control Unit (PCU)

The PCU fetches and decodes instructions, controls hardware DO loops, and processes exceptions. Its seven-stage pipeline controls the different processing states of the DSP56300 core. The PCU consists of three hardware blocks:

- Program decode controller decodes the 24-bit instruction loaded into the instruction latch and generates all signals for pipeline control.
- Program address generator contains all the hardware needed for program address generation, system stack, and loop control.
- Program interrupt controller arbitrates among all interrupt requests (internal interrupts, as well as the five external requests IRQA, IRQB, IRQC, IRQD, and NMI), and generates the appropriate interrupt vector address.

PCU features include the following:

- Position-independent code support
- Addressing modes optimized for DSP applications (including immediate offsets)
- On-chip instruction cache controller

- On-chip memory-expandable hardware stack
- Nested hardware DO loops
- Fast auto-return interrupts
- Hardware system stack

The PCU uses the following registers:

- Program counter register
- Status register
- Loop address register
- Loop counter register
- Vector base address register
- Size register
- Stack pointer
- Operating mode register
- Stack counter register

### 1.5.4 PLL and Clock Oscillator

The clock generator in the DSP56300 core comprises two main blocks: the PLL, which performs clock input division, frequency multiplication, and skew elimination; and the clock generator, which performs low-power division and clock pulse generation. These features allow you to:

- Change the low-power divide factor without losing the lock
- Output a clock with skew elimination

The PLL allows the processor to operate at a high internal clock frequency using a low-frequency clock input, a feature that offers two immediate benefits:

- A lower-frequency clock input reduces the overall electromagnetic interference generated by a system.
- The ability to oscillate at different frequencies reduces costs by eliminating the need to add additional oscillators to a system.

### 1.5.5 JTAG TAP and OnCE Module

In the DSP56300 core is a dedicated user-accessible TAP that is fully compatible with the *IEEE 1149.1 Standard Test Access Port and Boundary Scan Architecture*. Problems with testing high-density circuit boards led to the development of this standard under the sponsorship of the Test Technology Committee of IEEE and the JTAG. The DSP56300 core implementation supports circuit-board test strategies based on this standard. The test logic includes a TAP with four dedicated signals, a 16-state controller, and three test data registers. A boundary scan register links all device signals into a single shift register. The test logic, implemented utilizing static logic design, is independent of the device system logic. For details on the JTAG port, consult the *DSP56300 Family Manual*.

The OnCE module interacts with the DSP56300 core and its peripherals nonintrusively so that you can examine registers, memory, or on-chip peripherals. This facilitates hardware and software development on the DSP56300 core processor. OnCE module functions are provided through the JTAG TAP signals. For details on the OnCE module, consult the *DSP56300 Family Manual*.

### **1.5.6** On-Chip Memory

The memory space of the DSP56300 core is partitioned into program, X data, and Y data memory space. The data memory space is divided into X and Y data memory in order to work with the two address ALUs and to feed two operands simultaneously to the data ALU. Memory space includes internal RAM and ROM and can be expanded off-chip under software control. There is an on-chip 192 x 24-bit bootstrap ROM. For details on internal memory, see **Chapter 3**, *Memory Configuration*. Program RAM, instruction cache, X data RAM, and Y data RAM size are programmable, as **Table 1-2** shows.

| Program RAM<br>Size                                                                          | Instruction<br>Cache Size | X Data RAM<br>Size* | Y Data RAM<br>Size* | Instruction<br>Cache (CE) | Switch<br>Mode (MS) | MSW1 | MSW0 |
|----------------------------------------------------------------------------------------------|---------------------------|---------------------|---------------------|---------------------------|---------------------|------|------|
| 32 K × 24-bit                                                                                | 0                         | 48 K × 24-bit       | 48 K × 24-bit       | disabled                  | disabled            | 0/1  | 0/1  |
| 31 K × 24-bit                                                                                | 1024 × 24-bit             | 48 K × 24-bit       | 48 K × 24-bit       | enabled                   | disabled            | 0/1  | 0/1  |
| 96 K × 24-bit                                                                                | 0                         | 16 K × 24-bit       | 16 K × 24-bit       | disabled                  | enabled             | 0    | 0    |
| 95 K × 24-bit                                                                                | 1024 × 24-bit             | 16 K × 24-bit       | 16 K × 24-bit       | enabled                   | enabled             | 0    | 0    |
| 80 K × 24-bit                                                                                | 0                         | 24 K × 24-bit       | 24 K × 24-bit       | disabled                  | enabled             | 0    | 1    |
| 79 K × 24-bit                                                                                | 1024 × 24-bit             | 24 K × 24-bit       | 24 K × 24-bit       | enabled                   | enabled             | 0    | 1    |
| 64 K × 24-bit                                                                                | 0                         | 32 K × 24-bit       | 32 K × 24-bit       | disabled                  | enabled             | 1    | 0    |
| 63 K × 24-bit                                                                                | 1024 × 24-bit             | 32 K × 24-bit       | 32 K × 24-bit       | enabled                   | enabled             | 1    | 0    |
| 48 K × 24-bit                                                                                | 0                         | 40 K × 24-bit       | 40 K × 24-bit       | disabled                  | enabled             | 1    | 1    |
| 47 K × 24-bit                                                                                | 1024 × 24-bit             | 40 K × 24-bit       | 40 K × 24-bit       | enabled                   | enabled             | 1    | 1    |
| *Includes 10 K $\times$ 24-bit shared memory (i.e., memory shared by the core and the EFCOP) |                           |                     |                     |                           |                     |      |      |

Table 1-2. DSP56311 Switch Memory Configuration

### **1.5.7** Off-Chip Memory Expansion

Memory can be expanded off chip to the following capacities:

- Data memory expansion to two 256K × 24-bit word memory spaces (or up to two 4M x 24-bit word memory spaces by using the Address Attribute AA0 AA3 signals)
- Program memory expansion to one 256K × 24-bit word memory space (or up to one 4M x 24-bit word memory spaces by using the Address Attribute AA0 AA3 signals)

Further features of off-chip memory include the following:

- External memory expansion port
- Simultaneous glueless interface to static RAM (SRAM) and dynamic RAM (DRAM)

# **1.6** Internal Buses

To provide data exchange between the blocks, the DSP56311 implements the following buses:

- Peripheral I/O expansion bus to peripherals
- Program memory expansion bus to program ROM
- X memory expansion bus to X memory
- Y memory expansion bus to Y memory
- Global data bus between PCU and other core structures
- Program data bus for carrying program data throughout the core
- X memory data bus for carrying X data throughout the core
- Y memory data bus for carrying Y data throughout the core
- Program address bus for carrying program memory addresses throughout the core
- X memory address bus for carrying X memory addresses throughout the core
- Y memory address bus for carrying Y memory addresses throughout the core.

The block diagram in **Figure 1-1** illustrates these buses among other components.

# 1.7 Block Diagram

All internal buses on the DSP56300 family members are 24-bit buses. The program data bus is also a 24-bit bus. **Figure 1-1** shows a block diagram of the DSP56311.







# 1.8 DMA

The DMA block has the following features:

- Six DMA channels supporting internal and external accesses
- One-, two-, and three-dimensional transfers (including circular buffering)
- End-of-block-transfer interrupts
- Triggering from interrupt lines and all peripherals

# 1.9 Peripherals

In addition to the core features, the DSP56311 provides the following peripherals:

- As many as 34 user-configurable GPIO signals
- HI08 to external hosts
- Dual ESSI
- SCI
- Triple timer module
- Memory switch mode
- Four external interrupt/mode control lines

# 1.9.1 GPIO Functionality

The GPIO port consists of up to 34 programmable signals, also used by the peripherals (HI08, ESSI, SCI, and timer). There are no dedicated GPIO signals. After a reset, the signals are automatically configured as GPIO. Three memory-mapped registers per peripheral control GPIO functionality. Programming techniques for these registers to control GPIO functionality are detailed in **Chapter 5**, *Programming the Peripherals*.

# 1.9.2 HI08

The HI08 is a byte-wide, full-duplex, double-buffered parallel port that can connect directly to the data bus of a host processor. The HI08 supports a variety of buses and provides connection with a number of industry-standard DSPs, microcomputers, and microprocessors without requiring any additional logic. The DSP core treats the HI08 as a memory-mapped peripheral occupying eight 24-bit words in data memory space. The DSP can use the HI08 as a memory-mapped peripheral, using either standard polled or interrupt programming techniques. Separate double-buffered transmit and receive data registers allow the DSP and host processor to transfer data efficiently at high speed. Memory

mapping allows you to program DSP core communication with the HI08 registers using standard instructions and addressing modes.

### 1.9.3 ESSI

The DSP56311 provides two independent and identical ESSIs. Each ESSI has a full-duplex serial port for communication with a variety of serial devices, including one or more industry-standard codecs, other DSPs, microprocessors, and peripherals that implement the Motorola SPI. The ESSI consists of independent transmitter and receiver sections and a common ESSI clock generator. ESSI capabilities include the following:

- Independent (asynchronous) or shared (synchronous) transmit and receive sections with separate or shared internal/external clocks and frame syncs
- Normal mode operation using frame sync
- Network mode operation with as many as 32 time slots
- Programmable word length (8, 12, or 16 bits)
- Program options for frame synchronization and clock generation
- One receiver and three transmitters per ESSI

### 1.9.4 SCI

The SCI provides a full-duplex port for serial communication with other DSPs, microprocessors, or peripherals such as modems. The SCI interfaces without additional logic to peripherals that use TTL-level signals. With a small amount of additional logic, the SCI can connect to peripheral interfaces that have non-TTL level signals, such as the RS-232C, RS-422, etc. This interface uses three dedicated signals: transmit data, receive data, and SCI serial clock. It supports industry-standard asynchronous bit rates and protocols, as well as high-speed synchronous data transmission (up to 12.5 Mbps for a 100 MHz clock). SCI asynchronous protocols include a multidrop mode for master/slave operation with wakeup on idle line and wakeup on address bit capability. This mode allows the DSP56311 to share a single serial line efficiently with other peripherals.

Separate SCI transmit and receive sections can operate asynchronously with respect to each other. A programmable baud-rate generator provides the transmit and receive clocks. An enable vector and an interrupt vector allow the baud-rate generator to function as a general-purpose timer when the SCI is not using it or when the interrupt timing is the same as that used by the SCI.

### 1.9.5 Timer Module

The triple timer module is composed of a common 21-bit prescaler and three independent and identical general-purpose 24-bit timer/event counters, each with its own memory-mapped register set. Each timer has the following properties:

- A single signal that can function as a GPIO signal or as a timer signal
- Uses internal or external clocking and can interrupt the DSP after a specified number of events (clocks) or signal an external device after counting internal events
- Connection to the external world through one bidirectional signal. When this signal is configured as an input, the timer functions as an external event counter or measures external pulse width/signal period. When the signal is used as an output, the timer functions as either a timer, a watchdog, or a pulse width modulator.

# 1.9.6 EFCOP

The EFCOP interfaces with the DSP core via the peripheral module bus. It is a general-purpose, fully programmable coprocessor that performs filtering tasks concurrently with the DSP core, with minimum core overhead. The DSP core and the EFCOP can share data via an 8K-word shared data memory. DMA channels shuttle input and output data between the DSP core and the EFCOP. The EFCOP supports a variety of filter modes, some of which are optimized for cellular base station applications:

- Real finite impulse response (FIR) with real taps
- Complex FIR with complex taps
- Complex FIR generating pure real or pure imaginary outputs alternately
- A 4-bit decimation factor in FIR filters, thus providing a decimation ratio up to 16
- Direct form 1 (DFI) infinite impulse response (IIR) filter
- Direct form 2 (DFII) IIR filter
- Four scaling factors (1, 4, 8, 16) for IIR output
- Adaptive FIR filter with true least mean square (LMS) coefficient updates
- Adaptive FIR filter with delayed LMS coefficient updates

The EFCOP supports up to 10K taps and 10K coefficients in any combination of number and length of filters (e.g., eight filters of length 512, or 16 filters of length 256). It performs either 24-bit or 16-bit precision arithmetic with full support for saturation arithmetic. A cost-effective and power-efficient coprocessor, the EFCOP accelerates filtering tasks, such as echo cancellation or correlation, concurrently with software running on the DSP core.

# **Chapter 2** Signals/Connections

The DSP56311 input and output signals are organized into functional groups, as shown in **Table 2-1** and illustrated in **Figure 2-1**.

| Functional Group           |                            | Number of Signals      | Description              |
|----------------------------|----------------------------|------------------------|--------------------------|
| Power (V <sub>CC</sub> )   |                            | 20                     | Table 2-2                |
| Ground (GND)               |                            | 19                     | Table 2-3                |
| Clock                      |                            | 2                      | Table 2-4                |
| PLL                        |                            | <sup>3</sup> Table 2-5 |                          |
| Address bus                |                            | 18                     | Table 2-6                |
| Data bus                   | Port A <sup>1</sup>        | 24                     | Table 2-7                |
| Bus control                |                            | 13                     | Table 2-8                |
| Interrupt and mode control |                            | 5                      | Table 2-9                |
| HI08                       | Port B <sup>2</sup>        | 16                     | Table 2-10               |
| ESSI                       | Ports C and D <sup>3</sup> | 12                     | Table 2-11<br>Table 2-12 |
| SCI                        | Port E <sup>4</sup>        | 3                      | Table 2-13               |
| Timer <sup>5</sup>         |                            | 3                      | Table 2-14               |
| OnCE/JTAG Port             |                            | 6                      | <b>Table 2-15</b>        |

Table 2-1. DSP56311 Functional Signal Groupings

1. Port A signals define the external memory interface port, including the external address bus, data bus, and control signals. The data bus lines have internal keepers.

- 2. Port B signals are the HI08 port signals multiplexed with the GPIO signals. All Port B signals have keepers.
- 3. Port C and D signals are the two ESSI port signals multiplexed with the GPIO signals. All Port C and D signals have keepers.
- 4. Port E signals are the SCI port signals multiplexed with the GPIO signals. All Port C signals have keepers.
- 5. All timer signals have keepers.

**Note:** The Clock Output (CLKOUT) is not functional in the DSP56311. The CLKOUT output pin provides a 50 percent duty cycle output clock synchronized to the internal processor clock when the Phase Lock Loop (PLL) is enabled and locked. At 150 MHz and above, CLKOUT produces a low-amplitude waveform that is not usable externally by other devices. Several alternatives to using CLKOUT exist, such as enabling bus arbitration by setting the Asynchronous Bus Arbitration Enable Bit (ABE) in the Operating Mode register. When set, the ABE bit eliminates the setup and hold time requirements with respect to CLKOUT for BB and BG.



- NOTES: 1. The HI08 port supports a non-multiplexed or a multiplexed bus, single or double Data Strobe (DS), and single or double Host Request (HR) configurations. Since each of these modes is configured independently, any combination of these modes is possible. These HI08 signals can also be configured alternately as GPIO signals (PB0–PB15). Signals with dual designations (e.g., HAS/HAS) have configurable polarity.
  - 2. The ESSI0, ESSI1, and SCI signals are multiplexed: ESSI0 with the Port C GPIO signals (PC0–PC5), ESSI1 with Port D GPIO signals (PD0–PD5), and SCI with Port E GPIO signals (PE0–PE2).
  - 3. TIO0–TIO2 can be configured as GPIO signals.



Signals/Connections

# 2.1 Power

Table 2-2. Power Inputs

| Power Name        | Description                                                                                                                                                                                                                                                  |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| V <sub>CCP</sub>  | <b>PLL Power</b> —VCC dedicated for PLL use. The voltage should be well-regulated and the input should be provided with an extremely low impedance path to the $V_{CC}$ power rail.                                                                          |
| V <sub>CCQL</sub> | <b>Quiet Core (Low) Power</b> —An isolated power for the core processing logic. This input must be isolated externally from all other chip power inputs. The user must provide adequate external decoupling capacitors.                                      |
| V <sub>CCQH</sub> | <b>Quiet External (High) Power</b> —A quiet power source for I/O lines. This input must be tied externally to all other chip power inputs, <i>except</i> V <sub>CCQL</sub> . The user must provide adequate decoupling capacitors.                           |
| V <sub>CCA</sub>  | <b>Address Bus Power</b> —An isolated power for sections of the address bus I/O drivers. This input must be tied externally to all other chip power inputs, <i>except</i> V <sub>CCQL</sub> . The user must provide adequate external decoupling capacitors. |
| V <sub>CCD</sub>  | <b>Data Bus Power</b> —An isolated power for sections of the data bus I/O drivers. This input must be tied externally to all other chip power inputs, <i>except</i> V <sub>CCQL</sub> . The user must provide adequate external decoupling capacitors.       |
| V <sub>CCC</sub>  | <b>Bus Control Power</b> —An isolated power for the bus control I/O drivers. This input must be tied externally to all other chip power inputs, <i>except</i> V <sub>CCQL</sub> . The user must provide adequate external decoupling capacitors.             |
| V <sub>CCH</sub>  | <b>Host Power</b> —An isolated power for the HI08 I/O drivers. This input must be tied externally to all other chip power inputs, <i>except</i> V <sub>CCQL</sub> . The user must provide adequate external decoupling capacitors.                           |
| V <sub>CCS</sub>  | <b>ESSI, SCI, and Timer Power</b> —An isolated power for the ESSI, SCI, and timer I/O drivers. This input must be tied externally to all other chip power inputs, <i>except</i> $V_{CCQL}$ . The user must provide adequate external decoupling capacitors.  |

# 2.2 Ground

| Table 2-3. | <b>Ground Signals</b> |
|------------|-----------------------|
|------------|-----------------------|

| Ground<br>Name    | Description                                                                                                                                                                                                                                                                  |
|-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GND <sub>P</sub>  | <b>PLL Ground</b> — A ground dedicated for PLL use. The connection should be provided with an extremely low-impedance path to ground. V <sub>CCP</sub> should be bypassed to GND <sub>P</sub> by a 0.47 $\mu$ F capacitor located as close as possible to the chip package.  |
| GND <sub>P1</sub> | <b>PLL Ground 1</b> —A ground dedicated for PLL use. The connection should be provided with an extremely low-impedance path to ground.                                                                                                                                       |
| GND <sub>Q</sub>  | <b>Quiet Ground</b> —An isolated ground for the internal processing logic. This connection must be tied externally to all other chip ground connections. The user must provide adequate external decoupling capacitors.                                                      |
| GND <sub>A</sub>  | Address Bus Ground—An isolated ground for sections of the address bus I/O drivers. This connection must be tied externally to all other chip ground connections. The user must provide adequate external decoupling capacitors. There are four GND <sub>A</sub> connections. |

#### Table 2-3. Ground (Continued)Signals

| Ground<br>Name   | Description                                                                                                                                                                                                                                   |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| GND <sub>D</sub> | <b>Data Bus Ground</b> —An isolated ground for sections of the data bus I/O drivers. This connection must be tied externally to all other chip ground connections. The user must provide adequate external decoupling capacitors.             |
| GND <sub>C</sub> | <b>Bus Control Ground</b> —An isolated ground for the bus control I/O drivers. This connection must be tied externally to all other chip ground connections. The user must provide adequate external decoupling capacitors.                   |
| GND <sub>H</sub> | <b>Host Ground</b> —An isolated ground for the HI08 I/O drivers. This connection must be tied externally to all other chip ground connections. The user must provide adequate external decoupling capacitors.                                 |
| GND <sub>S</sub> | <b>ESSI, SCI, and Timer Ground</b> —An isolated ground for the ESSI, SCI, and timer I/O drivers. This connection must be tied externally to all other chip ground connections. The user must provide adequate external decoupling capacitors. |

## 2.3 Clock

Table 2-4. Clock Signals

| Signal<br>Name | Туре   | State During<br>Reset | Signal Description                                                                                                                                        |
|----------------|--------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| EXTAL          | Input  | Input                 | <b>External Clock/Crystal Input</b> —EXTAL interfaces the internal crystal oscillator input to an external crystal or an external clock.                  |
| XTAL           | Output | Chip-driven           | <b>Crystal Output</b> —XTAL connects the internal crystal oscillator output to an external crystal. If an external clock is used, leave XTAL unconnected. |

**Note:** The Clock Output (CLKOUT) is not functional in the DSP56311. The CLKOUT output pin provides a 50 percent duty cycle output clock synchronized to the internal processor clock when the Phase Lock Loop (PLL) is enabled and locked. At 150 MHz and above, CLKOUT produces a low-amplitude waveform that is not usable externally by other devices. Several alternatives to using CLKOUT exist, such as enabling bus arbitration by setting the Asynchronous Bus Arbitration Enable Bit (ABE) in the Operating Mode register. When set, the ABE bit eliminates the setup and hold time requirements with respect to CLKOUT for BB and BG.

## 2.4 PLL

 Table 2-5.
 Phase-Locked Loop Signals

| Signal Name | Туре  | State During<br>Reset | Signal Description                                                                                                                                                                                                                                       |
|-------------|-------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PCAP        | Input | Input                 | <b>PLL Capacitor</b> —PCAP is an input connecting an off-chip capacitor to the PLL filter. Connect one capacitor terminal to PCAP and the other terminal to $V_{CCP}$ .<br>If the PLL is not used, PCAP may be tied to $V_{CC}$ , GND, or left floating. |
| PINIT       | Input | Input                 | <b>PLL Initial</b> —During assertion of RESET, the value of PINIT is written into the PLL enable (PEN) bit of the PLL control (PCTL) register, determining whether the PLL is enabled or disabled.                                                       |
| NMI         | Input |                       | <b>Nonmaskable Interrupt</b> —After RESET deassertion and during normal instruction processing, this Schmitt-trigger input is the negative-edge-triggered NMI request internally synchronized to the internal clock.                                     |

## 2.5 External Memory Expansion Port (Port A)

When the DSP56311 enters a low-power standby mode (stop or wait), it releases bus mastership and tri-states the relevant Port A signals: A0–A17, D0–D23, AA0/ $\overline{RAS0}$ –AA3/ $\overline{RAS3}$ ,  $\overline{RD}$ ,  $\overline{WR}$ ,  $\overline{BB}$ ,  $\overline{CAS}$ .

#### 2.5.1 External Address Bus

| <b>Table 2-6.</b> | External Address Bus Signals |
|-------------------|------------------------------|
|-------------------|------------------------------|

| Signal Name | Туре   | State During<br>Reset | Signal Description                                                                                                                                                                                                                                                                                              |
|-------------|--------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0-A17      | Output | Tri-stated            | <b>Address Bus</b> —When the DSP is the bus master, A0–A17 are active-high outputs that specify the address for external program and data memory accesses. Otherwise, the signals are tri-stated. To minimize power dissipation, A0–A17 do not change state when external memory spaces are not being accessed. |

#### 2.5.2 External Data Bus

| Signal Name | Туре          | State During<br>Reset | Signal Description                                                                                                                                                                                                                                                                                                         |
|-------------|---------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| D0-D23      | Input/ Output | Tri-stated            | <b>Data Bus</b> —When the DSP is the bus master, D0–D23 are active-high, bidirectional input/outputs that provide the bidirectional data bus for external program and data memory accesses. Otherwise, D0–D23 are tri-stated. These lines have weak keepers to maintain the last state even if all drivers are tri-stated. |

#### **2.5.3** External Bus Control

| <b>Table 2-8.</b> | External Bus Control Signals |
|-------------------|------------------------------|
|-------------------|------------------------------|

| Signal Name | Туре   | State During<br>Reset | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------|--------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AA0-AA3     | Output | Tri-stated            | Address Attribute—When defined as AA, these signals can be<br>used as chip selects or additional address lines. The default use<br>defines a priority scheme under which only one AA signal can be<br>asserted at a time. Setting the AA priority disable (APD) bit (Bit 14) of<br>the OMR, the priority mechanism is disabled and the lines can be<br>used together as four external lines that can be decoded externally<br>into 16 chip select signals.<br>Row Address Strobe—When defined as RAS, these signals can be<br>used as RAS for DRAM interface. These signals are tri-statable |
| RAS0-RAS3   | Output |                       | outputs with programmable polarity.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| RD          | Output | Tri-stated            | <b>Read Enable</b> —When the DSP is the bus master, $\overline{RD}$ is an active-low output that is asserted to read external memory on the data bus (D0–D23). Otherwise, $\overline{RD}$ is tri-stated.                                                                                                                                                                                                                                                                                                                                                                                     |
| WR          | Output | Tri-stated            | <b>Write Enable</b> —When the DSP is the bus master, $\overline{\text{WR}}$ is an active-low output that is asserted to write external memory on the data bus (D0–D23). Otherwise, the signals are tri-stated.                                                                                                                                                                                                                                                                                                                                                                               |

External Memory Expansion Port (Port A)

| Signal Name | Туре   | State During<br>Reset  | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------|--------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TA          | Input  | Ignored Input          | Transfer Acknowledge—If the DSP56311 is the bus master and<br>there is no external bus activity, or the DSP56311 is not the bus<br>master, the TA input is ignored. The TA input is a data transfer<br>acknowledge (DTACK) function that can extend an external bus<br>cycle indefinitely. Any number of wait states (1, 2 infinity) may be<br>added to the wait states inserted by the bus control register (BCR) by<br>keeping TA deasserted. In typical operation, TA is deasserted at the<br>start of a bus cycle, is asserted to enable completion of the bus<br>cycle, and is deasserted before the next bus cycle. The current bus<br>cycle completes one clock period after TA is asserted synchronous<br>to the internal clock. The number of wait states is determined by the<br>TA input or by the BCR, whichever is longer. The BCR can be used<br>to set the minimum number of wait states in external bus cycles.<br>To use the TA functionality, the BCR must be programmed to at least<br>one wait state. A zero wait state access cannot be extended by TA<br>deassertion; otherwise, improper operation may result. TA can<br>operate synchronously or asynchronously depending on the setting<br>of the OMR[TAS] bit.<br>TA functionality must not be used while DRAM accesses are |
|             |        |                        | performed; otherwise, improper operation may result.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| BR          | Output | Output<br>(deasserted) | <b>Bus Request</b> —An active-low output, never tri-stated. BR is asserted when the DSP requests bus mastership. BR is deasserted when the DSP no longer needs the bus. BR may be asserted or deasserted independently of whether the DSP56311 is a bus master or a bus slave. Bus "parking" allows BR to be deasserted even though the DSP56311 is the bus master. (See the description of bus "parking" in the BB signal description.) The bus request hole (BRH) bit in the BCR allows BR to be asserted under software control even though the DSP does not need the bus. BR is typically sent to an external bus arbitrator that controls the priority, parking, and tenure of each master on the same external bus. BR is only affected by DSP requests for the external bus, never for the internal bus. During hardware reset, BR is deasserted and the arbitration is reset to the bus slave state.                                                                                                                                                                                                                                                                                                                                                                                          |

| Signal Name | Туре             | State During<br>Reset | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-------------|------------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| BG          | Input            | Ignored Input         | <ul> <li>Bus Grant—An active-low input. BG must be asserted/deasserted synchronous to the internal clock for proper operation. BG is asserted by an external bus arbitration circuit when the DSP56311 becomes the next bus master. When BG is asserted, the DSP56311 must wait until BB is deasserted before taking bus mastership. When BG is deasserted, bus mastership is typically given up at the end of the current bus cycle. This may occur in the middle of an instruction that requires more than one external bus cycle for execution.</li> <li>The default operation of this bit requires a setup and hold time as specified in <i>DSP56311 Technical Data</i> (the data sheet). An alternate mode can be invoked: set the asynchronous bus arbitration enable (ABE) bit (Bit 13) in the OMR. When this bit is set, BG and BB are synchronized internally. This eliminates the respective setup and hold time requirements but adds a required delay between the deassertion of an initial BG input and the assertion of a subsequent BG input.</li> </ul>             |
| BB          | Input/<br>Output | Input                 | <ul> <li>Bus Busy—A bidirectional active-low input/output. Must be asserted and deasserted synchronous to the internal clock. BB indicates that the bus is active. Only after BB is deasserted can the pending bus master become the bus master (and then assert the signal again). The bus master may keep BB asserted after ceasing bus activity regardless of whether BR is asserted or deasserted. Called "bus parking," this allows the current bus master to reuse the bus without rearbitration until another device requires the bus. The deassertion of BB is done by an "active pull-up" method (i.e., BB is driven high and then released and held high by an external pull-up resistor).</li> <li>The default operation of this bit requires a setup and hold time as specified in the <i>DSP56311 Technical Data sheet</i>. An alternate mode can be invoked: set the ABE bit (Bit 13) in the OMR. When this bit is set, BG and BB are synchronized internally. See BG for additional information.</li> <li>NOTE: BB requires an external pull-up resistor.</li> </ul> |
| CAS         | Output           | Tri-stated            | <b>Column Address Strobe</b> —When the DSP is the bus master, CAS is an active-low output used by DRAM to strobe the column address. Otherwise, if the bus mastership enable (BME) bit in the DRAM control register is cleared, the signal is tri-stated.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

## 2.6 Interrupt and Mode Control

The interrupt and mode control signals select the chip's operating mode as it comes out of hardware reset. After  $\overline{\texttt{RESET}}$  is deasserted, these inputs are hardware interrupt request lines.

| Signal Name | Туре  | State During<br>Reset | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------|-------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RESET       | Input | Input                 | <b>Reset</b> —An active-low, Schmitt-trigger input. Deassertion of<br>RESET is internally synchronized to the internal clock. When<br>asserted, the chip is placed in the Reset state and the internal<br>phase generator is reset. The Schmitt-trigger input allows a slowly<br>rising input (such as a capacitor charging) to reset the chip reliably.<br>If RESET is deasserted synchronous to the internal clock, exact<br>start-up timing is guaranteed, allowing multiple processors to start<br>synchronously and operate together in "lock-step." When the<br>RESET signal is deasserted, the initial chip operating mode is<br>latched from the MODA, MODB, MODC, and MODD inputs. The<br>RESET signal must be asserted after power up. |
| MODA        | Input | Input                 | <b>Mode Select A</b> —An active-low Schmitt-trigger input, internally synchronized to the internal clock. MODA, MODB, MODC, and MODD select one of 16 initial chip operating modes, latched into the OMR when the RESET signal is deasserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ĪRQĀ        | Input |                       | <b>External Interrupt Request A</b> —After reset, this input becomes a level-sensitive or negative-edge-triggered, maskable <u>interrupt</u> request input during normal instruction processing. If IRQA is asserted synchronous to the internal clock, multiple processors can be resynchronized using the WAIT instruction and asserting IRQA to exit the wait state. If the processor is in the stop standby state and IRQA is asserted, the processor will exit the stop state.                                                                                                                                                                                                                                                              |
| MODB        | Input | Input                 | <b>Mode Select B</b> —An active-low Schmitt-trigger input, internally synchronized to the internal clock. MODA, MODB, MODC, and MODD select one of 16 initial chip operating modes, latched into the OMR when the RESET signal is deasserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ĪRQB        | Input |                       | <b>External Interrupt Request B</b> —After reset, this input becomes a level-sensitive or negative-edge-triggered, maskable interrupt request input during normal instruction processing. If IRQB is asserted synchronous to the internal clock, multiple processors can be resynchronized using the WAIT instruction and asserting IRQB to exit the wait state. If the processor is in the stop standby state and IRQB is asserted, the processor will exit the stop state.                                                                                                                                                                                                                                                                     |
| MODC        | Input | Input                 | <b>Mode Select C</b> —An active-low Schmitt-trigger input, internally synchronized to the internal clock. MODA, MODB, MODC, and MODD select one of 16 initial chip operating modes, latched into the OMR when the RESET signal is deasserted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| IRQC        | Input |                       | <b>External Interrupt Request C</b> —After reset, this input becomes a level-sensitive or negative-edge-triggered, maskable interrupt request input during normal instruction processing. If IRQC is asserted synchronous to the internal clock, multiple processors can be resynchronized using the WAIT instruction and asserting IRQC to exit the wait state. If the processor is in the stop standby state and IRQC is asserted, the processor will exit the stop state.                                                                                                                                                                                                                                                                     |

| 11100 |
|-------|
|-------|

| Signal Name | Туре  | State During<br>Reset | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------|-------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MODD        | Input | Input                 | <b>Mode Select D</b> —An active-low Schmitt-trigger input, internally synchronized to the internal clock. MODA, MODB, MODC, and MODD select one of 16 initial chip operating modes, latched into the OMR when the RESET signal is deasserted.                                                                                                                                                                                                                                |
| ĪRQD        | Input |                       | <b>External Interrupt Request D</b> —After reset, this input becomes a level-sensitive or negative-edge-triggered, maskable interrupt request input during normal instruction processing. If IRQD is asserted synchronous to the internal clock, multiple processors can be resynchronized using the WAIT instruction and asserting IRQD to exit the wait state. If the processor is in the stop standby state and IRQD is asserted, the processor will exit the stop state. |

| <b>Table 2-9.</b> | Interrupt and Mode Control ( | Continued) |
|-------------------|------------------------------|------------|
|-------------------|------------------------------|------------|

## 2.7 HI08

The HI08 provides a fast parallel-data-to-8-bit port that connects directly to the host bus. The HI08 supports a variety of standard buses and can directly connect to a number of industry-standard microcomputers, microprocessors, DSPs, and DMA hardware.

| Signal Name | Туре               | State During<br>Reset | Signal Description                                                                                                                                                                                                    |
|-------------|--------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| H0-H7       | Input/<br>Output   | Tri-stated            | <b>Host Data</b> —When the HI08 is programmed to interface a nonmultiplexed host bus and the HI function is selected, these signals are lines 0–7 of the data bidirectional, tri-state bus.                           |
| HAD0–HAD7   | Input/<br>Output   |                       | <b>Host Address</b> —When HI08 is programmed to interface a multiplexed host bus and the HI function is selected, these signals are lines 0–7 of the address/data bidirectional, multiplexed, tri-state bus.          |
| PB0–PB7     | Input or<br>Output |                       | <b>Port B 0–7</b> —When the HI08 is configured as GPIO through the host port control register (HPCR), these signals are individually programmed as inputs or outputs through the HI08 data direction register (HDDR). |
|             |                    |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                    |

| <b>Table 2-10.</b> | Host Interface |
|--------------------|----------------|
|--------------------|----------------|

| Signal Name | Туре               | State During<br>Reset | Signal Description                                                                                                                                                                                                                                                                                      |
|-------------|--------------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HA0         | Input              | Input                 | <b>Host Address Input 0</b> —When the HI08 is programmed to interface a nonmultiplexed host bus and the HI function is selected, this signal is line 0 of the host address input bus.                                                                                                                   |
| HAS/HAS     | Input              |                       | Host Address Strobe—When HI08 is programmed to interface<br>a multiplexed host bus and the HI function is selected, this signal<br>is the host address strobe (HAS) Schmitt-trigger input. The<br>polarity of the address strobe is programmable but is configured<br>active-low (HAS) following reset. |
| PB8         | Input or<br>Output |                       | <b>Port B 8</b> —When the HI08 is configured as GPIO through the HPCR, this signal is individually programmed as an input or output through the HDDR.                                                                                                                                                   |
|             |                    |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                                      |
| HA1         | Input              | Input                 | Host Address Input 1—When the HI08 is programmed to interface a nonmultiplexed host bus and the HI function is selected, this signal is line 1 of the host address (HA1) input bus.                                                                                                                     |
| HA8         | Input              |                       | <b>Host Address 8</b> —When HI08 is programmed to interface a multiplexed host bus and the HI function is selected, this signal is line 8 of the host address (HA8) input bus.                                                                                                                          |
| PB9         | Input or<br>Output |                       | <b>Port B 9</b> —When the HI08 is configured as GPIO through the HPCR, this signal is individually programmed as an input or output through the HDDR.                                                                                                                                                   |
|             | - 1                |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                                      |
| HA2         | Input              | Input                 | Host Address Input 2—When the HI08 is programmed to                                                                                                                                                                                                                                                     |

interface a nonmultiplexed host bus and the HI function is selected, this signal is line 2 of the host address (HA2) input bus.

Host Address 9-When HI08 is programmed to interface a

line 9 of the host address (HA9) input bus.

output through the HDDR.

even if all drivers are tri-stated.

multiplexed host bus and the HI function is selected, this signal is

**Port B 10**—When the HI08 is configured as GPIO through the HPCR, this signal is individually programmed as an input or

NOTE: This signal has a weak keeper to maintain the last state

| <b>Table 2-10.</b> | Host Interface | (Continued) |
|--------------------|----------------|-------------|
|--------------------|----------------|-------------|

HI08

HA9

**PB10** 

Input

Input or

Output

| Signal Name | Туре               | State During<br>Reset | Signal Description                                                                                                                                                                                                                                                                                         |
|-------------|--------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HRW         | Input              | Input                 | Host Read/Write—When HI08 is programmed to interface a single-data-strobe host bus and the HI function is selected, this signal is the Host Read/Write (HRW) input.                                                                                                                                        |
| HRD/HRD     | Input              |                       | Host Read Data—When HI08 is programmed to interface a double-data-strobe host bus and the HI function is selected, this signal is the HRD strobe Schmitt-trigger input. The polarity of the data strobe is programmable, but is configured as active-low (HRD) after reset.                                |
| PB11        | Input or<br>Output |                       | <b>Port B 11</b> —When the HI08 is configured as GPIO through the HPCR, this signal is individually programmed as an input or output through the HDDR.                                                                                                                                                     |
|             |                    |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                                         |
| HDS/HDS     | Input              | Input                 | Host Data Strobe—When HI08 is programmed to interface a single-data-strobe host bus and the HI function is selected, this signal is the host data strobe (HDS) Schmitt-trigger input. The polarity of the data strobe is programmable, but is configured as active-low (HDS) following reset.              |
| HWR/HWR     | Input              |                       | <b>Host Write Data</b> —When HI08 is programmed to interface a double-data-strobe host bus and the HI function is selected, this signal is the host write data strobe (HWR) Schmitt-trigger input. The polarity of the data strobe is programmable, but is configured as active-low (HWR) following reset. |
| PB12        | Input or<br>Output |                       | <b>Port B 12</b> —When the HI08 is configured as GPIO through the HPCR, this signal is individually programmed as an input or output through the HDDR.                                                                                                                                                     |
|             |                    |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                                         |
| HCS         | Input              | Input                 | Host Chip Select—When HI08 is programmed to interface a nonmultiplexed host bus and the HI function is selected, this signal is the host chip select (HCS) input. The polarity of the chip select is programmable, but is configured active-low (HCS) after reset.                                         |
| HA10        | Input              |                       | <b>Host Address 10</b> —When HI08 is programmed to interface a multiplexed host bus and the HI function is selected, this signal is line 10 of the host address (HA10) input bus.                                                                                                                          |
| PB13        | Input or<br>Output |                       | <b>Port B 13</b> —When the HI08 is configured as GPIO through the HPCR, this signal is individually programmed as an input or output through the HDDR.                                                                                                                                                     |
|             |                    |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                                         |

| Table 2-10.         Host Interface (Continued) |
|------------------------------------------------|
|------------------------------------------------|

Enhanced Synchronous Serial Interface 0

| Signal Name   | Туре               | State During<br>Reset | Signal Description                                                                                                                                                                                                                                                                                                                                                                 |
|---------------|--------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HREQ/HREQ     | Output             | Input                 | Host Request—When HI08 is programmed to interface a single<br>host request host bus and the HI function is selected, this signal<br>is the host request (HREQ) output. The polarity of the host<br>request is programmable, but is configured as active-low (HREQ)<br>following reset. The host request may be programmed as a<br>driven or open-drain output.                     |
| HTRQ/HTRQ     | Output             |                       | <b>Transmit Host Request</b> —When HI08 is programmed to interface a double host request host bus and the HI function is selected, this signal is the transmit host request (HTRQ) output. The polarity of the host request is programmable, but is configured as active-low (HTRQ) following reset. The host request may be programmed as a driven or open-drain output.          |
| PB14          | Input or<br>Output |                       | <b>Port B 14</b> —When the HI08 is programmed to interface a multiplexed host bus and the signal is configured as GPIO through the HPCR, this signal is individually programmed as an input or output through the HDDR.                                                                                                                                                            |
|               |                    |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                                                                                                                 |
| HACK/<br>HACK | Input              | Input                 | Host Acknowledge—When HI08 is programmed to interface a single host request host bus and the HI function is selected, this signal is the host acknowledge (HACK) Schmitt-trigger input. The polarity of the host acknowledge is programmable, but is configured as active-low (HACK) after reset.                                                                                  |
| HRRQ/<br>HRRQ | Output             |                       | <b>Receive Host Request</b> —When HI08 is programmed to interface<br>a double host request host bus and the HI function is selected,<br>this signal is the receive host request (HRRQ) output. The<br>polarity of the host request is programmable, but is configured as<br>active-low (HRRQ) after reset. The host request may be<br>programmed as a driven or open-drain output. |
| PB15          | Input or<br>Output |                       | <b>Port B 15</b> —When the HI08 is configured as GPIO through the HPCR, this signal is individually programmed as an input or output through the HDDR.                                                                                                                                                                                                                             |
|               |                    |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                                                                                                                 |

| <b>Table 2-10.</b> | Host Interface (Continued) |
|--------------------|----------------------------|
|--------------------|----------------------------|

#### **Enhanced Synchronous Serial Interface 0** 2.8

Two synchronous serial interfaces (ESSI0 and ESSI1) provide a full-duplex serial port for serial communication with a variety of serial devices, including one or more industry-standard CODECs, other DSPs, microprocessors, and peripherals that implement the Motorola serial peripheral interface (SPI).

**Freescale Semiconductor, Inc.** 

| Signal Name | Туре             | State During<br>Reset | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------|------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SC00        | Input or Output  | Input                 | <b>Serial Control 0</b> —The function of SC00 is determined by the selection of either synchronous or asynchronous mode. For asynchronous mode, this signal will be used for the receive clock I/O (Schmitt-trigger input). For synchronous mode, this signal is used either for transmitter 1 output or for serial I/O flag 0.                                                                                                         |
| PC0         |                  |                       | <b>Port C 0</b> —The default configuration following reset is GPIO input PC0. When configured as PC0, signal direction is controlled through the port directions register (PRR0). The signal can be configured as ESSI signal SC00 through the port control register (PCR0).                                                                                                                                                            |
|             |                  |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                                                                                                                                                                      |
| SC01        | Input/<br>Output | Input                 | <b>Serial Control 1</b> —The function of this signal is determined<br>by the selection of either synchronous or asynchronous<br>mode. For asynchronous mode, this signal is the receiver<br>frame sync I/O. For synchronous mode, this signal is used<br>either for transmitter 2 output or for serial I/O flag 1.                                                                                                                      |
| PC1         | Input or Output  |                       | <b>Port C 1</b> —The default configuration following reset is GPIO input PC1. When configured as PC1, signal direction is controlled through PRR0. The signal can be configured as an ESSI signal SC01 through PCR0.                                                                                                                                                                                                                    |
|             |                  |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                                                                                                                                                                      |
| SC02        | Input/<br>Output | Input                 | <b>Serial Control Signal 2</b> —Used for frame sync I/O. SC02 is the frame sync for both the transmitter and receiver in synchronous mode, and for the transmitter only in asynchronous mode. When configured as an output, this signal is the internally generated frame sync signal. When configured as an input, this signal receives an external frame sync signal for the transmitter (and the receiver in synchronous operation). |
| PC2         | Input or Output  |                       | <b>Port C 2</b> —The default configuration following reset is GPIO input PC2. When configured as PC2, signal direction is controlled through PRR0. The signal can be configured as an ESSI signal SC02 through PCR0.                                                                                                                                                                                                                    |
|             |                  |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                                                                                                                                                                      |

| <b>Table 2-11.</b> | Enhanced Synchronous Serial Interface 0 (Continued) |
|--------------------|-----------------------------------------------------|
|--------------------|-----------------------------------------------------|

| Signal Name | Туре             | State During<br>Reset | Signal Description                                                                                                                                                                                                                                                                                                                                   |
|-------------|------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SCK0        | Input/<br>Output | Input                 | <b>Serial Clock</b> —A bidirectional Schmitt-trigger input signal providing the serial bit rate clock for the ESSI. The SCK0 is a clock input or output, used by both the transmitter and receiver in synchronous modes or by the transmitter in asynchronous modes.                                                                                 |
|             |                  |                       | Although an external serial clock can be independent of<br>and asynchronous to the DSP system clock, it must<br>exceed the minimum clock cycle time of 6T (i.e., the<br>system clock frequency must be at least three times the<br>external ESSI clock frequency). The ESSI needs at least<br>three DSP phases inside each half of the serial clock. |
| PC3         | Input or Output  |                       | <b>Port C 3</b> —The default configuration following reset is GPIO input PC3. When configured as PC3, signal direction is controlled through PRR0. The signal can be configured as an ESSI signal SCK0 through PCR0.                                                                                                                                 |
|             |                  |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                                                                                   |
| SRD0        | Input/<br>Output | Input                 | Serial Receive Data—Receives serial data and transfers<br>the data to the ESSI receive shift register. SRD0 is an input<br>when data is being received.                                                                                                                                                                                              |
| PC4         | Input or Output  |                       | <b>Port C 4</b> —The default configuration following reset is GPIO input PC4. When configured as PC4, signal direction is controlled through PRR0. The signal can be configured as an ESSI signal SRD0 through PCR0.                                                                                                                                 |
|             |                  |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                                                                                   |
| STD0        | Input/<br>Output | Input                 | <b>Serial Transmit Data</b> —Transmits data from the serial transmit shift register. STD0 is an output when data is transmitted.                                                                                                                                                                                                                     |
| PC5         | Input or Output  |                       | <b>Port C 5</b> —The default configuration following reset is GPIO input PC5. When configured as PC5, signal direction is controlled through PRR0. The signal can be configured as an ESSI signal STD0 through PCR0.                                                                                                                                 |
|             |                  |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                                                                                   |

## 2.9 Enhanced Synchronous Serial Interface 1

| Signal Name | Туре             | State During<br>Reset | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------|------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SC10        | Input or Output  | Input                 | <b>Serial Control 0</b> —The function of SC10 is determined by the selection of either synchronous or asynchronous mode. For asynchronous mode, this signal will be used for the receive clock I/O (Schmitt-trigger input). For synchronous mode, this signal is used either for transmitter 1 output or for serial I/O flag 0.                                                                                                    |
| PDO         | Input or Output  |                       | <b>Port D 0</b> —The default configuration following reset is GPIO input PD0. When configured as PD0, signal direction is controlled through the port directions register (PRR1). The signal can be configured as an ESSI signal SC10 through the port control register (PCR1).                                                                                                                                                    |
|             |                  |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                                                                                                                                                                 |
| SC11        | Input/<br>Output | Input                 | <b>Serial Control 1</b> —The function of this signal is determined<br>by the selection of either synchronous or asynchronous<br>mode. For asynchronous mode, this signal is the receiver<br>frame sync I/O. For synchronous mode, this signal is used<br>either for Transmitter 2 output or for Serial I/O Flag 1.                                                                                                                 |
| PD1         | Input or Output  |                       | <b>Port D 1</b> —The default configuration following reset is GPIO input PD1. When configured as PD1, signal direction is controlled through PRR1. The signal can be configured as an ESSI signal SC11 through PCR1.                                                                                                                                                                                                               |
|             |                  |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                                                                                                                                                                 |
| SC12        | Input/<br>Output | Input                 | <b>Serial Control Signal 2</b> —For frame sync I/O. SC12 is the frame sync for both the transmitter and receiver in synchronous mode, and for the transmitter only in asynchronous mode. When configured as an output, this signal is the internally generated frame sync signal. When configured as an input, this signal receives an external frame sync signal for the transmitter (and the receiver in synchronous operation). |
| PD2         | Input or Output  |                       | <b>Port D 2</b> —The default configuration following reset is GPIO input PD2. When configured as PD2, signal direction is controlled through PRR1. The signal can be configured as an ESSI signal SC12 through PCR1.                                                                                                                                                                                                               |
|             |                  |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                                                                                                                                                                 |

| <b>Table 2-12.</b> | Enhanced Serial Synchronous Interface 1 (Continued) |
|--------------------|-----------------------------------------------------|
|--------------------|-----------------------------------------------------|

| Signal Name | Туре             | State During<br>Reset | Signal Description                                                                                                                                                                                                                                                                                                                                   |
|-------------|------------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SCK1        | Input/<br>Output | Input                 | <b>Serial Clock</b> —A bidirectional Schmitt-trigger input signal providing the serial bit rate clock for the ESSI. The SCK1 is a clock input or output used by both the transmitter and receiver in synchronous modes, or by the transmitter in asynchronous modes.                                                                                 |
|             |                  |                       | Although an external serial clock can be independent of<br>and asynchronous to the DSP system clock, it must<br>exceed the minimum clock cycle time of 6T (i.e., the<br>system clock frequency must be at least three times the<br>external ESSI clock frequency). The ESSI needs at least<br>three DSP phases inside each half of the serial clock. |
| PD3         | Input or Output  |                       | <b>Port D 3</b> —The default configuration following reset is GPIO input PD3. When configured as PD3, signal direction is controlled through PRR1. The signal can be configured as an ESSI signal SCK1 through PCR1.                                                                                                                                 |
|             |                  |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                                                                                   |
| SRD1        | Input/<br>Output | Input                 | Serial Receive Data—Receives serial data and transfers<br>the data to the ESSI receive shift register. SRD1 is an input<br>when data is being received.                                                                                                                                                                                              |
| PD4         | Input or Output  |                       | <b>Port D 4</b> —The default configuration following reset is GPIO input PD4. When configured as PD4, signal direction is controlled through PRR1. The signal can be configured as an ESSI signal SRD1 through PCR1.                                                                                                                                 |
|             |                  |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                                                                                   |
| STD1        | Input/<br>Output | Input                 | <b>Serial Transmit Data</b> —Transmits data from the serial transmit shift register. STD1 is an output when data is being transmitted.                                                                                                                                                                                                               |
| PD5         | Input or Output  |                       | <b>Port D 5</b> —The default configuration following reset is GPIO input PD5. When configured as PD5, signal direction is controlled through PRR1. The signal can be configured as an ESSI signal STD1 through PCR1.                                                                                                                                 |
|             |                  |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                                                                                   |

## 2.10 SCI

The SCI provides a full duplex port for serial communication with other DSPs, microprocessors, or peripherals such as modems.

| Signal Name | Туре            | State During<br>Reset | Signal Description                                                                                                                                                                                                                                                                  |
|-------------|-----------------|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| RXD         | Input           | Input                 | Serial Receive Data—Receives byte oriented serial data and transfers it to the SCI receive shift register.                                                                                                                                                                          |
| PE0         | Input or Output |                       | <b>Port E 0</b> —The default configuration following reset is GPIO input PE0. When configured as PE0, signal direction is controlled through the SCI port directions register (PRR). The signal can be configured as an SCI signal RXD through the SCI port control register (PCR). |
|             |                 |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                  |
| TXD         | Output          | Input                 | Serial Transmit Data—Transmits data from the SCI transmit data register.                                                                                                                                                                                                            |
| PE1         | Input or Output |                       | <b>Port E 1</b> —The default configuration following reset is GPIO input PE1. When configured as PE1, signal direction is controlled through the SCI PRR. The signal can be configured as an SCI signal TXD through the SCI PCR.                                                    |
|             |                 |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                  |
| SCLK        | Input/ Output   | Input                 | <b>Serial Clock</b> —The bidirectional Schmitt-trigger input signal providing the input or output clock used by the transmitter and/or the receiver.                                                                                                                                |
| PE2         | Input or Output |                       | <b>Port E 2</b> —The default configuration following reset is GPIO input PE2. When configured as PE2, signal direction is controlled through the SCI PRR. The signal can be configured as an SCI signal SCLK through the SCI PCR.                                                   |
|             |                 |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                                                                  |

## 2.11 Timers

The DSP56311 has three identical and independent timers. Each timer can use internal or external clocking and either interrupt the DSP56311 after a specified number of events (clocks) or signal an external device after counting a specific number of internal events.

| Signal Name | Туре            | State During<br>Reset | Signal Description                                                                                                                                                                                                                            |
|-------------|-----------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TIO0        | Input or Output | Input                 | <b>Timer 0 Schmitt-Trigger Input/Output</b> — When Timer 0 functions as an external event counter or in measurement mode, TIO0 is used as input. When Timer 0 functions in watchdog, timer, or pulse modulation mode, TIO0 is used as output. |
|             |                 |                       | The default mode after reset is GPIO input. This can be changed to output or configured as a timer I/O through the timer 0 control/status register (TCSR0).                                                                                   |
|             |                 |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                            |
| TIO1        | Input or Output | Input                 | <b>Timer 1 Schmitt-Trigger Input/Output</b> — When Timer 1 functions as an external event counter or in measurement mode, TIO1 is used as input. When Timer 1 functions in watchdog, timer, or pulse modulation mode, TIO1 is used as output. |
|             |                 |                       | The default mode after reset is GPIO input. This can be changed to output or configured as a timer I/O through the timer 1 control/status register (TCSR1).                                                                                   |
|             |                 |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                            |
| TIO2        | Input or Output | Input                 | <b>Timer 2 Schmitt-Trigger Input/Output</b> — When timer 2 functions as an external event counter or in measurement mode, TIO2 is used as input. When timer 2 functions in watchdog, timer, or pulse modulation mode, TIO2 is used as output. |
|             |                 |                       | The default mode after reset is GPIO input. This can be changed to output or configured as a timer I/O through the timer 2 control/status register (TCSR2).                                                                                   |
|             |                 |                       | NOTE: This signal has a weak keeper to maintain the last state even if all drivers are tri-stated.                                                                                                                                            |

| <b>Table 2-14.</b> | Triple Timer Signals |
|--------------------|----------------------|
|--------------------|----------------------|

## 2.12 JTAG and OnCE Interface

The DSP56300 family and in particular the DSP56311 support circuit-board test strategies based on the *IEEE 1149.1 Standard Test Access Port and Boundary Scan Architecture*, the industry standard developed under the sponsorship of the Test Technology Committee of IEEE and the JTAG.

The OnCE module interfaces nonintrusively with the DSP56300 core and its peripherals so that you can examine registers, memory, or on-chip peripherals. Functions of the OnCE module are provided through the JTAG TAP signals.

2-20

| Signal Name | Туре          | State During<br>Reset | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|-------------|---------------|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| тск         | Input         | Input                 | <b>Test Clock</b> —A test clock input signal to synchronize the JTAG test logic.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| TDI         | Input         | Input                 | <b>Test Data Input</b> —A test data serial input signal used for test instructions and data. TDI is sampled on the rising edge of TCK and has an internal pull-up resistor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| TDO         | Output        | Tri-stated            | <b>Test Data Output</b> —A test data serial output signal used<br>for test instructions and data. TDO is tri-statable and is<br>actively driven in the shift-IR and shift-DR controller states.<br>TDO changes on the falling edge of TCK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| TMS         | Input         | Input                 | <b>Test Mode Select</b> —An input signal to sequence the test controller's state machine. TMS is sampled on the rising edge of TCK and has an internal pull-up resistor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| TRST        | Input         | Input                 | <b>Test Reset</b> —A Schmitt-trigger input signal to<br>asynchronously initialize the test controller. TRST has an<br>internal pull-up resistor. TRST must be asserted after<br>power up.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| DE          | Input/ Output | Input                 | <ul> <li>Debug Event—An open-drain signal. As an input, enters the Debug mode of operation from an external command controller. As an output, acknowledges that the chip has entered Debug mode. When asserted as an input, DE causes the DSP56300 core to finish the executing instruction, save the instruction pipeline information, enter the Debug mode, and wait for commands to be entered from the debug serial input line. This signal is asserted as an output for three clock cycles when the chip enters Debug mode as a result of a debug request or as a result of meeting a breakpoint condition. The DE has an internal pull-up resistor.</li> <li>This is not a standard part of the JTAG TAP controller. The signal connects directly to the OnCE module to initiate Debug mode directly or to provide a direct external indication that the chip has entered the debug mode. All other interface with the OnCE module must occur through the JTAG port.</li> </ul> |

#### Table 2-15.OnCE/JTAG Interface

# **Chapter 3** Memory Configuration

Like all members of the DSP56300 core family, the DSP56311 can address three sets of  $16 \text{ M} \times 24$ -bit memory internally: program, X data, and Y data. Each of these memory spaces includes both on-chip and external memory (accessed through the external memory interface). The DSP56311 is extremely flexible because it has several modes to allocate on-chip memory between the program memory and the two data memory spaces. You can also configure it to operate in a special sixteen-bit compatibility mode that allows the chip to use DSP56000 object code without any change; this can result in higher performance of existing code for applications that do not require a larger address space. This section provides detailed information on each of these memory spaces.

## 3.1 Program Memory Space

Program memory space consists of the following:

- Internal program memory (program RAM, 32K by default, up to 96K)
- (Optional) instruction cache (1K) formed from program RAM
- Bootstrap program ROM (192 x 24-bit)
- Optional off-chip memory expansion (as much as 128K in 16-bit mode or 256K in 24-bit mode using the 18 external address lines or 4 M using the external address lines and the four address attribute lines). Refer to the *DSP56300 Family Manual*, especially the Expansion Port chapter, for detailed information on using the external memory interface to access external program memory.
- **Note:** Program memory space at locations \$FF00C0 \$FFFFFF is reserved and should not be accessed.

#### 3.1.1 Internal Program Memory

The default on-chip program memory consists of a 24-bit-wide, high-speed, SRAM occupying the lowest 32K locations (\$0 – \$7FFF) in program memory space. The on-chip program RAM is organized in 32 banks with 1024 locations each. You can make additional program memory available using the memory switch mode described in **Section 3.1.2**, "Memory Switch Modes—Program Memory."

#### **3.1.2** Memory Switch Modes—Program Memory

Memory switch mode allows reallocation of portions of X and Y data RAM as program RAM. OMR[7] is the memory switch (MS) bit that controls this function, as follows:

- When the MS bit is cleared, program memory consists of the default 32K × 24-bit memory space described in the previous section. In this default mode, the lowest external program memory location is \$8000.
- When the MS bit is set, a portion of the higher locations of the internal X and Y data memory are switched to internal program memory. The memory switch configuration (MSW[1:0]) bits (also called M1 and M0) in the OMR select one of the following options:
  - **MSW[1:0] = 00**—The 32K higher locations (\$4000 \$BFFF) of the internal X data memory and the 32K higher locations (\$6000 \$BFFF) of the internal Y data memory are switched to internal program memory. In such a case, the on-chip program memory occupies the lowest 96K locations (\$0 \$17FFF) in the program memory space. The instruction cache, if enabled, occupies the lowest 1K program words (locations \$0 \$3FF). The lowest external program memory location in this mode is \$18000.

  - MSW[1:0] = 10—The 16K higher locations (\$8000 \$BFFF) of the internal X data memory and the 16K higher locations (\$8000 \$BFFF) of the internal Y data memory are switched to internal program memory. In such a case, the on-chip program memory occupies the lowest 64K locations (\$0 \$FFFF) in the program memory space. The instruction cache, if enabled, occupies the lowest 1K program words (locations \$0 \$3FF). The lowest external program memory locations \$10000 \$17FFF are considered reserved and should not be accessed.
  - MSW[1:0] = 11—The 8K higher locations (\$A000 \$BFFF) of the internal X memory and the 8K higher locations (\$A000 \$BFFF) of the internal Y memory are switched to internal program memory. In such a case, the on-chip program memory occupies the lowest 48K locations (\$0 \$BFFF) in the program memory space. The instruction cache, if enabled, occupies the

lowest 1 K program words (locations \$0 – \$3FF). The lowest external program memory location in this mode is \$18000, while program memory locations \$C000-\$17FFF are considered reserved and should not be accessed.

#### 3.1.3 Instruction Cache

In program memory space, the lowest 1024 (1K) program words (at locations 0 - 3FF) function as an internal instruction cache. When the instruction cache is enabled (that is, the CE bit in the SR is set), the lowest 1K program words are reserved for the instruction cache and should not be accessed for other purposes.

Note: When using an enabled instruction cache, you must assign a valid value for the vector address bus so that interrupts can be handled properly outside P:\$0 – \$3FF. (See the memory diagrams, starting with Figure 3-2, "Memory Switch Off, Cache On, 24-Bit Mode," on page 3-10.)

#### 3.1.4 Program Bootstrap ROM

The program memory space occupying locations \$FF0000 – \$FF00BF includes the internal bootstrap ROM. This ROM contains the 192-word DSP56311 bootstrap program.

## 3.2 X Data Memory Space

The X data memory space consists of the following:

- Internal X data memory (48K by default down to 8K)
- Internal X I/O space (upper 128 locations)
- Optional off-chip memory expansion (as much as 128K in 16-bit mode, or 256K in 24-bit mode using the 18 external address lines, or 4 M using the external address lines and the four address attribute lines). Refer to the *DSP56300 Family Manual*, especially **Section 2**, *Expansion Port*, for details on using the external memory interface to access external X data memory.
- **Note:** The X memory space at locations \$FF0000 \$FFEFFF is reserved and should not be accessed.

#### 3.2.1 Internal X Data Memory

The default on-chip X data RAM is a 24-bit-wide, internal, static memory occupying the lowest 48 K locations (0 - BFFF) in X memory space. The on-chip X data RAM is organized into 48 banks with 1024 locations each. Available X data memory space is reduced and reallocated to program memory using the memory switch mode described in the next section.

#### 3.2.2 Memory Switch Modes—X Data Memory

Memory switch mode reallocates of portions of X and Y data RAM as program RAM. Bit 7 in the OMR is the MS bit that controls this function, as follows:

- When the MS bit is cleared, the X data memory consists of the default 48K × 24-bit memory space described in the previous section. In this default mode, the lowest external X data memory location is \$6000.
- When the MS bit is set, a portion of the higher locations of the internal X memory is switched to internal program memory. The memory switch (MSW[1:0]) configuration bits in the OMR select one of the following options:
  - MSW[1:0] = 00—The 32K higher locations (\$4000 \$BFFF) of the internal X memory are switched to internal program memory, and therefore the highest internal X memory location is \$3FFF. The X memory space at the switched locations (\$4000 \$BFFF) becomes reserved and should not be accessed. The lowest external X memory location is \$C000.
  - MSW[1:0] = 01—The 24K higher locations (\$6000 \$BFFF) of the internal X memory are switched to internal program memory, and therefore the highest internal X memory location is \$5FFF. The X memory space at the switched locations (\$6000 \$BFFF) becomes reserved and should not be accessed. The lowest external X memory location is \$C000.
  - MSW[1:0] = 10—The 16K higher locations (\$8000 \$BFFF) of the internal X memory are switched to internal program memory, and therefore the highest internal X memory location is \$7FFF. The X memory space at the switched locations (\$8000 \$BFFF) becomes reserved and should not be accessed. The lowest external X memory location is \$C000.
  - MSW[1:0] = 11—The 8K higher locations (\$A000 \$BFFF) of the internal X memory are switched to internal program memory, and therefore the highest internal X memory location is \$9FFF. The X memory space at the switched locations (\$A000 \$BFFF) becomes reserved and should not be accessed. The lowest external X memory location is \$C000.
- **Note:** The 10K lowest locations (\$0 \$27FF) of the internal X memory are *shared memory*, which is accessible to both the core and the EFCOP. The EFCOP connects to the shared memory instead of the DMA bus, so there is no DMA accessibility to shared memory. Simultaneous accesses by the core and the EFCOP to the same memory bank (1024 locations) of the shared memory are not permitted. It is the programmer's responsibility to prevent such simultaneous accesses.

#### 3.2.3 Internal X I/O Space

One part of the on-chip peripheral registers and some of the DSP56311 core registers occupy the top 128 locations of the X data memory (\$FFFF80 – \$FFFFFF). This area is referred to as the internal X I/O space and it can be accessed by MOVE, MOVEP instructions and by bit-oriented instructions (BCHG, BCLR, BSET, BTST, BRCLR, BRSET, BSCLR, BSSET, JCLR, JSET, JSCLR and JSSET). The contents of the internal X I/O memory space are listed in Appendix A.

## 3.3 Y Data Memory Space

The Y data memory space consists of the following:

- Internal Y data memory (48K by default down to 16K)
- Internal Y I/O space (16 locations—\$FFFF80 \$FFFF8F)
- External Y I/O space (upper 112 locations)
- Optional off-chip memory expansion (as much as 128K in 16-bit mode or 256K in 24-bit mode using the 18 external address lines or 4 M using the external address lines and the four address attribute lines). Refer to the *DSP56300 Family Manual* for details on using the external memory interface to access external Y data memory.
- **Note:** The Y memory space at locations \$FF0000 \$FFEFFF is reserved and should not be accessed.

### 3.3.1 Internal Y Data Memory

The default on-chip Y data RAM is a 24-bit-wide, internal, static memory occupying the lowest 48K locations (\$0 - \$BFFF) in Y memory space. The on-chip Y data RAM is organized in 48 banks, 1024 locations each. Available Y data memory space is reduced and reallocated to program memory by using the memory switch mode described in the following paragraphs.

#### 3.3.2 Memory Switch Modes—Y Data Memory

Memory switch mode reallocates of portions of X and Y data RAM as program RAM. Bit 7 in the OMR is the MS bit that controls this function, as follows:

- When the MS bit is cleared, the Y data memory consists of the default 48K × 24-bit memory space described in the previous section. In this default mode, the lowest external Y data memory location is \$6000.
- When MS mode bit in the OMR is set, a portion of the higher locations of the internal Y memory are switched to internal program memory. The memory switch configuration (MSW[1:0]) bits in the OMR select one of the following options:
  - MSW[1:0] = 00—The 32K higher locations (\$4000 \$BFFF) of the internal Y memory are switched to internal program memory, and therefore the highest internal Y memory location is \$3FFF. The Y memory space at the switched locations (\$4000 – \$BFFF) becomes reserved and should not be accessed. The lowest external Y memory location is \$C000.
  - MSW[1:0] = 01—The 24K higher locations (\$6000 \$BFFF) of the internal Y memory are switched to internal program memory, and therefore the highest internal Y memory location is \$5FFF. The Y memory space at the switched locations (\$6000 – \$BFFF) becomes reserved and should not be accessed. The lowest external Y memory location is \$C000.
  - MSW[1:0] = 10—The 8K higher locations (\$8000 \$BFFF) of the internal Y memory are switched to internal program memory, and therefore the highest internal Y memory location is \$7FFF. The Y memory space at the switched locations (\$8000 – \$BFFF) becomes reserved and should not be accessed. The lowest external Y memory location is \$C000.
  - MSW[1:0] = 11—The 4K higher locations (\$A000 \$BFFF) of the internal Y memory are switched to internal program memory, and therefore the highest internal Y memory location is \$9FFF. The Y memory space at the switched locations (\$A000-\$BFFF) becomes reserved and should not be accessed. The lowest external Y memory location is \$C000.
- **Note:** The 10K lowest locations (\$0-\$27FF) of the internal Y memory are *shared memory*, which is accessible both to the core and the EFCOP. The EFCOP connects to the shared memory in place of the DMA bus. Therefore, DMA cannot access the shared memory, and simultaneous accesses by the core and EFCOP to the same memory bank (of 256 locations) of the shared memory are not permitted. It is your responsibility to prevent such simultaneous accesses.

## 3.3.3 Internal Y I/O Space

The second part of the on-chip peripheral registers occupies 16 locations (\$FFFF80 – \$FFFF8F) of the Y data memory. This area is the internal Y I/O space, and it can be accessed by MOVE, MOVEP instructions and by bit-oriented instructions (BCHG, BCLR, BSET, BTST, BRCLR, BRSET, BSCLR, BSSET, JCLR, JSET, JSCLR and JSSET). The contents of the internal Y I/O memory space are listed in Appendix A.

## 3.3.4 External Y I/O Space

Off-chip peripheral registers should be mapped into the top 112 locations (\$FFFF90 – \$FFFFF) to take advantage of the move peripheral data (MOVEP) instruction and the bit-oriented instructions (BCHG, BCLR, BSET, BTST, BRCLR, BRSET, BSCLR, BSSET, JCLR, JSET, JSCLR and JSSET). This area is the *external Y I/O space*.

## **3.4** Dynamic Memory Configuration Switching

When the internal memory configuration is altered by remapping RAM modules from X and Y data memories into program memory space and *vice versa*, data contents of the switched RAM modules are preserved. Any sequence that complies with the switch condition is valid. For example, if the program flow executes in the address range that is not affected by the switch, the switch condition can be met very easily. A switch can be accomplished just by changing the OMR[MS/MSW] bits in the regular program flow, assuming no accesses to the affected address ranges of the data memory occur up to three instructions after the instruction that changes the OMR bits.

## CAUTION

To ensure that dynamic switching is trouble-free, do not allow any accesses (including instruction fetches) to or from the affected address ranges in program and data memories during the switch cycle.

Because an interrupt could cause the DSP to fetch instructions out of sequence and might violate the switch condition, special care should be taken in relation to the interrupt vector routines.

### CAUTION

Pay special attention when executing a memory switch routine using the OnCE port. Running the switch routine in trace mode, for example, can cause the switch to complete after the MS/MSW bits change while the DSP is in Debug mode. As a result, subsequent instructions may be fetched according to the new memory configuration (after the switch) and thus may execute improperly.

## 3.5 Sixteen-Bit Compatibility Mode Configuration

The sixteen-bit compatibility (SC) mode allows the DSP56311 to use DSP56000 object code without change. The SC bit (Bit 13 in the SR) is used to switch from the default 24-bit mode to this special 16-bit mode. SC is cleared by reset. You must set this bit to select the SC mode. The address ranges described in the previous sections apply in the SC mode with regard to the reallocation of X and Y data memory to program memory in MS mode, but the maximum addressing ranges are limited to \$FFFF, and all data and program code are 16 bits wide.

## 3.6 Memory Maps

The following figures illustrate each of the memory space and RAM configurations defined by the settings of the MS (and MSW[1:0]), CE, and SC bits. The figures show the configuration and describe the bit settings, memory sizes, and memory locations.

**Note:** In 16-bit mode, if the MS mode bit in the Operating Mode Register (OMR) is set, external program memory is not accessible, so enabling the instruction cache is of little benefit. In addition, certain 16-bit modes prevent you from accessing the entire internal DSP56311 memory space.



|    | Bit Set                                                                                                                                        | tings |    | Memory Configuration   |                        |                        |       |                            |  |  |  |
|----|------------------------------------------------------------------------------------------------------------------------------------------------|-------|----|------------------------|------------------------|------------------------|-------|----------------------------|--|--|--|
| MS | MSW<br>[1:0]                                                                                                                                   | CE    | SC | Program RAM            | X Data RAM*            | Y Data RAM*            | Cache | Addressable<br>Memory Size |  |  |  |
| 0  | any<br>value                                                                                                                                   | 0     | 0  | 32K<br>\$0000 – \$7FFF | 48K<br>\$0000 – \$BFFF | 48K<br>\$0000 – \$BFFF | None  | 16 M                       |  |  |  |
|    | Lowest 10K of X data RAM and 10K of Y data RAM are shared memory that can be accessed by the core and the EFCOP but not by the DMA controller. |       |    |                        |                        |                        |       |                            |  |  |  |



Memory Maps



|    | Bit Set                                                                                                                                        | tings |    | Memory Configuration   |                        |                        |         |                            |  |  |  |
|----|------------------------------------------------------------------------------------------------------------------------------------------------|-------|----|------------------------|------------------------|------------------------|---------|----------------------------|--|--|--|
| MS | MSW<br>[1:0]                                                                                                                                   | CE    | SC | Program RAM            | X Data RAM*            | Y Data RAM*            | Cache   | Addressable<br>Memory Size |  |  |  |
| 0  | any<br>value                                                                                                                                   | 1     | 0  | 31K<br>\$0400 – \$7FFF | 48K<br>\$0000 – \$BFFF | 48K<br>\$0000 – \$BFFF | Enabled | 16 M                       |  |  |  |
|    | Lowest 10K of X data RAM and 10K of Y data RAM are shared memory that can be accessed by the core and the EFCOP but not by the DMA controller. |       |    |                        |                        |                        |         |                            |  |  |  |

Figure 3-2. Memory Switch Off, Cache On, 24-Bit Mode



|    | Bit Set      | tings |    |                            | Memory Configuration   |                        |       |                            |
|----|--------------|-------|----|----------------------------|------------------------|------------------------|-------|----------------------------|
| MS | MSW<br>[1:0] | CE    | sc | Program RAM                | X Data RAM*            | Y Data RAM*            | Cache | Addressable<br>Memory Size |
| 1  | 00           | 0     | 0  | 96K<br>\$0000 –<br>\$17FFF | 16K<br>\$0000 – \$3FFF | 16K<br>\$0000 – \$3FFF | None  | 16 M                       |

\* Lowest 10K of X data RAM and 410K of Y data RAM are shared memory that can be accessed by the core and the EFCOP but not by the DMA controller.

Figure 3-3. Memory Switch On (MSW = 00), Cache Off, 24-Bit Mode



|    | Bit Set                                                                                                                                        | tings |    | Memory Configuration   |                        |                        |         |                            |  |  |  |
|----|------------------------------------------------------------------------------------------------------------------------------------------------|-------|----|------------------------|------------------------|------------------------|---------|----------------------------|--|--|--|
| MS | MSW<br>[1:0]                                                                                                                                   | CE    | sc | Program RAM            | X Data RAM*            | Y Data RAM*            | Cache   | Addressable<br>Memory Size |  |  |  |
| 1  | 00                                                                                                                                             | 1     | 0  | 95K<br>\$0400 – \$BFFF | 16K<br>\$0000 – \$3FFF | 16K<br>\$0000 – \$3FFF | Enabled | 16 M                       |  |  |  |
|    | Lowest 10K of X data RAM and 10K of Y data RAM are shared memory that can be accessed by the core and the EFCOP but not by the DMA controller. |       |    |                        |                        |                        |         |                            |  |  |  |

Figure 3-4. Memory Switch On (MSW = 00), Cache On, 24-Bit Mode



|    | Bit Set      | tings |    | Memory Configuration       |                        |                        |       |                            |  |
|----|--------------|-------|----|----------------------------|------------------------|------------------------|-------|----------------------------|--|
| MS | MSW<br>[1:0] | CE    | SC | Program RAM                | X Data RAM*            | Y Data RAM*            | Cache | Addressable<br>Memory Size |  |
| 1  | 01           | 0     | 0  | 80K<br>\$0000 –<br>\$13FFF | 24K<br>\$0000 – \$5FFF | 24K<br>\$0000 – \$5FFF | None  | 16 M                       |  |

\* Lowest 10K of X data RAM and 10K of Y data RAM are shared memory that can be accessed by the core and the EFCOP but not by the DMA controller.

Figure 3-5. Memory Switch On (MSW = 01), Cache Off, 24-Bit Mode

Memory Maps



|    | Bit Set      | tings |    | Memory Configuration       |                        |                        |         |                            |
|----|--------------|-------|----|----------------------------|------------------------|------------------------|---------|----------------------------|
| MS | MSW<br>[1:0] | CE    | SC | Program RAM                | X Data RAM*            | Y Data RAM*            | Cache   | Addressable<br>Memory Size |
| 1  | 01           | 1     | 0  | 79K<br>\$0400 –<br>\$13FFF | 24K<br>\$0000 – \$5FFF | 24K<br>\$0000 – \$5FFF | Enabled | 16 M                       |

\* Lowest 10K of X data RAM and 10K of Y data RAM are shared memory that can be accessed by the core and the EFCOP but not by the DMA controller.

Figure 3-6. Memory Switch On (MSW = 01), Cache On, 24-Bit Mode



|    | Bit Set                                                                                                                                        | tings |    | Memory Configuration   |                        |                        |       |                            |  |  |  |
|----|------------------------------------------------------------------------------------------------------------------------------------------------|-------|----|------------------------|------------------------|------------------------|-------|----------------------------|--|--|--|
| MS | МSW<br>[1:0]                                                                                                                                   | CE    | sc | Program RAM            | X Data RAM*            | Y Data RAM*            | Cache | Addressable<br>Memory Size |  |  |  |
| 1  | 10                                                                                                                                             | 0     | 0  | 64K<br>\$0000 – \$FFFF | 32K<br>\$0000 – \$7FFF | 32K<br>\$0000 – \$7FFF | None  | 16 M                       |  |  |  |
|    | Lowest 10K of X data RAM and 10K of Y data RAM are shared memory that can be accessed by the core and the EFCOP but not by the DMA controller. |       |    |                        |                        |                        |       |                            |  |  |  |

**Figure 3-7.** Memory Switch On (MSW = 10), Cache Off, 24-Bit Mode

Memory Maps



|    | Bit Set                                                                                                                                        | tings |    | Memory Configuration   |                        |                        |         |                            |  |  |  |
|----|------------------------------------------------------------------------------------------------------------------------------------------------|-------|----|------------------------|------------------------|------------------------|---------|----------------------------|--|--|--|
| MS | MSW<br>[1:0]                                                                                                                                   | CE    | sc | Program RAM            | X Data RAM*            | Y Data RAM*            | Cache   | Addressable<br>Memory Size |  |  |  |
| 1  | 10                                                                                                                                             | 1     | 0  | 63K<br>\$0400 – \$FFFF | 32K<br>\$0000 – \$7FFF | 32K<br>\$0000 – \$7FFF | Enabled | 16 M                       |  |  |  |
|    | Lowest 10K of X data RAM and 10K of Y data RAM are shared memory that can be accessed by the core and the EFCOP but not by the DMA controller. |       |    |                        |                        |                        |         |                            |  |  |  |

**Figure 3-8.** Memory Switch On (MSW = 10), Cache On, 24-Bit Mode

Semiconductor, Inc.

reescale



|    | Bit Set                                                                                                                                           | tings |    | Memory Configuration   |                        |                        |       |                            |  |  |  |
|----|---------------------------------------------------------------------------------------------------------------------------------------------------|-------|----|------------------------|------------------------|------------------------|-------|----------------------------|--|--|--|
| MS | MSW<br>[1:0]                                                                                                                                      | CE    | SC | Program RAM            | X Data RAM*            | Y Data RAM*            | Cache | Addressable<br>Memory Size |  |  |  |
| 1  | 11                                                                                                                                                | 0     | 0  | 48K<br>\$0000 – \$BFFF | 40K<br>\$0000 – \$9FFF | 40K<br>\$0000 – \$9FFF | None  | 16 M                       |  |  |  |
|    | Lowest 10K of X data RAM and 10K of Y data RAM are shared memory that can be accessed by the core and<br>the EFCOP but not by the DMA controller. |       |    |                        |                        |                        |       |                            |  |  |  |



Memory Maps



| Bit Settings                                                                                                                                     |              |    |    | Memory Configuration   |                        |                        |         |                            |
|--------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----|----|------------------------|------------------------|------------------------|---------|----------------------------|
| MS                                                                                                                                               | MSW<br>[1:0] | CE | sc | Program RAM            | X Data RAM*            | Y Data RAM*            | Cache   | Addressable<br>Memory Size |
| 1                                                                                                                                                | 11           | 1  | 0  | 47K<br>\$0400 – \$BFFF | 40K<br>\$0000 – \$9FFF | 40K<br>\$0000 – \$9FFF | Enabled | 16 M                       |
| * Lowest 10K of X data RAM and 10K of Y data RAM are shared memory that can be accessed by the core and the EFCOP but not by the DMA controller. |              |    |    |                        |                        |                        |         |                            |

**Figure 3-10.** Memory Switch On (MSW = 11), Cache On, 24-Bit Mode



|    | Bit Set                                                                                                                                         | tings |    | Memory Configuration   |                        |                        |       |                            |
|----|-------------------------------------------------------------------------------------------------------------------------------------------------|-------|----|------------------------|------------------------|------------------------|-------|----------------------------|
| MS | MSW<br>[1:0]                                                                                                                                    | CE    | sc | Program RAM            | X Data RAM*            | Y Data RAM*            | Cache | Addressable<br>Memory Size |
| 0  | any<br>value                                                                                                                                    | 0     | 1  | 32K<br>\$0000 – \$3FFF | 48K<br>\$0000 – \$BFFF | 48K<br>\$0000 – \$BFFF | None  | 64K                        |
|    | *Lowest 10K of X data RAM and 10K of Y data RAM are shared memory that can be accessed by the core and the EFCOP but not by the DMA controller. |       |    |                        |                        |                        |       |                            |

Figure 3-11. Memory Switch Off, Cache Off, 16-Bit Mode



|    | Bit Set                                                                                                                                          | tings |    | Memory Configuration   |                        |                        |         |                            |
|----|--------------------------------------------------------------------------------------------------------------------------------------------------|-------|----|------------------------|------------------------|------------------------|---------|----------------------------|
| MS | MSW<br>[1:0]                                                                                                                                     | CE    | SC | Program RAM            | X Data RAM*            | Y Data RAM*            | Cache   | Addressable<br>Memory Size |
| 0  | any<br>value                                                                                                                                     | 1     | 1  | 31K<br>\$0400 – \$7FFF | 48K<br>\$0000 – \$BFFF | 48K<br>\$0000 – \$BFFF | Enabled | 64K                        |
|    | * Lowest 10K of X data RAM and 10K of Y data RAM are shared memory that can be accessed by the core and the EFCOP but not by the DMA controller. |       |    |                        |                        |                        |         |                            |

Figure 3-12. Memory Switch Off, Cache On, 16-Bit Mode



|    | Bit Set      | tings |    | Memory Configuration               |                        |                        |          |                            |
|----|--------------|-------|----|------------------------------------|------------------------|------------------------|----------|----------------------------|
| MS | MSW<br>[1:0] | CE    | SC | Program RAM                        | X Data RAM*            | Y Data RAM*            | Cache    | Addressable<br>Memory Size |
| 1  | 00           | 0     | 1  | 64K<br>\$0000 – \$FFFF             | 16K<br>\$0000 – \$3FFF | 16K<br>\$0000 – \$3FFF | None     | 64K                        |
|    |              |       |    | 1 and 10K of Y da<br>A controller. | ta RAM are shared      | memory that can b      | e access | ed by the core and         |

Figure 3-13. Memory Switch On (MSW = 00), Cache Off, 16-Bit Mode



|    | Bit Set                                                                                                                                          | tings |    |                        | Memory Configuration   |                        |         |                            |  |  |
|----|--------------------------------------------------------------------------------------------------------------------------------------------------|-------|----|------------------------|------------------------|------------------------|---------|----------------------------|--|--|
| MS | MSW<br>[1:0]                                                                                                                                     | CE    | SC | Program RAM            | X Data RAM*            | Y Data RAM*            | Cache   | Addressable<br>Memory Size |  |  |
| 1  | 00                                                                                                                                               | 1     | 1  | 63K<br>\$0400 – \$FFFF | 16K<br>\$0000 – \$3FFF | 16K<br>\$0000 – \$3FFF | Enabled | 64K                        |  |  |
|    | * Lowest 10K of X data RAM and 10K of Y data RAM are shared memory that can be accessed by the core and the EFCOP but not by the DMA controller. |       |    |                        |                        |                        |         |                            |  |  |

Figure 3-14. Memory Switch On (MSW = 00), Cache On, 16-Bit Mode



|    | Bit Set      | tings |    | Memory Configuration               |                        |                        |          |                            |
|----|--------------|-------|----|------------------------------------|------------------------|------------------------|----------|----------------------------|
| MS | MSW<br>[1:0] | CE    | SC | Program RAM                        | X Data RAM*            | Y Data RAM*            | Cache    | Addressable<br>Memory Size |
| 1  | 01           | 0     | 1  | 64K<br>\$0000 – \$FFFF             | 24K<br>\$0000 – \$5FFF | 24K<br>\$0000 – \$5FFF | None     | 64K                        |
|    |              |       |    | 1 and 10K of Y da<br>A controller. | ta RAM are shared      | memory that can b      | e access | ed by the core and         |





|    | Bit Set                                                                                                                                          | tings |    | Memory Configuration   |                        |                        |         |                            |  |
|----|--------------------------------------------------------------------------------------------------------------------------------------------------|-------|----|------------------------|------------------------|------------------------|---------|----------------------------|--|
| MS | MSW<br>[1:0]                                                                                                                                     | CE    | SC | Program RAM            | X Data RAM*            | Y Data RAM*            | Cache   | Addressable<br>Memory Size |  |
| 1  | 01                                                                                                                                               | 1     | 1  | 63K<br>\$0400 – \$FFFF | 24K<br>\$0000 – \$5FFF | 24K<br>\$0000 – \$5FFF | Enabled | 64K                        |  |
|    | * Lowest 10K of X data RAM and 10K of Y data RAM are shared memory that can be accessed by the core and the EFCOP but not by the DMA controller. |       |    |                        |                        |                        |         |                            |  |

Figure 3-16. Memory Switch On (MSW = 01), Cache On, 16-Bit Mode



|    | Bit Set      | tings |    | Memory Configuration               |                        |                        |          |                            |
|----|--------------|-------|----|------------------------------------|------------------------|------------------------|----------|----------------------------|
| MS | MSW<br>[1:0] | CE    | sc | Program RAM                        | X Data RAM*            | Y Data RAM*            | Cache    | Addressable<br>Memory Size |
| 1  | 10           | 0     | 1  | 64K<br>\$0000 – \$FFFF             | 32K<br>\$0000 – \$7FFF | 32K<br>\$0000 – \$7FFF | None     | 64K                        |
|    |              |       |    | I and 10K of Y da<br>A controller. | ta RAM are shared      | I memory that can b    | e access | ed by the core and         |





|    | Bit Set                                                                                                                                          | tings |    | Memory Configuration   |                        |                        |         |                            |
|----|--------------------------------------------------------------------------------------------------------------------------------------------------|-------|----|------------------------|------------------------|------------------------|---------|----------------------------|
| MS | MSW<br>[1:0]                                                                                                                                     | CE    | SC | Program RAM            | X Data RAM*            | Y Data RAM*            | Cache   | Addressable<br>Memory Size |
| 1  | 10                                                                                                                                               | 1     | 1  | 63K<br>\$0400 – \$FFFF | 24K<br>\$0000 – \$9FFF | 24K<br>\$0000 – \$9FFF | Enabled | 64K                        |
|    | * Lowest 10K of X data RAM and 10K of Y data RAM are shared memory that can be accessed by the core and the EFCOP but not by the DMA controller. |       |    |                        |                        |                        |         |                            |

Figure 3-18. Memory Switch On (MSW = 10), Cache On, 16-Bit Mode



|    | Bit Set                                                                                                                                          | tings |    | Memory Configuration   |                        |                        |       |                            |
|----|--------------------------------------------------------------------------------------------------------------------------------------------------|-------|----|------------------------|------------------------|------------------------|-------|----------------------------|
| MS | MSW<br>[1:0]                                                                                                                                     | CE    | SC | Program RAM            | X Data RAM*            | Y Data RAM*            | Cache | Addressable<br>Memory Size |
| 1  | 11                                                                                                                                               | 0     | 1  | 48K<br>\$0000 – \$BFFF | 40K<br>\$0000 – \$9FFF | 40K<br>\$0000 – \$9FFF | None  | 64K                        |
|    | * Lowest 10K of X data RAM and 10K of Y data RAM are shared memory that can be accessed by the core and the EFCOP but not by the DMA controller. |       |    |                        |                        |                        |       |                            |

Figure 3-19. Memory Switch On (MSW = 11), Cache Off, 16-Bit Mode



|    | Bit Set                                                                                                                                          | tings |    |                        | Mem                    | ory Configuration      |         |                            |  |
|----|--------------------------------------------------------------------------------------------------------------------------------------------------|-------|----|------------------------|------------------------|------------------------|---------|----------------------------|--|
| MS | MSW<br>[1:0]                                                                                                                                     | CE    | sc | Program RAM            | X Data RAM*            | Y Data RAM*            | Cache   | Addressable<br>Memory Size |  |
| 1  | 11                                                                                                                                               | 1     | 1  | 47K<br>\$0400 – \$BFFF | 40K<br>\$0000 – \$9FFF | 40K<br>\$0000 – \$9FFF | Enabled | 64K                        |  |
|    | * Lowest 10K of X data RAM and 10K of Y data RAM are shared memory that can be accessed by the core and the EFCOP but not by the DMA controller. |       |    |                        |                        |                        |         |                            |  |

**Figure 3-20.** Memory Switch On (MSW = 11), Cache On, 16-Bit Mode

# **Chapter 4** Core Configuration

This chapter presents DSP56300 core configuration details specific to the DSP56311. These configuration details include the following:

- Operating modes
- Bootstrap program
- Interrupt sources and priorities
- DMA request sources
- OMR
- PLL control register
- AA control registers
- JTAG boundary scan register

For information on specific registers or modules in the DSP56300 core, refer to the *DSP56300 Family Manual*.

### 4.1 Operating Modes

The DSP56311 begins operation by leaving the Reset state and going into one of eight operating modes. As the DSP56311 exits the Reset state, it loads the values of MODA, MODB, MODC, and MODD into bits MA, MB, MC, and MD of the OMR. These bit settings determine the chip's operating mode, which in turn determines the bootstrap program option the chip uses to start up.

Software can also directly set the OMR[MA–MD] bits. A jump directly to the bootstrap program entry point (\$FF0000) after the OMR bits are set causes the DSP56311 to execute the specified bootstrap program option (except modes 0 and 8). **Table 4-1** shows the DSP56311 bootstrap operation modes, the corresponding settings of the external operational mode signal lines (the OMR[MA–MD] bits), and the reset vector address to which the DSP56311 jumps once it leaves the Reset state.

**Operating Modes** 

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------|------|------|------|------|-----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0    | 0    | 0    | 0    | 0    | \$C00000        | Expanded mode<br>Bypasses the bootstrap ROM, and the DSP56311<br>starts fetching instructions beginning at address<br>\$C00000. Memory accesses are performed using<br>SRAM memory access type with 31 wait states<br>and no address attributes selected (default).<br>Address \$C00000 is reflected as address \$00000<br>on Port A signals A0–A17.                                                                                                                                                                                      |
| 1    | 0    | 0    | 0    | 1    | \$FF0000        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 2    | 0    | 0    | 1    | 0    | \$FF0000        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 3    | 0    | 0    | 1    | 1    | \$FF0000        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 4    | 0    | 1    | 0    | 0    | \$FF0000        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 5    | 0    | 1    | 0    | 1    | \$FF0000        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 6    | 0    | 1    | 1    | 0    | \$FF0000        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 7    | 0    | 1    | 1    | 1    | \$FF0000        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 8    | 1    | 0    | 0    | 0    | \$008000        | <b>Expanded mode</b><br>Bypasses the bootstrap ROM, and the DSP56311<br>starts fetching instructions beginning at address<br>\$008000. Memory accesses are performed using<br>SRAM memory access type with 31 wait states<br>and no address attributes selected.                                                                                                                                                                                                                                                                          |
| 9    | 1    | 0    | 0    | 1    | \$FF0000        | <b>Bootstrap from byte-wide memory</b><br>The bootstrap program loads instructions through<br>Port A from external byte-wide memory, starting at<br>P:\$D00000. The SRAM memory access type is<br>selected by the values in address attribute register<br>1 (AAR1). Thirty-one wait states are inserted<br>between each memory access. Address \$D00000<br>is reflected as address \$00000 on Port A signals<br>A0–A17. The boot program concatenates every 3<br>bytes read from the external memory into a 24-bit<br>wide DSP56311 word. |

Table 4-1. DSP56311 Operating Modes

| Table 4-1. | DSP56311 Operating Modes | (Continued) |
|------------|--------------------------|-------------|
|------------|--------------------------|-------------|

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------|------|------|------|------|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A    | 1    | 0    | 1    | 0    | \$FF0000        | <b>Bootstrap through SCI</b><br>Instructions are loaded through the SCI. The<br>bootstrap program sets the SCI to operate in 10-bit<br>asynchronous mode, with 1 start bit, 8 data bits, 1<br>stop bit, and no parity. Data is received in this<br>order: start bit, 8 data bits (LSB first), and one stop<br>bit. Data is aligned in the SCI receive data register<br>with the LSB of the least significant byte of the<br>received data appearing at Bit 0.The user must<br>provide an external clock source with a frequency<br>at least 16 times the transmission data rate. Each<br>byte received by the SCI is echoed back through<br>the SCI transmitter to the external transmitter. The<br>boot program concatenates every 3 bytes read<br>from the SCI into a 24-bit wide DSP56311 word. |
| В    | 1    | 0    | 1    | 1    | \$FF0000        | Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| С    | 1    | 1    | 0    | 0    | \$FF0000        | HI08 bootstrap in ISA/DSP563xx mode<br>The HI08 is configured to interface with an ISA bus<br>or with the memory expansion port of a master<br>DSP563xx processor through the HI08. The HI08<br>pin configuration is optimized for connection to the<br>ISA bus or memory expansion port of a master<br>DSP based on the DSP56300 core.                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| D    | 1    | 1    | 0    | 1    | \$FF0000        | HI08 bootstrap in HC11 nonmultiplexed mode<br>The bootstrap program sets the host interface to<br>interface with the Motorola HC11 microcontroller<br>through the HI08. The HI08 pin configuration is<br>optimized for connection to the Motorola HC11<br>nonmultiplexed bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| E    | 1    | 1    | 1    | 0    | \$FF0000        | HI08 bootstrap in 8051 multiplexed bus mode<br>The bootstrap program sets the host interface to<br>interface with the Intel 8051 bus through the HI08.<br>The program stored in this location, after testing<br>MODA, MODB, MODC, and MODD, bootstraps<br>through HI08. The HI08 pin configuration is<br>optimized for connection to the Intel 8051<br>multiplexed bus.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| F    | 1    | 1    | 1    | 1    | \$FF0000        | HI08 bootstrap in MC68302 bus mode<br>The bootstrap program sets the host interface to<br>interface with the Motorola MC68302 or MC68360<br>bus through the HI08. The HI08 pin configuration is<br>optimized for connection to a Motorola MC68302<br>or MC68360 bus.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

### 4.2 Bootstrap Program

The bootstrap program is factory-programmed in an internal 192-word by 24-bit bootstrap ROM located in program memory space at locations \$FF0000–\$FF00BF. The bootstrap program can load any program RAM segment from an external byte-wide EPROM, the SCI, or the host port. The bootstrap program code is listed in Appendix A.

Upon exiting the Reset state, the DSP56311 samples the MODA-MODD signal lines and loads their values into OMR[MA - MD]. The mode input signals (MODA–MODD) and the resulting MA, MB, MC, and MD bits determine which bootstrap mode the DSP56311 enters (see **Table 4-1**).

**Note:** To stop the bootstrap in any HI08 bootstrap mode, set the Host Flag 0 (HF0). The loaded user program begins executing from the specified starting address.

You can invoke the bootstrap program options (except modes 0 and 8) at any time by setting the MA, MB, MC, and MD bits in the OMR and jumping to the bootstrap program entry point, \$FF0000. Software can directly set the mode selection bits in the OMR. Bootstrap modes 0 and 8 are the normal DSP56311 functioning modes. Bootstrap modes 9, A, and C–F select different specific bootstrap loading source devices. In these modes, the bootstrap program expects the following data sequence when downloading the user program through an external port:

- **1.** Three bytes that specify the number of (24-bit) program words to be loaded
- 2. Three bytes that specify the (24-bit) start address where the user program loads in the DSP56311 program memory
- **3.** The user program (three bytes for each 24-bit program word)

**Note:** The three bytes for each data sequence are loaded least significant byte first.

When the bootstrap program finishes loading the specified number of words, it jumps to the specified starting address and executes the loaded program.

## 4.3 Interrupt Sources and Priorities

DSP56311 interrupt handling, like that for all DSP56300 family members, is optimized for DSP applications. Refer to the chapter on interrupts in the *DSP56300 Family Manual*. The interrupt table resides in the 256 locations of program memory to which the PCU vector base address (VBA) register points.

Semiconductor, Inc.

reescale

Go to: www.freescale.com

#### 4.3.1 Interrupt Sources

Each interrupt is allocated two instructions in the table, resulting in 128 table entries for interrupt handling. **Table 4-2** shows the table entry address for each interrupt source. The DSP56311 initialization program loads the table entry for each interrupt serviced with two interrupt servicing instructions. In the DSP56311, only some of the 128 vector addresses are used for specific interrupt sources. The remaining interrupt vectors are reserved and can be used for host NMI (IPL = 3) or for host command interrupt (IPL = 2). Unused interrupt vector locations can be used for program or data storage.

| Interrupt<br>Starting Address | Interrupt<br>Priority Level<br>Range | Interrupt Source            |  |
|-------------------------------|--------------------------------------|-----------------------------|--|
| VBA:\$00                      | 3                                    | Hardware RESET              |  |
| VBA:\$02                      | 3                                    | Stack error                 |  |
| VBA:\$04                      | 3                                    | Illegal instruction         |  |
| VBA:\$06                      | 3                                    | Debug request interrupt     |  |
| VBA:\$08                      | 3                                    | Тгар                        |  |
| VBA:\$0A                      | 3                                    | Nonmaskable interrupt (NMI) |  |
| VBA:\$0C                      | 3                                    | Reserved                    |  |
| VBA:\$0E                      | 3                                    | Reserved                    |  |
| VBA:\$10                      | 0–2                                  | ĪRQĀ                        |  |
| VBA:\$12                      | 0–2                                  | ĪRQB                        |  |
| VBA:\$14                      | 0–2                                  | IRQC                        |  |
| VBA:\$16                      | 0–2                                  | ĪRQD                        |  |
| VBA:\$18                      | 0–2                                  | DMA channel 0               |  |
| VBA:\$1A                      | 0–2                                  | DMA channel 1               |  |
| VBA:\$1C                      | 0–2                                  | DMA channel 2               |  |
| VBA:\$1E                      | 0–2                                  | DMA channel 3               |  |
| VBA:\$20                      | 0–2                                  | DMA channel 4               |  |
| VBA:\$22                      | 0–2                                  | DMA channel 5               |  |
| VBA:\$24                      | 0–2                                  | TIMER 0 compare             |  |
| VBA:\$26                      | 0–2                                  | TIMER 0 overflow            |  |
| VBA:\$28                      | 0–2                                  | TIMER 1 compare             |  |
| VBA:\$2A                      | 0–2                                  | TIMER 1 overflow            |  |
| VBA:\$2C                      | 0–2                                  | TIMER 2 compare             |  |
| VBA:\$2E                      | 0–2                                  | TIMER 2 overflow            |  |
| VBA:\$30                      | 0–2                                  | ESSI0 receive data          |  |

| Table 4-2. | Interrupt Sources |
|------------|-------------------|
|------------|-------------------|

Interrupt Sources and Priorities

| Interrupt<br>Starting Address | Interrupt<br>Priority Level<br>Range | Interrupt Source                          |  |
|-------------------------------|--------------------------------------|-------------------------------------------|--|
| VBA:\$32                      | 0–2                                  | ESSI0 receive data with exception status  |  |
| VBA:\$34                      | 0–2                                  | ESSI0 receive last slot                   |  |
| VBA:\$36                      | 0–2                                  | ESSI0 transmit data                       |  |
| VBA:\$38                      | 0–2                                  | ESSI0 transmit data with exception status |  |
| VBA:\$3A                      | 0–2                                  | ESSI0 transmit last slot                  |  |
| VBA:\$3C                      | 0–2                                  | Reserved                                  |  |
| VBA:\$3E                      | 0–2                                  | Reserved                                  |  |
| VBA:\$40                      | 0–2                                  | ESSI1 receive data                        |  |
| VBA:\$42                      | 0–2                                  | ESSI1 receive data with exception status  |  |
| VBA:\$44                      | 0–2                                  | ESSI1 receive last slot                   |  |
| VBA:\$46                      | 0–2                                  | ESSI1 transmit data                       |  |
| VBA:\$48                      | 0–2                                  | ESSI1 transmit data with exception status |  |
| VBA:\$4A                      | 0–2                                  | ESSI1 transmit last slot                  |  |
| VBA:\$4C                      | 0–2                                  | Reserved                                  |  |
| VBA:\$4E                      | 0–2                                  | Reserved                                  |  |
| VBA:\$50                      | 0–2                                  | SCI receive data                          |  |
| VBA:\$52                      | 0–2                                  | SCI receive data with exception status    |  |
| VBA:\$54                      | 0–2                                  | SCI transmit data                         |  |
| VBA:\$56                      | 0–2                                  | SCI idle line                             |  |
| VBA:\$58                      | 0–2                                  | SCI timer                                 |  |
| VBA:\$5A                      | 0–2                                  | Reserved                                  |  |
| VBA:\$5C                      | 0–2                                  | Reserved                                  |  |
| VBA:\$5E                      | 0–2                                  | Reserved                                  |  |
| VBA:\$60                      | 0–2                                  | Host receive data full                    |  |
| VBA:\$62                      | 0–2                                  | Host transmit data empty                  |  |
| VBA:\$64                      | 0–2                                  | Host command (default)                    |  |
| VBA:\$66                      | 0–2                                  | Reserved                                  |  |
| VBA:\$68                      | 0 - 2                                | EFCOP data input buffer empty             |  |
| VBA:\$6A                      | 0 - 2                                | EFCOP data output buffer full             |  |
| VBA:\$6C                      | 0 - 2                                | Reserved                                  |  |
| VBA:\$6E                      | 0 - 2                                | Reserved                                  |  |
| :                             | :                                    | :                                         |  |
| VBA:\$FE                      | 0–2                                  | Reserved                                  |  |

|  | Table 4-2. | Interrupt Sources | (Continued) |
|--|------------|-------------------|-------------|
|--|------------|-------------------|-------------|

**4-**6

#### 4.3.2 Interrupt Priority Levels

There are two interrupt priority registers in the DSP56311. The IPR–C (**Figure 4-1**) is dedicated to DSP56300 core interrupt sources, and IPR–P (**Figure 4-2**) is dedicated to DSP56311 peripheral interrupt sources.



Figure 4-1. Interrupt Priority Register C (IPR-C) (X:\$FFFFF)



Figure 4-2. Interrupt Priority Register P (IPR-P) (X:\$FFFFE)

Interrupt Sources and Priorities

| IPL bits |      | Interrupts Enabled | Interrupts Masked | Interrupt Priority Level |
|----------|------|--------------------|-------------------|--------------------------|
| xxL1     | xxL0 |                    | interrupts masked | interrupt Phonty Lever   |
| 0        | 0    | No                 | —                 | 0                        |
| 0        | 1    | Yes                | 0                 | 1                        |
| 1        | 0    | Yes                | 0, 1              | 2                        |
| 1        | 1    | Yes                | 0, 1, 2           | 3                        |

 Table 4-3.
 Interrupt Priority Level Bits

#### 4.3.3 Interrupt Source Priorities Within an IPL

If more than one interrupt request is pending when an instruction executes, the interrupt source with the highest IPL is serviced first. When several interrupt requests with the same IPL are pending, another fixed-priority structure within that IPL determines which interrupt source is serviced first. **Table 4-4** shows this fixed-priority list of interrupt sources within an IPL, from highest to lowest at each level The interrupt mask bits in the Status Register (I[1:0]) can be programmed to ignore low priority level interrupt requests.

| Priority | Interrupt Source          |  |  |
|----------|---------------------------|--|--|
|          |                           |  |  |
|          | Level 3 (nonmaskable)     |  |  |
| Highest  | Hardware RESET            |  |  |
|          | Stack error               |  |  |
|          | Illegal instruction       |  |  |
|          | Debug request interrupt   |  |  |
|          | Тгар                      |  |  |
| Lowest   | Nonmaskable interrupt     |  |  |
|          | Levels 0, 1, 2 (maskable) |  |  |
| Highest  | IRQA (external interrupt) |  |  |
|          | IRQB (external interrupt) |  |  |
|          | IRQC (external interrupt) |  |  |
|          | IRQD (external interrupt) |  |  |
|          | DMA channel 0 interrupt   |  |  |
|          | DMA channel 1 interrupt   |  |  |
|          | DMA channel 2 interrupt   |  |  |
|          | DMA channel 3 interrupt   |  |  |
|          | DMA channel 4 interrupt   |  |  |

| Table 4-4. | Interrupt Source Priorities Within an IPL (Continued) |
|------------|-------------------------------------------------------|
|------------|-------------------------------------------------------|

| Priority | Interrupt Source                          |  |
|----------|-------------------------------------------|--|
|          | DMA channel 5 interrupt                   |  |
| Highest  | Host command interrupt                    |  |
|          | Host transmit data empty                  |  |
|          | Host receive data full                    |  |
|          | ESSI0 RX data with exception interrupt    |  |
|          | ESSI0 RX data interrupt                   |  |
|          | ESSI0 receive last slot interrupt         |  |
|          | ESSI0 TX data with exception interrupt    |  |
|          | ESSI0 transmit last slot interrupt        |  |
|          | ESSI0 TX data interrupt                   |  |
|          | ESSI1 RX data with exception interrupt    |  |
|          | ESSI1 RX data interrupt                   |  |
|          | ESSI1 receive last slot interrupt         |  |
|          | ESSI1 TX data with exception interrupt    |  |
|          | ESSI1 transmit last slot interrupt        |  |
|          | ESSI1 TX data interrupt                   |  |
|          | SCI receive data with exception interrupt |  |
|          | SCI receive data                          |  |
|          | SCI transmit data                         |  |
|          | SCI idle line                             |  |
|          | SCI timer                                 |  |
|          | TIMER0 overflow interrupt                 |  |
|          | TIMER0 compare interrupt                  |  |
|          | TIMER1 overflow interrupt                 |  |
|          | TIMER1 compare interrupt                  |  |
|          | TIMER2 overflow interrupt                 |  |
|          | TIMER2 compare interrupt                  |  |
|          | EFCOP data input buffer empty             |  |
| Lowest   | EFCOP data output buffer full             |  |

#### 4.3.4 DMA Request Sources

The DMA request source bits (DRS[4:0]) in the DMA control/status registers) encode the source of DMA requests that trigger DMA transfers. The DMA request sources may be internal peripherals or external devices requesting service through the  $\overline{IRQA}$ ,  $\overline{IRQB}$ ,  $\overline{IRQC}$ , or  $\overline{IRQD}$  signals. **Table 4-5** shows the values of the DRS bits.

| DMA Request Source Bits<br>DRS4 DRS0 | Requesting Device                   |
|--------------------------------------|-------------------------------------|
| 00000                                | External (IRQA signal)              |
| 00001                                | External (IRQB signal)              |
| 00010                                | External (IRQC signal)              |
| 00011                                | External (IRQD signal)              |
| 00100                                | Transfer done from DMA channel 0    |
| 00101                                | Transfer done from DMA channel 1    |
| 00110                                | Transfer done from DMA channel 2    |
| 00111                                | Transfer done from DMA channel 3    |
| 01000                                | Transfer done from DMA channel 4    |
| 01001                                | Transfer done from DMA channel 5    |
| 01010                                | ESSI0 receive data (RDF0 = 1)       |
| 01011                                | ESSI0 transmit data (TDE0 = 1)      |
| 01100                                | ESSI1 receive data (RDF1 = 1)       |
| 01101                                | ESSI1 transmit data (TDE1 = 1)      |
| 01110                                | SCI receive data (RDRF = 1)         |
| 01111                                | SCI transmit data (TDRE = 1)        |
| 10000                                | Timer0 (TCF0 = 1)                   |
| 10001                                | Timer1 (TCF1 = 1)                   |
| 10010                                | Timer2 (TCF2 = 1)                   |
| 10011                                | Host receive data full (HRDF = 1)   |
| 10100                                | Host transmit data empty (HTDE = 1) |
| 10101                                | EFCOP input buffer empty (FDIBE=1)  |
| 10110                                | EFCOP output buffer full (FDOBF=1)  |
| 10111–11111                          | Reserved                            |

**Note:** The lowest 10K of X data RAM and 10K of Y data RAM are shared memory that can be accessed by the core and the EFCOP but not by the DMA controller.

DSP56311 User's Manual

### 4.4 Operating Mode Register (OMR)

The OMR is a read/write register divided into three byte-sized units. The lowest two bytes (EOM and COM) control the chip's operating mode. The high byte (SCS) controls and monitors the stack extension. The OMR control bits are shown in **Figure 4-3**.

|     | SCS                              |               |      |        |       |         |       | ЕОМ                                       |                          |                           |     |     |    | СОМ                  |      |                       |                       |       |       |       |      |    |    |
|-----|----------------------------------|---------------|------|--------|-------|---------|-------|-------------------------------------------|--------------------------|---------------------------|-----|-----|----|----------------------|------|-----------------------|-----------------------|-------|-------|-------|------|----|----|
| 23  | 22                               | 21            | 20   | 19     | 18    | 17      | 16    | 15                                        | 14                       | 13 12 11 10 9 8           |     |     |    |                      | 7    | 6                     | 5                     | 4     | 3     | 2     | 1    | 0  |    |
|     | MSW                              | /[1:0]        | SEN  | WRP    | EOV   | EUN     | XYS   |                                           | APD                      | ABE                       | BRT | TAS | BE | CDF                  | P1:0 | MS                    | SD                    |       | EBD   | MD    | MC   | MB | MA |
| MSV | V1-                              |               |      |        |       |         |       |                                           |                          |                           |     |     |    |                      |      | MS Memory Switch Mode |                       |       |       |       |      |    |    |
| MSV | MSW0 Memory Switch Configuration |               |      |        |       |         | tion  | APD Address Attribute Priority<br>Disable |                          |                           |     |     |    | SD Stop Delay        |      |                       |                       |       |       |       |      |    |    |
| S   | EN                               | Stack         | Exte | ension | n Ena | ble     |       | ABE Async. Bus Arbitration Enable         |                          |                           |     | EE  | BD | External Bus Disable |      |                       |                       |       |       |       |      |    |    |
| W   | RP                               | Stack         | Exte | nsion  | Wra   | ıp Fla  | g     | BF                                        | RT                       | Bus Release Timing        |     |     |    | Μ                    | D    | Chip                  | Oper                  | ating | Мос   | le D  |      |    |    |
| E   | VC                               | Stack         | Exte | ension | Ove   | rflow   | Flag  | TÆ                                        | S                        | S TA Synchronize Select   |     |     |    |                      | Μ    | С                     | Chip                  | Oper  | ating | ) Moc | le C |    |    |
| E   |                                  | Stack<br>Flag | Exte | ension | n Und | lerflov | N     | В                                         | E                        | E Cache Burst Mode Enable |     |     |    | le                   | М    | В                     | Chip Operating Mode B |       |       |       |      |    |    |
| X   | YS                               | Stack         | Exte | ension | n Spa | ice Se  | elect | CD                                        | P1                       | Core-DMA Priority 1       |     |     | М  | A                    | Chip | Ope                   | rating                | g Moo | de A  |       |      |    |    |
|     |                                  |               |      |        |       |         |       | CD                                        | CDP0 Core-DMA Priority 0 |                           |     |     |    |                      |      |                       |                       |       |       |       |      |    |    |

Reserved bit; read as zero; should be written with zero for future compatibility

Figure 4-3. DSP56311 Operating Mode Register (OMR) Format

The EOM and COM bytes are affected only by processor reset and by instructions directly referencing the OMR (i.e., ANDI, ORI, and other instructions, such as MOVEC, that specify OMR as a destination). The SCS byte is referenced implicitly by some instructions, such as DO, JSR, and RTI, or directly by the MOVEC instruction. During processor reset, the chip operating mode bits (MD, MC, MB, and MA) are loaded from the external mode select pins MODD, MODC, MODB, and MODA respectively. **Table 4-6** defines the DSP56311 OMR bits.

| Table 4-6. | Operating Mode Register (OMR) Bit Definitions |
|------------|-----------------------------------------------|
|------------|-----------------------------------------------|

| Bit Number | Bit Name  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|-----------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23         |           | 0           | Reserved. Set to 0 for future compatibility.                                                                                                                                                                                                                                                                                                                                                 |
| 22 – 21    | MSW[1 –0] | 0           | <b>Memory Switch Configuration</b><br>Reallocate portions of X and Y data RAM as program RAM. Memory<br>Switch Mode is enabled when the Memory Switch bit, OMR[7] is set.<br>The Memory Switch Configuration (MSW) bits determine what portion of<br>the higher locations of internal X and Y data memory are switched to<br>internal program memory when the Memory Switch Mode is enabled. |

#### Table 4-6. Operating Mode Register (OMR) Bit Definitions (Continued)

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|----------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20         | SEN      | 0           | Stack Extension Enable<br>Enables/disables the stack extension in data memory. If the SEN bit is<br>set, the extension is enabled. Hardware reset clears this bit, so the<br>default out of reset is a disabled stack extension.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 19         | WRP      | 0           | Stack Extension Wrap Flag<br>Set when copying from the on-chip hardware stack (System Stack<br>Register file) to the stack extension memory begins. You can use this<br>flag during the debugging phase of the software development to<br>evaluate and increase the speed of software-implemented algorithms.<br>The WRP flag is a <i>sticky bit</i> (i.e., cleared only by hardware reset or by<br>an explicit MOVEC operation to the OMR).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 18         | EOV      | 0           | <b>Stack Extension Overflow Flag</b><br>Set when a stack overflow occurs in Stack Extended mode. Extended<br>stack overflow is recognized when a push operation is requested while<br>SP = SZ (Stack Size register), and the Extended mode is enabled by<br>the SEN bit. The EOV flag is a <i>sticky bit</i> (i.e., cleared only by hardware<br>reset or by an explicit MOVEC operation to the OMR). The transition of<br>the EOV flag from zero to one causes a Priority Level 3 (Non-maskable)<br>stack error exception.                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 17         | EUN      | 0           | Stack Extension Underflow Flag<br>Set when a stack underflow occurs in Extended Stack mode. Extended<br>stack underflow is recognized when a pull operation is requested, SP =<br>0, and the SEN bit enables Extended mode. The EUN flag is a <i>sticky bit</i><br>(i.e., cleared only by hardware reset or by an explicit MOVEC operation<br>to the OMR). Transition of the EUN flag from zero to one causes a<br>Priority Level 3 (Non-maskable) stack error exception.<br>NOTE: While the chip is in Extended Stack mode, the UF bit in the SP<br>acts like a normal counter bit.                                                                                                                                                                                                                                                                                                                                                         |
| 16         | XYS      | 0           | <b>Stack Extension XY Select</b><br>Determines whether the stack extension is mapped onto X or Y memory<br>space. If the bit is clear, then the stack extension is mapped onto the X<br>memory space. If the XYS bit is set, the stack extension is mapped to<br>the Y memory space.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 15         |          | 0           | Reserved. Set to 0 for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 14         | APD      | 0           | Address Attribute Priority Disable<br>Disables the priority assigned to the Address Attribute signals<br>(AA0-AA3). When APD = 0 (default setting), the four Address Attribute<br>signals each have a certain priority: AA3 has the highest priority, AA0<br>has the lowest priority. Therefore, only one AA signal can be active at<br>one time. This allows continuous partitioning of external memory;<br>however, certain functions, such as using the AA signals as additional<br>address lines, require the use of additional interface hardware. When<br>APD is set, the priority mechanism is disabled, allowing more than one<br>AA signal to be active simultaneously. Therefore, the AA signals can be<br>used as additional address lines without the need for additional<br>interface hardware. For details on the Address Attribute Registers, see<br>Section 4.8, "Address Attribute Registers (AAR0–AAR3)," on page<br>4-22. |

| Table 4-6. | Operating Mode Register (OMR) Bit Definitions (Continued) |
|------------|-----------------------------------------------------------|
|------------|-----------------------------------------------------------|

| Bit Number | Bit Name | Reset Value |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Description                                                                                                                                                                                                                                                                                                                                                                         |  |  |  |  |  |
|------------|----------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 13         | ABE      | 0           | Asynchronous Bus Arbitration Enable<br>Eliminates the setup and hold time requirements for BB and BG, and<br>substitutes a required non-overlap interval between the deassertion of<br>one BG input to a DSP56300 family device and the assertion of a<br>second BG input to a second DSP56300 family device on the same bus<br>When the ABE bit is set, the BG and BB inputs are synchronized. This<br>synchronization causes a delay between a change in BG or BB until this<br>change is actually accepted by the receiving device.                                                               |                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| 12         | BRT      | 0           | <b>Bus Release Timing</b><br>Selects between fast or slow bus release. If BRT is cleared, a Fast Bus<br>Release mode is selected (i.e., no additional cycles are added to the<br>access and BB is not guaranteed to be the last Port A pin that is<br>tri-stated at the end of the access). If BRT is set, a Slow Bus Release<br>mode is selected (i.e., an additional cycle is added to the access, and<br>BB is the last Port A pin that is tri-stated at the end of the access).                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| 11         | TAS      | 0           | <b>TA</b> Synchronize Select<br>Selects the synchronization method for the input Port A pin—TA<br>(Transfer Acknowledge). If TAS is cleared, you are responsible for<br>asserting the TA pin in synchrony with the chip clock, as described in<br>the technical data sheet. If TAS is set, the TA input pin is synchronized<br>inside the chip, thus eliminating the need for an off-chip synchronizer.<br>Note that the TAS bit has no effect when the TA pin is deasserted: you<br>are responsible for deasserting the TA pin in synchrony with the chip<br>clock, regardless of the value of TAS. |                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| 10         | BE       | 0           | Enables/dis<br>instruction of<br>only one pro-<br>instruction of<br>is enabled,                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | st Mode Enable<br>ables Burst mode in the memory expansion port during an<br>cache miss. If the bit is cleared, Burst mode is disabled and<br>ogram word is fetched from the external memory when an<br>cache miss condition is detected. If the bit is set, Burst mode<br>and up to four program words are fetched from the external<br>ten an instruction cache miss is detected. |  |  |  |  |  |
| 9 – 8      | CDP      | 11          | Core-DMA<br>Specify the                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Priority<br>priority of core and DMA accesses to the external bus.                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|            |          |             | 00                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Determined by comparing status register CP[1:0] to the active DMA channel priority                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |
|            |          |             | 01                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | DMA accesses have higher priority than core accesses                                                                                                                                                                                                                                                                                                                                |  |  |  |  |  |
|            |          |             | 10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | DMA accesses have the same priority as the core accesses                                                                                                                                                                                                                                                                                                                            |  |  |  |  |  |
|            |          |             | 11                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | DMA accesses have lower priority than the core accesses                                                                                                                                                                                                                                                                                                                             |  |  |  |  |  |

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|----------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | MS       | 0           | <ul> <li>Memory Switch Mode Allows some internal data memory (X, Y, or both) to become part of the chip internal Program RAM. Notes: <ol> <li>Program data placed in the Program RAM/Instruction Cache area changes its placement after the MS bit is set (i.e., the Instruction Cache always uses the lowest internal Program RAM addresses).</li> <li>To ensure proper operation, place six NOP instructions after the instruction that changes the MS bit.</li> <li>To ensure proper operation, do not set the MS bit while the Instruction Cache is enabled (CE bit is set in SR). </li> </ol></li></ul>                                     |
| 6          | SD       | 0           | Stop Delay Mode<br>Determines the length of the delay invoked when the core exits the Stop<br>state. The STOP instruction suspends core processing indefinitely until<br>a defined event occurs to restart it. If SD is cleared, a 128K clock cycle<br>delay is invoked before a STOP instruction cycle continues. However, if<br>SD is set, the delay before the instruction cycle continues is 16 clock<br>cycles. The long delay allows a clock stabilization period for the internal<br>clock to begin oscillating and to stabilize. When a stable external clock<br>is used, the shorter delay allows faster start-up of the DSP56300 core. |
| 5          |          | 0           | Reserved. Write to zero for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 4          | EBD      | 0           | <b>External Bus Disable</b><br>Disables the external bus controller to reduce power consumption when<br>external memories are not used. When EBD is set, the external bus<br>controller is disabled and external memory cannot be accessed. When<br>EBD is cleared, the external bus controller is enabled and external<br>access can be performed. Hardware reset clears the EBD bit.                                                                                                                                                                                                                                                           |
| 3 - 0      | MD – MA  | *           | <b>Chip Operating Mode</b><br>Indicate the operating mode of the DSP56300 core. On hardware reset,<br>these bits are loaded from the external mode select pins, MODD,<br>MODC, MODB, and MODA, respectively. After the DSP56300 core<br>leaves the Reset state, MD, MC, MB, and MA can be changed under<br>program control.                                                                                                                                                                                                                                                                                                                      |

### 4.5 Status Register (SR)

The Status Register (SR) (**Figure 4-4**) is a 24-bit register that indicates the current system state of the processor and the results of previous arithmetic computations. The SR is pushed onto the system stack when program looping is initialized or a JSR is performed, including long interrupts. The SR consists of the following three special-purpose 8-bit control registers:

- Extended Mode Register (EMR) (SR[23:16]) and Mode Register (MR) (SR[15:8]) —Define the current system state of the processor. The bits in both registers are affected by hardware reset, exception processing, ENDDO (end current DO loop) instructions, RTI (return from interrupt) instructions, and TRAP instructions. In addition, the EMR bits are affected by instructions that specify SR as their destination, DO FOREVER instructions, BRKcc instructions, and instructions that specify SR as a destination (e.g., MOVEC). During hardware reset, all EMR bits are cleared. The MR register bits are affected by DO instructions, such as MOVEC, that specify SR as the destination). During processor reset, the interrupt mask bits are set and all other bits are cleared.
- Condition Code Register (CCR) (SR[7:0])—Defines the results of previous arithmetic computations. The CCR bits are affected by Data Arithmetic Logic Unit (Data ALU) operations, parallel move operations, instructions that directly reference the CCR (ORI and ANDI), and instructions that specify SR as a destination (e.g., MOVEC). Parallel move operations affect only the S and L bits of the CCR. During processor reset, all CCR bits are cleared.

The definition of the three 8-bit registers within the SR is primarily for the purpose of compatibility with other Motorola DSPs. Bit definitions in the following paragraphs identify the bits within the SR and not within the subregister.

| E  | Extended Mode Register (EMR) |    |    |    |    |    | Mode Register (MR) |    |    |    |    | Condition Code Register (CCR) |    |     |    |    |   |   |   |   |   |   |   |   |
|----|------------------------------|----|----|----|----|----|--------------------|----|----|----|----|-------------------------------|----|-----|----|----|---|---|---|---|---|---|---|---|
| 23 |                              | 22 | 21 | 20 | 19 | 18 | 17                 | 16 | 15 | 14 | 13 | 12                            | 11 | 10  | 9  | 8  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| С  | P1                           | :0 | RM | SM | CE |    | SA                 | FV | LF | DM | SC |                               | S  | 1:0 | 11 | :0 | S | L | Е | U | Ν | Z | V | С |

Reserved bit. Read as zero. Write with zero for future compatibility

|     | Values after reset:        |     |                           |     |                   |  |  |  |  |  |  |  |  |  |
|-----|----------------------------|-----|---------------------------|-----|-------------------|--|--|--|--|--|--|--|--|--|
| 1 1 | 0 0 0 0 0 0                | 0 0 | 0 0 0 0 1 1               | 0 0 | 0 0 0 0 0 0       |  |  |  |  |  |  |  |  |  |
| CP1 | Core Priority Bit 1        | LF  | DO-Loop Flag              | S   | Scaling Flag      |  |  |  |  |  |  |  |  |  |
| CP0 | Core Priority Bit 0        | DM  | Double Precision Multiply | L   | Limit Flag        |  |  |  |  |  |  |  |  |  |
| RM  | Rounding Mode              | SC  | Sixteen-bit Compatibility | Е   | Extension Flag    |  |  |  |  |  |  |  |  |  |
| SM  | Arithmetic Saturation Mode | S1  | Scaling Mode Bit 1        | U   | Unnormalized Flag |  |  |  |  |  |  |  |  |  |
| CE  | Instruction Cache Enable   | S0  | Scaling Mode Bit 0        | Ν   | Negative Flag     |  |  |  |  |  |  |  |  |  |
| SA  | Sixteen-Bit Arithmetic     | 11  | Interrupt Mask Bit 1      | Z   | Zero Flag         |  |  |  |  |  |  |  |  |  |
| FV  | DO-Forever Flag            | 10  | Interrupt Mask Bit 0      | V   | Overflow Flag     |  |  |  |  |  |  |  |  |  |
|     |                            |     |                           | С   | Carry Flag        |  |  |  |  |  |  |  |  |  |

Figure 4-4. Status Register

| Table 4-7. | Status | Register | Bit | Definitions |
|------------|--------|----------|-----|-------------|
|------------|--------|----------|-----|-------------|

| Bit Number | Bit Name  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                  |                          |                   |                |  |  |  |  |  |  |  |
|------------|-----------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------------------------|-------------------|----------------|--|--|--|--|--|--|--|
| 23 - 22    | CP[1 – 0] | 11          | <b>Core Priority</b><br>Under control of the CDP[1:0] bits in the OMR, the CP bits specify the priority of core accesses to external memory. These bits are compared against the priority bits of the active DMA channel. If the core priority is greater than the DMA priority, the DMA waits for a free time slot on the external bus. If the core priority is less than the DMA priority, the core for a free time slot on the external bus. If the core and DMA access the external bus in a round robin pa (e.g., P, X, Y, DMA, P, X, Y,). |                  |                          |                   |                |  |  |  |  |  |  |  |
|            |           |             | Priority<br>Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Core<br>Priority | DMA<br>Priority          | OMR<br>(CDP[1-0]) | SR (CP[1 - 0]) |  |  |  |  |  |  |  |
|            |           |             | Dynamic                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0<br>(Lowest)    | Determined<br>by DCRn    | 00                | 00             |  |  |  |  |  |  |  |
|            |           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1                | (DPR[1:0])<br>for active | 00                | 01             |  |  |  |  |  |  |  |
|            |           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 2                | DMA<br>channel           | 00                | 10             |  |  |  |  |  |  |  |
|            |           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 3<br>(Highest)   | channel                  | 00                | 11             |  |  |  |  |  |  |  |
|            |           |             | Static                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | core             | < DMA                    | 01                | ХХ             |  |  |  |  |  |  |  |
|            |           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | core             | = DMA                    | 10                | xx             |  |  |  |  |  |  |  |
|            |           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | core > DMA 11 xx |                          |                   |                |  |  |  |  |  |  |  |

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |  |
|------------|----------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 21         | RM       | 0           | <b>Rounding Mode</b><br>Selects the type of rounding performed by the Data ALU during arithme<br>operations. If RM is cleared, convergent rounding is selected. If RM is s<br>two's-complement rounding is selected.                                                                                                                                                                                                                                                                                                                       |  |
| 20         | SM       | 0           | Arithmetic Saturation Mode<br>Selects automatic saturation on 48 bits for the results going to the<br>accumulator. This saturation is performed by a special circuit inside the<br>MAC unit. The purpose of this bit is to provide an Arithmetic Saturation<br>mode for algorithms that do not recognize or cannot take advantage of the<br>extension accumulator.                                                                                                                                                                         |  |
| 19         | CE       | 0           | <b>Cache Enable</b><br>Enables/disables the instruction cache controller. If CE is set, the cache is<br>enabled, and instructions are cached into and fetched from the internal<br>Program RAM. If CE is cleared, the cache is disabled and the DSP56300<br>core fetches instructions from external or internal program memory,<br>according to the memory space table of the specific DSP56300 core-based<br>device.<br>NOTE: To ensure proper operation, do not clear Cache Enable mode while<br>Burst mode is enabled (OMR[BE] is set). |  |
| 18         |          | 0           | Reserved. Write to zero for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
| 17         | SA       | 0           | Sixteen-Bit Arithmetic Mode<br>Affects data width functionality, enabling the Sixteen-bit Arithmetic mode of<br>operation. When SA is set, the core uses 16-bit operations instead of 24-bit<br>operations. In this mode, 16-bit data is right-aligned in the 24-bit memory<br>locations, registers, and 24-bit register portions. Shifting, limiting, rounding,<br>arithmetic instructions, and moves are performed accordingly. For details<br>on Sixteen-Bit Arithmetic mode, consult the <i>DSP56300 Family Manual</i> .               |  |
| 16         | FV       | 0           | <b>DO FOREVER Flag</b><br>Set when a DO FOREVER loop executes. The FV flag, like the LF flag, is<br>restored from the stack when a DO FOREVER loop terminates. Stacking<br>and restoring the FV flag when initiating and exiting a DO FOREVER loop,<br>respectively, allow program loops to be nested. When returning from the<br>long interrupt with an RTI instruction, the system stack is pulled and the<br>value of the FV bit is restored.                                                                                           |  |
| 15         | LF       | 0           | <b>Do Loop Flag</b><br>When a program loop is in progress, enables the detection of the end of the<br>loop. The LF is restored from stack when a program loop terminates.<br>Stacking and restoring the LF when initiating and exiting a program loop,<br>respectively, allow program loops to be nested. When returning from the<br>long interrupt with an RTI instruction, the System Stack is pulled and the LF<br>bit value is restored.                                                                                               |  |

| Table 4-7. | Status Register Bit Definitions (Continued) |
|------------|---------------------------------------------|
|------------|---------------------------------------------|

| Table 4-7. Status Register Bit Definitions (Continued) |
|--------------------------------------------------------|
|--------------------------------------------------------|

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|----------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14         | DM       | 0           | <ul> <li>Double-Precision Multiply Mode Enables four multiply/MAC operations to implement a double-precision algorithm that multiplies two 48-bit operands with a 96-bit result. Clearing the DM bit disables the mode. NOTE: The Double-Precision Multiply mode is supported to maintain object code compatibility with devices in the DSP56000 family. For a more efficient way of executing double precision multiply, refer to the chapter on the Data Arithmetic Logic Unit in the DSP56300 Family Manual. In Double-Precision Multiply mode, the behavior of the four specific operations listed in the double-precision algorithm is modified. Therefore, do not use these operations (with those specific register combinations) in Double-Precision Multiply mode for any purpose other than the double precision multiply algorithm. All other Data ALU operations (or the four listed operations, but with other register combinations) can be used. The double-precision multiply algorithm uses the Y0 Register at all stages. Therefore, do not change Y0 when running the double-precision multiply algorithm. If the Data ALU must be used in an interrupt service routine, Y0 should be saved with other Data ALU registers to be used and restored before the interrupt routine terminates.</li></ul>               |
| 13         | SC       | 0           | <b>Sixteen-bit Compatibility mode</b><br>Affects addressing functionality, enabling full compatibility with object code<br>written for the DSP56000 family. When SC is set, MOVE operations to/from<br>any of the following PCU registers clear the eight MSBs of the destination:<br>LA, LC, SP, SSL, SSH, EP, SZ, VBA and SC. If the source is either the SR<br>or OMR, then the eight MSBs of the destination are also cleared. If the<br>destination is either the SR or OMR, then the eight MSBs of the destination<br>are left unchanged. To change the value of one of the eight MSBs of the<br>SR or OMR, clear SC.<br>SC also affects the contents of the Loop Counter Register. If SC is cleared<br>(normal operation), then a loop count value of zero causes the loop body to<br>be skipped, and a loop count value of \$FFFFFF causes the loop to execute<br>the maximum number of $2^{24} - 1$ times. If the SC bit is set, a loop count<br>value of zero causes the loop to execute $2^{16}$ times, and a loop count value<br>of \$FFFFFF causes the loop to execute $2^{16} - 1$ times.<br>NOTE: Due to pipelining, a change in the SC bit takes effect only after<br>three instruction cycles. Insert three NOP instructions after the instruction<br>that changes the value of this bit to ensure proper operation. |
| 12         |          | 0           | Reserved. Set to 0 for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |    |    |                         |                   |  |
|------------|----------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|-------------------------|-------------------|--|
| 11 – 10    | S1/S0    | 0           | Scaling Mode<br>Specify the scaling to be performed in the Data ALU shifter/limiter and the<br>rounding position in the Data ALU MAC unit. The Shifter/limiter Scaling<br>mode affects data read from the A or B accumulator registers out to the<br>X-data bus (XDB) and Y-data bus (YDB). Different scaling modes can be<br>used with the same program code to allow dynamic scaling. One<br>application of dynamic scaling is to facilitate block floating-point arithmetic.<br>The scaling mode also affects the MAC rounding position to maintain<br>proper rounding when different portions of the accumulator registers are<br>read out to the XDB and YDB. Scaling mode bits are cleared at the start of<br>a long Interrupt Service Routine and during a hardware reset. |    |    |                         |                   |  |
| 9 – 8      | 11/10    | 11          | Interrupt Mask<br>Reflect the current Interrupt Priority Level (IPL) of the processor and<br>indicate the IPL needed for an interrupt source to interrupt the processor.<br>The current IPL of the processor can be changed under software control.<br>The interrupt mask bits are set during hardware reset, but not during<br>software reset.                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |    |                         |                   |  |
|            |          |             | Priority                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 11 | 10 | Exceptions<br>Permitted | Exceptions Masked |  |
|            |          |             | Lowest                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0  | 0  | IPL 0, 1, 2, 3          | None              |  |
|            |          |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0  | 1  | IPL 1, 2, 3             | IPL 0             |  |
|            |          |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1  | 0  | IPL 2, 3                | IPL 0, 1          |  |
|            |          |             | Highest                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1  | 1  | IPL 3                   | IPL 0, 1, 2       |  |
| 7          | S        | 0           | Scaling<br>Set when a result moves from accumulator A or B to the XDB or YDB<br>buses (during an accumulator to memory or accumulator to register move)<br>and remains set until explicitly cleared; that is, the S bit is a <i>sticky bit</i> . The<br>logical equations of this bit are dependent on the Scaling mode. The<br>scaling bit is set if the absolute value in the accumulator, before scaling, is<br>$\geq 0.25$ or < 0.75.                                                                                                                                                                                                                                                                                                                                         |    |    |                         |                   |  |
| 6          | L        | 0           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |    |                         |                   |  |

| Table 4-7. | Status Register Bit Definitions (Continued) |
|------------|---------------------------------------------|
|------------|---------------------------------------------|

| Table 4-7. | Status Register Bit Definitions | (Continued) |
|------------|---------------------------------|-------------|
|------------|---------------------------------|-------------|

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |               |                                |                                              |  |  |
|------------|----------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|--------------------------------|----------------------------------------------|--|--|
| 5          | E        | 1           | <b>Extension</b><br>Cleared if all the bits of the integer portion of the 56-bit result are all of<br>all zeros; otherwise, this bit is set. The Scaling mode defines the inter<br>portion. If the E bit is cleared, then the low-order fraction portion conta<br>the significant bits; the high-order integer portion is sign extension. I<br>case, the accumulator extension register can be ignored. If the E bit<br>it indicates that the accumulator extension register is in use. |               |                                |                                              |  |  |
|            |          |             | S1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | S0            | Scaling Mode                   | Integer Portion                              |  |  |
|            |          |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0             | No Scaling                     | Bits 55,5448,47                              |  |  |
|            |          |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1             | Scale Down                     | Bits<br>55,5449,48                           |  |  |
|            |          |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0             | Scale Up                       | Bits<br>55,5447,46                           |  |  |
| 4          | U        | 0           | <b>Unnormalized</b><br>Set if the two MSBs of the Most Significant Portion (MSP) of the result<br>identical; otherwise, this bit is cleared. The MSP portion of the A or E<br>accumulators is defined by the Scaling mode.                                                                                                                                                                                                                                                              |               |                                |                                              |  |  |
|            |          |             | S1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | S0            | Scaling Mode                   | Integer Portion                              |  |  |
|            |          |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0             | No Scaling                     | $U = \overline{(Bit 47 \text{ xor Bit 46})}$ |  |  |
|            |          |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 1             | Scale Down                     | $U = \overline{(Bit \ 48 \ xor \ Bit \ 47)}$ |  |  |
|            |          |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0             | Scale Up                       | $U = \overline{(Bit \ 46 \ xor \ Bit \ 45)}$ |  |  |
| 3          | Ν        | 0           | Negative<br>Set if the N                                                                                                                                                                                                                                                                                                                                                                                                                                                                | /ISB of the r | esult is set; otherwise, this  | bit is cleared.                              |  |  |
| 2          | Z        | 0           | <b>Zero</b><br>Set if the r                                                                                                                                                                                                                                                                                                                                                                                                                                                             | esult equals  | s zero; otherwise, this bit is | cleared.                                     |  |  |
| 1          | V        | 0           | <b>Overflow</b><br>Set if an arithmetic overflow occurs in the 56-bit result; otherwise, this bit is cleared. V indicates that the result cannot be represented in the accumulator register (i.e., the register overflowed). In Arithmetic Saturation mode, an arithmetic overflow occurs if the Data ALU result is not representable in the accumulator without the extension part (i.e., 48-bit accumulator or the 32-bit accumulator in Arithmetic Sixteen-bit mode).                |               |                                |                                              |  |  |
| 0          | С        | 0           | <b>Carry</b><br>Set if a carry is generated by the MSB resulting from an addition operation.<br>This bit is also set if a borrow is generated in a subtraction operation;<br>otherwise, this bit is cleared. The carry or borrow is generated from Bit 55<br>of the result. The C bit is also affected by bit manipulation, rotate, and shift<br>instructions.                                                                                                                          |               |                                |                                              |  |  |

### 4.6 PLL Control Register (PCTL)

The PCTL is an X-I/O mapped, read/write register that directs the operation of the on-chip PLL. (See **Figure 4-5**.)

| 23                | 22                | 21              | 20              | 19              | 18  | 17   | 16   | 15   | 14  | 13  | 12              |
|-------------------|-------------------|-----------------|-----------------|-----------------|-----|------|------|------|-----|-----|-----------------|
| PD3               | PD2               | PD1             | PD0             | COD             | PEN | PSTP | XTLD | XTLR | DF2 | DF1 | DF0             |
|                   |                   |                 |                 |                 |     |      |      |      |     |     |                 |
| 11                | 10                | 9               | 8               | 7               | 6   | 5    | 4    | 3    | 2   | 1   | 0               |
| <b>11</b><br>MF11 | <b>10</b><br>MF10 | <b>9</b><br>MF9 | <b>8</b><br>MF8 | <b>7</b><br>MF7 | -   | -    |      | -    |     |     | <b>0</b><br>MF0 |

Figure 4-5. PLL Control Register (PCTL)

Table 4-8 defines the DSP56311 PCTL bits.

| Table 4-8. | PLL Control Register (PCTL) Bit Definitions |
|------------|---------------------------------------------|
|            |                                             |

| Bit Number | Bit Name  | Reset Value | Description                                                                                                                                                                                                                              |  |
|------------|-----------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 23 - 20    | PD[3 – 0] | 0           | <b>Predivider Factor Bits</b><br>Define the predivision factor (PDF) to be applied to the PLL input<br>frequency. The PD[3:0] bits are cleared during DSP56311<br>hardware reset, which corresponds to a PDF of one.                     |  |
| 19         | COD       |             | <b>Clock Output Disable</b><br>Controls the output buffer of the clock at the CLKOUT pin. When<br>COD is set, the CLKOUT output is pulled high. When COD is<br>cleared, the CLKOUT pin provides a 50 percent duty cycle clock.           |  |
| 18         | PEN       |             | PLL Enable<br>Enables PLL operation.                                                                                                                                                                                                     |  |
| 17         | PSTP      |             | PLL Stop State<br>Controls PLL and on-chip crystal oscillator behavior during the<br>stop processing state.                                                                                                                              |  |
| 16         | XTLD      |             | <b>XTAL Disable</b><br>Controls the on-chip crystal oscillator XTAL output. The XTLD bit<br>is cleared during DSP56311 hardware reset, so the XTAL output<br>signal is active, permitting normal operation of the crystal<br>oscillator. |  |
| 15         | XTLR      | 0           | Crystal Range<br>Controls the on-chip crystal oscillator transconductance. The<br>XTLR bit is set to a predetermined value during hardware reset. In<br>the DSP56311, this value is zero.                                                |  |
| 14–12      | DF        |             | <b>Division Factor</b><br>Define the DF of the low-power divider. These bits specify the DF<br>as a power of two in the range from $2^0$ to $2^7$ .                                                                                      |  |
| 11–0       | MF[1 –0]  | 0           | <b>PLL Multiplication Factor</b><br>Define the multiplication factor that is applied to the PLL input<br>frequency. The MF bits are cleared during DSP56311 hardware<br>reset and thus correspond to an MF of one.                       |  |

### 4.7 Device Identification Register (IDR)

The IDR is a read-only factory-programmed register that identifies DSP56300 family members. It specifies the derivative number and revision number of the device. This information is used in testing or by software. **Figure 4-6** shows the contents of the IDR. Revision numbers are assigned as follows: \$0 is revision 0, \$1 is revision A, and so on. Changing the following bits may cause the PLL to lose lock and re-lock according to their new value: PD[3 - 0], PEN, XTLR, and MF.

| 23  | 16    | 15       | 12              | 11 | 0                |
|-----|-------|----------|-----------------|----|------------------|
| Res | erved | Revision | Revision Number |    | erivative Number |
| \$  | 00    | \$       | \$0             |    | \$311            |

Figure 4-6. Identification Register Configuration (Revision 0)

### 4.8 Address Attribute Registers (AAR0–AAR3)

The Address Attribute Registers (AAR0–AAR3) are read/write registers that control the activity of the AA0–AA3/RAS0–RAS3 pins. The associated AAn/RASn pin is asserted if the address defined by the BAC bits in the associated AAR matches the exact number of external address bits defined by the BNC bits, and the external address space (X data, Y data, or program) is enabled by the AAR. **Figure 4-7** shows an AAR register; **Table 4-9** lists the bit definitions. Note that the DSP56311 does not support address multiplexing.



Figure 4-7. Address Attribute Registers (AAR0–AAR3) (X:\$FFFF9–\$FFFF6)

| Table 4-9. Address Attribute Registers (AAR0–AAR3) Bit Definitions | Registers (AAR0–AAR3) Bit Definitions |
|--------------------------------------------------------------------|---------------------------------------|
|--------------------------------------------------------------------|---------------------------------------|

| Bit Number | Bit Name    | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
|------------|-------------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 23 - 12    | BAC[11 – 0] | 0           | Bus Address to Compare<br>Read/write control bits that define the upper 12 bits of the 24-bit address<br>with which to compare the external address to determine whether to assert<br>the corresponding AA/RAS signal. This is also true of 16-bit compatibility<br>mode. The BNC[3:0] bits define the number of address bits to compare.                                                                                                                                                                                                                                                                                                                      |  |  |
| 11 – 8     | BNC[3 – 0]  | 0           | Bus Number of Address Bits to Compare<br>Specify the number of bits (from the BAC bits) that are compared to the<br>external address. The BAC bits are always compared with the Most<br>Significant Portion of the external address (e.g., if BNC[3:0] = 0011, then<br>the BAC[11:9] bits are compared to the 3 MSBs of the external address). If<br>no bits are specified (i.e., BNC[3:0] = 0000), the AA signal is activated for<br>the entire 16 M-word space identified by the space enable bits (BPEN,<br>BXEN, BYEN), but only when the address is external to the internal<br>memory map. The combinations BNC[3:0] = 1111, 1110, 1101 are<br>reserved. |  |  |

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |  |  |  |
|------------|----------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| 7          | BPAC     | 0           | <b>Bus Packing Enable</b><br>Enables/disables the internal packing/unpacking logic. When BPAC is set, packing is enabled. In this mode each DMA external access initiates three external accesses to an 8-bit wide external memory (the addresses for these accesses are DAB, then DAB + 1 and then DAB + 2). Packing to a 24-bit word (or unpacking from a 24-bit word to three 8-bit words) is done automatically by the expansion port control hardware. The external memory should reside in the eight Least Significant Bits (LSBs) of the external data bus, and the packing (or unpacking for external write accesses) occurs in "Little Endian" order (i.e., the low byte is stored in the lowest of the three memory locations and is transferred first; the middle byte is stored/transferred last). When this bit is cleared, the expansion port control logic assumes a 24-bit wide external memory. |  |  |  |  |  |
|            |          |             | <ol> <li>NOTES:         <ol> <li>BPAC is used only for DMA accesses and not core accesses.</li> <li>To ensure sequential external accesses, the DMA address should advance three steps at a time in two-dimensional mode with a row length of one and an offset size of three. For details, refer to Motorola application note, APR23/D, Using the DSP56300 Direct Memory Access Controller.</li> <li>To prevent improper operation, DMA address + 1 and DMA address + 2 should not cross the AAR bank borders.</li> <li>Arbitration is not allowed during the packing access (i.e., the three accesses are treated as one access with respect to arbitration, and the bus mastership is not released during these accesses).</li> </ol> </li> </ol>                                                                                                                                                             |  |  |  |  |  |
| 6          |          | 0           | Reserved. Set to 0 for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| 5          | BYEN     | 0           | Bus Y Data Memory Enable<br>A read/write control bit that enables/disables the AA pin and logic during<br>external Y data space accesses. When set, BYEN enables the comparison<br>of the external address to the BAC bits during external Y data space<br>accesses. If BYEN is cleared, no address comparison is performed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| 4          | BXEN     | 0           | Bus X Data Memory Enable<br>A read/write control bit that enables/disables the AA pin and logic during<br>external X data space accesses. When set, BXEN enables the comparison<br>of the external address to the BAC bits during external X data space<br>accesses. If BXEN is cleared, no address comparison is performed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |  |
| 3          | BPEN     | 0           | <b>Bus Program Memory Enable</b><br>A read/write control bit that enables/disables the AA/RAS pin and logic<br>during external program space accesses. When set, BPEN enables the<br>comparison of the external address to the BAC bits during external program<br>space accesses. If BPEN is cleared, no address comparison is performed.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |  |  |  |
| 2          | ВААР     | 0           | <b>Bus Address Attribute Polarity</b><br>A read/write Bus Address Attribute Polarity (BAAP) control bit that defines<br>whether the AA/ <u>RAS</u> signal is active low or active high. When BAAP is<br>cleared, the AA/ <u>RAS</u> signal is active low (useful for enabling memory<br>modules or for DRAM Row Address Strobe). If BAAP is set, the appropriate<br>AA/ <u>RAS</u> signal is active high (useful as an additional address bit).                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |  |  |  |

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|----------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1 - 0      | BAT      | 0           | Bus Access Type<br>Read/write bits that define the type of external memory (DRAM or SRAM)<br>to access for the area defined by the BAC[11:0],BYEN, BXEN, and BPEN<br>bits. The encoding of BAT[1:0] is:<br>00 = Reserved<br>01 = SRAM access<br>10 = DRAM access<br>11 = Reserved<br>When the external access type is defined as a DRAM access (BAT[1:0] =<br>10), AA/RAS acts as a Row Address Strobe (RAS) signal. Otherwise, it acts<br>as an Address Attribute signal. External accesses to the default area<br>always execute as if BAT[1:0] = 01 (i.e., SRAM access). |

| Table 4-9. | Address Attribute Registers | (AAR0–AAR3) Bit Definitions |
|------------|-----------------------------|-----------------------------|
|------------|-----------------------------|-----------------------------|

### 4.9 JTAG Identification (ID) Register

The JTAG ID register is a 32-bit read-only factory-programmed register that distinguishes the component on a board according to the IEEE 1149.1 standard. **Figure 4-8** shows the JTAG ID register configuration. Version information corresponds to the revision number (\$0 for revision 0, \$1 for revision A, etc.).

| 31          | 28       | 27                        | 22 | 21          | 12 | 11         | 1 | 0 |
|-------------|----------|---------------------------|----|-------------|----|------------|---|---|
| Version Inf | ormation | n Design Center<br>Number |    | Sequ<br>Num |    | Manu<br>Id | 1 |   |
| 000         | 00       | 000110                    |    | 0000001011  |    | 0000001110 |   | 1 |

Figure 4-8. JTAG Identification Register Configuration (Revision 0)

## 4.10 JTAG Boundary Scan Register (BSR)

The BSR in the DSP56311 JTAG implementation contains bits for all device signals, clock pins, and their associated control signals. All DSP56311 bidirectional pins have a corresponding register bit in the BSR for pin data and are controlled by an associated control bit in the BSR. For details on the BSR, consult the *DSP56300 Family Manual*.

JTAG Boundary Scan Register (BSR)

# **Chapter 5** Programming the Peripherals

When peripherals are programmed in a given application, a number of possible modes and options are available for use. Chapters 6 through 10 describe in detail the possible modes and configurations for peripheral registers and ports. This chapter presents general guidelines for initializing the peripherals. These guidelines include a description of how the control registers are mapped in the DSP56311, data transfer methods that are available when the various peripherals are used, and information on General-Purpose Input/Output (GPIO) configuration.

# 5.1 Peripheral Initialization Steps

Each peripheral has its own initialization process. However, all four peripherals share some common steps, which follow:

- **1.** Determine the Register values to be programmed.
  - Find the peripheral register descriptions in the manual.
  - Choose the appropriate modes to configure for a given application.
  - Determine the bit settings for programming those modes.
- 2. Make sure the peripheral is in individual reset state or disabled.
  - Peripheral registers should not be modified while the peripheral is active.
- **3.** Configure the registers by writing the predetermined values to them.
  - Write the register values determined in step 1 into the appropriate register locations.
- **4.** Enable the peripheral.
  - Once the peripheral is enabled, it operates according the programmed modes determined in step 1.

For detailed initialization procedures unique to each peripheral, consult the initialization section within each peripheral's chapter.

# **5.2** Mapping the Control Registers

The I/O peripherals are controlled through registers mapped to the top 128 words of X-data memory (\$FFFF80 - \$FFFFF). Referred to as the internal I/O space, the control registers are accessed by move (MOVE, MOVEP) instructions and bit-oriented instructions (BCHG, BCLR, BSET, BTST, BRCLR, BRSET, BSCLR, BSSET, JCLR, JSET, JSCLR, and JSSET). The contents of the internal X I/O memory space are listed in **Appendix B**, *Programming Reference*, Table B-2.





# **5.3** Reading Status Registers

Each peripheral has a read-only status register that indicate the state of the peripheral at a given time. The HI08, ESSI, and SCI have dedicated status registers. The triple timer has status bits embedded within a control/status register. Changes in the status bits can generate interrupt conditions. For example, the HI08 has a host status register with two host flag bits that can be encoded by the host to generate an interrupt in the DSP.

# 5.4 Data Transfer Methods

Peripheral I/O on the DSP56311 can be accomplished in three ways:

- Polling
- Interrupts
- DMA

# 5.4.1 Polling

Polling is the easiest method for data transfers. When polling is chosen, the DSP56311 core continuously checks a specified register flag waiting for an event to happen. One example would be setting an overflow flag in one of the Timers. Once the event occurs, the DSP56311 is free to continue with its next task. However, while it is waiting for the event to occur, the DSP56311 core is not executing any other code. Polling is the easiest transfer method since it does not require register initializations, but it is also the least efficient use of the DSP core.

Each peripheral has its own set of flags which may be polled to determine when data is ready to be transferred. For example, the ESSI control registers provide bits that tell the core when data is ready to be transferred to or from the peripheral. The core polls these bits to determine when to interact with the peripheral. Similar flags exist for each peripheral.

Example 5-1 shows software polling programmed in an application using the HI08.

|      | Example 5-1.      | Software Polling        |
|------|-------------------|-------------------------|
| jclr | #1,x:M_HSR,*      | ; loop if HSR[1]:HTDE=0 |
| move | y:(TBUFF PTR)+,x1 | ; move data to x1       |

In this example, the core waits until the Host Status Register's (HSR) Host Transmit Data Empty (HTDE) flag is set. When the flag is set, the core moves data from Y memory to the X1 register.

### 5.4.2 Interrupts

Interrupts are more efficient than polling, but interrupts also require additional register initializations. Polling requires the core to remain busy checking a flag in a specified control register and therefore does not allow the core to execute other code at the same time. For interrupts, you can initialize the interrupt so it is triggered off one of the same flags that can also be polled. Then the core does not have to continuously check a flag. Once the interrupt is initialized and the flag is set, the core is notified to execute a data transfer. Until the flag is set, the core can remain busy executing other sections of code.

When an interrupt occurs, the core execution flow jumps to the interrupt start address defined in Table B-4 in **Appendix B**, *Programming Reference*. It executes code starting at the interrupt address. If it is a short interrupt (i.e., the service routine is two opcodes long), the code automatically returns to the original program flow after executing two opcodes with no impact to the pipeline. Otherwise, if a longer service routine is required the programmer can place a jump-to-subroutine (JSR) instruction at the interrupt service address. In this case, the program executes that service routine and continues until a return-from-interrupt (RTI) instruction executes. The execution flow then resumes from the position the program counter was in before the interrupt was triggered.

Configuring interrupts requires two steps:

- **1.** Setting up the interrupt routine
  - The interrupt handler is located at the interrupt starting address.
  - The interrupt routines can be short (only two opcodes long) or long (more than two opcodes and requiring a JSR instruction).
- 2. Enabling the interrupts
  - a. Set the corresponding bits in the applicable peripheral control register.
  - b. Enable peripheral interrupts in the Interrupt Priority Register (IPRP).
  - c. Enable global interrupts in the Mode Register (MR) portion of the Status Register (SR).

Events that change bits in the peripheral control registers can then trigger the interrupt. Depending on the peripheral, from two to six peripheral interrupt sources are available to the programmer.

**Example 5-2** shows a short interrupt programmed for the HI08. The main program enables the Host Receive Interrupt in the Host Control Register (HCR). When the interrupt is triggered during code execution, the core processing jumps to the Host Receive Interrupt routine location at p:\$60 and executes the code there. Since this is a short interrupt, the core returns to normal code execution after executing the two move instructions, and an RTI instruction is not necessary.

Example 5-2. Interrupts

```
bset #M_HRIE,x:M_HCR; enable host receive interrupt
; Short Interrupt Routine
org    P:$60
movep    x:M_HRX,x1    ; HI08 Receive Data Full interrupt
move    x1,y:(r0)+
```

### 5.4.3 DMA

The Direct Memory Access (DMA) controller permits data transfers between internal/external memory and/or internal/external I/O in any combination without the intervention of the DSP56311 core. Dedicated DMA address and data buses and internal memory partitioning ensure that a high level of isolation is achieved so the DMA operation does not interfere with the core operation or slow it down. The DMA moves data to/from the peripheral transmit/receive registers. The programmer may use the DMA control registers to configure sources and destinations of data transfers. Depending on the peripheral, you will find one to four peripheral request sources available. This is the most efficient method of data transfer available. Core intervention is not required after the DMA channel is initialized.

| Pleak | Desister | DMA  |       |  |
|-------|----------|------|-------|--|
| Block | Register | Read | Write |  |
| ESSI  | TX0      | No   | Yes   |  |
|       | TX1      | No   | Yes   |  |
|       | TX2      | No   | Yes   |  |
|       | RX       | Yes  | No    |  |
| SCI   | SRX      | Yes  | No    |  |
|       | STX      | No   | Yes   |  |
| EFCOP | FDIR     | No   | Yes   |  |
|       | FDOR     | Yes  | No    |  |
| HI08  | НТХ      | No   | Yes   |  |
|       | HRX      | Yes  | No    |  |
| Timer |          |      |       |  |

| Table 5-1. | DMA-Accessible Registers |
|------------|--------------------------|
|------------|--------------------------|

**Example 5-3** shows a DMA configuration for transferring data to the Host Transmit register of the HI08.

Example 5-3. DMA Transfers

|       | #M_D1L0,x:M_IPRC<br>#M_D1L1,x:M_IPRC | ; | disable DMA1 interrupts                                                                    |
|-------|--------------------------------------|---|--------------------------------------------------------------------------------------------|
| movep | #M_HTX,x:M_DDR1                      | ; | DMA1 source is transmit buffer<br>DMA1 destination is HTX<br>DMA1 count is the full buffer |
| movep | <pre>#INIT_DCR1,x:M_DCR1</pre>       | ; | init. DMA1 control register                                                                |

General-Purpose Input/Output (GPIO)

DMA requires more initialization code and consideration of DMA modes. However, it is the most efficient use of core resources. Once these registers are programmed, the user must enable the DMA by triggering a DMA request off one of the peripheral control flags or enabling it in normal program flow or an interrupt service routine.

### 5.4.4 Advantages and Disadvantages

Polling is the easiest method to implement, but it requires a large amount of DSP56311 core processing power. The core cannot be involved in other processing activities while it is polling receive and transmit ready bits. Interrupts require more code, but the core can process other routines while waiting for data I/O. An interrupt is generated when data is ready to be transferred to or from the peripheral device. DMA requires even less core intervention, and the setup code is minimal, but the DMA channels must be available.

Note: Do not interrupt requests and DMA requests simultaneously.

# 5.5 General-Purpose Input/Output (GPIO)

The DSP56311 provides 34 bidirectional signals that can be configured as GPIO signals or as peripheral dedicated signals. No dedicated GPIO signals are provided. All of these signals are GPIO by default after reset. The control register settings of the DSP56311 peripherals determine whether these signals function as GPIO or as peripheral dedicated signals. This section tells how signals can be used as GPIO.

**Chapter 2,** *Signals/Connections* details the special uses of the 34 bidirectional signals. These signals fall into five groups and are controlled separately or as a group:

- Port B: 16 GPIO signals (shared with the HI08 signals)
- Port C: six GPIO signals (shared with the ESSI0 signals)
- Port D: six GPIO signals (shared with the ESSI1 signals)
- Port E: three GPIO signals (shared with the SCI signals)
- Timers: three GPIO signals (shared with the triple timer signals)

### 5.5.1 Port B Signals and Registers

Each of the 16 Port B signals not used as an HI08 signal can be configured as a GPIO signal. Three registers control the GPIO functionality of Port B: host control register (HCR), host port GPIO data register (HDR), and host port GPIO direction register (HDDR). **Chapter 6,** *Host Interface (HI08)* discusses these registers.



Figure 5-2. Port B Signals

### 5.5.2 Port C Signals and Registers

Each of the six Port C signals not used as an ESSI0 signal can be configured as a GPIO signal. Three registers control the GPIO functionality of Port C: Port C control register (PCRC), Port C direction register (PRRC), and Port C data register (PDRC). **Chapter 7**, *Enhanced Synchronous Serial Interface (ESSI)* discusses these registers.



Figure 5-3. Port C Signals

### 5.5.3 Port D Signals and Registers

Each of the six Port D signals not used as an ESSI1 signal can be configured as a GPIO signal. Three registers control the GPIO functionality of Port D: Port D control register (PCRD), Port D direction register (PRRD), and Port D data register (PDRD). **Chapter 7**, *Enhanced Synchronous Serial Interface (ESSI)* discusses these registers.



Figure 5-4. Port D Signals

# 5.5.4 Port E Signals and Registers

Each of the three Port E signals not used as an SCI signal can be configured as a GPIO signal. Three registers control the GPIO functionality of Port E: Port E control register (PCRE), Port E direction register (PRRE), and Port E data register (PDRE). **Chapter 8**, *Serial Communication Interface (SCI)* discusses these registers.



Figure 5-5. Port E Signals

### 5.5.5 Triple Timer Signals and Registers

Each of the three triple timer interface signals (TIO0–TIO2) not used as a timer signal can be configured as a GPIO signal. Each signal is controlled by the appropriate timer control status register (TCSR0–TCSR2). **Chapter 9**, *Triple Timer Module* discusses these registers.



Figure 5-6. Triple Timer Signals

### Freescale Semiconductor, Inc.

General-Purpose Input/Output (GPIO)

# **Chapter 6** Host Interface (HI08)

The host interface (HI08) is a byte-wide, full-duplex, double-buffered parallel port that can connect directly to the data bus of a host processor. The HI08 supports a variety of buses and provides glueless connection with a number of industry-standard microcomputers, microprocessors, and DSPs. The HI08 signals not used to interface to the host can be configured as GPIO signals, up to a total of 16.

# 6.1 Features

The HI08 host is a slave device that operates asynchronously to the DSP core and host clocks. Thus, the HI08 peripheral has a host processor interface and a DSP core interface. This section lists the features of the host processor and DSP core interfaces.

### 6.1.1 DSP Core Interface

- Mapping:
  - Registers are directly mapped into eight internal X data memory locations.
- Data word:
  - DSP56311 24-bit (native) data words are supported, as are 8-bit and 16-bit words.
- Handshaking protocols:
  - Software polled
  - Interrupt driven
  - Core DMA accesses
- Instructions:
  - Memory-mapped registers allow the standard MOVE instruction to transfer data between the DSP56311 and external hosts.
  - A special MOVEP instruction for I/O service capability using fast interrupts.
  - Bit addressing instructions (for example, BCHG, BCLR, BSET, BTST, JCLR, JSCLR, JSET, JSSET) simplify I/O service routines.

### 6.1.2 Host Processor Interface

- Sixteen signals support nonmultiplexed or multiplexed buses:
  - H0–H7/HAD0–HAD7 host data bus (H0–H7) or host multiplexed address/data bus (HAD0–HAD7)
  - HAS/HA0 address strobe (HAS) or host address line (HA0)
  - HA8/HA1 host address line (HA8) or host address line (HA1)
  - HA9/HA2 host address line (HA9) or host address line (HA2)
  - HRW/HRD read/write select (HRW) or read strobe (HRD)
  - HDS/HWR data strobe (HDS) or write strobe (HWR)
  - HCS/HA10 host chip select (HCS) or host address line (HA10)
  - HREQ/HTRQ host request (HREQ) or host transmit request (HTRQ)
  - HACK/HRRQ host acknowledge (HACK) or host receive request (HRRQ)
- Mapping:
  - HI08 registers are mapped into eight consecutive locations in the host's external bus address space.
  - The HI08 acts as a memory or I/O-mapped peripheral for microprocessors, microcontrollers, etc.
- Transfer modes:
  - Mixed 8-bit, 16-bit, and 24-bit data transfers
    - DSP-to-host
    - Host-to-DSP
  - Host command
- Handshaking protocols:
  - Software polled
  - Interrupt-driven (Interrupts are compatible with most processors, including the MC68000, 8051, HC11, and Hitachi H8.)
- Data word: 8 bits
- Dedicated interrupts:
  - Separate request lines for each interrupt source
  - Special host commands force DSP core interrupts under host processor control. These commands are useful for
    - Real-time production diagnostics

- Creation of a debugging window for program development
- Host control protocols
- Interface capabilities:
  - Glueless interface (no external logic required) to
    - Motorola HC11
    - Hitachi H8
    - 8051 family
    - Thomson P6 family
  - Minimal glue-logic (pull-ups, pull-downs) required to interface to
    - ISA bus
    - Motorola 68K family
    - Intel X86 family

# 6.2 Host Port Signals

The host port signals are discussed in **Chapter 2**, *Signals/Connections*. Each host port signal can be programmed as a host port signal or as a GPIO signal, PB0–PB15. See **Table 6-1** through **Table 6-3**.

 Table 6-1.
 HI08 Signal Definitions for Operational Modes

| HI08 Port Signal | Multiplexed Address/Data Bus<br>Mode | Nonmultiplexed Bus Mode | GPIO Mode |
|------------------|--------------------------------------|-------------------------|-----------|
| HAD0-HAD7        | HAD0–HAD7                            | H0–H7                   | PB0–PB7   |
| HAS/HA0 HAS/HAS  |                                      | HA0                     | PB8       |
| HA8/HA1          | HA8                                  | HA1                     | PB9       |
| HA9/HA2 HA9      |                                      | HA2                     | PB10      |
| HCS/HA10 HA10    |                                      | HCS/HCS                 | PB13      |

Table 6-2. HI08 Data Strobe Signals

| HI08 Port Single Strobe Bus |  | Dual Strobe Bus | GPIO Mode |
|-----------------------------|--|-----------------|-----------|
| HRW/HRD HRW                 |  | HRD/HRD         | PB11      |
| HDS/HWR HDS/HDS             |  | HWR/HWR         | PB12      |

| HI08 Port<br>Signal | Vector Required | No Vector Required | GPIO Mode |
|---------------------|-----------------|--------------------|-----------|
| HREQ/<br>HTRQ       | HREQ/HREQ       | HTRQ/HTRQ          | PB14      |
| HACK/<br>HRRQ       | HACK/HACK       | HRRQ/HRRQ          | PB15      |

 Table 6-3.
 HI08 Host Request Signals

The HI08 port can operate in multiplexed or non-multiplexed mode. In multiplexed mode (HPCR[11]:HMUX=1), the lower eight address signals multiplex with the eight data lines. In non-multiplexed mode (HPCR[11]:HMUX=0), the HI08 requires a chip select signal and three address lines to select one of the eight registers accessible to the host. Eight lines are used for data. The HI08 port can also be programmed to use a single or dual read/write data strobe and single or double host request line.

Software and hardware resets clear all DSP-side control registers and configure the HI08 as GPIO with all 16 signals disconnected. To select GPIO functions, clear HPCR bits 6 through 1; to select other HI08 functions, set those same bits. If the HI08 is in GPIO mode, the HDDR configures each corresponding signal in the HDR as an input signal if the HDDR bit is cleared or as an output signal if the HDDR bit is set. For details, see **Section 6.6.3**, "Host Data Direction Register (HDDR)," on page 6-16 and **Section 6.6.4**, "Host Data Register (HDR)," on page 6-16.

# 6.3 Overview

The HI08 is partitioned into two register banks, as **Figure 6-1** shows. The host-side register bank is accessible only to the host, and the DSP-side register bank is accessible only to the DSP core. For the host, the HI08 appears as eight byte-wide locations mapped in its external address space. The DSP-side registers appear to the DSP core as six 24-bit registers mapped into internal I/O X memory space and therefore accessible via standard DSP56300 instructions and addressing modes. In GPIO mode, two additional registers (HDDR and HDR) are related to the HI08 peripheral.

The separate receive and transmit data paths are double buffered for efficient, high speed asynchronous transfers. The host-side transmit data path (host writes) is also the DSP-side receive path; the host-side receive data path (host reads) is also the DSP-side transmit path. The Receive (RXH:M:L) and Transmit Data Registers (TXH:M:L) use the same host address. During host writes to these addresses, the data is transferred to the Transmit Data Registers while reads are performed from the Receive Data Registers.

**6-**4

#### **DSP-Side Registers**

#### **Control Registers**

HCR = Host Control Register HSR = Host Status Register HPCR = Host Port Control Register HBAR = Host Base Address Register

#### **Data Registers**

HTX = Host Transmit Register HRX = Host Receive Register HDDR = Host Data Direction Register HDR = Host Data Register



#### **Host-Side Registers**

#### **Control Registers**

ISR = Interface Status Register ICR = Interface Control Register CVR = Command Vector Register IVR = Interrupt Vector Register

#### **Data Registers**

RXH = Receive Register High RXM = Receive Register Middle RXL = Receive Register Low TXH = Transmit Register High TXM = Transmit Register Middle TXL = Transmit Register Low

Figure 6-1. HI08 Block Diagram

# 6.4 Operation

The HI08 is a slave-only device, so the host is the master of all bus transfers. In host-to-DSP transfers, the host writes data to the Transmit Byte Registers (TXH:M:L). In DSP-to-host transfers the host reads data from the Receive Byte Registers (RXH:M:L). The DSP side has access only to the Host Receive Data Register (HRX) and the Host Transmit Data Register (HTX). Data automatically moves between the host-side data registers and the DSP-side data registers when it is available. This double-buffered mechanism allows for fast data transfers but creates a "pipeline" that can either stall communication (if the pipeline is either full or empty) or cause erroneous data transfers (new data to be overwritten or old data to be read twice). The HI08 port has several handshaking mechanisms to counter these buffering effects.

Suppose the host is writing several pieces of data to the HI08 port. The host first uses one of the handshaking protocols to determine whether any data previously written to the Transmit Byte Registers (TXH:M:L) has successfully transferred to the DSP side. If the host-side Transmit Byte Registers (TXH:M:L) are empty, the host writes the data to these registers. The transfer to the DSP-side Host Receive Data Register (HRX) occurs only if HRX is empty (that is, the DSP has read it). The DSP core then uses an appropriate handshaking protocol to move data from the HRX to the receiving buffer or register. Without handshaking, the host might overwrite data not transferred to the DSP side or the DSP might receive stale data.

Similarly, when the host performs multiple reads from the HI08 port Receive Byte Registers (RXH:M:L), the DSP side uses an appropriate handshaking protocol to determine whether any data previously written to the Host Transmit Register (HTX) has successfully transferred to the host-side registers. If HTX is empty, the DSP writes the data to this register. Data transfers to the host-side Receive Byte Registers (RXH:M:L) occur only if they are empty (that is, the host has read them). The host can then use any of the available handshaking protocols to determine whether more data is ready to be read.

The DSP56311 HI08 port offers the following handshaking protocols for data transfers with the host:

- Software polling
- Interrupts
- Core DMA access
- Host requests

The choice of which protocol to use is based on such system constraints as the amount of data to be transferred, the timing requirements for the transfer, and the availability of such resources as processing bandwidth and DMA channels. All of these constraints are

discussed in the following sections. The transfers described here occur asynchronously between the host and the DSP; each transferring data at its own pace. However, use of the appropriate handshaking protocol allows data transfers to occur at optimum rates.

### 6.4.1 Software Polling

Software polling is the simplest data transfer method to use, but it demands the greatest amount of the core's processing power. Status bits are provided for the host or the DSP core to test and determine if the data registers are empty or full. However, the DSP core cannot be involved in other processing activities while it is polling these status bits.

On the DSP side, for transfers from the DSP to the host (host reads), the DSP core must determine the state of Host Transmit Data register (HTX). In transfers from the host to the DSP (host writes), the DSP side should determine the state of the Host Receive Data Register (HRX). Thus, two bits are provided to the core for polling:

- the Host Transmit Data Empty bit in the Host Status register (HSR[1]:HTDE)
- the Host Receive Data Full bit in the Host Status register (HSR[0]:HRDF)

A similar mechanism is available on the host-side to determine the state of the Transmit Registers (TXH:TXM:TXL) and Receive Registers (RXH:RHM:RHL). Two bits are provided to the host for polling:

- the Transmit Data Empty bit in the Interface Status Register (ISR[1]:TXDE)
- the Receive Data Full bit in the Interface Status Register (ISR[0]:RXDF)

The HI08 also offers four general-purpose flags for communication between the host and the DSP. The DSP-side uses the HSR Host Flag bits (HCR[4 - 3]=HF3:HF2) to pass application-specific information to the host. The status of HF3:HF2 is reflected in the host-side ISR Host Flag bits (ISR[4 - 3]=HF3:HF2). Similarly, the host side can use the ICR Host Flag bits (ICR[4 - 3]=HF1:HF0) to pass application-specific information to the DSP. The status of HF1:HF0 is reflected in the DSP-side HSR Host Flag bits (HSR[4 - 3]=HF1:HF0).

### 6.4.2 Core Interrupts and Host Commands

The HI08 can request interrupt service from the DSP56311 core. The DSP56311 core interrupts are internal and do not require the use of an external interrupt signal. When the appropriate interrupt enable bit in the HCR is set, an interrupt condition caused by the host interface sets the appropriate bit in the HSR, generating an interrupt request to the DSP56311 interrupt controller (see **Figure 6-2**). The DSP56311 acknowledges interrupts

by jumping to the appropriate interrupt service routine. The following DSP core interrupts are possible from the HI08 peripheral:

- Host command
- Transmit data register empty
- Receive data register full

These interrupts are maskable via the Host Receive Interrupt Enable bit (HCR[0]=HRIE), the Host Transmit Interrupt Enable bit (HCR[1]=HTIE), and the Host Command Interrupt Enable bit (HCR[2]=HCIE), respectively. Receive Data Full and Transmit Data Empty interrupts move data to/from the HTX and HRX data registers. The DSP interrupt service routine must read or write the appropriate HI08 data register (HRX or HTX) to clear the interrupt condition.



Figure 6-2. HI08 Core Interrupt Operation

Host commands allow the host to issue command requests to the DSP by selecting any of 128 DSP interrupt routines for execution. For example, the host may issue a command via the HI08 that sets up and enables a DMA transfer. The DSP56311 processor has reserved interrupt vector addresses for application-specific service routines. However, this flexibility is independent of the data transfer mechanisms in the HI08 and allows the host to force execution of any interrupt handler (for example, SSI, SCI, IRQx, and so on).

To enable Host Command interrupts, the HCR[2]=HCIE bit is set on the DSP side. The host then uses the Command Vector Register (CVR) to start an interrupt routine. The host sets the Host Command bit (CVR[7]=HC) to request the command interrupt and the seven Host Vector bits CVR[6 - 0]=HV6:HV0 to select the interrupt address to be used. When

the DSP core recognizes the host command interrupt, the address of the interrupt taken is 2xHV. For host command interrupts, the interrupt acknowledge from the DSP56311 program controller clears the pending interrupt condition.

**Note:** When the DSP enters Stop mode, the HI08 pins are electrically disconnected internally, thus disabling the HI08 until the core leaves Stop mode. Do *not* issue a STOP command via the HI08 unless some other mechanism for exiting this mode is provided.

### 6.4.3 Core DMA Access

The DSP56300 family Direct Memory Access (DMA) controller permits transfers between internal or external memory and I/O without any core intervention. A DMA channel can be set up to transfer data to/from the HTX and HRX data registers, freeing the core to use its processing power on functions other than polling or interrupt routines for the HI08. DMA may well be the best method to use for data transfers, but it requires that one of the six DMA channels be available for use. Two HI08 DMA sources are possible, as **Table 6-4** shows. Refer to the *DSP56300 Family Manual* to learn about DMA accesses.

| Table 6-4. | DMA Request Sources |
|------------|---------------------|
|------------|---------------------|

| Requesting Device                 | DCRx[15 – 11]=DRS4 – DRS0 |
|-----------------------------------|---------------------------|
| Host Receive Data Full (HRDF=1)   | 10011                     |
| Host Transmit Data Empty (HTDE=1) | 10100                     |

Note that DMA transfers do not access the host bus. The host must determine when data is available in the host-side data registers using an appropriate polling mechanism.

### 6.4.4 Host Requests

A set of signal lines allow the HI08 to request service from the host. The request signal lines normally connect to the host interrupt request pins (IRQx) and indicate to the host when the DSP HI08 port requires service. The HI08 can be configured to use either a single Host Request (HREQ) line for both receive and transmit requests or two signal lines, a Host Transmit Request (HTRQ) and a Host Receive Request (HRRQ), for each type of transfer.

Host requests are enabled on both the DSP-side and host-side. On the DSP side, the HPCR Host Request Enable bit (HPCR[4]=HREN) is set to enable host requests. On the host side, clearing the ICR Double Host Request bit (ICR[2]=HDRQ) configures the HI08 to use a single request line (HREQ). Setting the ICR[2]=HDRQ bit enables both transmit and request lines to be used. Further, the host uses the ICR Receive Request Enable bit (ICR[0]=RREQ) and the ICR Transmit Request Enable bit (ICR[1]=TREQ) to enable receive and transmit requests, respectively. When host requests are enabled, the host request pins operate as shown in **Figure 6-3**.



Figure 6-3. HI08 Host Request Structure

**Table 6-5** shows the operation of the HREQ pin when a single request line is used. The host can test these ICR bits to determine the interrupt source.

| Table 6-5. | HREQ Pin Operation In Single Request Mode (ICR[2]=HDRQ=0) |
|------------|-----------------------------------------------------------|
|------------|-----------------------------------------------------------|

| ICR[1]=TREQ | ICR[0]=RREQ     | HREQ Pin                      |  |
|-------------|-----------------|-------------------------------|--|
| 0           | 0 No interrupts |                               |  |
| 0           | 1               | RXDF request enabled          |  |
| 1           | 0               | TXDE Request enabled          |  |
| 1           | 1               | RXDF and TXDE request enabled |  |

**Table 6-6** shows the operation of the transmit request (HTRQ) and receive request (HRRQ) lines with dual host requests enabled.

Table 6-6.HTRQ and HRRQ Pin Operation In Double Request Mode(ICR[2]=HDRQ=1)

| ICR[1]=TREQ | ICR[0]=RREQ | HTRQ Pin             | HRRQ Pin             |
|-------------|-------------|----------------------|----------------------|
| 0           | 0           | No interrupts        | No interrupts        |
| 0           | 1           | No interrupts        | RXDF request enabled |
| 1           | 0           | TXDE Request enabled | No interrupts        |
| 1           | 1           | TXDE Request enabled | RXDF request enabled |

### 6.4.5 Endian Modes

The Host Little Endian bit in the host-side Interface Control Register (ICR[5]=HLEND) allows the host to access the HI08 data registers in Big Endian or Little Endian mode. In Little Endian mode (HLEND=1), a host transfer occurs as shown in the **Figure 6-4**.



Figure 6-4. HI08 Read and Write Operations in Little Endian Mode

The host can transfer one byte at a time, so a 24-bit datum would be transferred using three store (or load) byte operations, ensuring that the data byte at host bus address \$7 is written last since this causes the transfer of the data to the DSP-side HRX. However, the host bus controller may be sophisticated enough that the host can transfer all bytes in a single operation (instruction). For example, in the Power PC MPC860 processor, the General-Purpose Controller Module (GPCM) in the memory controller can be programmed so that the host can execute a single read (load word, LDW) or write (store word, STW) instruction to the HI08 port and cause four byte transfers to occur on the host bus. The 32-bit datum transfer shown in **Figure 6-4** has byte data xx written to HI08 address \$4, byte aa to address \$5, byte bb to address \$6 and byte cc to address \$7 (this assumes the 24-bit datum is contained in the lower 24 bits of the host's 32-bit data register as shown).

A similar operation occurs when the HI08 is initialized in Big Endian mode by clearing the Host Little Endian bit (ICR[5]=HLEND). Big Endian mode is depicted in **Figure 6-5**.

### Freescale Semiconductor, Inc.





# 6.5 Boot-up Using the HI08 Host Port

The DSP56300 core has eight bootstrap operating modes to start up after reset. As the processor exits the Reset state the value at the external mode pins MODA/IRQA, MODB/IRQB, MODC/IRQC and MODD/IRQD are loaded into the Chip Operating Mode bits (MA, MB, MC and MD) of the Operating Mode Register (OMR). These bits determine the bootstrap operating mode. Modes C, D, E and F use the HI08 host port to bootstrap the application code to the DSP. The following table describes these modes.

| Mode | MODD | MODC | MODB | MODA | HI08 Bootstrap Description    |
|------|------|------|------|------|-------------------------------|
| С    | 1    | 1    | 0    | 0    | ISA/DSP5630x mode             |
| D    | 1    | 1    | 0    | 1    | HC11 non-multiplexed bus mode |
| E    | 1    | 1    | 1    | 0    | 8051 multiplexed bus mode     |
| F    | 1    | 1    | 1    | 1    | MC68302 bus mode              |

The bootstrap program is factory-programmed into an internal 192-word by 24-bit bootstrap ROM at locations \$FF0000 to \$FF00BF of P memory. This program can load program RAM segment from the HI08 host port. When any of the modes in the preceding table are used, the core begins executing the bootstrap program and configures the HI08 based on the OMR mode bits. The bootstrap program then expects the following data sequence when the user program is downloaded from the HI08:

**1.** Three bytes (least significant byte first) indicating the number of 24-bit program words to be loaded.

Semiconductor, Inc

reescale

- 2. Three bytes (least significant byte first) indicating the 24-bit starting address in P-memory to load the user's program.
- **3.** The user's program (three bytes, least significant byte first, for each program word).

Once the bootstrap program finishes loading the specified number of words, it jumps to the specified starting address and executes the loaded program.

# 6.6 DSP Core Programming Model

The DSP56300 core treats the HI08 as a memory-mapped peripheral occupying eight 24-bit words in X data memory space. The DSP can use the HI08 as a normal memory-mapped peripheral, employing either standard polled or interrupt-driven programming techniques. Separate transmit and receive data registers are double-buffered to allow the DSP and host processor to transfer data efficiently at high speed. Direct memory mapping allows the DSP56311 core to communicate with the HI08 registers using standard instructions and addressing modes. In addition, the MOVEP instruction allows direct data transfers between DSP56311 internal memory and the HI08 registers or *vice versa*.

There are two types of host processor registers, data and control, with eight registers in all. The DSP core can access all eight registers, but the external host cannot. The following data registers are 24-bit registers used for high-speed data transfer to and from the DSP.

- Host data receive register (HRX), on page 6-22
- Host data transmit register (HTX), on **page 6-21**

The DSP-side control registers are 16-bit registers that control HI08 functionality:

- Host control register (HCR), on **page 6-14**
- Host status register (HSR), on **page 6-15**
- Host GPIO data direction register (HDDR), on **page 6-16**
- Host GPIO data register (HDR), on **page 6-16**
- Host base address register (HBAR), on **page 6-17**
- Host port control register (HPCR), on **page 6-17**

Both hardware and software resets disable the HI08. After a reset, the HI08 signals are configured as GPIO and disconnected from the DSP56300 core (that is, the signals are left floating).

# 6.6.1 Host Control Register (HCR)

This read/write register controls the HI08 interrupt operation. Initialization values for HCR bits are presented in **Section 6.6.9**, "DSP-Side Registers After Reset," on page 6-22.

| ſ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2    | 1    | 0    |
|---|----|----|----|----|----|----|---|---|---|---|---|-----|-----|------|------|------|
| ſ |    |    |    |    |    |    |   |   |   |   |   | HF3 | HF2 | HCIE | HTIE | HRIE |

Reserved bit; read as 0; should be written with 0 for future compatibility.

| Figure 6-6. Host Control Register (HCR) (X:\$FFFFC | 2) |
|----------------------------------------------------|----|
|----------------------------------------------------|----|

| Bit Number | Bit Name | Reset Value |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Description              |  |  |  |  |
|------------|----------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|--|--|--|--|
| 15 – 5     |          | 0           | Reserved. Set to 0 for future                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | compatibility.           |  |  |  |  |
| 4 - 3      | HF[3 –2] | 0           | Host Flags 2, 3<br>General-purpose flags for DSP-to-host communication. The DSP core<br>can set or clear HF[3 – 2]. The values of HF[3 – 2] are reflected in the<br>interface status register (ISR); that is, if they are modified by the DSP<br>software, the host processor can read the modified values by reading<br>the ISR. These two general-purpose flags can be used individually or as<br>encoded pairs in a simple DSP-to-host communication protocol,<br>implemented in both the DSP and the host processor software. The bit<br>value is indeterminate after an individual reset. |                          |  |  |  |  |
| 2          | HCIE     | 0           | Host Command Interrupt Enable<br>Generates a host command interrupt request if the host command<br>pending (HCP) status bit in the HSR is set. If HCIE is cleared, HCP<br>interrupts are disabled. The interrupt address is determined by the host<br>command vector register (CVR).<br>NOTE: If more than one interrupt request source is asserted and<br>enabled (for example, HRDF is set, HCP is set, HRIE is set, and HCIE is<br>set), the HI08 generates interrupt requests according to priorities shown<br>here. The bit value is indeterminate after an individual reset.             |                          |  |  |  |  |
|            |          |             | Priority                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Interrupt Source         |  |  |  |  |
|            |          |             | Highest                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Host Command (HCP = 1)   |  |  |  |  |
|            |          |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Transmit Data (HTDE = 1) |  |  |  |  |
|            |          |             | Lowest                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Receive Data (HRDF = 1)  |  |  |  |  |
| 1          | HTIE     | 0           | Host Transmit Interrupt Enable<br>Generates a host transmit data interrupt request if the host transmit data<br>empty (HTDE) bit in the HSR is set. The HTDE bit is set when data is<br>transferred from the HTX to the RXH, RXM, or RXL registers. If HTIE<br>cleared, HTDE interrupts are disabled. The bit value is indeterminate<br>after an individual reset.                                                                                                                                                                                                                             |                          |  |  |  |  |

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|----------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | HRIE     | 0           | Host Receive Interrupt Enable<br>Generates a host receive data interrupt request if the host receive data<br>full (HRDF) bit in the host status register (HSR, Bit 0) is set. The HRDF<br>bit is set when data is transferred to the HRX from the TXH, TXM, or<br>TXL registers. If HRIE is cleared, HRDF interrupts are disabled. The bit<br>value is indeterminate after an individual reset. |

| Table 6-7. | Host Control Register (HCR) Bit Definitions |
|------------|---------------------------------------------|
|------------|---------------------------------------------|

### 6.6.2 Host Status Register (HSR)

The HSR is a 16-bit read-only status register by which the reads the HIO8 status and flags. The host processor cannot access it directly. The initialization values for the HSR bits are discussed in **Section 6.6.9**, "DSP-Side Registers After Reset," on page 6-22.

| ſ | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2   | 1    | 0    |
|---|----|----|----|----|----|----|---|---|---|---|---|-----|-----|-----|------|------|
|   |    |    |    |    |    |    |   |   |   |   |   | HF1 | HF0 | HCP | HTDE | HRDF |

-Reserved bit; read as 0; should be written with 0 for future compatibility.

| Figure 6-7. | Host Status Register (HSR) (X:\$FFFFC3) |
|-------------|-----------------------------------------|
|-------------|-----------------------------------------|

| Bit Number | Bit Name  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                        |
|------------|-----------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15 – 5     |           | 0           | Reserved. Set to 0 for future compatibility.                                                                                                                                                                                                                                                                                                                       |
| 4 - 3      | HF[1 – 0] | 0           | Host Flags 0, 1<br>General-purpose flags for host-to-DSP communication. These bits<br>reflect the status of host flags $HF[1 - 0]$ in the ICR on the host side.<br>These two general-purpose flags can be used individually or as<br>encoded pairs in a simple host-to-DSP communication protocol,<br>implemented in both the DSP and the host processor software. |
| 2          |           | 0           | Host Command Pending<br>Reflects the status of the CVR[HC] bit. When set, it indicates that a host<br>command interrupt is pending. HI08 hardware clears HC and HCP when<br>the DSP core services the interrupt request. If the host clears HC, HCP<br>is also cleared.                                                                                            |
| 1          | HTDE      | 0           | Host Transmit Data Empty<br>Indicates that the host transmit data register (HTX) is empty and can be<br>written by the DSP core. HTDE is set when the HTX register is<br>transferred to the RXH:RXM:RXL registers. The host processor can also<br>set HTDE using the initialize function. HTDE is cleared when the DSP<br>core writes to HTX.                      |

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                  |
|------------|----------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | HRDF     | 0           | Host Receive Data Full<br>Indicates that the host receive data register (HRX) contains data from<br>the host processor. HRDF is set when data is transferred from the<br>TXH:TXM:TXL registers to the HRX register. The host processor can<br>also clear HRDF using the initialize function. |

| Table 6-8. | Host Status Register (HSR) Bit Definitions |
|------------|--------------------------------------------|
|------------|--------------------------------------------|

### 6.6.3 Host Data Direction Register (HDDR)

The HDDR controls the direction of the data flow for each of the HI08 signals configured as GPIO. Even when the HI08 functions as the host interface, its unused signals can be configured as GPIO signals. For information on the HI08 GPIO configuration options, see **Section 6.2**, "Host Port Signals," on page 6-3. If Bit DR*xx* is set, the corresponding HI08 signal is configured as an output signal. If Bit DR*xx* is cleared, the corresponding HI08 signal is configured as an input signal. Hardware and software reset clear the HDDR bits.

| 15  | 14     | 13   | 12   | 11   | 10   | 9   | 8   | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|--------|------|------|------|------|-----|-----|-----|-----|-----|-----|-----|-----|-----|-----|
| DR1 | 5 DR14 | DR13 | DR12 | DR11 | DR10 | DR9 | DR8 | DR7 | DR6 | DR5 | DR4 | DR3 | DR2 | DR1 | DR0 |

Figure 6-8. Host Data Direction Register (HDDR) (X:\$FFFFC8)

### 6.6.4 Host Data Register (HDR)

The HDR register holds the data value of the corresponding bits of the HI08 signals configured as GPIO signals. The functionality of Dxx depends on the corresponding HDDR bit (that is, DRxx).

| HDDR      | HDR                                                                                                                                                        |                                                      |  |  |  |  |  |  |  |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|--|--|--|--|--|--|--|
| DRxx      | Dxx                                                                                                                                                        |                                                      |  |  |  |  |  |  |  |
| DKXX      | GPIO Signal <sup>1</sup>                                                                                                                                   | Non-GPIO Signal <sup>a</sup>                         |  |  |  |  |  |  |  |
| 0         | Read-only bit—The value read is the binary value<br>of the signal. The corresponding signal is<br>configured as an input.                                  | Read-only bit—Does not contain significant data.     |  |  |  |  |  |  |  |
| 1         | Read/write bit— The value written is the value<br>read. The corresponding signal is configured as an<br>output and is driven with the data written to Dxx. | Read/write bit— The value written is the value read. |  |  |  |  |  |  |  |
| 1. Define | d by the selected configuration.                                                                                                                           |                                                      |  |  |  |  |  |  |  |

| Table 6-9.         HDR and HDDR Functionality |
|-----------------------------------------------|
|-----------------------------------------------|

reescale Semiconductor, Inc.

### 6.6.5 Host Base Address Register (HBAR)

In multiplexed bus modes, HBAR selects the base address where the host-side registers are mapped into the host bus address space. The address from the host bus is compared with the base address as programmed in the Base Address Register. An internal chip select is generated if a match is found. **Figure 6-10** shows how the chip-select logic uses HBAR.

| 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7    | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----|----|----|----|----|----|---|---|------|-----|-----|-----|-----|-----|-----|-----|
|    |    |    |    |    |    |   |   | BA10 | BA9 | BA8 | BA7 | BA6 | BA5 | BA4 | BA3 |

Reserved bit, read as 0, should be written with 0 for future compatibility.

Figure 6-9. Host Base Address Register (HBAR) (X:\$FFFFC5)

| Bit Number | Bit Name   | Reset Value | Description                                                                                                      |
|------------|------------|-------------|------------------------------------------------------------------------------------------------------------------|
| 15 – 8     |            | 0           | Reserved. Set to 0 for future compatibility.                                                                     |
| 7 – 0      | BA[10 – 3] | \$80        | Base Address<br>Reflect the base address where the host-side registers are mapped into<br>the bus address space. |





### 6.6.6 Host Port Control Register (HPCR)

The HPCR is a read/write control register that controls the HI08 operating mode. HPCR bit initialization values s are discussed in **Section 6.6.9**, "DSP-Side Registers After Reset," on page 6-22. Hardware and software reset clear the HPCR bits.

### Freescale Semiconductor, Inc.

| 15  | 14  | 13   | 12   | 11   | 10   | 9    | 8    | 7 | 6   | 5    | 4    | 3     | 2     | 1     | 0    |
|-----|-----|------|------|------|------|------|------|---|-----|------|------|-------|-------|-------|------|
| HAP | HRP | HCSP | HDDS | HMUX | HASP | HDSP | HROD |   | HEN | HAEN | HREN | HCSEN | HA9EN | HA8EN | HGEN |

Reserved bit, read as 0, should be written with 0 for future compatibility.

Figure 6-11. Host Port Control Register (HPCR) (X:\$FFFFC4)

Note: To assure proper operation of the DSP56311, the HPCR bits HAP, HRP, HCSP, HDDS, HMUX, HASP, HDSP, HROD, HAEN, and HREN should be changed only if HEN is cleared. Similarly, the HPCR bits HAP, HRP, HCSP, HDDS, HMUX, HASP, HDSP, HROD, HAEN, HREN, HCSEN, HA9EN, and HA8EN should not be set when HEN is set nor at the time HEN is set.

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|----------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15         | HAP      | 0           | Host Acknowledge Polarity<br>If HAP is cleared, the host acknowledge (HACK) signal is configured as<br>an active low input. The HI08 drives the contents of the IVR onto the<br>host bus when the HACK signal is low. If the HAP bit is set, the HACK<br>signal is configured as an active high input. The HI08 outputs the<br>contents of the IVR when the HACK signal is high.                                                                                                                                                                                                                                                                                                                                                       |
| 14         | HRP      | 0           | Host Request Polarity<br>Controls the polarity of the host request signals. In single host request<br>mode (that is, when HDRQ is cleared in the ICR), if HRP is cleared and<br>host requests are enabled (that is, if HREN is set and HEN is set), then<br>the HREQ signal is an active low output. If HRP is set and host requests<br>are enabled, the HREQ signal is an active high output. In the double<br>host request mode (that is, when HDRQ is set in the ICR), if HRP is<br>cleared and host requests are enabled (that is, if HREN is set and HEN<br>is set), then the HTRQ and HRRQ signals are active low outputs. If HRP<br>is set and host requests are enabled, the HTRQ and HRRQ signals are<br>active high outputs. |
| 13         | HCSP     | 0           | Host Chip Select Polarity<br>If the HCSP bit is cleared, the host chip select (HCS) signal is<br>configured as an active low input and the HI08 is selected when the<br>HCS signal is low. If the HCSP signal is set, HCS is configured as an<br>active high input and the HI08 is selected when the HCS signal is high.                                                                                                                                                                                                                                                                                                                                                                                                               |
| 12         | HDDS     | 0           | Host Dual Data Strobe<br>If the HDDS bit is cleared, the HI08 operates in single strobe bus mode.<br>In this mode, the bus has a single data strobe signal for both reads and<br>writes. If the HDDS bit is set, the HI08 operates in dual strobe bus<br>mode. In this mode, the bus has two separate data strobes: one for data<br>reads, the other for data writes. See <b>Figure 6-12</b> on page 6-21 and<br><b>Figure 6-13</b> on page 6-21 for more information on dual and single<br>strobe modes.                                                                                                                                                                                                                              |

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|----------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | HMUX     | 0           | Host Multiplexed Bus<br>If HMUX is set, the HI08 operates in multiplex mode, latching the lower<br>portion of a multiplexed address/data bus. In this mode the internal<br>address line values of the host registers are taken from the internal<br>latch. If HMUX is cleared, it indicates that the HI08 is connected to a<br>nonmultiplexed type of bus. The values of the address lines are then<br>taken from the HI08-dedicated address signals.                                                                                                                                                                                                                                                                                                                                                  |
| 10         | HASP     | 0           | Host Address Strobe Polarity<br>If HASP is cleared, the host address strobe (HAS) signal is an active low<br>input, and the address on the host address/data bus is sampled when<br>the HAS signal is low. If HASP is set, HAS is an active-high address<br>strobe input, and the address on the host address or data bus is<br>sampled when the HAS signal is high.                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 9          | HDSP     | 0           | Host Data Strobe Polarity<br>If HDSP is cleared, the data strobe signals are configured as active low<br>inputs, and data is transferred when the data strobe is low. If HDSP is<br>set, the data strobe signals are configured as active high inputs, and<br>data is transferred when the data strobe is high. The data strobe signals<br>are either HDS by itself or both HRD and HWR together.                                                                                                                                                                                                                                                                                                                                                                                                      |
| 8          | HROD     | 0           | Host Request Open Drain<br>Controls the output drive of the host request signals. In the single host<br>request mode (that is, when HDRQ is cleared in ICR), if HROD is<br>cleared and host requests are enabled (that is, if HREN is set and HEN<br>is set in the host port control register (HPCR)), then the HREQ signal is<br>always driven by the HI08. If HROD is set and host requests are<br>enabled, the HREQ signal is an open drain output. In the double host<br>request mode (that is, when HDRQ is set in the ICR), if HROD is cleared<br>and host requests are enabled (that is, if HREN is set and HEN is set in<br>the HPCR), then the HTRQ and HRRQ signals are always driven. If<br>HROD is set and host requests are enabled, the HTRQ and HRRQ<br>signals are open drain outputs. |
| 7          |          | 0           | Reserved. Set to 0 for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 6          | HEN      | 0           | <b>Host Enable</b><br>If HEN is set, the HI08 operates as the host interface. If HEN is cleared,<br>the HI08 is not active, and all the HI08 signals are configured as GPIO<br>signals according to the value of the HDDR and HDR.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 5          | HAEN     | 0           | Host Acknowledge Enable<br>Controls the HACK signal. In the single host request mode (HDRQ is<br>cleared in the ICR), if HAEN and HREN are both set, HACK/HRRQ is<br>configured as the host acknowledge (HACK) input. If HAEN or HREN is<br>cleared, HACK/HRRQ is configured as a GPIO signal according to the<br>value of the HDDR and HDR. In the double host request mode (HDRQ<br>is set in the ICR), HAEN is ignored.                                                                                                                                                                                                                                                                                                                                                                             |

DSP Core Programming Model

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------|----------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | HREN     | 0           | <ul> <li>Host Request Enable</li> <li>Controls the host request signals. If HREN is set and the HI08 is in the single host request mode (that is, if HDRQ is cleared in the host interface control register (ICR)), then HREQ/HTRQ is configured as the host request (HREQ) output. If HREN is cleared, HREQ/HTRQ and HACK/HRRQ are configured as GPIO signals according to the value of the HDDR and HDR.</li> <li>If HREN is set in the double host request mode (that is, if HDRQ is set in the ICR), HREQ/HTRQ is configured as the host transmit request (HTRQ) output and HACK/HRRQ as the host receive request (HRRQ) output. If HREN is cleared, HREQ/HTRQ and HDR.</li> </ul> |
|            |          |             | HDR.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 3          | HCSEN    | 0           | <b>Host Chip Select Enable</b><br>If the HCSEN bit is set, HCS/HA10 is a host chip select (HCS) in the<br>non-multiplexed bus mode (that is, when HMUX is cleared) and host<br>address line 10 (HA10) in the multiplexed bus mode (that is, when<br>HMUX is set). If this bit is cleared, HCS/HA10 is configured as a GPIO<br>signal according to the value of the HDDR and HDR.                                                                                                                                                                                                                                                                                                       |
| 2          | HA9EN    | 0           | Host Address Line 9 Enable<br>If HA9EN is set and the HI08 is in multiplexed bus mode, then HA9/HA2<br>is host address line 9 (HA9). If this bit is cleared and the HI08 is in<br>multiplexed bus mode, then HA9/HA2 is configured as a GPIO signal<br>according to the value of the HDDR and HDR.                                                                                                                                                                                                                                                                                                                                                                                     |
|            |          |             | NOTE: HA9EN is ignored when the HI08 is not in the multiplexed bus mode (that is, when HMUX is cleared).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 1          | HA8EN    | 0           | Host Address Line 8 Enable<br>If HA8EN is set and the HI08 is in multiplexed bus mode, then HA8/A1 is<br>host address line 8 (HA8). If this bit is cleared and the HI08 is in<br>multiplexed bus mode, then HA8/HA1 is a GPIO signal according to the<br>value of the HDDR and HDR.                                                                                                                                                                                                                                                                                                                                                                                                    |
|            |          |             | NOTE: HA8EN is ignored when the HI08 is not in the multiplexed bus mode (that is, when HMUX is cleared).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 0          | HGEN     | 0           | Host GPIO Port Enable<br>Enables/disables signals configured as GPIO. If this bit is cleared,<br>signals configured as GPIO are disconnected: outputs are high<br>impedance, inputs are electrically disconnected. Signals configured as<br>HI08 are not affected by the value of HGEN.                                                                                                                                                                                                                                                                                                                                                                                                |



In a single-strobe bus, a DS (data strobe) signal qualifies the access, while a R/W (Read-Write) signal specifies the direction of the access.





In dual-strobe bus, separate HRD and HWR signals specify the access as a read or write access, respectively.



### 6.6.7 Host Transmit Data Register (HTX)

The HTX register performs DSP-to-host data transfers. The DSP56311 views it as a 24-bit write-only register. Its address is X:\$FFFFC7. Writing to the HTX register clears the host transfer data empty bit (HSR[HTDE]) on the DSP side. The contents of the HTX register are transferred as 24-bit data to the receive byte registers (RXH:RXM:RXL) when both HSR[HTDE] and receive data full (ISR[RXDF]) on the host-side bits are cleared. This transfer operation sets the ISR[RXDF] and HSR[HTDE] bits. The DSP56311 can set the HCR[HTIE] bit to cause a host transmit data interrupt when HSR[HTDE] is set. To prevent the previous data from being overwritten, data should not be written to the HTX until HSR[HTDE] is set.

**Note:** When data is written to a peripheral device, there is a two-cycle pipeline delay until any status bits affected by this operation are updated. If you read any of the status bits within the next two cycles, the bit does not reflect its current status. For details, see the *DSP56300 Family Manual*, "Appendix B, Polling a Peripheral Device for Write."

### 6.6.8 Host Receive Data Register (HRX)

The HRX register performs host-to-DSP data transfers. The DSP56311 views it as a 24-bit read-only register. Its address is X:\$FFFFC6. It is loaded with 24-bit data from the transmit data registers (TXH:TXM:TXL on the host side) when both the transmit data register empty (ISR[TXDE]) on the host side and host receive data full (HSR[HRDF]) on the DSP side are cleared. The transfer operation sets both ISR[TXDE] and HSR[HRDF]. When the HSR[HRDF] is set, the HRX register contains valid data. The DSP56311 can set the HCR[HRIE] to cause a host receive data interrupt when HSR[HRDF] is set. When the DSP56311 reads the HRX register, the HSR[HRDF] bit is cleared.

### 6.6.9 DSP-Side Registers After Reset

**Table 6-12** shows the results of the four reset types on the bits in each of the HI08 registers accessible to the DSP56311. The hardware reset (HW) is caused by the  $\overline{\texttt{RESET}}$  signal. The software reset (SW) is caused by execution of the RESET instruction. The individual reset (IR) occurs when HPCR[HEN] is cleared. The stop reset (ST) occurs when the STOP instruction executes.

| <b>.</b>         |                  | Reset Type  |             |             |             |  |  |  |
|------------------|------------------|-------------|-------------|-------------|-------------|--|--|--|
| Register<br>Name | Register<br>Data | HW<br>Reset | SW<br>Reset | IR<br>Reset | ST<br>Reset |  |  |  |
| HCR              | All bits         | 0           | 0           | 1           | —           |  |  |  |
| HPCR             | All bits         | 0           | 0           | —           | _           |  |  |  |
| HSR              | HF[1 – 0]        | 0           | 0           | —           | _           |  |  |  |
|                  | HCP              | 0           | 0           | 0           | 0           |  |  |  |
|                  | HTDE             | 1           | 1           | 1           | 1           |  |  |  |
|                  | HRDF             | 0           | 0           | 0           | 0           |  |  |  |
| HBAR             | BA[10 – 3]       | \$80        | \$80        | _           | _           |  |  |  |
| HDDR             | DR[15 – 0]       | 0           | 0           | —           | —           |  |  |  |
| HDR              | D[15 – 0]        | —           | —           | —           | —           |  |  |  |
| HRX              | HRX [23 – 0]     | empty       | empty       | empty       | empty       |  |  |  |
| HTX              | HTX [23 – 0]     | empty       | empty       | empty       | empty       |  |  |  |

1. The bit value is indeterminate after reset

### 6.7 Host Programmer's Model

The HI08 provides a simple, high-speed interface to a host processor. To the host bus, the HI08 appears to be eight byte-wide registers. Separate transmit and receive data paths are double-buffered to allow the DSP core and host processor to transfer data efficiently at high speed. The host can access the HI08 asynchronously using polling techniques or interrupt-based techniques. The HI08 appears to the host processor as a memory-mapped peripheral occupying eight bytes in the host processor address space. (See **Table 6-13**.)

The eight HI08 registers include the following:

- A control register (ICR), on **page 6-24**
- A status register (ISR), on page 6-28
- Three data registers (RXH/TXH, RXM/TXM, and RXL/TXL), on **page 6-30**
- Two vector registers (CVR and IVR), on page 6-27 and page 6-30

To transfer data between itself and the HI08, the host processor bus performs the following steps:

- **1.** Asserts the HI08 address and strobes to select the register to be read or written. (Chip select in non-multiplexed mode, the address strobe in multiplexed mode.)
- 2. Selects the direction of the data transfer. If it is writing, the host processor sources the data on the bus. Otherwise, the HI08 places the data on the bus.
- **3.** Strobes the data transfer.

Host processors can use standard host processor instructions (for example, byte move) and addressing modes to communicate with the HI08 registers. The HI08 registers are aligned so that 8-bit host processors can use 8-, 16-, or 24-bit load and store instructions for data transfers. The HREQ/HTRQ and HACK/HRRQ handshake flags are provided for polled or interrupt-driven data transfers with the host processor. Because of the speed of the DSP56311 interrupt response, most host microprocessors can load or store data at their maximum programmed I/O instruction rate without testing the handshake flags for each transfer. If full handshake is not needed, the host processor can treat the DSP56311 as a fast device, and data can be transferred between the host processor and the DSP56311 at the fastest data rate of the host processor.

One of the most innovative features of the host interface is the host command feature. With this feature, the host processor can issue vectored interrupt requests to the DSP56311. The host can select any of 128 DSP interrupt routines for execution by writing a vector address register in the HI08. This flexibility allows the host processor to execute up to 128 pre-programmed functions inside the DSP56311. For example, the DSP56311 host interrupts allow the host processor to read or write DSP registers (X, Y, or program memory locations), force interrupt handlers (for example, SSI, SCI,  $\overline{IRQA}$ ,  $\overline{IRQB}$  interrupt routines), and perform control or debugging operations.

**Note:** When the DSP enters Stop mode, the HI08 signals are electrically disconnected internally, thus disabling the HI08 until the core leaves stop mode. While the HI08 configuration remains unchanged in Stop mode, the core cannot be restarted via the HI08 interface. Do not issue a STOP command to the DSP via the HI08 unless you provide some other mechanism to exit stop mode.

| Host<br>Address | Big Endian<br>HLEND = 0 | Little Endian<br>HLEND = 1 |                           |
|-----------------|-------------------------|----------------------------|---------------------------|
| 0               | ICR                     | ICR                        | Interface Control         |
| 1               | CVR                     | CVR                        | Command Vector            |
| 2               | ISR                     | ISR                        | Interface Status          |
| 3               | IVR                     | IVR                        | Interrupt Vector          |
| 4               | 0000000                 | 0000000                    | Unused                    |
| 5               | RXH/TXH                 | RXL/TXL                    | Doooiyo/Tronomit          |
| 6               | RXM/TXM                 | RXM/TXM                    | Receive/Transmit<br>Bytes |
| 7               | RXL/TXL                 | RXH/TXH                    |                           |

 Table 6-13.
 Host-Side Register Map

# 6.7.1 Interface Control Register (ICR)

The ICR is an 8-bit read/write control register by which the host processor controls the HI08 interrupts and flags. The DSP core cannot access the ICR. The ICR is a read/write register, which allows the use of bit manipulation instructions on control register bits. Hardware and software reset clear the ICR bits.

| 7    | 6 | 5     | 4   | 3   | 2    | 1    | 0          |
|------|---|-------|-----|-----|------|------|------------|
| INIT |   | HLEND | HF1 | HF0 | HDRQ | TREQ | RREQ       |
|      |   |       |     |     |      | •    | with 0 for |

Figure 6-14. Interface Control Register (ICR)

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |                                                              |                                   |  |  |
|------------|----------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|--------------------------------------------------------------|-----------------------------------|--|--|
| 7          | INIT     | 0           | <b>Initialize</b><br>The host processor uses the INIT bit to force initialization of the HI08<br>hardware. During initialization, the HI08 transmit and receive control bits<br>are configured. Whether it is necessary to use the INIT bit to initialize<br>the HI08 hardware depends on the software design of the interface.<br>The type of initialization when the INIT bit is set depends on the state of<br>TREQ and RREQ in the HI08. The INIT command, which is local to the<br>HI08, configures the HI08 into the desired data transfer mode. When the<br>host sets the INIT bit, the HI08 hardware executes the INIT command.<br>The interface hardware clears the INIT bit after the command executes. |      |                                                              |                                   |  |  |
|            |          |             | TREQ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | PREQ | After INIT<br>Execution                                      | Transfer Direction<br>Initialized |  |  |
|            |          |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0    | INIT = 0                                                     | None                              |  |  |
|            |          |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1    | INIT = 0;<br>RXDF = 0;<br>HTDE = 1                           | DSP to host                       |  |  |
|            |          |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0    | INIT = 0;<br>TXDE = 1;<br>HRDF = 0                           | Host to DSP                       |  |  |
|            |          |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1    | INIT = 0;<br>RXDF = 0;<br>HTDE = 1;<br>TXDE = 1;<br>HRDF = 0 | Host to/from DSP                  |  |  |
| 6          |          | 0           | Reserved. Write to 0 for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |      |                                                              |                                   |  |  |
| 5          | HLEND    | 0           | Host Little Endian<br>If the HLEND bit is cleared, the host can access the HI08 in Big-Endian<br>byte order. If set, the host can access the HI08 in Little-Endian byte<br>order. If the HLEND bit is cleared the RXH/TXH register is located at<br>address \$5, the RXM/TXM register at \$6, and the RXL/TXL register at<br>\$7. If the HLEND bit is set, the RXH/TXH register is located at address<br>\$7, the RXM/TXM register at \$6, and the RXL/TXL register at \$5.                                                                                                                                                                                                                                       |      |                                                              |                                   |  |  |
| 4          | HF1      | 0           | Host Flag 1<br>A general-purpose flag for host-to-DSP communication. The host<br>processor can set or clear HF1, and the DSP56311cannot change it.<br>HF1 is reflected in the HSR on the DSP side of the HI08.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |      |                                                              |                                   |  |  |
| 3          | HF0      | 0           | Host Flag 0<br>A general-purpose flag for host-to-DSP communication. The host<br>processor can set or clear, and the DSP56311 cannot change it. HF0 is<br>reflected in the HSR on the DSP side of the HI08.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |      |                                                              |                                   |  |  |
| 2          | HDRQ     | 0           | <b>Double Host Request</b><br>If cleared, the HDRQ bit configures HREQ/HTRQ and HACK/HRRQ as<br>HREQ and HACK, respectively. If HDRQ is set, HREQ/HTRQ is<br>configured as HTRQ, and HACK/HRRQ is configured as HRRQ.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |      |                                                              |                                   |  |  |

#### Table 6-14. Interface Control Register (ICR) Bit Definitions

#### Table 6-14. Interface Control Register (ICR) Bit Definitions (Continued)

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                           |          |                                                     |                             |  |  |  |
|------------|----------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------------------------------------------------|-----------------------------|--|--|--|
| 1          | TREQ     | 0           | <b>Transmit Request Enable</b><br>Enables host requests via the host request (HREQ or HTRQ) signal<br>when the transmit data register empty (TXDE) status bit in the ISR is<br>set. If TREQ is cleared, TXDE interrupts are disabled. If TREQ and<br>TXDE are set, the host request signal is asserted.                                                                               |          |                                                     |                             |  |  |  |
|            |          |             |                                                                                                                                                                                                                                                                                                                                                                                       | TREQ and | RREQ modes (HI                                      | DRQ = 0)                    |  |  |  |
|            |          |             | TREQ                                                                                                                                                                                                                                                                                                                                                                                  | RREQ     | HR                                                  | HREQ Signal                 |  |  |  |
|            |          |             | 0                                                                                                                                                                                                                                                                                                                                                                                     | 0        | No interrupts (polling)<br>RXDF request (interrupt) |                             |  |  |  |
|            |          |             | 0                                                                                                                                                                                                                                                                                                                                                                                     | 1        |                                                     |                             |  |  |  |
|            |          |             | 1                                                                                                                                                                                                                                                                                                                                                                                     | 0        | TXDE request (interrupt)                            |                             |  |  |  |
|            |          |             | 1                                                                                                                                                                                                                                                                                                                                                                                     | 1        | RXDF and TXDE request (interrupts)                  |                             |  |  |  |
|            |          |             |                                                                                                                                                                                                                                                                                                                                                                                       | TREQ and | RREQ modes (HDRQ = 1)                               |                             |  |  |  |
|            |          |             | TREQ                                                                                                                                                                                                                                                                                                                                                                                  | RREQ     | HTRQ Signal HRRQ Signal                             |                             |  |  |  |
|            |          |             | 0                                                                                                                                                                                                                                                                                                                                                                                     | 0        | No interrupts<br>(polling)                          | No interrupts (polling)     |  |  |  |
|            |          |             | 0                                                                                                                                                                                                                                                                                                                                                                                     | 1        | No interrupts<br>(polling)                          | RXDF request<br>(interrupt) |  |  |  |
|            |          |             | 1                                                                                                                                                                                                                                                                                                                                                                                     | 0        | TXDE request<br>(interrupt)                         | No interrupts (polling)     |  |  |  |
|            |          |             | 1                                                                                                                                                                                                                                                                                                                                                                                     | 1        | TXDE request<br>(interrupt)                         | RXDF request<br>(interrupt) |  |  |  |
| 0          | RREQ     | 0           | <b>Receive Request Enable</b><br>Controls the HREQ signal for host receive data transfers. RREQ<br>enables host requests via the host request (HREQ or HRRQ) signal<br>when the receive data register full (RXDF) status bit in the ISR is set. If<br>RREQ is cleared, RXDF interrupts are disabled. If RREQ and RXDF are<br>set, the host request signal (HREQ or HRRQ) is asserted. |          |                                                     |                             |  |  |  |

#### 6.7.2 Command Vector Register (CVR)

The host processor uses the CVR to cause the DSP56311 to execute an interrupt. The host command feature is independent of any of the data transfer mechanisms in the HI08. It can cause execution of any of the 128 possible interrupt routines in the DSP core. Hardware, software, individual, and stop resets clear the CVR bits.

| 7  | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----|-----|-----|-----|-----|-----|-----|-----|
| HC | HV6 | HV5 | HV4 | HV3 | HV2 | HV1 | HV0 |

Figure 6-15. Command Vector Register (CVR)

| Bit Number | Bit Name  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-----------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7          | HC        | 0           | Host Command<br>The host processor uses the HC bit to handshake the execution of host<br>command interrupts. Normally, the host processor sets HC to request a<br>host command interrupt from the DSP56311. When the DSP56311<br>acknowledges the host command interrupt, HIO8 hardware clears the<br>HC bit. The host processor can read the state of HC to determine when<br>the host command has been accepted. After setting HC, the host must<br>not write to the CVR again until the HIO8 hardware clears the HC.<br>Setting the HC bit causes host command pending (HCP) to be set in the<br>HSR. The host can write to the HC and HV bits in the same write cycle.                                                                       |
| 6 - 0      | HV[6 – 0] | 0           | <ul> <li>Host Vector</li> <li>Select the host command interrupt address for use by the host command interrupt logic. When the DSP interrupt control logic recognizes the host command interrupt, the address of the interrupt routine taken is 2 × HV. The host can write HC and HV in the same write cycle.</li> <li>The host processor can select any of the 128 possible interrupt routine starting addresses in the DSP by writing the interrupt routine address divided by 2 into the HV bits. This means that the host processor can select any reserved or otherwise unused addresses (if have been pre-programmed in the DSP). HV is set to \$32 (vector location \$0064) by hardware, software, individual, and stop resets.</li> </ul> |

# 6.7.3 Interface Status Register (ISR)

The host processor uses the ISR, an 8-bit read-only status register, to interrogate the HI08 status and flags. The host processor can write to this address without affecting the internal state of the HI08. The DSP core cannot access the ISR.



Reserved bit; read as 0; should be written with 0 for future compatibility.

Figure 6-16. Interface Status Registe (ISR)

| Bit Number | Bit Name | Reset Value                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                   | Description                                                            |  |
|------------|----------|-----------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|------------------------------------------------------------------------|--|
| 7          | HREQ     | 0 (Hardware<br>and Software<br>reset)<br>1 (Individual<br>reset and<br>TREQ is set)<br>1 (Stop reset<br>and TREQ is<br>set) | transmit and receive request output signals (HTRQ and HRRQ). If<br>HDRQ is cleared, HREQ indicates the status of the external host<br>request output signal (HREQ). The HREQ bit is set from either or both<br>two conditions— the receive byte registers are full or the transmit by<br>registers are empty. These conditions are indicated by status bits: IS<br>RXDF indicates that the receive byte registers are full, and ISR TXD<br>indicates that the transmit byte registers are empty. If the interrupt<br>source is enabled by the associated request enable bit in the ICR,<br>HREQ is set if one or more of the two enabled interrupt sources is s |                   |                                                                        |  |
|            |          |                                                                                                                             | HDRQ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | HREQ              | Effect                                                                 |  |
|            |          |                                                                                                                             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0                 | HREQ is cleared; no host processor interrupts are requested.           |  |
|            |          |                                                                                                                             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 1                 | HREQ is set; an interrupt is requested.                                |  |
|            |          |                                                                                                                             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0                 | HTRQ and HRRQ are cleared, no host processor interrupts are requested. |  |
|            |          |                                                                                                                             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 1                 | HTRQ or HRRQ are set; an interrupt is requested.                       |  |
| 6 – 5      |          | 0                                                                                                                           | Reserved. Set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | t to 0 for future | e compatibility.                                                       |  |
| 4          | HF3      | 0                                                                                                                           | Host Flag 3<br>Indicates the state of HF3 in the HCR on the DSP side. HF3 can be<br>changed only by the DSP56311. Hardware and software reset clear<br>HF3.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                   |                                                                        |  |
| 3          | HF2      | 0                                                                                                                           | <b>Host Flag 2</b><br>Indicates the state of HF2 in the HCR on the DSP side. HF2 can be<br>changed only by the DSP56311. Hardware and software reset clear<br>HF2.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                   |                                                                        |  |

#### Table 6-16. Interface Status Register (ISR) Bit Definitions

| Table 6-16. | Interface Status Register ( | (ISR) Bit Definitions | (Continued) |
|-------------|-----------------------------|-----------------------|-------------|
|-------------|-----------------------------|-----------------------|-------------|

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|----------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | TRDY     | 1           | Transmitter Ready<br>Indicates that TXH:TXM:TXL and the HRX registers are empty. If TRDY<br>is set, the data that the host processor writes to TXH:TXM:TXL is<br>immediately transferred to the DSP side of the HI08. This feature has<br>many applications. For example, if the host processor issues a host<br>command that causes the DSP56311 to read the HRX, the host<br>processor can be guaranteed that the data it just transferred to the HI08<br>is that being received by the DSP56311. Hardware, software, individual,<br>and stop resets all set TRDY.                                                                                                                                                                                                                         |
|            |          |             | CAUTION                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|            |          |             | TRDY = TXDE and HRDF                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 1          | TXDE     | 1           | Transmit Data Register Empty<br>Indicates that the transmit byte registers (TXH:TXM:TXL) are empty and<br>can be written by the host processor. TXDE is set when the contents of<br>the transmit byte registers are transferred to the HRX register. TXDE is<br>cleared when the transmit register (TXL or TXH according to HLEND bit)<br>is written by the host processor. The host processor can set TXDE using<br>the initialize function. TXDE can assert the external HTRQ signal if the<br>TREQ bit is set. Regardless of whether the TXDE interrupt is enabled,<br>TXDE indicates whether the TX registers are full and data can be<br>latched in (so that polling techniques may be used by the host<br>processor). Hardware, software, individual, and stop resets all set<br>TXDE. |
| 0          | RXDF     | 0           | <b>Receive Data Register Full</b><br>Indicates that the receive byte registers (RXH:RXM:RXL) contain data<br>from the DSP56311 to be read by the host processor. RXDF is set when<br>the HTX is transferred to the receive byte registers. RXDF is cleared<br>when the host processor reads the receive data register (RXL or RXH<br>according to HLEND bit). The host processor can clear RXDF using the<br>initialize function. RXDF can assert the external HREQ signal if the<br>RREQ bit is set. Regardless of whether the RXDF interrupt is enabled,<br>RXDF indicates whether the RX registers are full and data can be<br>latched out (so that the host processor can use polling techniques).                                                                                       |

# 6.7.4 Interrupt Vector Register (IVR)

The IVR is an 8-bit read/write register that typically contains the interrupt vector number used with MC68000 family processor vectored interrupts. Only the host processor can read and write this register. The contents of the IVR are placed on the host data bus, H[7 – 0], when both the HREQ and HACK signals are asserted. The contents of this register are initialized to \$0F by a hardware or software reset. This value corresponds to the uninitialized interrupt vector in the MC68000 family. The hardware and software reset value of the IVR is \$0F.

| 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|
| IV7 | IV6 | IV5 | IV4 | IV3 | IV2 | IV1 | IV0 |

Figure 6-17. Interrupt Vector Register (IVR)

# 6.7.5 Receive Byte Registers (RXH: RXM: RXL)

The host processor views the receive byte registers as three 8-bit read-only registers: the receive high register (RXH), the receive middle register (RXM), and the receive low register (RXL). They receive data from the high, middle, and low bytes, respectively, of the HTX register and are selected by the external host address inputs (HA[2 - 0]) during a host processor read operation. The memory address of the receive byte registers are set by ICR[HLEND]. If ICR[HLEND] is set, the RXH is located at address \$7, RXM at \$6, and RXL at \$5. If ICR[HLEND] is cleared, the RXH is located at address \$5, RXM at \$6, and RXL at \$7.

When data is transferred from the HTX register to the receive byte register at host address \$7, the ISR Receive Data Register Full (RXDF) bit is set. The host processor can program the RREQ bit to assert the external HREQ signal when ISR[RXDF] is set. This indicates that the HI08 has a full word (either 8, 16, or 24 bits) for the host processor. The host processor can program the RREQ bit to assert the external HREQ signal informs the host processor that the receive byte registers have data to be read. When the host reads the receive byte register at host address \$7, the ISR[RXDF] bit is cleared.

# 6.7.6 Transmit Byte Registers (TXH:TXM:TXL)

The host processor views the transmit byte registers as three 8-bit write-only registers. These registers are the transmit high register (TXH), the transmit middle register (TXM), and the transmit low register (TXL). These registers send data to the high, middle, and low bytes, respectively, of the HRX register and are selected by the external host address inputs, HA[2-0], during a host processor write operation.

If ICR[HLEND] is set, the TXH register is located at address \$7, the TXM register at \$6, and the TXL register at \$5. If the HLEND bit in the ICR is cleared, the TXH register is located at address \$5, the TXM register at \$6, and the TXL register at \$7.

Data can be written into the transmit byte registers when the ISR transmit data register empty (TXDE) bit is set. The host processor can program the ICR[TREQ] bit to assert the external HREQ/HTRQ signal when ISR[TXDE] is set. This informs the host processor that the transmit byte registers are empty. Writing to the data register at host address \$7 clears the ISR[TXDE] bit. The contents of the transmit byte registers are transferred as 24-bit data to the HRX register when both ISR[TXDE] and HSR[HRDF] are cleared. This transfer operation sets HSR[TXDE] and HSR[HRDF].

**Note:** When data is written to a peripheral device, there is a two-cycle pipeline delay until any status bits affected by this operation are updated. If you read any of those status bits within the next two cycles, the bit will not reflect its current status. For details, see the *DSP56300 Family Manual*, "Appendix B, Polling a Peripheral Device for Write."

#### 6.7.7 Host-Side Registers After Reset

**Table 6-17** shows the result of the four kinds of reset on bits in each of the HI08 registers seen by the host processor. To cause a hardware reset, assert the  $\overline{\texttt{RESET}}$  signal. To cause a software reset, execute the RESET instruction. To reset the HEN bit individually, clear the HPCR[HEN] bit. To cause a stop reset, execute the STOP instruction.

| Register | Register     | Reset Type  |             |                                  |                                  |  |  |  |
|----------|--------------|-------------|-------------|----------------------------------|----------------------------------|--|--|--|
| Name     | Data         | HW<br>Reset | SW<br>Reset | IR<br>Reset                      | ST<br>Reset                      |  |  |  |
| ICR      | All bits     | 0           | 0           | _                                | —                                |  |  |  |
| CVR      | HC           | 0           | 0           | 0                                | 0                                |  |  |  |
|          | HV[0-6]      | \$32        | \$32        | —                                | —                                |  |  |  |
| ISR      | HREQ         | 0           | 0           | 1 if TREQ is set;<br>0 otherwise | 1 if TREQ is set;<br>0 otherwise |  |  |  |
|          | HF3 -HF2     | 0           | 0           | _                                | —                                |  |  |  |
|          | TRDY         | 1           | 1           | 1                                | 1                                |  |  |  |
|          | TXDE         | 1           | 1           | 1                                | 1                                |  |  |  |
|          | RXDF         | 0           | 0           | 0                                | 0                                |  |  |  |
| IVR      | IV[0 – 7]    | \$0F        | \$0F        | —                                | —                                |  |  |  |
| RX       | RXH: RXM:RXL | empty       | empty       | empty                            | empty                            |  |  |  |
| ТХ       | TXH: TXM:TXL | empty       | empty       | empty                            | empty                            |  |  |  |

| Table 6-17. | Host-Side Registers After Reset |
|-------------|---------------------------------|
|-------------|---------------------------------|

# 6.8 Programming Model Quick Reference

 Table 6-18 summarizes the HI08 programming model.

|      |   |       |                                     | Bit    |                                                   | Rese      | et Type | e  |
|------|---|-------|-------------------------------------|--------|---------------------------------------------------|-----------|---------|----|
| Reg  | # |       | Name                                | Value  | Function                                          | HW/<br>SW | IR      | ST |
| HCR  | 0 | HRIE  | Receive<br>Interrupt<br>Enable      | 0<br>1 | HRRQ interrupt disabled<br>HRRQ interrupt enabled | 0         | _       | —  |
|      | 1 | HTIE  | Transmit<br>Interrupt<br>Enable     | 0<br>1 | HTRQ interrupt disabled<br>HTRQ interrupt enabled | 0         | —       | —  |
|      | 2 | HCIE  | Host Command<br>Interrupt<br>Enable | 0<br>1 | HCP interrupt disabled<br>HCP interrupt enabled   | 0         | —       | —  |
|      | 3 | HF2   | Host Flag 2                         |        |                                                   | 0         |         |    |
|      | 4 | HF3   | Host Flag 3                         |        |                                                   | 0         | —       | _  |
| HPCR | 0 | HGEN  | Host GPIO<br>Enable                 | 0<br>1 | GPIO signal disconnected<br>GPIO signals active   | 0         | —       | _  |
|      | 1 | HA8EN | Host Address<br>Line 8 Enable       | 0<br>1 | HA8/A1 = GPIO<br>HA8/A1 = HA8                     | 0         | —       | —  |
|      | 2 | HA9EN | Host Address<br>Line 9 Enable       | 0<br>1 | HA9/A2 = GPIO<br>HA9/A2 = HA9                     | 0         | —       | —  |
|      | 3 | HCSEN | Host Chip<br>Select Enable          | 0<br>1 | HCS/A10 = GPIO<br>HCS/A10 = HCS                   | 0         | —       | —  |

Table 6-18. HI08 Programming Model, DSP Side

|      |    |      |                                 | Bit    |                                                                                                                                      | Res       | et Typ | e  |
|------|----|------|---------------------------------|--------|--------------------------------------------------------------------------------------------------------------------------------------|-----------|--------|----|
| Reg  | #  |      | Name                            | Value  | Function                                                                                                                             | HW/<br>SW | IR     | ѕт |
| HPCR | 4  | HREN | Host Request<br>Enable          | 0      | HDRQ = 0<br>HDRQ = 1<br>HREQ/HTRQ = GPIO<br>HREQ/HTRQ<br>HACK/HRRQ = GPIO<br>HREQ/HTRQ =<br>HREQ,HREQ/HTRQ<br>HACK/HRRQ = HTRQ, HRRQ | 0         |        |    |
|      | 5  | HAEN | Host<br>Acknowledge<br>Enable   | 0      | HDRQ = 0<br>HDRQ=1<br>HACK/HRRQ = GPIO<br>HREQ/HTRQ<br>HACK/HRRQ = GPIO<br>HACK/HRRQ = HACK<br>HREQ/HTRQ<br>HACK/HRRQ = HTRQ, HRRQ   | 0         | _      |    |
|      | 6  | HEN  | Host Enable                     | 0<br>1 | Host Port = GPIO<br>Host Port Active                                                                                                 | 0         | —      | —  |
|      | 8  | HROD | Host Request<br>Open Drain      | 0<br>1 | HREQ/HTRQ/HRRQ = driven<br>HREQ/HTRQ/HRRQ = open<br>drain                                                                            | 0         |        |    |
|      | 9  | HDSP | Host Data<br>Strobe Polarity    | 0<br>1 | HDS/HRD/HWR active low<br>HDS/HRD/HWR active high                                                                                    | 0         | —      | —  |
|      | 10 | HASP | Host Address<br>Strobe Polarity | 0<br>1 | HAS active low<br>HAS active high                                                                                                    | 0         | —      | —  |
|      | 11 | HMUX | Host<br>Multiplexed Bus         | 0<br>1 | Separate address and data<br>lines<br>Multiplexed address/data                                                                       | 0         | -      | —  |
|      | 12 | HDDS | Host Dual Data<br>Strobe        | 0<br>1 | Single Data Strobe (HDS)<br>Double Data Strobe (HWR,<br>HRD)                                                                         | 0         | -      | -  |
| HPCR | 13 | HCSP | Host Chip<br>Select Polarity    | 0<br>1 | HCS active low<br>HCS active high                                                                                                    | 0         | -      | _  |
|      | 14 | HRP  | Host Request<br>Polarity        | 0<br>1 | HREQ/HTRQ/HRRQ active low<br>HREQ/HTRQ/HRRQ active<br>high                                                                           | 0         | -      | —  |
|      | 15 | НАР  | Host<br>Acknowledge<br>Polarity | 0<br>1 | HACK active low<br>HACK active high                                                                                                  | 0         | _      | —  |

#### Table 6-18. HI08 Programming Model, DSP Side (Continued)

Programming Model Quick Reference

| Table 6-18. | HI08 Programming Model, DSP Side (Continued) |
|-------------|----------------------------------------------|
|             |                                              |

|      |      |              |                                  | Bit        |                                                                                        | Rese      | et Type | e  |
|------|------|--------------|----------------------------------|------------|----------------------------------------------------------------------------------------|-----------|---------|----|
| Reg  | #    |              | Name                             | Value      | Function                                                                               | HW/<br>SW | IR      | ST |
| HSR  | 0    | HRDF         | Host Receive<br>Data Full        | 0<br>1     | no receive data to be read<br>Receive Data Register is full                            | 0         | 0       | 0  |
|      | 1    | HTDE         | Host Transmit<br>Data Empty      | 1<br>0     | The Transmit Data Register is<br>empty.<br>The Transmit Data Register is<br>not empty. | 1         | 1       | 1  |
|      | 2    | HCP          | Host Command<br>Pending          | 0<br>1     | no host command pending host command pending                                           | 0         | 0       | 0  |
|      | 3    | HF0          | Host Flag 0                      |            |                                                                                        | 0         | -       | -  |
|      | 4    | HF1          | Host Flag 1                      |            |                                                                                        | 0         | —       | -  |
| HBAR | 7-0  | BA10-B<br>A3 | Host Base<br>Address<br>Register |            |                                                                                        | \$80      |         |    |
| HRX  | 23-0 |              | DSP Receive<br>Data Register     |            |                                                                                        | empty     |         |    |
| HTX  | 23-0 |              | DSP Transmit<br>Data Register    |            |                                                                                        | empty     |         |    |
| HDR  | 16-0 | D16-<br>D0   | GPIO signal<br>Data              |            |                                                                                        | \$0000    | —       | —  |
| HDRR | 16-0 | DR16-D<br>R0 | GPIO signal<br>Direction         | [0]<br>[1] | Input<br>Output                                                                        | \$0000    | _       | —  |

|             |     |         | Bit                             |        |                                                                                | Rese      | et Typ | е      |
|-------------|-----|---------|---------------------------------|--------|--------------------------------------------------------------------------------|-----------|--------|--------|
| Reg         | #   |         | Name                            | Value  | Function                                                                       | HW/<br>SW | IR     | S<br>T |
| ICR         | 0   | RREQ    | Receive Request Enable          | 0<br>1 | HRRQ interrupt disabled<br>HRRQ interrupt enabled                              | 0         | —      | _      |
|             | 1   | TREQ    | Transmit Request Enable         | 0<br>1 | HTRQ interrupt disabled<br>HTRQ interrupt enabled                              | 0         | -      | _      |
|             | 2   | HDRQ    | Double Host Request             | 0<br>1 | HREQ/HTRQ = HREQ,<br>HACK/HRRQ = HACK<br>HREQ/HTRQ = HTRQ,<br>HACK/HRRQ = HRRQ | 0         |        | _      |
|             | 3   | HF0     | Host Flag 0                     |        |                                                                                | 0         | —      | —      |
|             | 4   | HF1     | Host Flag 1                     |        |                                                                                | 0         | _      | —      |
|             | 5   | HLEND   | Host Little Endian              | 0<br>1 | Big Endian order<br>Little Endian order                                        | 0         | —      | —      |
|             | 7   | INIT    | Initialize                      | 1      | Reset data paths according to TREQ and RREQ                                    | 0         | —      | —      |
| ISR         | 0   | RXDF    | Receive Data Register Full      | 0<br>1 | Host Receive Register is empty<br>Host Receive Register is full                | 0         | 0      | 0      |
|             | 1   | TXDE    | Transmit Data Register<br>Empty | 1<br>0 | Host Transmit Register is empty<br>Host Transmit Register is full              | 1         | 1      | 1      |
|             | 2   | TRDY    | Transmitter Ready               | 1<br>0 | transmit FIFO (6 deep) is empty<br>transmit FIFO is not empty                  | 1         | 1      | 1      |
|             | 3   | HF2     | Host Flag 2                     |        |                                                                                | 0         | _      | —      |
|             | 4   | HF3     | Host Flag 3                     |        |                                                                                | 0         |        | _      |
|             | 7   | HREQ    | Host Request                    | 0<br>1 | HREQ signal is deasserted<br>HREQ signal is asserted (if<br>enabled)           | 0         | 0      | 0      |
| CVR         | 6-0 | HV6-HV0 | Host Command Vector             |        |                                                                                | \$32      | —      | —      |
| CVR         | 7   | НС      | Host Command                    | 0<br>1 | no host command pending host command pending                                   | 0         | 0      | 0      |
| RXH<br>/M/L | 7-0 |         | Host Receive Data<br>Register   |        |                                                                                | empty     |        |        |
| TXH<br>/M/L | 7-0 |         | Host Transmit Data<br>Register  |        |                                                                                | empty     |        |        |
| IVR         | 7-0 | IV7-IV0 | Interrupt Register              |        | 68000 family vector register                                                   | \$0F      | —      | —      |

| Table 6-19. | HI08 Programming Model: Host Side |
|-------------|-----------------------------------|
|-------------|-----------------------------------|

# Freescale Semiconductor, Inc.

Programming Model Quick Reference

# **Chapter 7** Enhanced Synchronous Serial Interface (ESSI)

The ESSI provides a full-duplex serial port for serial communication with a variety of serial devices, including one or more industry-standard CODECs, other DSPs, microprocessors, and peripherals. The ESSI consists of independent transmitter and receiver sections and a common ESSI clock generator. There are two independent and identical ESSIs in the DSP56311: ESSIO and ESSI1. For simplicity, a single generic ESSI is described here. The ESSI block diagram is shown in **Figure 7-1**. This interface is synchronous because all serial transfers are synchronized to one clock.

**Note:** This synchronous interface should not be confused with the asynchronous channels mode of the ESSI, in which separate clocks are used for the receiver and transmitter. In that mode, the ESSI is still a synchronous device because all transfers are synchronized to these clocks.

Pin notations for the generic ESSI refer to the analogous pin of ESSI0 (PCx) and ESSI1 (PDx).

Additional synchronization signals delineate the word frames. The Normal mode of operation transfers data at a periodic rate, one word per period. The Network mode is similar in that it is also for periodic transfers; however, it supports up to 32 words (time slots) per period. The Network mode can be used to build time division multiplexed (TDM) networks. In contrast, the On-Demand mode is for nonperiodic transfers of data. This mode, which offers a subset of the Motorola Serial Peripheral Interface (SPI) protocol, can transfer data serially at high speed when the data become available. Since each ESSI unit can be configured with one receiver and three transmitters, the two units can be used together for surround sound applications (which need two digital input channels and six digital output channels).

# 7.1 ESSI Enhancements

The DSP56000 SSI is enhanced in the following ways to make the ESSI:

- Network enhancements
  - Time slot mask registers (receive and transmit)
  - End-of-frame interrupt
  - Drive enable signal (to be used with transmitter 0)



- Audio enhancements
  - Three transmitters per ESSI (for six-channel surround sound)
- General enhancements
  - Can trigger DMA interrupts (receive or transmit)
  - Separate exception enable bits
- Other changes
  - One divide-by-2 removed from the internal clock source chain
  - Control register A prescaler range (CRA[PSR]) bit definition is reversed
  - Gated clock mode not available

# 7.2 ESSI Data and Control Signals

Three to six signals are required for ESSI operation, depending on the operating mode selected. The serial transmit data (STD) signal and serial control (SC0 and SC1) signals are fully synchronized to the clock if they are programmed as transmit-data signals.

## 7.2.1 Serial Transmit Data Signal (STD)

The STD signal transmits data from the serial transmit shift register. STD is an output when data is transmitted from the TX0 shift register. With an internally-generated bit clock, the STD signal becomes a high impedance output signal for a full clock period after the last data bit is transmitted if another data word does not follow immediately. If sequential data words are transmitted, the STD signal does not assume a high-impedance state. The STD signal can be programmed as a GPIO signal (P5) when the ESSI STD function is not in use.

## 7.2.2 Serial Receive Data Signal (SRD)

The SRD signal receives serial data and transfers the data to the receive shift register. SRD can be programmed as a GPIO signal (P4) when the SRD function is not in use.

## 7.2.3 Serial Clock (SCK)

The SCK signal is a bidirectional signal providing the serial bit rate clock for the ESSI interface. The SCK signal is a clock input or output used by all the enabled transmitters and receivers in synchronous modes or by all the enabled transmitters in Asynchronous modes. See **Table 7-1** for details. SCK can be programmed as a GPIO signal (P3) when the ESSI SCK function is not in use.

ESSI Data and Control Signals

| SYN | SCKD         | SCD0 | RX Clock Source | RX Clock<br>Out | TX Clock Source | TX Clock Out |  |  |  |
|-----|--------------|------|-----------------|-----------------|-----------------|--------------|--|--|--|
|     | Asynchronous |      |                 |                 |                 |              |  |  |  |
| 0   | 0            | 0    | EXT, SC0        | —               | EXT, SCK        | —            |  |  |  |
| 0   | 0            | 1    | INT             | SC0             | EXT, SCK        | —            |  |  |  |
| 0   | 1            | 0    | EXT, SC0        | —               | INT             | SCK          |  |  |  |
| 0   | 1            | 1    | INT             | SC0             | INT             | SCK          |  |  |  |
|     | Synchronous  |      |                 |                 |                 |              |  |  |  |
| 1   | 0            | 0/1  | EXT, SCK        | _               | EXT, SCK        | _            |  |  |  |
| 1   | 1            | 0/1  | INT             | SCK             | INT             | SCK          |  |  |  |

**Note:** Although an external serial clock can be independent of and asynchronous to the DSP system clock, the external ESSI clock frequency must not exceed  $F_{core}/3$ , and each ESSI phase must exceed the minimum of 1.5 CLKOUT cycles. The internally sourced ESSI clock frequency must not exceed  $F_{core}/4$ .

# 7.2.4 Serial Control Signal (SC0)

#### ESSI0: SC00; ESSI1: SC10

To determine the function of the SC0 signal, select either Synchronous or Asynchronous mode, according to **Table 7-2**. In Asynchronous mode, this signal is used for the receive clock I/O. In Synchronous mode, this signal is the transmitter data out signal for transmit shift register TX1 or for serial flag I/O. A typical application of serial flag I/O would be multiple device selection for addressing in CODEC systems.

If SC0 is configured as a serial flag signal or receive clock signal, its direction is determined by the serial control direction 0 (SCD0) bit in ESSI control register B (CRB). When configured as an output, SC0 functions as the serial output flag 0 (OF0) or as a receive shift register clock output. If SC0 is used as the serial output flag 0, its value is determined by the value of the serial output flag 0 (OF0) bit in the CRB. If SC0 is an input, it functions as either serial Input Flag 0 or a receive shift register clock input. As serial input flag 0, SC0 controls the state of the serial input flag 0 (IF0) bit in the ESSI status register (SSISR).

When SC0 is configured as a transmit data signal, it is always an output signal, regardless of the SCD0 bit value. SC0 is fully synchronized with the other transmit data signals (STD and SC1). SC0 can be programmed as a GPIO signal (P0) when the ESSI SC0 function is not in use.

**Note:** The ESSI can operate with more than one active transmitter only in Synchronous mode.

## 7.2.5 Serial Control Signal (SC1)

#### ESSI0:SC01; ESSI1: SCI11

To determine the function of SC1, select either Synchronous or Asynchronous mode, according to **Table 7-2**. In Asynchronous mode (as for a single CODEC with asynchronous transmit and receive), SC1 is the receiver frame sync I/O. In Synchronous mode, SC1 is the transmitter data out signal of transmit shift register TX2, for the transmitter 0 drive-enabled signal, or for serial flag I/O. As serial flag I/O, SC1 operates like SC0. SC0 and SC1are independent flags but can be used together for multiple serial device selection; they can be unencoded to select up to two CODECs or decoded externally to select up to four CODECs. If SC1 is configured as a serial flag or receive frame sync signal, the Serial Control Direction 1 CRB[SCD1] bit determines its direction.

|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | C   | ontrol Bi | ts  |    | ESSI Signals |          |     |     |     |     |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-----------|-----|----|--------------|----------|-----|-----|-----|-----|--|--|
| SYN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | TE0 | TE1       | TE2 | RE | SC0          | SC1      | SC2 | SCK | STD | SRD |  |  |
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0   | Х         | Х   | 0  | U            | U        | U   | U   | U   | U   |  |  |
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0   | Х         | Х   | 1  | RXC          | FSR      | U   | U   | U   | RD  |  |  |
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1   | Х         | Х   | 0  | U            | U        | FST | TXC | TD0 | U   |  |  |
| 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1   | Х         | Х   | 1  | RXC          | FSR      | FST | TXC | TD0 | RD  |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0   | 0         | 0   | 0  | U            | U        | U   | U   | U   | U   |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0   | 0         | 0   | 1  | F0/U         | F1/T0D/U | FS  | XC  | U   | RD  |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0   | 0         | 1   | 0  | F0/U         | TD2      | FS  | XC  | U   | U   |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0   | 0         | 1   | 1  | F0/U         | TD2      | FS  | XC  | U   | RD  |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0   | 1         | 0   | 0  | TD1          | F1/T0D/U | FS  | XC  | U   | U   |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0   | 1         | 0   | 1  | TD1          | F1/T0D/U | FS  | XC  | U   | RD  |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0   | 1         | 1   | 0  | TD1          | TD2      | FS  | XC  | U   | U   |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 0   | 1         | 1   | 1  | TD1          | TD2      | FS  | XC  | U   | RD  |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1   | 0         | 0   | 0  | F0/U         | F1/T0D/U | FS  | XC  | TD0 | U   |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1   | 0         | 0   | 1  | F0/U         | F1/T0D/U | FS  | XC  | TD0 | RD  |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1   | 0         | 1   | 0  | F0/U         | TD2      | FS  | XC  | TD0 | U   |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1   | 0         | 1   | 1  | F0/U         | TD2      | FS  | XC  | TD0 | RD  |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1   | 1         | 0   | 0  | TD1          | F1/T0D/U | FS  | XC  | TD0 | U   |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1   | 1         | 0   | 1  | TD1          | F1/T0D/U | FS  | XC  | TD0 | RD  |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1   | 1         | 1   | 0  | TD1          | TD2      | FS  | XC  | TD0 | U   |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1   | 1         | 1   | 1  | TD1          | TD2      | FS  | XC  | TD0 | RD  |  |  |
| TXC=Transmitter clockRXC=Receiver clockXC=Transmitter/receiver clock (synchronous operation)FST=Transmitter frame syncFSR=Receiver frame sync (synchronous operation)TD0=Transmitter/receiver frame sync (synchronous operation)TD0=Transmit data signal 0TD1=Transmit data signal 1TD2=Transmit data signal 2T0D=Transmit data signal 2T0D=Transmitter 0 drive enable if SSC1 = 1 & SCD1 = 1RD=Receive dataF0=Flag 0F1=Flag 1 if SSC1 = 0U=Unused (can be used as GPIO signal)X=Indeterminate |     |           |     |    |              |          |     |     |     |     |  |  |

#### Freescale Semiconductor, Inc.

Operation

When configured as an output, the SC1 signal functions as a serial output flag, as the transmitter 0 drive-enabled signal, or as the receive frame sync signal output. If SC1 is used as serial output flag 1, its value is determined by the value of the serial output flag 1 (OF1) bit in the CRB. When configured as an input, this signal can receive frame sync signals from an external source, or it acts as a serial input flag. As a serial input flag, SC1controls status bit IF1 in the SSISR.

When SC1 is configured as a transmit data signal, it is always an output signal, regardless of the SCD1 bit value. As an output, it is fully synchronized with the other ESSI transmit data signals (STD and SC0). SC1 can be programmed as a GPIO signal (P1) when the ESSI SC1 function is not in use.

## 7.2.6 Serial Control Signal (SC2)

#### ESSI0:SC02; ESSI1:SC12

SC2 is a frame sync I/O signal for both the transmitter and receiver in Synchronous mode and for the transmitter only in Asynchronous mode. The direction of this signal is determined by the SCD2 bit in the CRB. When configured as an output, this signal outputs the internally generated frame sync signal. When configured as an input, this signal receives an external frame sync signal for the transmitter in Asynchronous mode and for both the transmitter and receiver when in Synchronous mode. SC2 can be programmed as a GPIO signal (P2) when the ESSI SC2 function is not in use.

# 7.3 Operation

This section discusses ESSI basics: reset state, initialization, and exceptions.

#### 7.3.1 ESSI After Reset

A hardware RESET signal or software RESET instruction clears the port control register and the port direction control register, thus configuring all the ESSI signals as GPIO. The ESSI is in the reset state while all ESSI signals are programmed as GPIO; it is active only if at least one of the ESSI I/O signals is programmed as an ESSI signal.

#### 7.3.2 Initialization

To initialize the ESSI, do the following:

- 1. Send a reset: hardware RESET signal, software RESET instruction, ESSI individual reset, or STOP instruction reset.
- 2. Program the ESSI control and time slot registers.
- **3.** Write data to all the enabled transmitters.

7-6

Semiconductor, Inc

reescale

- **4.** Configure at least one signal as ESSI signal.
- **5.** If an external frame sync is used, from the moment the ESSI is activated, at least five (5) serial clocks are needed before the first external frame sync is supplied. Otherwise, improper operation may result.

When the PC[5 - 0] bits in the GPIO Port Control Register (PCR) are cleared during program execution, the ESSI stops serial activity and enters the individual reset state. All status bits of the interface are set to their reset state. The contents of CRA and CRB are not affected. The ESSI individual reset allows a program to reset each interface separately from the other internal peripherals. During ESSI individual reset, internal DMA accesses to the data registers of the ESSI are not valid, and data read there are undefined. To ensure proper operation of the ESSI, use an ESSI individual reset when you change the ESSI control registers (except for bits TEIE, REIE, TLIE, RLIE, TIE, RIE, TE2, TE1, TE0, and RE). Here is an example of how to initialize the ESSI.

- **1.** Put the ESSI in its individual reset state by clearing the PCR bits.
- 2. Configure the control registers (CRA, CRB) to set the operating mode. Disable the transmitters and receiver by clearing the TE[2 0] and RE bits. Set the interrupt enable bits for the operating mode chosen.
- **3.** Enable the ESSI by setting the PCR bits to activate the input/output signals to be used.
- **4.** Write initial data to the transmitters that are in use during operation. This step is needed even if DMA services the transmitters.
- **5.** Enable the transmitters and receiver to be used.

Now the ESSI can be serviced by polling, interrupts, or DMA. Once the ESSI is enabled (Step 3), operation starts as follows:

- **1.** For internally generated clock and frame sync, these signals start activity immediately after the ESSI is enabled.
- 2. The ESSI receives data after a frame sync signal (either internally or externally generated) only when the receive enable (RE) bit is set.
- **3.** Data is transmitted after a frame sync signal (either internally or externally generated) only when the transmitter enable (TE[2 0]) bit is set.

## 7.3.3 Exceptions

The ESSI can generate six different exceptions. They are discussed in the following paragraphs (ordered from the highest to the lowest exception priority):

- ESSI receive data with exception status: Occurs when the receive exception interrupt is enabled, the receive data register is full, and a receiver overrun error has occurred. This exception sets the ROE bit. The ROE bit is cleared when you first read the SSISR and then read the Receive Data Register (RX).
- **ESSI** receive data:

Occurs when the receive interrupt is enabled, the receive data register is full, and no receive error conditions exist. A read of RX clears the pending interrupt. This error-free interrupt can use a fast interrupt service routine for minimum overhead.

**ESSI** receive last slot interrupt:

Occurs when the ESSI is in Network mode and the last slot of the frame has ended. This interrupt is generated regardless of the receive mask register setting. The receive last slot interrupt can signal that the receive mask slot register can be reset, the DMA channels can be reconfigured, and data memory pointers can be reassigned. Using the receive last slot interrupt guarantees that the previous frame is serviced with the previous setting and the new frame is serviced with the new setting without synchronization problems.

- Note: The maximum time it takes to service a receive last slot interrupt should not exceed N 1 ESSI bits service time (where N is the number of bits the ESSI can transmit per time slot).
  - **ESSI** transmit data with exception status:

Occurs when the transmit exception interrupt is enabled, at least one transmit data register of the enabled transmitters is empty, and a transmitter underrun error has occurred. This exception sets the TUE bit. The TUE bit is cleared when you first read the SSISR and then write to all the transmit data registers of the enabled transmitters, or when you write to TSR to clear the pending interrupt.

**ESSI** transmit last slot interrupt:

Occurs when the ESSI is in Network mode at the start of the last slot of the frame. This exception occurs regardless of the transmit mask register setting. The transmit last slot interrupt can signal that the transmit mask slot register can be reset, the DMA channels can be reconfigured, and data memory pointers can be reassigned. Using the Transmit Last Slot interrupt guarantees that the previous frame is serviced with the previous frame settings and the new frame is serviced with the new frame settings without synchronization problems.

7-8

- Note: The maximum transmit last slot interrupt service time should not exceed N 1 ESSI bits service time (where N is the number of bits in a slot).
  - **ESSI** transmit data:

Occurs when the transmit interrupt is enabled, at least one of the enabled transmit data registers is empty, and no transmitter error conditions exist. Write to all the enabled TX registers or to the TSR to clear this interrupt. This error-free interrupt uses a fast interrupt service routine for minimum overhead (if no more than two transmitters are used).

To configure an ESSI exception, perform the following steps:

- **1.** Configure the interrupt service routine (ISR):
  - a. Load vector base address register VBA (b23:8)
  - b. Define I\_VEC to be equal to the VBA value (if that is nonzero). If it is defined, I\_VEC must be defined for the assembler before the interrupt equate file is included.
  - c. Load the exception vector table entry: two-word fast interrupt, or jump/branch to subroutine (long interrupt). p:I\_SIOTD
- 2. Configure interrupt trigger; preload transmit data
  - a. Enable and prioritize overall peripheral interrupt functionality.

|    |                                                    | <pre>IPRP (SOL1:0)</pre> |
|----|----------------------------------------------------|--------------------------|
| b. | Write data to all enabled transmit registers.      | TX00                     |
| c. | Enable a peripheral interrupt-generating function. | CRB (TE0)                |
| d. | Enable a specific peripheral interrupt.            | CRBO (TIE)               |
| e. | Enable peripheral and associated signals.          | PCRC ( $PC[5 - 0]$ )     |
| f. | Unmask interrupts at the global level.             | SR (I1 - 0)              |
|    |                                                    |                          |

**Note:** The example material to the right of the steps shows register settings for configuring an ESSI0 transmit interrupt using transmitter 0. The order of the steps is optional except that the interrupt trigger configuration must not be completed until the ISR configuration is complete. Since **step c** may cause an immediate transmit without generating an interrupt, perform the transmit data preload in **step b** before **step c** to ensure that valid data is sent in the first transmission.

After the first transmit, subsequent transmit values are typically loaded into TXnn by the ISR (one value per register per interrupt). Therefore, if N items are to be sent from a particular TXnn, the ISR needs to load the transmit register (N - 1) times. **Steps**, **c**, and **d** can be performed in **step a** as a single instruction. If an interrupt trigger event occurs before all interrupt trigger configuration steps are performed, the event is ignored and not queued. If interrupts derived from

Operating Modes: Normal, Network, and On-Demand

the core or other peripherals need to be enabled at the same time as ESSI interrupts, **step g** should be performed last.

# 7.4 Operating Modes: Normal, Network, and On-Demand

The ESSI has three basic operating modes and several data and operation formats. These modes are programmed via the ESSI control registers. The data and operation formats available to the ESSI are selected when you set or clear control bits in the CRA and CRB. These control bits are WL[2 - 1], MOD, SYN, FSL[1 - 0], FSR, FSP, CKP, and SHFD.

## 7.4.1 Normal/Network/On-Demand Mode Selection

To select either Normal mode or Network mode, clear or set CRB[MOD]. In Normal mode, the ESSI sends or receives one data word per frame (per enabled receiver or transmitter). In Network mode, 2 to 32 time slots per frame can be selected. During each frame, 0 to 32 data words are received or transmitted (from each enabled receiver or transmitter). In either case, the transfers are periodic.

The Normal mode typically transfers data to or from a single device. Network mode is typically used in time division multiplexed networks of CODECs or DSPs with multiple words per frame.

Network mode has a submode called On-Demand mode. Set the CRB[MOD] for Network mode, and set the frame rate divider to 0 (DC = \$00000) to select On-Demand mode. This submode does not generate a periodic frame sync. A frame sync pulse is generated only when data is available to transmit. The frame sync signal indicates the first time slot in the frame. On-Demand mode requires that the transmit frame sync be internal (output) and the receive frame sync be external (input). For simplex operation, Synchronous mode could be used; however, for full-duplex operation, Asynchronous mode must be used. You can enable data transmission that is data-driven by writing data into each TX. Although the ESSI is double-buffered, only one word can be written to each TX, even if the transmit shift register is empty. The receive and transmit interrupts function normally, using TDE and RDF; however, transmit underruns are impossible for On-Demand transmission and are disabled. This mode is useful for interfacing with CODECs requiring a continuous clock.

Note: When the ESSI transmits data in On-Demand mode (that is, MOD = 1 in the CRB and DC[4 - 0] = \$00000 in the CRA) with WL[2 - 0] = 100, the transmission does not work properly. To ensure correct operation, do not use On-Demand mode with the WL[2 - 0] = 100 32-bit word length mode.

#### 7.4.2 Synchronous/Asynchronous Operating Modes

The transmit and receive sections of the ESSI interface are synchronous or asynchronous. The transmitter and receiver use common clock and synchronization signals in Synchronous mode; they use separate clock and sync signals in Asynchronous mode. The SYN bit in CRB selects synchronous or asynchronous operation. When the SYN bit is cleared, the ESSI TX and RX clocks and frame sync sources are independent. If the SYN bit is set, the ESSI TX and RX clocks and frame sync are driven by the same source (either external or internal). Since the ESSI operates either synchronously or asynchronously, separate receive and transmit interrupts are provided.

Transmitter 1 and transmitter 2 operate only in Synchronous mode. Data clock and frame sync signals are generated internally by the DSP or obtained from external sources. If clocks are internally generated, the ESSI clock generator derives bit clock and frame sync signals from the DSP internal system clock. The ESSI clock generator consists of a selectable fixed prescaler with a programmable prescaler for bit rate clock generation and a programmable frame-rate divider with a word-length divider for frame-rate sync-signal generation.

## 7.4.3 Frame Sync Selection

The transmitter and receiver can operate independently. The transmitter can have either a bit-long or word-long frame-sync signal format, and the receiver can have the same or another format. The selection is made by programming the CRB FSL[1 – 0], FSR, and FSP bits.

## 7.4.4 Frame Sync Signal Format

CRB[FSL1] controls the frame sync signal format.

- If CRB[FSL1] is cleared, the RX frame sync is asserted during the entire data transfer period. This frame sync length is compatible with Motorola CODECs, serial peripherals that conform to the Motorola SPI, serial A/D and D/A converters, shift registers, and telecommunication pulse code modulation serial I/O.
- If CRB[FSL1] is set, the RX frame sync pulses active for one bit clock immediately before the data transfer period. This frame sync length is compatible with Intel<sup>®1</sup> and National Semiconductor Corporation components, CODECs, and telecommunication pulse code modulation serial I/O.

<sup>1.</sup> Intel<sup>®</sup> is a registered trademark of Intel Corporation;

#### 7.4.5 Frame Sync Length for Multiple Devices

The ability to mix frame sync lengths is useful to configure systems in which data is received from one type of device (for example, CODEC) and transmitted to a different type of device. CRB[FSL0] controls whether RX and TX have the same frame sync length.

- If CRB[FSL0] is cleared, both RX and TX have the same frame sync length.
- If CRB[FSL0] is set, RX and TX have different frame sync lengths.

CRB[FSL0] is ignored when CRB[SYN] is set.

## 7.4.6 Word Length Frame Sync and Data Word Timing

The CRB[FSR] bit controls the relative timing of the word length frame sync relative to the data word timing.

- When CRB[FSR] is cleared, the word length frame sync is generated (or expected) with the first bit of the data word.
- When CRB[FSR] is set, the word length frame sync is generated (or expected) with the last bit of the previous word.

CRB[FSR] is ignored when a bit length frame sync is selected.

# 7.4.7 Frame Sync Polarity

The CRB[FSP] bit controls the polarity of the frame sync.

- When CRB[FSP] is cleared, the polarity of the frame sync is positive; that is, the frame sync signal is asserted high. The ESSI synchronizes on the leading edge of the frame sync signal.
- When CRB[FSP] is set, the polarity of the frame sync is negative; that is, the frame sync is asserted low. The ESSI synchronizes on the trailing edge of the frame sync signal.

The ESSI receiver looks for a receive frame sync edge (leading edge if CRB[FSP] is cleared, trailing edge if FSP is set) only when the previous frame is completed. If the frame sync is asserted before the frame is completed (or before the last bit of the frame is received in the case of a bit frame sync or a word-length frame sync with CRB[FSR] set), the current frame sync is not recognized, and the receiver is internally disabled until the next frame sync.

Frames do not have to be adjacent; that is, a new frame sync does not have to follow the previous frame immediately. Gaps of arbitrary periods can occur between frames. All the enabled transmitters are tri-stated during these gaps.

## 7.4.8 Byte Format (LSB/MSB) for the Transmitter

Some devices, such as CODECs, require a MSB-first data format. Other devices, such as those that use the AES – EBU digital audio format, require the LSB first. To be compatible with all formats, the shift registers in the ESSI are bidirectional. You select either MSB or LSB by programming CRB[SHFD].

- If CRB[SHFD] is cleared, data is shifted into the receive shift register MSB first and shifted out of the transmit shift register MSB first.
- If CRB[SHFD] is set, data is shifted into the receive shift register LSB first and shifted out of the transmit shift register LSB first.

# 7.4.9 Flags

Two ESSI signals (SC[1 – 0]) are available for use as serial I/O flags. Their operation is controlled by the SYN, SCD[1 – 0], SSC1, and TE[2 – 1] bits in the CRB/CRA.The control bits OF[1 – 0] and status bits IF[1 – 0] are double-buffered to and from SC[1 – 0]. Double-buffering the flags keeps the flags in sync with TX and RX.

The SC[1 – 0] flags are available in Synchronous mode only. Each flag can be separately programmed. The SC0 flag is enabled when transmitter 1 is disabled (TE1 = 0). The flag's direction is selected by the SCD0 bit. When SCD0 is set, SC0 is configured as output. When SCD0 is cleared, SC0 is configured as input. Similarly, the SC1 flag is enabled when transmitter 2 is disabled (TE2 = 0), and the SC1 signal is not configured as the transmitter 0 drive-enabled signal (Bit SSC1 = 0). The direction of SC1 is determined by the SCD1 bit. When SCD1 is set, SC1 is an output flag.

When programmed as input flags, the value of the SC[1 - 0] bits is latched at the same time as the first bit of the received data word is sampled. Once the input is latched, the signal on the input flag signal (SC0 and SC1) can change without affecting the input flag. The value of SC[1 - 0] does not change until the first bit of the next data word is received. When the received data word is latched by RX, the latched values of SC[1 - 0] are latched by the SSISR IF[1 - 0] bits, respectively, and can be read by software.

When they are programmed as output flags, the value of the SC[1 - 0] bits is taken from the value of the OF[1 - 0] bits. The value of OF[1 - 0] is latched when the contents of TX transfer to the transmit shift register. The value on SC[1 - 0] is stable from the time the first bit of the transmit data word transmits until the first bit of the next transmit data word transmits. Software can directly set the OF[1 - 0] values, allowing the DSP56311 to control data transmission by indirectly controlling the value of the SC[1 - 0] flags.

# 7.5 ESSI Programming Model

The ESSI is composed of the following registers:

- Two control registers (CRA, CRB), page 7-14 and page 7-18
- One status register (SSISR), page 7-29
- One Receive Shift Register, **page 7-31**
- One Receive Data Register (RX), **page 7-31**
- Three Transmit Shift Registers, **page 7-31**
- Three Transmit Data Registers (TX0, TX1, TX2), page 7-31
- One special-purpose Time Slot Register (TSR), page 7-34
- Two Transmit Slot Mask Registers (TSMA, TSMB), page 7-34
- Two Receive Slot Mask Registers (RSMA, RSMB), page 7-35

This section discusses the ESSI registers and describes their bits. **Section 7.6**, "GPIO Signals and Registers," on page 7-36 covers ESSI GPIO.

# 7.5.1 ESSI Control Register A (CRA)

The ESSI Control Register A (CRA) is one of two 24-bit read/write control registers that direct the operation of the ESSI. CRA controls the ESSI clock generator bit and frame sync rates, word length, and number of words per frame for serial data.

| 23 | 22   | 21  | 20  | 19  | 18  | 17 | 16  | 15  | 14  | 13  | 12  |
|----|------|-----|-----|-----|-----|----|-----|-----|-----|-----|-----|
|    | SSC1 | WL2 | WL1 | WL0 | ALC |    | DC4 | DC3 | DC2 | DC1 | DC0 |
|    |      |     |     |     |     |    |     |     |     |     |     |
| 11 | 10   | 9   | 8   | 7   | 6   | 5  | 4   | 3   | 2   | 1   | 0   |

(ESSI0 X:\$FFFFB5, ESSI1 X:\$FFFFA5)

Figure 7-2. ESSI Control Register A(CRA)

| Table 7-3. | ESSI Control Register A (CRA) Bit Definitions |
|------------|-----------------------------------------------|
|------------|-----------------------------------------------|

| Bit Number | Bit Name | Reset Value | Description                                    |
|------------|----------|-------------|------------------------------------------------|
| 23         |          | 0           | Reserved. Write to 0 for future compatibility. |

| Table 7-3.         ESSI Control Register A (CRA) Bit Definitions (Continued) |
|------------------------------------------------------------------------------|
|------------------------------------------------------------------------------|

| Bit Number | Bit Name  | Reset Value | DescriptionSelect SC1Controls the functionality of the SC1 signal. If SSC1 is set, the ESSI is<br>configured in Synchronous mode (the CRB synchronous/asynchronous bit<br>(SYN) is set), and transmitter 2 is disabled (transmit enable (TE2) = 0), then<br>the SC1 signal acts as the transmitter 0 driver-enabled signal while the SC1<br>signal is configured as output (SCD1 = 1). This configuration enables an<br>external buffer for the transmitter 0 output. If SSC1 is cleared, the ESSI is<br>configured in Synchronous mode (SYN = 1), and transmitter 2 is disabled<br>(TE2 = 0), then the SC1 acts as the serial I/O flag while the SC1 signal is<br>configured as output (SCD1 = 1). |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     |                                            |  |  |  |  |  |
|------------|-----------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|--------------------------------------------|--|--|--|--|--|
| 22         | SSC1      | 0           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     |                                            |  |  |  |  |  |
| 21 – 19    | WL[2 – 0] | 0           | Select the len<br>of 8-, 12-, 16-<br>programming<br>information or<br>registers are<br>ways:<br>by du                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | <ul> <li>Word Length Control</li> <li>Select the length of the data words transferred via the ESSI. Word lengths of 8-, 12-, 16-, 24-, or 32-bits can be selected. The ESSI data path programming model in Figure 7-12 and Figure 7-13 shows additional information on how to select different lengths for data words. The ESSI data egisters are 24 bits long. The ESSI transmits 32-bit words in one of two ways:</li> <li>by duplicating the last bit 8 times when WL[2 - 0] = 100</li> <li>by duplicating the first bit 8 times when WL[2 - 0] = 101.</li> </ul> |     |                                            |  |  |  |  |  |
|            |           |             | of the 24-bit transmission eight times to fill the 32-bit shifter. Instead, after the 24-bit word is shifted correctly, eight zeros (0s) are shifted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     |                                            |  |  |  |  |  |
|            |           |             | ESSI Word Length Selection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     |                                            |  |  |  |  |  |
|            |           |             | WL2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | WL1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | WL0 | Number of Bits/Word                        |  |  |  |  |  |
|            |           |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0   | 8                                          |  |  |  |  |  |
|            |           |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1   | 12                                         |  |  |  |  |  |
|            |           |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0   | 16                                         |  |  |  |  |  |
|            |           |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1   | 24                                         |  |  |  |  |  |
|            |           |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0   | 32<br>(valid data in the first 24<br>bits) |  |  |  |  |  |
|            |           |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1   | 32<br>(valid data in the last 24<br>bits)  |  |  |  |  |  |
|            |           |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 0   | Reserved                                   |  |  |  |  |  |
|            |           |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 1   | Reserved                                   |  |  |  |  |  |
|            |           |             | NOTE: When the ESSI transmits data in On-Demand mode (that is, MOD 1 in the CRB and DC[4 – 0]=00000 in the CRA) with WL[2 – 0] = 100, the transmission does not work properly. To ensure correct operation, do not use On-Demand mode with the WL[2 – 0] = 100 32-bit word length mode.                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |     |                                            |  |  |  |  |  |

#### Table 7-3. ESSI Control Register A (CRA) Bit Definitions (Continued)

| Bit Number | Bit Name  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|-----------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18         | ALC       | 0           | Alignment Control<br>The ESSI handles 24-bit fractional data. Shorter data words are left-aligned<br>to the MSB, bit 23. For applications that use 16-bit fractional data, shorter<br>data words are left-aligned to bit 15. The ALC bit supports shorter data<br>words. If ALC is set, received words are left-aligned to bit 15 in the receive<br>shift register. Transmitted words must be left-aligned to bit 15 in the transmit<br>shift register. If the ALC bit is cleared, received words are left-aligned to bit<br>23 in the receive shift register. Transmitted words must be left-aligned to bit<br>23 in the transmit shift register.<br>NOTE: If the ALC bit is set, only 8-, 12-, or 16-bit words are used. The use<br>of 24- or 32-bit words leads to unpredictable results.                                                     |
| 17         |           |             | Reserved. Set to 0 for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 16 – 12    | DC[4 - 0] | 0           | <b>Frame Rate Divider Control</b><br>Control the divide ratio for the programmable frame rate dividers that<br>generate the frame clocks. In Network mode, this ratio is the number of<br>words per frame minus one. In Normal mode, this ratio determines the word<br>transfer rate. The divide ratio ranges from 1 to 32 (DC = 00000 to 11111) for<br>Normal mode and 2 to 32 (DC = 00001 to 11111) for Network mode. A<br>divide ratio of one (DC = 00000) in Network mode is a special case known<br>as On-Demand mode. In Normal mode, a divide ratio of one (DC = 00000)<br>provides continuous periodic data word transfers. A bit-length frame sync<br>must be used in this case; you select it by setting the FSL[1 – 0] bits in the<br>CRA to (01). <b>Figure 7-4</b> shows the ESSI frame sync generator functional<br>block diagram. |
| 11         | PSR       | 0           | Prescaler RangeControls a fixed divide-by-eight prescaler in series with the variableprescaler. This bit extends the range of the prescaler when a slower bitclock is needed. When PSR is set, the fixed prescaler is bypassed. WhenPSR is cleared, the fixed divide-by-eight prescaler is operational, as inFigure 7-3. This definition is reversed from that of the SSI in otherDSP56000 family members. The maximum allowed internally generated bitclock frequency is the internal DSP56311 clock frequency divided by 4; theminimum possible internally generated bit clock frequency is the DSP56311internal clock frequency divided by 4096.NOTE: The combination PSR = 1 and PM[7 - 0] = \$00 (dividing F <sub>core</sub> by 2)can cause synchronization problems and thus should not be used.                                           |
| 10 – 8     |           | 0           | Reserved. Set to 0 for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

#### Table 7-3. ESSI Control Register A (CRA) Bit Definitions (Continued)

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|----------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7 – 0      | РМ       | 0           | <b>Prescale Modulus Select</b><br>Specify the divide ratio of the prescale divider in the ESSI clock generator. A divide ratio from 1 to 256 (PM = $0 \text{ to }FF$ ) can be selected. The bit clock output is available at the transmit clock signal (SCK) and/or the receive clock (SC0) signal of the DSP. The bit clock output is also available internally for use as the bit clock to shift the transmit and receive shift registers. Figure 7-3 shows the ESSI clock generator functional block diagram. F <sub>core</sub> is the DSP56311 core clock frequency (the same frequency as the enabled CLKOUT signal). Careful choice of the crystal oscillator frequency and the prescaler modulus can generate the industry-standard CODEC master clock frequencies of 2.048 MHz, 1.544 MHz, and 1.536 MHz. |



Figure 7-3. ESSI Clock Generator Functional Block Diagram

#### Freescale Semiconductor, Inc.





## 7.5.2 ESSI Control Register B (CRB)

Control Register B (CRB) is one of two read/write control registers that direct the operation of the ESSI (see **Figure 7-5**). The CRB bit definitions are presented in **Table 7-4**. CRB controls the ESSI multifunction signals, SC[2 - 0], which can be used as clock inputs or outputs, frame synchronization signals, transmit data signals, or serial I/O flag signals.

| 23   | 22   | 21   | 20   | 19  | 18  | 17 | 16  | 15  | 14  | 13  | 12  |
|------|------|------|------|-----|-----|----|-----|-----|-----|-----|-----|
| REIE | TEIE | RLIE | TLIE | RIE | TIE | RE | TE0 | TE1 | TE2 | MOD | SYN |
|      |      |      |      |     |     |    |     |     |     |     |     |
| 11   | 10   | 9    | 8    | 7   | 6   | 5  | 4   | 3   | 2   | 1   | 0   |

(ESSI0 X:\$FFFFB6, ESSI1 X:\$FFFFA6)

Figure 7-5. ESSI Control Register B (CRB)

The CRB contains the serial output flag control bits and the direction control bits for the serial control signals. Also in the CRB are interrupt enable bits for the receiver and the transmitter. Bit settings of the CRB determines how many transmitters are enabled: 0, 1, 2,

or 3. The CRB settings also determine the ESSI operating mode. Either a hardware  $\overline{\text{RESET}}$  signal or a software RESET instruction clears all the bits in the CRB. **Table 7-2**, "Mode and Signal Definitions," on page 7-5 summarizes the relationship between the ESSI signals SC[2 – 0], SCK, and the CRB bits.

The ESSI has two serial output flag bits, OF1 and OF0. The normal sequence follows for setting output flags when transmitting data (by transmitter 0 through the STD signal only).

- **1.** Wait for TDE (TX0 empty) to be set.
- 2. Write the flags.
- **3.** Write the transmit data to the TX register.

Bits OF0 and OF1 are double-buffered so that the flag states appear on the signals when the TX data is transferred to the transmit shift register. The flag bit values are synchronized with the data transfer.

**Note:** The timing of the optional serial output signals SC[2 - 0] is controlled by the frame timing and is not affected by the settings of TE2, TE1, TE0, or the receive enable (RE) bit of the CRB.

The ESSI has three transmit enable bits (TE[2 - 0]), one for each data transmitter. The process of transmitting data from TX1 and TX2 is the same. TX0 differs from these two bits in that it can also operate in Asynchronous mode. The normal transmit enable sequence is to write data to one or more transmit data registers (or the time slot register (TSR)) before you set the TE bit. The normal transmit disable sequence is to set the transmit data empty (TDE) bit and then to clear the TE, transmit interrupt enable (TIE), and transmit exception interrupt enable (TEIE) bits. In Network mode, if you clear the appropriate TE bit and set it again, then you disable the corresponding transmitter (0, 1, or 2) after transmission of the current data word. The transmitter remains disabled until the beginning of the next frame. During that time period, the corresponding SC (or STD in the case of TX0) signal remains in a high-impedance state. The CRB bits are cleared by either a hardware RESET signal or a software RESET instruction.

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|----------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23         | REIE     | 0           | <b>Receive Exception Interrupt Enable</b><br>When the REIE bit is set, the DSP is interrupted when both RDF and<br>ROE in the ESSI status register are set. When REIE is cleared, this<br>interrupt is disabled. The receive interrupt is documented in <b>Section</b><br><b>7.3.3</b> , "Exceptions," on page 7-8. A read of the status register followed<br>by a read of the receive data register clears both ROE and the pending<br>interrupt. |

#### Table 7-4. ESSI Control Register B (CRB) Bit Definitions (Continued)

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|----------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22         | TEIE     | 0           | <b>Transmit Exception Interrupt Enable</b><br>When the TEIE bit is set, the DSP is interrupted when both TDE and<br>TUE in the ESSI status register are set. When TEIE is cleared, this<br>interrupt is disabled. The use of the transmit interrupt is documented<br>in <b>Section 7.3.3</b> , "Exceptions," on page 7-8. A read of the status<br>register, followed by a write to all the data registers of the enabled<br>transmitters, clears both TUE and the pending interrupt.                                                                                                                                                                                                                                                                                                            |
| 21         | RLIE     | 0           | <b>Receive Last Slot Interrupt Enable</b><br>Enables/disables an interrupt after the last slot of a frame ends when<br>the ESSI is in Network mode. When RLIE is set, the DSP is interrupted<br>after the last slot in a frame ends regardless of the receive mask register<br>setting. When RLIE is cleared, the receive last slot interrupt is disabled.<br>The use of the receive last slot interrupt is documented in <b>Section</b><br><b>7.3.3</b> , "Exceptions," on page 7-8. RLIE is disabled when the ESSI is in<br>On-Demand mode (DC = \$0).                                                                                                                                                                                                                                        |
| 20         | TLIE     | 0           | <b>Transmit Last Slot Interrupt Enable</b><br>Enables/disables an interrupt at the beginning of the last slot of a frame<br>when the ESSI is in Network mode. When TLIE is set, the DSP is<br>interrupted at the start of the last slot in a frame regardless of the<br>transmit mask register setting. When TLIE is cleared, the transmit last<br>slot interrupt is disabled. The transmit last slot interrupt is documented<br>in <b>Section 7.3.3</b> , "Exceptions," on page 7-8. TLIE is disabled when the<br>ESSI is in On-Demand mode (DC = \$0).                                                                                                                                                                                                                                        |
| 19         | RIE      | 0           | <b>Receive Interrupt Enable</b><br>Enables/disables a DSP receive data interrupt; the interrupt is<br>generated when both the RIE and receive data register full (RDF) bit (in<br>the SSISR) are set. When RIE is cleared, this interrupt is disabled. The<br>receive interrupt is documented in <b>Section 7.3.3</b> , "Exceptions," on page<br>7-8. When the receive data register is read, it clears RDF and the<br>pending interrupt. Receive interrupts with exception have higher priority<br>than normal receive data interrupts. If the receiver overrun error (ROE)<br>bit is set (signaling that an exception has occurred) and the REIE bit is<br>set, the ESSI requests an SSI receive data with exception interrupt from<br>the interrupt controller.                              |
| 18         | TIE      | 0           | Transmit Interrupt Enable<br>Enables/disables a DSP transmit interrupt; the interrupt is generated<br>when both the TIE and the TDE bits in the ESSI status register are set.<br>When TIE is cleared, the transmit interrupt is disabled. The transmit<br>interrupt is documented in <b>Section 7.3.3</b> . When data is written to the<br>data registers of the enabled transmitters or to the TSR, it clears TDE<br>and also clears the interrupt. Transmit interrupts with exception<br>conditions have higher priority than normal transmit data interrupts. If<br>the transmitter underrun error (TUE) bit is set (signaling that an<br>exception has occurred) and the TEIE bit is set, the ESSI requests an<br>SSI transmit data with exception interrupt from the interrupt controller. |

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|----------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17         | RE       | 0           | Receive Enable<br>Enables/disables the receive portion of the ESSI. When RE is cleared,<br>the receiver is disabled: data transfer into RX is inhibited. If data is being<br>received while this bit is cleared, the remainder of the word is shifted in<br>and transferred to the ESSI receive data register. RE must be set in<br>both Normal and On-Demand modes for the ESSI to receive data. In<br>Network mode, clearing RE and setting it again disables the receiver<br>after reception of the current data word. The receiver remains disabled<br>until the beginning of the next data frame.<br>NOTE: The setting of the RE bit does not affect the generation of a<br>frame sync.                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 16         | TEO      | 0           | Transmit 0 EnableEnables the transfer of data from TX1 to Transmit Shift Register 0. TE0is functional when the ESSI is in either synchronous or Asynchronousmode. When TE0 is set and a frame sync is detected, the transmitter 0is enabled for that frame.When TE0 is cleared, transmitter 0 is disabled after the transmission ofdata currently in the ESSI transmit shift register. The STD output istri-stated, and any data present in TX0 is not transmitted. In otherwords, data can be written to TX0 with TE0 cleared; the TDE bit iscleared, but data is not transferred to the transmit shift register 0. Thetransmit enable sequence in On-Demand mode can be the same as inNormal mode, or TE0 can be left enabled.NOTE: Transmitter 0 is the only transmitter that can operate inAsynchronous mode (SYN = 0). The setting of the TE0 bit does not                                                                                                                                                                                                                                                                    |
| 15         | TE1      | 0           | affect the generation of frame sync or output flags.<br><b>Transmit 1 Enable</b><br>Enables the transfer of data from TX1 to Transmit Shift Register 1. TE1<br>is functional only when the ESSI is in Synchronous mode and is ignored<br>when the ESSI is in Asynchronous mode. When TE1 is set and a frame<br>sync is detected, transmitter 1 is enabled for that frame.<br>When TE1 is cleared, transmitter 1 is disabled after completing<br>transmission of data currently in the ESSI transmit shift register. Any<br>data present in TX1 is not transmitted. If TE1 is cleared, data can be<br>written to TX1; the TDE bit is cleared, but data is not transferred to<br>transmit shift register 1. If the TE1 bit is kept cleared until the start of the<br>next frame, it causes the SC0 signal to act as serial I/O flag from the<br>start of the frame in both Normal and Network mode. The transmit<br>enable sequence in On-Demand mode can be the same as in Normal<br>mode, or the TE1 bit can be left enabled.<br>NOTE: The setting of the TE1 bit does not affect the generation of frame<br>sync or output flags. |

#### Table 7-4. ESSI Control Register B (CRB) Bit Definitions (Continued)

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|----------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14         | TE2      | 0           | <b>Transmit 2 Enable</b><br>Enables the transfer of data from TX2 to Transmit Shift Register 2. TE2<br>is functional only when the ESSI is in Synchronous mode and is ignored<br>when the ESSI is in Asynchronous mode. When TE2 is set and a frame<br>sync is detected, transmitter 2 is enabled for that frame.                                                                                                                                                                                                                                                                                                               |
|            |          |             | When TE2 is cleared, transmitter 2 is disabled after completing transmission of data currently in the ESSI transmit shift register. Any data present in TX2 is not transmitted. If TE2 is cleared, data can be written to TX2; the TDE bit is cleared, but data is not transferred to transmit shift register 2. If the TE2 bit is kept cleared until the start of the next frame, it causes the SC1 signal to act as a serial I/O flag from the start of the frame in both Normal mode and Network mode. The transmit enable sequence in On-Demand mode can be the same as in Normal mode, or the TE2 bit can be left enabled. |
|            |          |             | NOTE: The setting of the TE2 bit does not affect the generation of frame sync or output flags.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 13         | MOD      | 0           | <b>Mode Select</b><br>Selects the operational mode of the ESSI, as in <b>Figure 7-8</b> on page<br>7-27, <b>Figure 7-9</b> on page 7-28, and <b>Figure 7-10</b> on page 7-28. When<br>MOD is cleared, the Normal mode is selected; when MOD is set, the<br>Network mode is selected. In Normal mode, the frame rate divider<br>determines the word transfer rate: one word is transferred per frame<br>sync during the frame sync time slot. In Network mode, a word can be<br>transferred every time slot. For details, see <b>Section 7.3</b> .                                                                               |
| 12         | SYN      | 0           | Synchronous/Asynchronous<br>Controls whether the receive and transmit functions of the ESSI occur<br>synchronously or asynchronously with respect to each other. (See<br>Figure 7-7 on page 7-26.) When SYN is cleared, the ESSI is in<br>Asynchronous mode, and separate clock and frame sync signals are<br>used for the transmit and receive sections. When SYN is set, the ESSI<br>is in Synchronous mode, and the transmit and receive sections use<br>common clock and frame sync signals. Only in Synchronous mode can<br>more than one transmitter be enabled.                                                          |
| 11         | СКР      | 0           | <b>Clock Polarity</b><br>Controls which bit clock edge data and frame sync are clocked out and<br>latched in. If CKP is cleared, the data and the frame sync are clocked<br>out on the rising edge of the transmit bit clock and latched in on the<br>falling edge of the receive bit clock. If CKP is set, the data and the frame<br>sync are clocked out on the falling edge of the transmit bit clock and<br>latched in on the rising edge of the receive bit clock.                                                                                                                                                         |
| 10         | FSP      | 0           | <b>Frame Sync Polarity</b><br>Determines the polarity of the receive and transmit frame sync signals.<br>When FSP is cleared, the frame sync signal polarity is positive; that is,<br>the frame start is indicated by the frame sync signal going high. When<br>FSP is set, the frame sync signal polarity is negative; that is, the frame<br>start is indicated by the frame sync signal going low.                                                                                                                                                                                                                            |

| <b>Table 7-4.</b> ESSI Control Register B (CRB) Bit Definitions (Continued) |
|-----------------------------------------------------------------------------|
|-----------------------------------------------------------------------------|

| Bit Number | Bit Name   | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                                                                                                                                                                          |                                                                                                                                                                                    |                                                                                                                                                                                                           |  |  |
|------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 9          | FSR        | 0           | Frame Sync Relative Timing<br>Determines the relative timing of the receive and transmit frame sync<br>signal in reference to the serial data lines for word length frame sync<br>only. When FSR is cleared, the word length frame sync occurs together<br>with the first bit of the data word of the first slot. When FSR is set, the<br>word length frame sync occurs one serial clock cycle earlier (that is,<br>simultaneously with the last bit of the previous data word).                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                          |                                                                                                                                                                                    |                                                                                                                                                                                                           |  |  |
| 7 – 8      | FSL[1 – 0] | 0           | Frame Sync Length<br>Selects the length of frame sync to be generated or recognized, as in<br>Figure 7-6 on page 7-25, Figure 7-9 on page 7-28, and Figure 7-10 or<br>page 7-28.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                          |                                                                                                                                                                                    |                                                                                                                                                                                                           |  |  |
|            |            |             | FSL1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | FSL0                                                                                                                                                                                     | Frame                                                                                                                                                                              | Sync Length                                                                                                                                                                                               |  |  |
|            |            |             | FOLI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | FSLU                                                                                                                                                                                     | RX                                                                                                                                                                                 | ТΧ                                                                                                                                                                                                        |  |  |
|            |            |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0                                                                                                                                                                                        | word                                                                                                                                                                               | word                                                                                                                                                                                                      |  |  |
|            |            |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1                                                                                                                                                                                        | word                                                                                                                                                                               | bit                                                                                                                                                                                                       |  |  |
|            |            |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 0                                                                                                                                                                                        | bit                                                                                                                                                                                | bit                                                                                                                                                                                                       |  |  |
|            |            |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 1                                                                                                                                                                                        | bit                                                                                                                                                                                | word                                                                                                                                                                                                      |  |  |
| 6          | SHFD       | 0           | Shift Direction<br>Determines the shift direction of the transmit or receive shift register. If<br>SHFD is set, data is shifted in and out with the LSB first. If SHFD is<br>cleared, data is shifted in and out with the MSB first, as in Figure 7-12<br>on page 7-32 and Figure 7-13 on page 7-33.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                          |                                                                                                                                                                                    |                                                                                                                                                                                                           |  |  |
| 5          | SCKD       | 0           | Clock Source Direction<br>Selects the source of the clock signal that clocks the transmit shift<br>register in Asynchronous mode and both the transmit and receive shift<br>registers in Synchronous mode. If SCKD is set and the ESSI is in<br>Synchronous mode, the internal clock is the source of the clock signal<br>used for all the transmit shift registers and the receive shift register. If<br>SCKD is set and the ESSI is in Asynchronous mode, the internal clock<br>source becomes the bit clock for the transmit shift register and word<br>length divider. The internal clock is output on the SCK signal. When<br>SCKD is cleared, the external clock source is selected. The internal<br>clock generator is disconnected from the SCK signal, and an external<br>clock source may drive this signal. |                                                                                                                                                                                          |                                                                                                                                                                                    |                                                                                                                                                                                                           |  |  |
| 4          | SCD2       | 0           | an output; whe<br>NOTE: Progra<br>SCD2 = 1 in C<br>as outputs. Ho<br>programmed b<br>Port Direction<br>an external fra<br>either program<br>PCR as ESSI                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | irection of the sen SCD2 is clear<br>symming the ES<br>CRB) causes the<br>owever, if the c<br>by the Port Con<br>Register (PRR<br>ame sync if GPI<br>in the GPIO pine<br>signals. The de | ared, SC2 is an inp<br>SI to use an interna<br>e SC2 and SC1 sig<br>orresponding multij<br>trol Register (PCR)<br>chooses their dire<br>O is selected. To a<br>s as outputs or con | al frame sync (that is,<br>gnals to be programmed<br>plexed pins are<br>to be GPIOs, the GPIO<br>ection. The ESSI uses<br>ssure correct operation,<br>figure the pins in the<br>these signals after reset |  |  |

#### Table 7-4. ESSI Control Register B (CRB) Bit Definitions (Continued)

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                  |
|------------|----------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3          | SCD1     | 0           | Serial Control Direction 1<br>In Synchronous mode (SYN = 1) when transmitter 2 is disabled (TE2 = 0), or in Asynchronous mode (SYN = 0), SCD1 controls the direction of the SC1 I/O signal. When SCD1 is set, SC1 is an output; when SCD1 is cleared, SC1 is an input. When TE2 is set, the value of SCD1 is ignored and the SC1 signal is always an output. |
| 2          | SCD0     | 0           | Serial Control Direction 0<br>In Synchronous mode (SYN = 1) when transmitter 1 is disabled (TE1 = 0), or in Asynchronous mode (SYN = 0), SCD0 controls the direction of the SC0 I/O signal. When SCD0 is set, SC0 is an output; when SCD0 is cleared, SC0 is an input. When TE1 is set, the value of SCD0 is ignored and the SC0 signal is always an output. |
| 1          | OF1      | 0           | Serial Output Flag 1<br>In Synchronous mode (SYN = 1), when transmitter 2 is disabled (TE2 = 0), the SC1 signal is configured as ESSI flag 1. When SCD1 is set, SC1 is an output. Data present in bit OF1 is written to SC1 at the beginning of the frame in Normal mode or at the beginning of the next time slot in Network mode.                          |
| 0          | OF0      | 0           | Serial Output Flag 0<br>In Synchronous mode (SYN = 1), when transmitter 1 is disabled (TE1 = 0), the SC0 signal is configured as ESSI flag 0. When SCD0 is set, the SC0 signal is an output. Data present in Bit OF0 is written to SC0 at the beginning of the frame in Normal mode or at the beginning of the next time slot in Network mode.               |

#### Freescale Semiconductor, Inc.



Figure 7-6. CRB FSL0 and FSL1 Bit Operation (FSR = 0)



NOTE: Transmitter and receiver may have different clocks and frame syncs.



NOTE: Transmitter and receiver may have the same clock frame syncs.

Figure 7-7. CRB SYN Bit Operation



Figure 7-8. CRB MOD Bit Operation

Motorola



Figure 7-9. Normal Mode, External Frame Sync (8 Bit, 1 Word in Frame)



Figure 7-10. Network Mode, External Frame Sync (8 Bit, 2 Words in Frame)

### 7.5.3 ESSI Status Register (SSISR)

The SSISR is a 24-bit read-only status register by which the DSP reads the ESSI status and serial input flags.

| 23 | 22 | 21 | 20 | 19  | 18  | 17  | 16  | 15  | 14  | 13  | 12  |
|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|-----|
|    |    |    |    |     |     |     |     |     |     |     |     |
| 11 | 10 | 9  | 8  | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|    |    |    |    | RDF | TDE | ROE | TUE | RFS | TFS | IF1 | IF0 |

(ESSI0 X:\$FFFFB7, ESSI1 X:\$FFFFA7)

Figure 7-11. ESSI Status Register (SSISR)

| Table 7-5. | ESSI Status Register | (SSISR) Bit Definitions |
|------------|----------------------|-------------------------|
|            |                      |                         |

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|----------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23 – 8     |          | 0           | Reserved. Set to 0 for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 7          | RDF      | 0           | <b>Receive Data Register Full</b><br>Set when the contents of the receive shift register transfer to the receive<br>data register. RDF is cleared when the DSP reads the receive data<br>register. If RIE is set, a DSP receive data interrupt request is issued<br>when RDF is set.                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| 6          | TDE      | 0           | <b>Transmit Data Register Empty</b><br>Set when the contents of the transmit data register of every enabled<br>transmitter are transferred to the transmit shift register. It is also set for a<br>TSR disabled time slot period in Network mode (as if data were being<br>transmitted after the TSR has been written). When TDE is set, TDE data<br>is written to all the TX registers of the enabled transmitters or to the<br>TSR. The TDE bit is cleared when the DSP writes to all the transmit<br>data registers of the enabled transmitters, or when the DSP writes to the<br>TSR to disable transmission of the next time slot. If the TIE bit is set, a<br>DSP transmit data interrupt request is issued when TDE is set. |
| 5          | ROE      | 0           | <b>Receiver Overrun Error Flag</b><br>Set when the serial receive shift register is filled and ready to transfer to<br>the receive data register (RX) but RX is already full (that is, the RDF bit<br>is set). If the REIE bit is set, a DSP receiver overrun error interrupt<br>request is issued when the ROE bit is set. The programmer clears ROE<br>by reading the SSISR with the ROE bit set and then reading the RX.                                                                                                                                                                                                                                                                                                        |

### Table 7-5. ESSI Status Register (SSISR) Bit Definitions (Continued)

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------|----------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | TUE      | 0           | <b>Transmitter Underrun Error Flag</b><br>TUE is set when at least one of the enabled serial transmit shift registers<br>is empty (that is, there is no new data to be transmitted) and a transmit<br>time slot occurs. When a transmit underrun error occurs, the previous<br>data (which is still present in the TX registers not written) is<br>retransmitted. In Normal mode, there is only one transmit time slot per<br>frame. In Network mode, there can be up to 32 transmit time slots per<br>frame. If the TEIE bit is set, a DSP transmit underrun error interrupt<br>request is issued when the TUE bit is set. The programmer can also<br>clear TUE by first reading the SSISR with the TUE bit set, then writing to<br>all the enabled transmit data registers or to the TSR. |
| 3          | RFS      | 0           | <b>Receive Frame Sync Flag</b><br>When set, the RFS bit indicates that a receive frame sync occurred<br>during the reception of a word in the serial receive data register. In other<br>words, the data word is from the first time slot in the frame. When the<br>RFS bit is cleared and a word is received, it indicates (only in Network<br>mode) that the frame sync did not occur during reception of that word.<br>RFS is valid only if the receiver is enabled (that is , if the RE bit is set).<br>NOTE: In Normal mode, RFS is always read as 1 when data is read<br>because there is only one time slot per frame, the frame sync time slot.                                                                                                                                      |
| 2          | TFS      | 0           | Transmit Frame Sync Flag<br>When set, TFS indicates that a transmit frame sync occurred in the<br>current time slot. TFS is set at the start of the first time slot in the frame<br>and cleared during all other time slots. If the transmitter is enabled, data<br>written to a transmit data register during the time slot when TFS is set is<br>transmitted (in Network mode) during the second time slot in the frame.<br>TFS is useful in Network mode to identify the start of a frame. TFS is<br>valid only if at least one transmitter is enabled that is, when TE0, TE1, or<br>TE2 is set).<br>NOTE: In Normal mode, TFS is always read as 1 when data is being<br>transmitted because there is only one time slot per frame, the frame<br>sync time slot.                         |
| 1          | IF1      | 0           | <b>Serial Input Flag 1</b><br>The ESSI latches any data on the SC1 signal during reception of the<br>first received bit after the frame sync is detected. IF1 is updated with this<br>data when the data in the receive shift register transfers into the receive<br>data register. IF1 is enabled only when SC1 is an input flag and<br>Synchronous mode is selected; that is, when SC1 is programmed as<br>ESSI in the port control register (PCR), the SYN bit is set, and the TE2<br>and SCD1 bits are cleared. If it is not enabled, IF1 is cleared.                                                                                                                                                                                                                                   |
| 0          | IF0      | 0           | Serial Input Flag 0<br>The ESSI latches any data on the SC0 signal during reception of the<br>first received bit after the frame sync is detected. The IF0 bit is updated<br>with this data when the data in the receive shift register transfers into the<br>receive data register. IF0 is enabled only when SC0 is an input flag and<br>the Synchronous mode is selected; that is, when SC0 is programmed as<br>ESSI in the port control register (PCR), the SYN bit is set, and the TE1<br>and SCD0 bits are cleared. If it is not enabled, the IF0 bit is cleared.                                                                                                                                                                                                                      |

#### 7.5.4 ESSI Receive Shift Register

The 24-bit Receive Shift Register (see **Figure 7-12** and **Figure 7-13**) receives incoming data from the serial receive data signal. The selected (internal/external) bit clock shifts data in when the associated frame sync I/O is asserted. Data is received MSB first if SHFD is cleared and LSB first if SHFD is set. Data transfers to the ESSI receive data register after 8, 12, 16, 24, or 32 serial clock cycles are counted, depending on the word length control bits in the CRA.

### 7.5.5 ESSI Receive Data Register (RX)

The Receive Data Register (RX) is a 24-bit read-only register that accepts data from the receive shift register as it becomes full, according to **Figure 7-12** and **Figure 7-13**. The data read is aligned according to the value of the ALC bit. When the ALC bit is cleared, the MSB is bit 23, and the least significant byte is unused. When the ALC bit is set, the MSB is bit 15, and the most significant byte is unused. Unused bits are read as 0. If the associated interrupt is enabled, the DSP is interrupted whenever the RX register becomes full.

### 7.5.6 ESSI Transmit Shift Registers

The three 24-bit transmit shift registers contain the data being transmitted, as in **Figure 7-12** and **Figure 7-13**. Data is shifted out to the serial transmit data signals by the selected (whether internal or external) bit clock when the associated frame sync I/O is asserted. The word-length control bits in CRA determine the number of bits that must be shifted out before the shift registers are considered empty and can be written again. Depending on the setting of the CRA, the number of bits to be shifted out can be 8, 12, 16, 24, or 32.

Transmitted data is aligned according to the value of the ALC bit. When ALC is cleared, the MSB is Bit 23 and the least significant byte is unused. When ALC is set, the MSB is Bit 15 and the most significant byte is unused. Unused bits are read as 0. Data shifts out of these registers MSB first if the SHFD bit is cleared and LSB first if SHFD is set.









### 7.5.7 ESSI Transmit Data Registers (TX[2 – 0])

#### ESSI0:TX20, TX10, TX00; ESSI1:TX21, TX11, TX01

TX2, TX1, and TX0 are 24-bit write-only registers. Data written into these registers automatically transfers to the transmit shift registers. (See **Figure 7-12** and **Figure 7-13**.) The data transmitted (8, 12, 16, or 24 bits) is aligned according to the value of the ALC bit. When the ALC bit is cleared, the MSB is Bit 23. When ALC is set, the MSB is Bit 15. If the transmit data register empty interrupt has been enabled, the DSP is interrupted whenever a transmit data register becomes empty.

**Note:** When data is written to a peripheral device, there is a two-cycle pipeline delay while any status bits affected by this operation are updated. If any of those status bits are read during the two-cycle delay, the status bit may not reflect the current status. For details, see the *DSP56300 Family Manual*, "**Appendix B**, Polling a Peripheral Device for Write."

### 7.5.8 ESSI Time Slot Register (TSR)

TSR is effectively a write-only null data register that prevents data transmission in the current transmit time slot. For timing purposes, TSR is a write-only register that behaves as an alternative transmit data register, except that, rather than transmitting data, the transmit data signals of all the enabled transmitters are in the high-impedance state for the current time slot.

### 7.5.9 Transmit Slot Mask Registers (TSMA, TSMB)

Both transmit slot mask registers are read/write registers. When the TSMA or TSMB is read to the internal data bus, the register contents occupy the two low-order bytes of the data bus, and the high-order byte is filled by 0. In Network mode the transmitter(s) use these registers to determine which action to take in the current transmission slot. Depending on the bit settings, the transmitter(s) either tri-state the transmitter(s) data signal(s) or transmit a data word and generate a transmitter empty condition.

| 23   | 22   | 21     | 20    | 19          | 18       | 17          | 16   | 15      | 14   | 13   | 12   |
|------|------|--------|-------|-------------|----------|-------------|------|---------|------|------|------|
|      |      |        |       |             |          |             |      | TS15    | TS14 | TS13 | TS12 |
|      |      |        |       |             |          |             |      |         |      |      |      |
| 11   | 10   | 9      | 8     | 7           | 6        | 5           | 4    | 3       | 2    | 1    | 0    |
| TS11 | TS10 | TS9    | TS8   | TS7         | TS6      | TS5         | TS4  | TS3     | TS2  | TS1  | TS0  |
|      |      |        | (ESS  | SIO X:\$FFF | FB4, ESS | SI1 X:\$FFF | FA4) |         |      |      |      |
|      |      | Figure | 7 4 4 |             | ronomit  |             |      | inter A |      |      |      |



| 23         | 22                | 21               | 20               | 19               | 18               | 17               | 16               | 15               | 14               | 13        | 12               |
|------------|-------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|-----------|------------------|
|            |                   |                  |                  |                  |                  |                  |                  | TS31             | TS30             | TS29      | TS28             |
|            |                   |                  |                  |                  |                  |                  |                  |                  |                  |           |                  |
|            |                   |                  |                  |                  |                  |                  |                  |                  |                  |           |                  |
| 11         | 10                | 9                | 8                | 7                | 6                | 5                | 4                | 3                | 2                | 1         | 0                |
| 11<br>TS27 | <b>10</b><br>TS26 | <b>9</b><br>TS25 | <b>8</b><br>TS24 | <b>7</b><br>TS23 | <b>6</b><br>TS22 | <b>5</b><br>TS21 | <b>4</b><br>TS20 | <b>3</b><br>TS19 | <b>2</b><br>TS18 | 1<br>TS17 | <b>0</b><br>TS16 |

Figure 7-15. ESSI Transmit Slot Mask Register B (TSMB)

TSMA and TSMB (as in **Figure 7-12** and **Figure 7-13**) can be seen as a single 32-bit register, TSM. Bit n in TSM (TSn) is an enable/disable control bit for transmission in slot number N. When TSn is cleared, all the data signals of the enabled transmitters are tri-stated during transmit time slot number N. The data still transfers from the enabled transmit data register(s) to the transmit shift register. However, the TDE and the TUE flags are not set. Consequently, during a disabled slot, no transmitter empty interrupt is generated. The DSP is interrupted only for enabled slots. Data written to the transmit data register when the transmitter empty interrupt request is serviced transmits in the next enabled transmit time slot. When TSn is set, the transmit sequence proceeds normally. Data transfers from the TX register to the shift register during slot number N, and the TDE flag is set.

The TSM slot mask does not conflict with the TSR. Even if a slot is enabled in the TSM, you can chose to write to the TSR to tri-state the signals of the enabled transmitters during the next transmission slot. Setting the bits in the TSM affects the next frame transmission. The frame being transmitted is not affected by the new TSM setting. If the TSM is read, it shows the current setting.

After a hardware RESET signal or software RESET instruction, the TSM register is reset to \$FFFFFFF, enabling all 32 slots for data transmission.

### 7.5.10 Receive Slot Mask Registers (RSMA, RSMB)

Both receive slot mask registers are read/write registers. In Network mode, the receiver(s) use these registers to determine which action to take in the current time slot. Depending on the setting of the bits, the receiver(s) either tri-state the receiver(s) data signal(s) or receive a data word and generate a receiver full condition.

| 23         | 22                | 21              | 20              | 19              | 18              | 17              | 16              | 15              | 14              | 13              | 12       |
|------------|-------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|----------|
|            |                   |                 |                 |                 |                 |                 |                 | RS15            | RS14            | RS13            | RS12     |
|            |                   |                 |                 |                 |                 |                 |                 |                 |                 |                 |          |
|            |                   |                 |                 |                 |                 |                 |                 |                 |                 |                 |          |
| 11         | 10                | 9               | 8               | 7               | 6               | 5               | 4               | 3               | 2               | 1               | 0        |
| 11<br>RS11 | <b>10</b><br>RS10 | <b>9</b><br>RS9 | <b>8</b><br>RS8 | <b>7</b><br>RS7 | <b>6</b><br>RS6 | <b>5</b><br>RS5 | <b>4</b><br>RS4 | <b>3</b><br>RS3 | <b>2</b><br>RS2 | <b>1</b><br>RS1 | 0<br>RS0 |



| 23         | 22         | 21               | 20               | 19        | 18        | 17        | 16               | 15               | 14               | 13               | 12               |
|------------|------------|------------------|------------------|-----------|-----------|-----------|------------------|------------------|------------------|------------------|------------------|
|            |            |                  |                  |           |           |           |                  | RS31             | RS30             | RS29             | RS28             |
|            |            |                  |                  |           |           |           |                  |                  |                  |                  |                  |
|            |            |                  |                  |           |           |           |                  |                  |                  |                  |                  |
| 11         | 10         | 9                | 8                | 7         | 6         | 5         | 4                | 3                | 2                | 1                | 0                |
| 11<br>RS27 | 10<br>RS26 | <b>9</b><br>RS25 | <b>8</b><br>RS24 | 7<br>RS23 | 6<br>RS22 | 5<br>RS21 | <b>4</b><br>RS20 | <b>3</b><br>RS19 | <b>2</b><br>RS18 | <b>1</b><br>RS17 | <b>0</b><br>RS16 |

(ESSI0 X:\$FFFFB1, ESSI1 X:\$FFFFA1)

RSMA and RSMB (as in **Figure 7-12** and **Figure 7-13**) can be seen as one 32-bit register, RSM. Bit n in RSM (RSn) is an enable/disable control bit for time slot number N. When RSn is cleared, all the data signals of the enabled receivers are tri-stated during time slot number N. Data transfers from the receive data register(s) to the receive shift register(s), but the RDF and ROE flags are not set. Consequently, during a disabled slot, no receiver full interrupt is generated. The DSP is interrupted only for enabled slots. When RSn is set, the receive sequence proceeds normally. Data is received during slot number N, and the RDF flag is set.

When the bits in the RSM are set, their setting affects the next frame transmission. The frame being transmitted is not affected by the new RSM setting. If the RSM is read, it shows the current setting.

When RSMA or RSMB is read by the internal data bus, the register contents occupy the two low-order bytes of the data bus, and the high-order byte is filled by 0.

After a hardware RESET signal or a software RESET instruction, the RSM register is reset to \$FFFFFFFF, enabling all 32 time slots for data transmission.

# 7.6 GPIO Signals and Registers

The GPIO functionality of an ESSI port (whether C or D) is controlled by three registers: port control register (PCRC, PCRD), port direction register (PRRC, PRRD), and port data register (PDRC, PDRD).

## 7.6.1 Port Control Register (PCR)

The read/write 24-bit PCR controls the functionality of the ESSI GPIO signals. Each of the PC[5-0] bits controls the functionality of the corresponding port signal. When a PC[i] bit is set, the corresponding port signal is configured as an ESSI signal. When a PC[i] bit is cleared, the corresponding port signal is configured as a GPIO signal. Either a hardware RESET signal or a software RESET instruction clears all PCR bits.

Figure 7-17. ESSI Receive Slot Mask Register B (RSMB)



Reserved. Read as zero. Write with zero for future compatibility.

Figure 7-18. Port Control Register (PCR) (PCRC X:\$FFFFBF) (PCRD X:\$FFFAF)

### 7.6.2 Port Direction Register (PRR)

The read/write 24-bit PRR controls the data direction of the ESSI GPIO signals. When PRR[i] is set, the corresponding signal is an output signal. When PRR[i] is cleared, the corresponding signal is an input signal. Either a hardware RESET signal or a software RESET instruction clears all PRR bits.



Reserved. Read as zero. Write with zero for future compatibility.



The following table shows the port signal configurations.

| PC[i]         | PDC[i]            | Port Signal[i] Function               |
|---------------|-------------------|---------------------------------------|
| 1             | Х                 | ESSI                                  |
| 0             | 0                 | GPIO input                            |
| 0             | 1                 | GPIO output                           |
| X: The signal | setting is irrele | evant to the Port Signal[i] function. |

### 7.6.3 Port Data Register (PDR)

The read/write 24-bit PDR reads or writes data to and from the ESSI GPIO signals. The PD[5 - 0] bits read or write data from and to the corresponding port signals if they are configured as GPIO signals. If a port signal [i] is configured as a GPIO input, the corresponding PD[i] bit reflects the value present on this signal. If a port signal [i] is configured as a GPIO output, the value written into the corresponding PD[i] bit is reflected on this signal. Either a hardware  $\overline{RESET}$  signal or a software RESET instruction clears all PDR bits.



Figure 7-20. Port Data Register (PDR) (PDRC X:\$FFFFBD) (PDRD X: \$FFFFAD)

# **Chapter 8** Serial Communication Interface (SCI)

The DSP56311 Serial Communication Interface (SCI) provides a full-duplex port for serial communication with other DSPs, microprocessors, or peripherals such as modems. The SCI interfaces without additional logic to peripherals that use TTL-level signals. With a small amount of additional logic, the SCI can connect to peripheral interfaces that have non-TTL level signals, such as RS232C, RS422, and so on. This interface uses three dedicated signals: transmit data, receive data, and SCI serial clock. It supports industry-standard asynchronous bit rates and protocols, as well as high-speed synchronous data transmission (up to 8.25 Mbps for a 66 MHz clock). SCI asynchronous protocols include a multidrop mode for master/slave operation with wake-up on idle line and wake-up on address bit capability. This mode allows the DSP56311 to share a single serial line efficiently with other peripherals.

The SCI consists of separate transmit and receive sections that can operate asynchronously with respect to each other. A programmable baud rate generator supplies the transmit and receive clocks. An enable vector and an interrupt vector are included so that the baud-rate generator can function as a general-purpose timer when the SCI is not using it, or when the interrupt timing is the same as that used by the SCI.

# 8.1 Operating Modes

The operating modes for the DSP56311 SCI are as follows:

- 8-bit synchronous (shift register mode)
- 10-bit asynchronous (1 start, 8 data, 1 stop)
- 11-bit asynchronous (1 start, 8 data, 1 even parity, 1 stop)
- 11-bit asynchronous (1 start, 8 data, 1 odd parity, 1 stop)
- 11-bit multidrop asynchronous (1 start, 8 data, 1 data type, 1 stop) This mode is used for master/slave operation with wake-up on idle line and wakeup on address bit capability. It allows the DSP56311 to share a single serial line efficiently with other peripherals.

These modes are selected by the SCR WD[0-2] bits. Synchronous data mode is essentially a high-speed shift register for I/O expansion and stream-mode channel

**Operating Modes** 

interfaces. A gated transmit and receive clock compatible with the Intel 8051 serial interface mode 0 synchronizes data. Asynchronous modes are compatible with most UART-type serial devices. Standard RS232C communication links are supported by these modes. Multidrop Asynchronous mode is compatible with the MC68681 DUART, the M68HC11 SCI interface, and the Intel 8051 serial interface.

#### 8.1.1 Synchronous Mode

Synchronous mode (WDS=0, Shift Register mode) handles serial-to-parallel and parallel-to-serial conversions. In Synchronous mode, the clock is always common to the transmit and receive shift registers. As a controller (synchronous master), the DSP puts out a clock on the SCLK pin. To select master mode, choose the internal transmit and receive clocks (set TCM and RCM=0).

As a peripheral (synchronous slave), the DSP accepts an input clock from the SCLK pin. To select the slave mode, choose the external transmit and receive clocks (TCM and RCM=1). Since there is no frame signal, if a clock is missed because of noise or any other reason, the receiver loses synchronization with the data without any error signal being generated. You can detect an error of this type with an error detecting protocol or with external circuitry such as a watchdog timer. The simplest way to recover synchronization is to reset the SCI.

### 8.1.2 Asynchronous Mode

Asynchronous data uses a data format with embedded word sync, which allows an unsynchronized data clock to be synchronized with the word if the clock rate and number of bits per word is known. Thus, the clock can be generated by the receiver rather than requiring a separate clock signal. The transmitter and receiver both use an internal clock that is  $16 \times$  the data rate to allow the SCI to synchronize the data. The data format requires that each data byte have an additional start bit and stop bit. Also, two of the word formats have a parity bit. The Multidrop mode used when SCIs are on a common bus has an additional data type bit. The SCI can operate in full-duplex or half-duplex modes since the transmitter and receiver are independent.

### 8.1.3 Multidrop Mode

Multidrop is a special case of asynchronous data transfer. The key difference is that a protocol allows networking transmitters and receivers on a single data-transmission line. Inter-processor messages in a multidrop network typically begin with a destination address. All receivers check for an address match at the start of each message. Receivers with no address match can ignore the remainder of the message and use a wakeup mode to enable the receiver at the start of the next message. Receivers with an address match can

receive the message and optionally transmit an acknowledgment to the sender. The particular message format and protocol used are determined by the user's software.

#### 8.1.3.1 Transmitting Data and Address Characters

To send data, the 8-bit data character must be written to the STX register. Writing the data character to the STX register sets the ninth bit in the frame to zero, which indicates that this frame contains data. To send an 8-bit address, the address data is written to the STXA register, and the ninth bit in the frame is set to one, indicating that this frame contains an address.

#### 8.1.3.2 Wired-OR Mode

Building a multidrop bus network requires connecting multiple transmitters to a common wire. The Wired-OR mode allows this to be done without damaging the transmitters when the transmitters are not in use. A protocol is still needed to prevent two transmitters from simultaneously driving the bus. The SCI multidrop word format provides an address field to support this protocol.

#### 8.1.3.3 Idle Line Wakeup

A wakeup mode frees a DSP from reading messages intended for other processors. The usual operational procedure is for each DSP to suspend SCI reception (the DSP can continue processing) until the beginning of a message. Each DSP compares the address in the message header with the DSP's address. If the addresses do not match, the SCI again suspends reception until the next address. If the address matches, the DSP reads and processes the message and then suspends reception until the next address. The Idle Line Wakeup mode wakes up the SCI to read a message before the first character arrives.

#### 8.1.3.4 Address Mode Wakeup

The purpose and basic operational procedure for Address Mode Wakeup is the same as for Idle Line Wakeup. The difference is that Address Mode Wakeup re-enables the SCI when the ninth bit in a character is set to one (if cleared, this bit marks a character as data; if set, an address). As a result, an idle line is not needed, which eliminates the dead time between messages.

# 8.2 I/O Signals

Each of the three SCI signals (RXD, TXD, and SCLK) can be configured as either a GPIO signal or as a specific SCI signal. Each signal is independent of the others. For example, if only the TXD signal is needed, the RXD and SCLK signals can be programmed for GPIO. However, at least one of the three signals must be selected as an SCI signal to release the SCI from reset.

To enable SCI interrupts, program the SCI control registers before any of the SCI signals are programmed as SCI functions. In this case, only one transmit interrupt can be generated because the Transmit Data Register is empty. The timer and timer interrupt operate regardless of how the SCI pins are configured, either as SCI or GPIO.

### 8.2.1 Receive Data (RXD)

This input signal receives byte-oriented serial data and transfers the data to the SCI receive shift register. Asynchronous input data is sampled on the positive edge of the receive clock ( $1 \times SCLK$ ) if the SCI Clock Polarity (SCKP) bit is cleared. RXD can be configured as a GPIO signal (PE0) when the SCI RXD function is not in use.

### 8.2.2 Transmit Data (TXD)

This output signal transmits serial data from the SCI transmit shift register. Data changes on the negative edge of the asynchronous transmit clock (SCLK) if SCKP is cleared. This output is stable on the positive edge of the transmit clock. TXD can be programmed as a GPIO signal (PE1) when the SCI TXD function is not in use.

### 8.2.3 SCI Serial Clock (SCLK)

This bidirectional signal provides an input or output clock from which the transmit and/or receive baud rate is derived in Asynchronous mode and from which data is transferred in Synchronous mode. SCLK can be programmed as a GPIO signal (PE2) when the SCI SCLK function is not in use. This signal can be programmed as PE2 when data is being transmitted on TXD, since the clock does not need to be transmitted in Asynchronous mode. Because SCLK is independent of SCI data I/O, there is no connection between programming the PE2 signal as SCLK and data coming out the TXD signal.

## 8.3 SCI After Reset

There are several different ways to reset the SCI:

- Hardware RESET signal
- Software RESET instruction:

Both hardware and software resets clear the port control register bits, which configure all I/O as GPIO input. The SCI remains in the Reset state as long as all SCI signals are programmed as GPIO (PC2, PC1, and PC0 all are cleared); the SCI becomes active only when at least one of the SCI I/O signals is not programmed as GPIO.

#### Individual reset:

During program execution, the PC2, PC1, and PC0 bits can all be cleared (that is, individually reset), causing the SCI to stop serial activity and enter the Reset state. All SCI status bits are set to their reset state. However, the contents of the SCR remain unaffected so the DSP program can reset the SCI separately from the other internal peripherals. During individual reset, internal DMA accesses to the data registers of the SCI are not valid, and the data is unknown.

Stop processing state reset (that is, the STOP instruction) Executing the STOP instruction halts operation of the SCI until the DSP is restarted, causing the SCI Status Register (SSR) to be reset. No other SCI registers are affected by the STOP instruction.

**Table 8-1** illustrates how each type of reset affects each register in the SCI.

| Register | Bit Mnemonic | Bit Number       |          | Reset    | Туре     |          |
|----------|--------------|------------------|----------|----------|----------|----------|
| Register | Bit Whemonic | Bit Number       | HW Reset | SW Reset | IR Reset | ST Reset |
|          | REIE         | 16               | 0        | 0        | —        | _        |
|          | SCKP         | 15               | 0        | 0        | —        | —        |
|          | STIR         | 14               | 0        | 0        | —        | —        |
|          | TMIE         | 13               | 0        | 0        | —        | _        |
|          | TIE          | 12               | 0        | 0        | —        | _        |
|          | RIE          | 11               | 0        | 0        | —        | _        |
|          | ILIE         | 10               | 0        | 0        | —        | _        |
|          | TE           | 9                | 0        | 0        | —        | _        |
| SCR      | RE           | 8                | 0        | 0        | _        | _        |
|          | WOMS         | 7                | 0        | 0        | _        | _        |
|          | RWU          | 6                | 0        | 0        | _        | _        |
|          | WAKE         | 5                | 0        | 0        | _        | _        |
|          | SBK          | 4                | 0        | 0        | _        | _        |
|          | SSFTD        | 3                | 0        | 0        | _        | _        |
|          | WDS[2 – 0]   | 2–0              | 0        | 0        | _        | _        |
| SSR      | R8           | 7                | 0        | 0        | 0        | 0        |
|          | FE           | 6                | 0        | 0        | 0        | 0        |
|          | PE           | 5                | 0        | 0        | 0        | 0        |
|          | OR           | 4                | 0        | 0        | 0        | 0        |
|          | IDLE         | 3                | 0        | 0        | 0        | 0        |
|          | RDRF         | 2                | 0        | 0        | 0        | 0        |
|          | TDRE         | 1                | 1        | 1        | 1        | 1        |
|          | TRNE         | 0                | 1        | 1        | 1        | 1        |
|          | TCM          | 15               | 0        | 0        | —        | —        |
|          | RCM          | 14               | 0        | 0        | —        | —        |
| SCCR     | SCP          | 13               | 0        | 0        | —        | —        |
|          | COD          | 12               | 0        | 0        | —        | —        |
|          | CD[11 – 0]   | 11–0             | 0        | 0        | —        | —        |
| SRX      | SRX [23 – 0] | 23–16, 15–8, 7–0 | —        | _        | —        | —        |
| STX      | STX[23-0]    | 23–0             | —        | _        | —        | —        |

 Table 8-1.
 SCI Registers After Reset

| Bog  | lister    | Bit Mnemonic              | Bit Number                 | Reset Type     |          |          |          |  |  |
|------|-----------|---------------------------|----------------------------|----------------|----------|----------|----------|--|--|
| Reg  | ISLEI     | Bit Whenonic              | Bit Nulliber               | HW Reset SW    |          | IR Reset | ST Reset |  |  |
| SR   | RSH       | SRS[8 – 0]                | 8–0                        | —              |          | —        | —        |  |  |
| ST   | SH        | STS[8 – 0]                | 8–0                        |                | _        | —        | _        |  |  |
| SRSH | SCI rece  | eive shift register, STSI | I — SCI transmit shift reg | gister         |          |          |          |  |  |
| HW   | Hardwa    | re reset is caused by a   | sserting the external RES  | SET signal.    |          |          |          |  |  |
| SW   | Software  | e reset is caused by ex   | ecuting the RESET instru   | iction.        |          |          |          |  |  |
| IR   | Individua | al reset is caused by cl  | earing PCRE (bits 0-2) (d  | configured for | r GPIO). |          |          |  |  |
| ST   | Stop res  | set is caused by execut   | ing the STOP instruction.  |                |          |          |          |  |  |
| 1    | The bit i | s set during this reset.  | -                          |                |          |          |          |  |  |
| 0    | The bit i | s cleared during this re  | set.                       |                |          |          |          |  |  |
| —    | The bit i | s not changed during tl   | nis reset.                 |                |          |          |          |  |  |

Table 8-1. SCI Registers After Reset (Continued)

# 8.4 SCI Initialization

The SCI is initialized as follows:

- **1.** Ensure that the SCI is in its individual reset state (PCRE = \$0). Use a hardware RESET signal or software RESET instruction.
- 2. Program the SCI control registers.
- **3.** Configure at least one SCI signal as and SCI signal.

If interrupts are to be used, the signals must be selected, and global interrupts must be enabled and unmasked before the SCI can operate. The order does not matter; any one of these three requirements for interrupts can enable the SCI, but the interrupts should be unmasked last (that is, I[1 - 0] bits in the Status Register (SR) should be changed last). Synchronous applications usually require exact frequencies, so the crystal frequency must be chosen carefully. An alternative to selecting the system clock to accommodate the SCI requirements is to provide an external clock to the SCI. When the SCI is configured in Synchronous mode, internal clock, and all the SCI pins are simultaneously enabled, an extra pulse of one DSP clock length is provided on the SCLK pin. There are two workarounds for this issue:

- Enable an SCI pin other than SCLK.
- In the next instruction, enable the remaining SCI pins, including the SCLK pin.

Following is an example of one way to initialize the SCI:

- **1.** Ensure that the SCI is in its individual reset state (PCRE = \$0).
- 2. Configure the control registers (SCR, SCCR) according to the operating mode, but do not enable transmitter (TE = 0) or receiver (RE = 0).

It is now possible to set the interrupts enable bits that are used during the operation. No interrupt occurs yet.

- **3.** Enable the SCI by setting the PCRE bits according to which signals are used during operation.
- 4. If transmit interrupt is not used, write data to the transmitter.

If transmitter interrupt enable is set, an interrupt is issued and the interrupt handler should write data into the transmitter. The DMA channel services the SCI transmit request if it is programmed to service the SCI transmitter.

**5.** Enable transmitters (TE = 1) and receiver (RE = 1) according to use.

Operation starts as follows:

- For an internally-generated clock, the SCLK signal starts operation immediately after the SCI is enabled (Step 3 above) for Asynchronous modes. In Synchronous mode, the SCLK signal is active only while transmitting (that is, a gated clock).
- Data is received only when the receiver is enabled (RE = 1) and after the occurrence of the SCI receive sequence on the RXD signal, as defined by the operating mode (that is, idle line sequence).
- Data is transmitted only after the transmitter is enabled (TE = 1), and after the initialization sequence has been transmitted (depending on the operating mode).

### 8.4.1 Preamble, Break, and Data Transmission Priority

Two or three transmission commands can be set simultaneously:

- A preamble (TE is set.)
- A break (SBK is set or is cleared.)
- An indication that there is data for transmission (TDRE is cleared.)

After the current character transmission, if two or more of these commands are set, the transmitter executes them in the following order: preamble, break, data.

## **8.4.2** Bootstrap Loading Through the SCI (Operating Mode 6)

When the DSP comes out of reset, it checks the MODD, MODC, MODB, and MODA pins and sets the corresponding mode bits in the Operating Mode Register (OMR). If the mode bits are set to 1010, respectively, the DSP loads the program RAM from the SCI.

**Appendix A,** *Bootstrap Program* shows the complete bootstrap code. This program (1) configures the SCI, (2) loads the program size, (3) loads the location where the program begins loading in program memory, and (4) loads the program.

First, the SCI Control Register is set to \$0302, which enables the transmitter and receiver and configures the SCI for 10 bits asynchronous with one start bit, 8 data bits, one stop bit, and no parity. Next, the SCI Clock Control Register is set to \$C000, which configures the

SCI to use external receive and transmit clocks on the SCLK pin. This clock must be 16 times the serial data rate.

The next step is to receive the program size and then the starting address to load the program. These two numbers are three bytes each loaded least significant byte first. Each byte is echoed back as it is received. After both numbers are loaded, the program size is in A0 and the starting address is in A1.

The program is then loaded one byte at a time, least significant byte first. After the program is loaded, the operating mode is set to zero, the CCR is cleared, and the DSP begins execution with the first instruction loaded

# 8.5 Exceptions

Semiconductor, Inc

eescale

The SCI can cause five different exceptions in the DSP, discussed here from the highest to the lowest priority:

- 1. SCI receive data with exception status occurs when the receive data register is full with a receiver error (parity, framing, or overrun error). To clear the pending interrupt, read the SCI status register; then read SRX. Use a long interrupt service routine to handle the error condition. This interrupt is enabled by SCR[16] (REIE).
- 2. SCI receive data occurs when the receive data register is full. Read SRX to clear the pending interrupt. This error-free interrupt can use a fast interrupt service routine for minimum overhead. This interrupt is enabled by SCR[11] (RIE).
- **3.** SCI transmit data occurs when the transmit data register is empty. Write STX to clear the pending interrupt. This error-free interrupt can use a fast interrupt service routine for minimum overhead. This interrupt is enabled by SCR[12] (TIE).
- **4.** SCI idle line occurs when the receive line enters the idle state (10 or 11 bits of ones). This interrupt is latched and then automatically reset when the interrupt is accepted. This interrupt is enabled by SCR[10] (ILIE).
- **5.** SCI timer occurs when the baud rate counter reaches zero. This interrupt is automatically reset when the interrupt is accepted. This interrupt is enabled by SCR[13] (TMIE).

### 8.6 SCI Programming Model

The SCI programming model can be viewed as three types of registers:

- Control
  - SCI Control Register (SCR) in Figure 8-3
  - SCI Clock Control Register (SCCR) in Figure 8-5
- Status
  - SCI Status Register (SSR) in Figure 8-4
- Data transfer
  - SCI Receive Data Registers (SRX) in Figure 8-8
  - SCI Transmit Data Registers (STX) in Figure 8-8
  - SCI Transmit Data Address Register (STXA) in Figure 8-8

The SCI includes the GPIO functions described in **Section 8.7**, "GPIO Signals and Registers," on page 8-25. The next subsections describe the registers and their bits.







Figure 8-2. SCI Data Word Formats (SSFTD = 0), 2

### 8.6.1 SCI Control Register (SCR)

The SCR is a read/write register that controls the serial interface operation. Seventeen of its 24 bits are defined.

| 23   | 22   | 21   | 20  | 19    | 18   | 17   | 16   |
|------|------|------|-----|-------|------|------|------|
|      |      |      |     |       |      |      | REIE |
| 15   | 14   | 13   | 12  | 11    | 10   | 9    | 8    |
| SCKP | STIR | TMIE | TIE | RIE   | ILIE | TE   | RE   |
|      |      |      |     |       |      |      |      |
| 7    | 6    | 5    | 4   | 3     | 2    | 1    | 0    |
| WOMS | RWU  | WAKE | SBK | SSFTD | WDS2 | WDS1 | WDS0 |

Figure 8-3. SCI Control Register (SCR)

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|------------|----------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23 – 17    |          | 0           | Reserved. Set to 0 for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 16         | REIE     | 0           | <b>Receive with Exception Interrupt Enable</b><br>Enables/disables the SCI receive data with exception interrupt. If REIE<br>is cleared, the receive data with exception interrupt is disabled. If both<br>REIE and RDRF are set, and PE, FE, and OR are not all cleared, the<br>SCI requests an SCI receive data with <u>exception</u> interrupt from the<br>interrupt controller. Either a hardware RESET signal or a software<br>RESET instruction clears REIE.                                                                                                                                                                                                                                                                                                                                                                                                      |
| 15         | SCKP     | 0           | SCI Clock Polarity<br>Controls the clock polarity sourced or received on the clock signal<br>(SCLK), eliminating the need for an external inverter. When SCKP is<br>cleared, the clock polarity is positive; when SCKP is set, the clock<br>polarity is negative. In Synchronous mode, positive polarity means that<br>the clock is normally positive and transitions negative during valid data.<br>Negative polarity means that the clock is normally negative and<br>transitions positive during valid data. In Asynchronous mode, positive<br>polarity means that the rising edge of the clock occurs in the center of<br>the period that data is valid. Negative polarity means that the falling<br>edge of the clock occurs during the center of the period that data is<br>valid. Either a hardware RESET signal or a software RESET instruction<br>clears SCKP. |
| 14         | STIR     | 0           | <b>Timer Interrupt Rate</b><br>Controls a divide-by-32 in the SCI Timer interrupt generator. When<br>STIR is cleared, the divide-by-32 is inserted in the chain. When STIR is<br>set, the divide-by-32 is bypassed, thereby increasing timer resolution by<br>a factor of 32. Either a hardware RESET signal or a software RESET<br>instruction clears this bit. To ensure proper operation of the timer, STIR<br>must not be changed during timer operation (that is, if TMIE = 1).                                                                                                                                                                                                                                                                                                                                                                                    |

#### Table 8-2. SCI Control Register (SCR) Bit Definitions

| Table 8-2.         SCI Control Register (SCR) Bit Definitions (Continued) | Table 8-2. | SCI Control Register | (SCR) Bit Definitions | (Continued) |
|---------------------------------------------------------------------------|------------|----------------------|-----------------------|-------------|
|---------------------------------------------------------------------------|------------|----------------------|-----------------------|-------------|

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------|----------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 13         | TMIE     | 0           | <b>Timer Interrupt Enable</b><br>Enables/disables the SCI timer interrupt. If TMIE is set, timer interrupt requests are sent to the interrupt controller at the rate set by the SCI clock register. The timer interrupt is automatically cleared by the timer interrupt acknowledge from the interrupt controller. This feature allows DSP programmers to use the SCI baud rate generator as a simple periodic interrupt generator if the SCI is not in use, if external clocks are used for the SCI, or if periodic interrupts are needed at the SCI baud rate. The SCI internal clock is divided by 16 (to match the 1 × SCI baud rate) for timer interrupt generation. This timer does not require that any SCI signals be configured for SCI use to operate. Either a hardware RESET signal or a software RESET instruction clears TMIE.                                                  |
| 12         | TIE      | 0           | SCI Transmit Interrupt Enable<br>Enables/disables the SCI transmit data interrupt. If TIE is cleared,<br>transmit data interrupts are disabled, and the transmit data register<br>empty (TDRE) bit in the SCI status register must be polled to determine<br>whether the transmit data register is empty. If both TIE and TDRE are<br>set, the SCI requests an SCI transmit data interrupt from the interrupt<br>controller. Either a hardware RESET signal or a software RESET<br>instruction clears TIE.                                                                                                                                                                                                                                                                                                                                                                                    |
| 11         | RIE      | 0           | SCI Receive Interrupt Enable<br>Enables/disables the SCI receive data interrupt. If RIE is cleared, the<br>receive data interrupt is disabled, and the RDRF bit in the SCI status<br>register must be polled to determine whether the receive data register is<br>full. If both RIE and RDRF are set, the SCI requests an SCI receive<br>data interrupt from the interrupt controller. Receive interrupts with<br>exception have higher priority than normal receive data interrupts.<br>Therefore, if an exception occurs (that is, if PE, FE, or OR are set) and<br>REIE is set, the SCI requests an SCI receive data with <u>exception</u><br>interrupt from the interrupt controller. Either a hardware RESET signal<br>or a software RESET instruction clears RIE.                                                                                                                       |
| 10         | ILIE     | 0           | <ul> <li>Idle Line Interrupt Enable</li> <li>When ILIE is set, the SCI interrupt occurs when IDLE (SCI status register bit 3) is set. When ILIE is cleared, the IDLE interrupt is disabled. Either a hardware RESET signal or a software RESET instruction clears ILIE. An internal flag, the shift register idle interrupt (SRIINT) flag, is the interrupt request to the interrupt controller. SRIINT is not directly accessible to the user. When a valid start bit is received, an idle interrupt is generated if both IDLE and ILIE are set. The idle interrupt request. The idle interrupt is not asserted again until at least one character has been received. The results are as follows:</li> <li>The IDLE bit shows the real status of the receive line at all times. An idle interrupt is generated once for each idle state, no matter how long the idle state lasts.</li> </ul> |

### Table 8-2. SCI Control Register (SCR) Bit Definitions (Continued)

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|----------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9          | TE       | 0           | <b>Transmitter Enable</b><br>When TE is set, the transmitter is enabled. When TE is cleared, the transmitter completes transmission of data in the SCI transmit data shift register, and then the serial output is forced high (that is, idle). Data present in the SCI transmit data register (STX) is not transmitted. STX can be written and TDRE cleared, but the data is not transferred into the shift register. TE does not inhibit TDRE or transmit interrupts. Either a hardware RESET signal or a software RESET instruction clears TE. |
|            |          |             | Setting TE causes the transmitter to send a preamble of 10 or 11 consecutive ones (depending on WDS), giving you a convenient way to ensure that the line goes idle before a new message starts. To force this separation of messages by the minimum idle line time, we recommend the following sequence:                                                                                                                                                                                                                                         |
|            |          |             | <ol> <li>Write the last byte of the first message to STX.</li> <li>Wait for TDRE to go high, indicating the last byte has been transferred to the transmit shift register.</li> </ol>                                                                                                                                                                                                                                                                                                                                                             |
|            |          |             | <ol> <li>Clear TE and set TE to queue an idle line preamble to follow immediately the transmission of the last character of the message (including the stop bit).</li> </ol>                                                                                                                                                                                                                                                                                                                                                                      |
|            |          |             | <ol> <li>Write the first byte of the second message to STX.</li> </ol>                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|            |          |             | In this sequence, if the first byte of the second message is not transferred to STX prior to the finish of the preamble transmission, the transmit data line remains idle until STX is finally written.                                                                                                                                                                                                                                                                                                                                           |
| 8          | RE       | 0           | <b>Receiver Enable</b><br>When RE is set, the receiver is enabled. When RE is cleared, the receiver is disabled, and data transfer from the receive shift register to the receive data register (SRX) is inhibited. If RE is cleared while a character is being received, the reception of the character completes before the receiver is disabled. <u>RE does not inhibit RDRF or receive interrupts</u> . Either a hardware RESET signal or a software RESET instruction clears RE.                                                             |
| 7          | WOMS     | 0           | Wired-OR Mode Select<br>When WOMS is set, the SCI TXD driver is programmed to function as<br>an open-drain output and can be wired together with other TXD signals<br>in an appropriate bus configuration, such as a master-slave multidrop<br>configuration. An external pullup resistor is required on the bus. When<br>WOMS is cleared, the TXD signal uses an active internal pullup. Either<br>a hardware RESET signal or a software RESET instruction clears<br>WOMS.                                                                       |

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|------------|----------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6          | RWU      | 0           | <b>Receiver Wakeup Enable</b><br>When RWU is set and the SCI is in Asynchronous mode, the wakeup<br>function is enabled; i. e., the SCI is asleep and can be awakened by the<br>event defined by the WAKE bit. In Sleep state, all interrupts and all<br>receive flags except IDLE are disabled. When the receiver wakes up,<br>RWU is cleared by the wakeup hardware. You can also clear the RWU<br>bit to wake up the receiver. You can use RWU to ignore messages that<br>are for other devices on a multidrop serial network. Wakeup on idle line<br>(i. e., WAKE is cleared) or wakeup on address bit (i. e., WAKE is set)<br>must be chosen. When WAKE is cleared and RWU is set, the receiver<br>does not respond to data on the data line until an idle line is detected.<br>When WAKE is set and RWU is set, the receiver does not respond to<br>data on the data line until a data frame with Bit 9 set is detected.<br>When the receiver wakes up, the RWU bit is cleared, and the first frame<br>of data is received. If interrupts are enabled, the CPU is interrupted and<br>the interrupt routine reads the message header to determine whether<br>the message is intended for this DSP. If the message is for this DSP,<br>the message is not for this DSP, the DSP immediately sets RWU.<br>Setting RWU causes the DSP to ignore the remainder of the message<br>and wait for the next message. Either a hardware RESET signal or a<br>software RESET instruction clears RWU. RWU is ignored in<br>Synchronous mode. |
| 5          | WAKE     | 0           | Wakeup Mode Select<br>When WAKE is cleared, the wakeup on Idle Line mode is selected. In<br>the wakeup on idle line mode, the SCI receiver is re-enabled by an idle<br>string of at least 10 or 11 (depending on WDS mode) consecutive ones.<br>The transmitter's software must provide this idle string between<br>consecutive messages. The idle string cannot occur within a valid<br>message because each word frame there contains a start bit that is 0.<br>When WAKE is set, the wakeup on address bit mode is selected. In the<br>wakeup on address bit mode, the SCI receiver is re-enabled when the<br>last (eighth or ninth) data bit received in a character (frame) is 1. The<br>ninth data bit is the address bit (R8) in the 11-bit multidrop mode; the<br>eighth data bit is the address bit in the 10-bit asynchronous and 11-bit<br>asynchronous with parity modes. Thus, the received character is an<br>address that has to be processed by all sleeping processors—that is,<br>each processor has to compare the received character with its own<br>address and decide whether to receive or ignore all following<br>characters.                                                                                                                                                                                                                                                                                                                                                                                 |

#### Table 8-2. SCI Control Register (SCR) Bit Definitions (Continued)

| Bit Number | Bit Name   | Reset Value |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      | Des  | cription                                                                |
|------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|------|-------------------------------------------------------------------------|
| 4          | SBK        | 0           | A break<br>(includin<br>dependi<br>transmit<br>and reve<br>continua<br>the end<br>bit befor<br>bit. Brea                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Send Break<br>A break is an all-zero word frame—a start bit 0, characters of all zeros<br>(including any parity), and a stop bit 0 (that is, ten or eleven zeros,<br>depending on the mode selected). If SBK is set and then cleared, the<br>transmitter finishes transmitting the current frame, sends 10 or 11 0s,<br>and reverts to idle or sending data. If SBK remains set, the transmitter<br>continually sends whole frames of 0s (10 or 11 bits with no stop bit). At<br>the end of the break code, the transmitter sends at least one high (set)<br>bit before transmitting any data to guarantee recognition of a valid start<br>bit. Break can signal an unusual condition, message, and so on, by<br>forcing a frame error; the frame error is caused by a missing stop bit. |      |      |                                                                         |
| 3          | SSFTD      | 0           | SCI Shift Direction<br>Determines the order in which the SCI data shift registers shift data in or<br>out: MSB first when set, LSB first when cleared. The parity and data<br>type bits do not change their position in the frame, and they remain<br>adjacent to the stop bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |      |                                                                         |
| 2-0        | WDS[2 – 0] | 0           | Word Select<br>Select the format of transmitted and received data. Asynchronous<br>modes are compatible with most UART-type serial devices, and they<br>support standard RS232C communication links. Multidrop<br>Asynchronous mode is compatible with the MC68681 DUART, the<br>M68HC11 SCI interface, and the Intel 8051 serial interface.<br>Synchronous data mode is essentially a high-speed shift register for I/O<br>expansion and stream-mode channel interfaces. You can synchronize<br>data by using a gated transmit and receive clock compatible with the<br>Intel 8051 serial interface mode 0. When odd parity is selected, the<br>transmitter counts the number of ones in the data word. If the total is not<br>an odd number, the parity bit is set, thus producing an odd number. If<br>the receiver counts an even number of ones, an error in transmission<br>has occurred. When even parity is selected, an even number must<br>result from the calculation performed at both ends of the line, or an error<br>in transmission has occurred. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |      |      |                                                                         |
|            |            |             | WDS2                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | WDS1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | WDS0 | Mode | Word Formats                                                            |
|            |            |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0    | 0    | 8-Bit Synchronous Data (shift register mode)                            |
|            |            |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1    | 1    | Reserved                                                                |
|            |            |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0    | 2    | 10-Bit Asynchronous (1 start, 8 data,<br>1 stop)                        |
|            |            |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1    | 3    | Reserved                                                                |
|            |            |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0    | 4    | 11-Bit Asynchronous<br>(1 start, 8 data, 1 even parity, 1 stop)         |
|            |            |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1    | 5    | 11-Bit Asynchronous<br>(1 start, 8 data, 1 odd parity, 1 stop)          |
|            |            |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0    | 6    | 11-Bit Multidrop Asynchronous<br>(1 start, 8 data, 1 data type, 1 stop) |
|            |            |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 1    | 7    | Reserved                                                                |

#### 8.6.2 SCI Status Register (SSR)

The SSR is a 24-bit read-only register that indicates the status of the SCI.



Figure 8-4. SCI Status Register

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|----------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23 – 8     |          | 0           | Reserved. Set to 0 for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 7          | R8       | 0           | <b>Received Bit 8</b><br>In 11-bit Asynchronous Multidrop mode, the R8 bit indicates whether<br>the received byte is an address or data. R8 is set for addresses and is<br>cleared for data. R8 is not affected by reads of the SRX or SCI status<br>register. A hardware RESET signal, a software RESET instruction, an<br>SCI individual reset, or a STOP instruction clears R8.                                                                                                                                                                                                                                                                                                                                                                                               |
| 6          | FE       | 0           | <b>Framing Error Flag</b><br>In Asynchronous mode, FE is set when no stop bit is detected in the<br>data string received. FE and RDRE are set simultaneously when the<br>received word is transferred to the SRX. However, the FE flag inhibits<br>further transfer of data into the SRX until it is cleared. FE is cleared<br>when the <u>SCI status</u> register is read followed by a read of the SRX. A<br>hardware RESET signal, a software RESET instruction, an SCI<br>individual reset, or a STOP instruction clears FE. In 8-bit Synchronous<br>mode, FE is always cleared. If the byte received causes both framing<br>and overrun errors, the SCI receiver recognizes only the overrun error.                                                                         |
| 5          | PE       | 0           | <b>Parity Error</b><br>In 11-bit Asynchronous modes, PE is set when an incorrect parity bit is detected in the received character. PE and RDRF are set simultaneously when the received word is transferred to the SRX. If PE is set, further data transfer into the SRX is not inhibited. PE is cleared when the <u>SCI status</u> register is read, followed by a read of SRX. A hardware RESET signal, a software RESET instruction, an SCI individual reset, or a STOP instruction also clears PE. In 10-bit Asynchronous mode, 11-bit multidrop mode, and 8-bit Synchronous mode, the PE bit is always cleared since there is no parity bit in these modes. If the byte received causes both parity and overrun errors, the SCI receiver recognizes only the overrun error. |

#### Table 8-3. SCI Status Register (SSR) Bit Definitions

#### Table 8-3. SCI Status Register (SSR) Bit Definitions (Continued)

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|------------|----------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4          | OR       | 0           | <b>Overrun Error Flag</b><br>Set when a byte is ready to be transferred from the receive shift register<br>to the receive data register (SRX) that is already full (RDRF = 1). The<br>receive shift register data is not transferred to the SRX. The OR flag<br>indicates that character(s) in the received data stream may have been<br>lost. The only valid data is located in the SRX. OR is cleared when the<br>SCI status register is read, followed by a read of SRX. The OR bit<br>clears the FE and PE bits; that is, overrun error has higher priority than<br>FE or PE. A hardware RESET signal, a software RESET instruction, an<br>SCI individual reset, or a STOP instruction clears OR.                            |
| 3          | IDLE     | 0           | Idle Line Flag<br>Set when 10 (or 11) consecutive ones are received. IDLE is cleared by<br>a start-bit detection. The IDLE status bit represents the status of the<br>receive line. The transition of IDLE from 0 to 1 can cause an IDLE<br>interrupt (ILIE).                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 2          | RDRF     | 0           | <b>Receive Data Register Full</b><br>Set when a valid character is transferred to the SCI receive data<br>register from the SCI receive shift register (regardless of the error bits<br>condition). RDRF is cleared when the SCI receive data register is read.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 1          | TDRE     | 1           | <b>Transmit Data Register Empty</b><br>Set when the SCI transmit data register is empty. When TDRE is set,<br>new data can be written to one of the SCI transmit data registers (STX)<br>or the transmit data address register (STXA). TDRE is cleared when the<br>SCI transmit data register is written. Either a hardware RESET signal, a<br>software RESET instruction, an SCI individual reset, or a STOP<br>instruction sets TDRE.                                                                                                                                                                                                                                                                                          |
|            |          |             | In Synchronous mode, when the internal SCI clock is in use, there is a delay of up to 5.5 serial clock cycles between the time that STX is written until TDRE is set, indicating the data has been transferred from the STX to the transmit shift register. There is a delay of 2 to 4 serial clock cycles between writing STX and loading the transmit shift register; in addition, TDRE is set in the middle of transmitting the second bit. When using an external serial transmit clock, if the clock stops, the SCI transmitter stops. TDRE is not set until the middle of the second bit after the external clock starts. Gating the external clock off after the first bit has been transmitted delays TDRE indefinitely. |
|            |          |             | In Asynchronous mode, the TDRE flag is not set immediately after a word is transferred from the STX or STXA to the transmit shift register nor when the word first begins to be shifted out. TDRE is set 2 cycles (of the 16 × clock) after the start bit; that is, 2 (16 × clock) cycles into the transmission time of the first data bit.                                                                                                                                                                                                                                                                                                                                                                                      |

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|----------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0          | TRNE     | 1           | <b>Transmitter Empty</b><br>This flag bit is set when both the transmit shift register and transmit data<br>register (STX) are empty, indicating that there is no data in the<br>transmitter. When TRNE is set, data written to one of the three STX<br>locations or to the transmit data address register (STXA) is transferred<br>to the transmit shift register and is the first data transmitted. TRNE is<br>cleared when a write into STX or STXA clears TDRE or when an idle,<br>preamble, or break is transmitted. When set, TRNE indicates that the<br>transmitter is empty; therefore, the data written to STX or STXA is<br>transmitted next. That is, there is no word in the transmit shift register<br>being transmitted. This procedure is useful when initiating the transfer<br>of a message (that is, a string of characters). |

#### Table 8-3. SCI Status Register (SSR) Bit Definitions (Continued)

### 8.6.3 SCI Clock Control Register (SCCR)

The SCCR is a 24-bit read/write register that controls the selection of clock modes and baud rates for the transmit and receive sections of the SCI interface. The SCCR is cleared by a hardware  $\overline{\text{RESET}}$  signal.

| 15 14 13 12 11 10 9                                                         | 8   |
|-----------------------------------------------------------------------------|-----|
| TCM RCM SCP COD CD11 CD10 CD9                                               | CD8 |
|                                                                             |     |
| 7 6 5 4 3 2 1                                                               | 0   |
| CD7         CD6         CD5         CD4         CD3         CD2         CD1 | CD0 |

Reserved. Read as 0. Write with 0 for future compatibility.

#### Figure 8-5. SCI Clock Control Register (SCCR)

The basic features of the clock generator, as shown in Figure 8-6 and Figure 8-7, follow:

- The SCI logic always uses a 16 × internal clock in Asynchronous mode and always uses a 2 × internal clock in Synchronous mode. The maximum internal clock available to the SCI peripheral block is the oscillator frequency divided by 4. These maximum rates are the same for internally or externally supplied clocks.
- The 16 × clock is necessary for Asynchronous modes to synchronize the SCI to the incoming data (as shown in **Figure 8-6**).
- For Asynchronous modes, you must provide a 16 × clock if you want to use an external baud rate generator (that is, SCLK input).

SCI Programming Model

- For Asynchronous modes, you can select either  $1 \times \text{ or } 16 \times \text{ for the output clock}$ when using internal TX and RX clocks (TCM = 0 and RCM = 0).
- When SCKP is cleared, the transmitted data on the TXD signal changes on the negative edge of the 1 × serial clock and is stable on the positive edge. When SCKP is set, the data changes on the positive edge and is stable on the negative edge.
- The received data on the RXD signal is sampled on the positive edge (if SCKP = 0) or on the negative edge (if SCKP = 1) of the 1 × serial clock.
- For Asynchronous mode, the output clock is continuous.
- For Synchronous mode, a 1 × clock is used for the output or input baud rate. The maximum 1 × clock is the crystal frequency divided by 8.
- For Synchronous mode, the clock is gated.
- For Synchronous mode, the transmitter and receiver are synchronous with each other.





The SCI clock determines the data transmission rate and can also establish a periodic interrupt that can act as an event timer or be used in any other timing function. Bits CD11–CD0, SCP, and SCR[STIR] work together to determine the time base. If SCR[TMIE] = 1 when the periodic time-out occurs, the SCI timer interrupt is recognized and pending. The SCI timer interrupt is automatically cleared when the interrupt is serviced. This interrupt occurs every time the periodic timer times out.

8-20

Semiconductor, Inc

reescale

| Table 8-4.         SCI Clock Control Register (SCCR) Bit | Definitions |
|----------------------------------------------------------|-------------|
|----------------------------------------------------------|-------------|

| Bit Number | Bit Name   | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |     |             |             |                |                          |
|------------|------------|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|-------------|-------------|----------------|--------------------------|
| 23 – 16    |            | 0           | Reserved. Set to 0 for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |     |             |             |                |                          |
| 15         | ТСМ        | 0           | <b>Transmit Clock Source</b><br>Selects whether an internal or external clock is used for the transmitter. If<br>TCM is cleared, the internal clock is used. If TCM is set, the external clock<br>(from the SCLK signal) is used.                                                                                                                                                                                                                                                                                                                                                                           |     |             |             |                |                          |
| 14         | RCM        | 0           | <b>Receive Clock Mode Source</b><br>Selects whether an internal or external clock is used for the receiver. If RCM is cleared, the internal clock is used. If RCM is set, the external clock (from the SCLK signal) is used.                                                                                                                                                                                                                                                                                                                                                                                |     |             |             |                |                          |
|            |            |             | тсм                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | RCM | TX<br>Clock | RX<br>Clock | SCLK<br>Signal | Mode                     |
|            |            |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0   | Internal    | Internal    | Output         | Synchronous/asynchronous |
|            |            |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1   | Internal    | External    | Input          | Asynchronous only        |
|            |            |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 0   | External    | Internal    | Input          | Asynchronous only        |
|            |            |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 1   | External    | External    | Input          | Synchronous/asynchronous |
| 13         | SCP        | 0           | <b>Clock Prescaler</b><br>Selects a divide by 1 (SCP is cleared) or divide by 8 (SCP is set) prescaler<br>for the clock divider. The output of the prescaler is further divided by 2 to<br>form the SCI clock.                                                                                                                                                                                                                                                                                                                                                                                              |     |             |             |                |                          |
| 12         | COD        | 0           | <ul> <li>Clock Out Divider</li> <li>The clock output divider is controlled by COD and the SCI mode. If the SCI mode is synchronous, the output divider is fixed at divide by 2. If the SCI mode is asynchronous, either: <ul> <li>If COD is cleared and SCLK is an output (that is, TCM and RCM are both cleared), then the SCI clock is divided by 16 before being output to the SCLK signal. Thus, the SCLK output is a 1 × clock.</li> <li>If COD is set and SCLK is an output, the SCI clock is fed directly out to the SCLK signal. Thus, the SCLK output is a 16 × baud clock.</li> </ul> </li> </ul> |     |             |             |                |                          |
| 11 – 0     | CD[11 – 0] | 0           | <b>Clock Divider</b><br>Specifies the divide ratio of the prescale divider in the SCI clock generator. A divide ratio from 1 to 4096 (CD[11 – 0] = $000$ to \$FFF) can be selected.                                                                                                                                                                                                                                                                                                                                                                                                                         |     |             |             |                |                          |





#### 8.6.4 SCI Data Registers

The SCI data registers are divided into two groups: receive and transmit, as shown in **Figure 8-8**. There are two receive registers: a receive data register (SRX) and a serial-to-parallel receive shift register. There are also two transmit registers: a transmit data register (called either STX or STXA) and a parallel-to-serial transmit shift register.

SCI Programming Model





### 8.6.4.1 SCI Receive Register (SRX)

Data bits received on the RXD signal are shifted into the SCI receive shift register. When a complete word is received, the data portion of the word is transferred to the byte-wide SRX. This process converts serial data to parallel data and provides double buffering. Double buffering promotes flexibility and increased throughput since the programmer can save (and process) the previous word while the current word is being received.

The SRX can be read at three locations as SRXL, SRXM, and SRXH. When SRXL is read, the contents of the SRX are placed in the lower byte of the data bus and the remaining bits on the data bus are read as zeros. Similarly, when SRXM is read, the contents of SRX are placed into the middle byte of the bus, and when SRXH is read, the contents of SRX are placed into the high byte with the remaining bits are read as 0s. This way of mapping SRX efficiently packs three bytes into one 24-bit word by ORing three data bytes read from the three addresses.

The SCR WDS0, WDS1, and WDS2 control bits define the length and format of the serial word. The SCR receive clock mode (RCM) defines the clock source.

In Synchronous mode, the start bit, the eight data bits, the address/data indicator bit or the parity bit, and the stop bit are received, respectively. Data bits are sent LSB first if SSFTD is cleared, and MSB first if SSFTD is set. In Synchronous mode, a gated clock provides synchronization. In either synchronous or Asynchronous mode, when a complete word is clocked in, the contents of the shift register can be transferred to the SRX and the flags; RDRF, FE, PE, and OR are changed appropriately. Because the operation of the receive shift register is transparent to the DSP, the contents of this register are not directly accessible to the programmer.

#### 8.6.4.2 SCI Transmit Register (STX)

The transmit data register is a one-byte-wide register mapped into four addresses as STXL, STXM, STXH, and STXA. In Asynchronous mode, when data is to be transmitted, STXL, STXM, and STXH are used. When STXL is written, the low byte on the data bus is transferred to the STX. When STXM is written, the middle byte is transferred to the STX. When STXH is written, the high byte is transferred to the STX. This structure makes it easy for the programmer to unpack the bytes in a 24-bit word for transmission. TDXA should be written in 11-bit asynchronous multidrop mode when the data is an address and the programmer wants to set the ninth bit (the address bit). When STXA is written, the data from the low byte on the data bus is stored in it. The address data bit is cleared in 11-bit asynchronous multidrop mode when any of STXL, STXM, or STXH is written. When either STX (STXL, STXM, or STXH) or STXA is written, TDRE is cleared.

The transfer from either STX or STXA to the transmit shift register occurs automatically, but not immediately, after the last bit from the previous word is shifted out; that is, the transmit shift register is empty. Like the receiver, the transmitter is double-buffered. However, a delay of two to four serial clock cycles occurs between when the data is transferred from either STX or STXA to the transmit shift register and when the first bit appears on the TXD signal. (A serial clock cycle is the time required to transmit one data bit.)

The transmit shift register is not directly addressable, and there is no dedicated flag for this register. Because of this fact and the two- to four-cycle delay, two bytes cannot be written consecutively to STX or STXA without polling, because the second byte might overwrite the first byte. Thus, you should always poll the TDRE flag prior to writing STX or STXA to prevent overruns unless transmit interrupts are enabled. Either STX or STXA is usually written as part of the interrupt service routine. An interrupt is generated only if TDRE is set. The transmit shift register is indirectly visible via the SSR[TRNE] bit.

In Synchronous mode, data is synchronized with the transmit clock. That clock can have either an internal or external source, as defined by the TCM bit in the SCCR. The length and format of the serial word is defined by the WDS0, WDS1, and WDS2 control bits in the SCR. In Asynchronous mode, the start bit, the eight data bits (with the LSB first if SSFTD = 0 and the MSB first if SSFTD = 1), the address/data indicator bit or parity bit, and the stop bit are transmitted in that order.

The data to be transmitted can be written to any one of the three STX addresses. If SCKP is set and SSHTD is set, SCI Synchronous mode is equivalent to the SSI operation in 8-bit data on-demand mode.

**Note:** When data is written to a peripheral device, there is a two-cycle pipeline delay until any status bits affected by this operation are updated. If you read any of those status bits within the next two cycles, the bit does not reflect its current status. For details see the *DSP56300 Family Manual*.

# 8.7 GPIO Signals and Registers

Three registers control the GPIO functionality of port SCI: Port E control register (PCRE), Port E direction register (PRRE) and Port E data register (PDRE).

## 8.7.1 Port E Control Register (PCRE)

The read/write PCRE controls the functionality of SCI GPIO signals. Each of PC[2 - 0] bits controls the functionality of the corresponding port signal. When a PC[i] bit is set, the corresponding port signal is configured as an SCI signal. When a PC[i] bit is cleared, the corresponding port signal is configured as a GPIO signal. A hardware RESET signal or a software RESET instruction clears all PCR bits.



Reserved. Read as 0. Write with 0 for future compatibility.

Figure 8-9. Port E Control Register (PCRE)

# 8.7.2 Port E Direction Register (PRRE)

The read/write PRRE controls the direction of SCI GPIO signals. When port signal[i] is configured as GPIO, PDC[i] controls the port signal direction. When PDC[i] is set, the GPIO port signal[i] is configured as output. When PDC[i] is cleared, the GPIO port signal[i] is configured as input. A hardware RESET signal or a software RESET instruction clears all PRR bits.



Reserved. Read as 0. Write with 0 for future compatibility

#### Figure 8-10. Port E Direction Register (PRRE)

 Table 8-5 shows the port signal configurations.

| Table 8-5. | Port Control Register | and Port Direction Register Bits |
|------------|-----------------------|----------------------------------|
|------------|-----------------------|----------------------------------|

| PC[i] | PDC[i] | Port Signal[i] Function |
|-------|--------|-------------------------|
| 1     | 1 or 0 | SCI                     |
| 0     | 0      | GPIO input              |
| 0     | 1      | GPIO output             |

# 8.7.3 Port E Data Register (PDRE)

The read/write PDRE reads or writes data to or from SCI GPIO signals. Bits PD[2 - 0] read or write data to or from the corresponding port signals if they are configured as GPIO. If a port signal [i] is configured as a GPIO input, then the corresponding PD[i] bit reflects the value of this signal. If a port signal [i] is configured as a GPIO output, then the value of the corresponding PD[i] bit is reflected on this signal. A hardware RESET signal or a software RESET instruction clears all PDRE bits.



Reserved. Read as 0. Write with 0 for future compatibility

#### Figure 8-11. Port E Data Register (PDRE)

# Freescale Semiconductor, Inc.

# **Chapter 9** Triple Timer Module

The timers in the DSP56311 internal triple timer module act as timed pulse generators or as pulse-width modulators. Each timer has a single signal that can function as a GPIO signal or as a timer signal. Each timer can also function as an event counter to capture an event or to measure the width or period of a signal.

# 9.1 Overview

The timer module contains a common 21-bit prescalar and three independent and identical general-purpose 24-bit timer/event counters, each with its own register set. Each timer has the following capabilities:

- uses internal or external clocking
- interrupts the DSP56311 after a specified number of events (clocks) or signals an external device after counting internal events
- triggers DMA transfers after a specified number of events (clocks) occurs
- connects to the external world through one bidirectional signal, designated TIO[0-2] for timers 0-2.

When the TIO signal is configured as input, the timer functions as an external event counter or measures external pulse width/signal period. When the TIO signal is configured as an output, the timer functions as a timer, a watchdog timer, or a pulse-width modulator. When the timer is not using the TIO signal, TIO can be used as a GPIO signal (also called TIO[0 - 2]).

**Figure 9-1** shows a block diagram of the triple timer module. Notice the 24-bit timer Prescalar Load Register (TPLR) and the 24-bit Timer Prescalar Count Register (TPCR). Each of the three timers can use the prescalar clock as its clock source. The timer block diagram in **Figure 9-2** shows the structure of a timer module. The DSP56311 treats each timer as a memory-mapped peripheral with four registers occupying four 24-bit words in the X data memory space. The three timers are identical in structure and function. Either standard polled or interrupt programming techniques can be used to service the timers. A single, generic timer is discussed in this chapter. The timer includes a 24-bit counter, a 24-bit read/write Timer Control and Status Register (TCSR), a 24-bit read-only Timer Count Register (TCR), a 24-bit write-only Timer Load Register (TLR), a 24-bit read/write Timer Compare Register (TCPR), and logic for clock selection and interrupt/DMA trigger generation.



Figure 9-1. Triple Timer Module Block Diagram

The timer mode is controlled by the TC[3 - 0] bits of the Timer Control/Status Register (TCSR). For a listing of the timer modes and descriptions of their operations, see **Section 9.3**, "Operating Modes," on page 9-4.

# 9.2 Operation

This section discusses timer basics: reset state, initialization, and exceptions.

# 9.2.1 Timer After Reset

A hardware RESET signal or software RESET instruction clears the Timer Control Register, thus configuring the timer as GPIO. A timer is active only if TCSR[TE] is set.





## 9.2.2 Timer Initialization

To initialize a timer, do the following:

- **1.** Ensure that the timer is not active either by sending a reset or clearing the TCSR[TE] bit.
- 2. Configure the control register (TCSR) to set the timer operating mode. Set the interrupt enable bits as needed for the application.
- **3.** Configure other registers: Prescalar Load Register (TPLR), Load register (TLR), and Compare register (TCPR) as needed for the application.
- 4. Enable the timer by setting the TCSR[TE] bit.

# 9.2.3 Timer Exceptions

Each timer can generate two different exceptions:

- Timer Overflow (highest priority) Occurs when the timer counter reaches the overflow value. This exception sets the TOF bit. TOF is cleared when a value of one is written to it or when the timer overflow exception is serviced.
- Timer Compare (lowest priority) Occurs when the timer counter reaches the value given in the Timer Compare Register (TCPR) for all modes except

measurement modes. In measurement modes, 4 - 6, a compare exception occurs when the appropriate transition occurs on the TIO signal. The Compare exception sets the TCF bit. TCF is cleared when a value of one is written to it or when the timer compare interrupt is serviced.

To configure a timer exception, perform the following steps. The example at the right of each step shows the register settings for configuring a Timer 0 compare interrupt. The order of the steps is optional except that the timer should not be enabled (step 2e) until all other exception configuration is complete:

- **1.** Configure the interrupt service routine (ISR):
  - a. Load vector base address register VBA (b23 8)
  - b. Define I\_VEC to be equal to the VBA value (if that is nonzero). If it is defined,
     I\_VEC must be defined for the assembler before the interrupt equate file is included.
  - c. Load the exception vector table entry: two-word fast interrupt, or jump/branch to subroutine (long interrupt). p:TIMOC
- 2. Configure the interrupt trigger:
  - a. Enable and prioritize overall peripheral interrupt functionality.

|    |                                                     | IPRP (TOL[1 - 0]) |
|----|-----------------------------------------------------|-------------------|
| b. | Enable a specific peripheral interrupt.             |                   |
|    |                                                     | TCSR0 (TCIE)      |
| c. | Unmask interrupts at the global level.              |                   |
|    |                                                     | SR (I[1 - 0])     |
| d. | Configure a peripheral interrupt-generating functio | n.                |
|    |                                                     | TCSR0 (TC[7 - 4]) |
| e. | Enable peripheral and associated signals.           | TCSR0 (TE)        |
|    |                                                     |                   |

# 9.3 Operating Modes

Each timer has operating modes that meet a variety of system requirements, as follows:

- Timer
  - GPIO, mode 0: Internal timer interrupt generated by the internal clock
  - Pulse, mode 1: External timer pulse generated by the internal clock
  - Toggle, mode 2: Output timing signal toggled by the internal clock
  - Event counter, mode 3: Internal timer interrupt generated by an external clock

DSP56311 User's Manual

- Measurement
  - Input width, mode 4: Input pulse width measurement
  - Input pulse, mode 5: Input signal period measurement
  - Capture, mode 6: Capture external signal
- PWM, mode 7: Pulse width modulation
- Watchdog
  - Pulse, mode 9: Output pulse, internal clock
  - Toggle, mode 10: Output toggle, internal clock
- **Note:** To ensure proper operation, the TCSR TC[3 0] bits should be changed only when the timer is disabled (that is, when TCSR[TE] is cleared).

#### 9.3.1 Triple Timer Modes

For all triple timer modes, the following points are true:

- The TCSR[TE] bit is set to clear the counter and enable the timer. Clearing TCSR[TE] disables the timer.
- The value to which the timer is to count is loaded into the TCPR. (This is true for all modes except the measurement modes (modes 4 through 6).
- The counter is loaded with the TLR value on the first clock.
- If the counter overflows, TCSR[TOF] is set, and if TCSR[TOIE] is set, an overflow interrupt is generated.
- You can read the counter contents at any time from the Timer Count Register (TCR).

#### 9.3.1.1 Timer GPIO (Mode 0)

| Bit Settings |     |     |     | Mode Characteristics         |      |       |      |          |
|--------------|-----|-----|-----|------------------------------|------|-------|------|----------|
| TC3          | TC2 | TC1 | TC0 | Mode Name Function TIO Clock |      |       |      |          |
| 0            | 0   | 0   | 0   | 0                            | GPIO | Timer | GPIO | Internal |

In Mode 0, the timer generates an internal interrupt when a counter value is reached, if the timer compare interrupt is enabled (see **Figure 9-3** and **Figure 9-4**). When the counter equals the TCPR value, TCSR[TCF] is set and a compare interrupt is generated if the TCSR[TCIE] bit is set. If the TCSR[TRM] bit is set, the counter is reloaded with the TLR value at the next timer clock and the count is resumed. If TCSR[TRM] is cleared, the counter continues to increment on each timer clock signal. This process repeats until the timer is disabled.





#### Mode 0 (internal clock, no timer output): TRM = 0





# **Freescale Semiconductor, Inc.**

#### 9.3.1.2 Timer Pulse (Mode 1)

|     | Bit Settings |     |     |                              | Mode Characteristics |       |        |          |
|-----|--------------|-----|-----|------------------------------|----------------------|-------|--------|----------|
| TC3 | TC2          | TC1 | TC0 | Mode Name Function TIO Clock |                      |       |        |          |
| 0   | 0            | 0   | 1   | 1                            | Timer Pulse          | Timer | Output | Internal |

In Mode 1, the timer generates an external pulse on its TIO signal when the timer count reaches a pre-set value. The TIO signal is loaded with the value of the TCSR[INV] bit. When the counter matches the TCPR value, TCSR[TCF] is set and a compare interrupt is generated if the TCSR[TCIE] bit is set. The polarity of the TIO signal is inverted for one timer clock period. If TCSR[TRM] is set, the counter is loaded with the TLR value on the next timer clock and the count is resumed. If TCSR[TRM] is cleared, the counter continues to increment on each timer clock. This process repeats until TCSR[TE] is cleared (disabling the timer).

The TLR value in the TCPR sets the delay between starting the timer and generating the output pulse. To generate successive output pulses with a delay of X clock cycles between signals, set the TLR value to X/2 and set the TCSR[TRM] bit. This process repeats until the timer is disabled.

#### Mode 1 (internal clock): TRM = 1





Figure 9-6. Pulse Mode (TRM = 0)

# 9.3.1.3 Timer Toggle (Mode 2)

|     | Bit Se | ttings |     |                              | Mode Characteristics |       |        |          |  |
|-----|--------|--------|-----|------------------------------|----------------------|-------|--------|----------|--|
| TC3 | TC2    | TC1    | TC0 | Mode Name Function TIO Clock |                      |       |        |          |  |
| 0   | 0      | 1      | 0   | 2                            | Toggle               | Timer | Output | Internal |  |

In Mode 2, the timer periodically toggles the polarity of the TIO signal. When the timer is enabled, the TIO signal is loaded with the value of the TCSR[INV] bit. When the counter value matches the value in the TCPR, the polarity of the TIO output signal is inverted. TCSR[TCF] is set, and a compare interrupt is generated if the TCSR[TCIE] bit is set. If the TCSR[TRM] bit is set, the counter is loaded with the value of the TLR when the next timer clock is received, and the count resumes. If the TRM bit is cleared, the counter continues to increment on each timer clock. This process repeats until the timer is cleared (disabling the timer). The TCPR[TLR] value sets the delay between starting the timer and toggling the TIO signal. To generate output signals with a delay of X clock cycles between toggles, set the TLR value to X/2, and set the TCSR[TRM] bit. This process repeats until the timer is disabled (that is, TCSR[TE] is cleared).

Semiconductor, Inc

reescale









#### 9.3.1.4 Timer Event Counter (Mode 3)

|     | Bit Se | ttings |     | Mode Characteristics         |               |       |       |          |
|-----|--------|--------|-----|------------------------------|---------------|-------|-------|----------|
| TC3 | TC2    | TC1    | TC0 | Mode Name Function TIO Clock |               |       |       |          |
| 0   | 0      | 1      | 1   | 3                            | Event Counter | Timer | Input | External |

In Mode 3, the timer counts external events and issues an interrupt (if interrupt enable bits are set) when the timer counts a preset number of events. The timer clock signal can be taken from either the TIO input signal or the prescalar clock output. If an external clock is used, it must be internally synchronized to the internal clock, and its frequency must be less than the DSP56311 internal operating frequency divided by 4. The value of the TCSR[INV] bit determines whether low-to-high (0 to 1) transitions or high-to-low (1 to 0) transitions increment the counter. If the INV bit is set, high-to-low transitions increment the counter.

When the counter matches the value contained in the TCPR, TCSR[TCF] is set and a compare interrupt is generated if the TCSR[TCIE] bit is set. If the TCSR[TRM] bit is set, the counter is loaded with the value of the TLR when the next timer clock is received, and the count is resumed. If the TCSR[TRM] bit is cleared, the counter continues to increment on each timer clock. This process repeats until the timer is disabled.

Mode 3 (internal clock): TRM = 1



**Figure 9-9.** Event Counter Mode, TRM = 1



NOTE: If INV = 1, counter is clocked on 1-to-0 clock transitions, instead of 0-to-1 transitions.

Figure 9-10. Event Counter Mode, TRM = 0

#### 9.3.2 Signal Measurement Modes

The following signal measurement and pulse width modulation modes are provided:

- Measurement input width (Mode 4)
- Measurement input period (Mode 5)
- Measurement capture (Mode 6)
- Pulse width modulation mode (Mode 7)

The external signal synchronizes with the internal clock that increments the counter. This synchronization process can cause the number of clocks measured for the selected signal value to vary from the actual signal value by plus or minus one counter clock cycle.

#### 9.3.2.1 Measurement Input Width (Mode 4)

|     | Bit Settings |     |     |                              | Mode Characteristics |             |       |          |
|-----|--------------|-----|-----|------------------------------|----------------------|-------------|-------|----------|
| TC3 | TC2          | TC1 | TC0 | Mode Name Function TIO Clock |                      |             |       |          |
| 0   | 1            | 0   | 0   | 4                            | Input width          | Measurement | Input | Internal |

In Mode 4, the timer counts the number of clocks that occur between opposite edges of an input signal. After the first appropriate transition (as determined by the TCSR[INV] bit) occurs on the TIO input signal, the counter is loaded with the TLR value. If TCSR[INV] is set, the timer starts on the first high-to-low (1 to 0) signal transition on the TIO signal. If the INV bit is cleared, the timer starts on the first low-to-high (that is, 0 to 1) transition on the TIO signal. When the first transition opposite in polarity to the INV bit setting occurs on the TIO signal, the counter stops. TCSR[TCF] is set and a compare interrupt is generated if the TCSR[TCIE] bit is set. The value of the counter (which measures the width of the TIO pulse) is loaded into the TCR, which can be read to determine the external signal pulse width. If the TCSR[TRM] bit is set, the counter is loaded with the TLR value on the first timer clock received following the next valid transition on the TIO input signal, and the count resumes. If TCSR[TRM] is cleared, the counter continues to increment on each timer clock. This process repeats until the timer is disabled.



NOTE: If INV = 1, a 1-to-0 edge on TIO loads the counter, and a 0-to-1 edge on TIO stops the counter and loads TCR with the count.

#### Figure 9-11. Pulse Width Measurement Mode, TRM = 1



NOTE: If INV = 1, a 1-to-0 edge on TIO loads the counter, and a 0-to-1 edge on stops the counter and loads TCR with the count.



#### 9.3.2.2 Measurement Input Period (Mode 5)

|     | Bit Se | ttings |     | Mode Characteristics         |              |             |       |          |
|-----|--------|--------|-----|------------------------------|--------------|-------------|-------|----------|
| TC3 | TC2    | TC1    | TC0 | Mode Name Function TIO Clock |              |             |       |          |
| 0   | 1      | 0      | 1   | 5                            | Input period | Measurement | Input | Internal |

In Mode 5, the timer counts the period between the reception of signal edges of the same polarity across the TIO signal. The value of the INV bit determines whether the period is measured between consecutive low-to-high (0 to 1) transitions of TIO or between consecutive high-to-low (1 to 0) transitions of TIO. If INV is set, high-to-low signal transitions are selected. If INV is cleared, low-to-high signal transitions are selected. After the first appropriate transition occurs on the TIO input signal, the counter is loaded with the TLR value. On the next signal transition of the same polarity that occurs on TIO, TCSR[TCF] is set, and a compare interrupt is generated if the TCSR[TCIE] bit is set. The contents of the counter load into the TCR. The TCR then contains the value of the time that elapsed between the two signal transitions on the TIO signal. After the second signal transition, if the TCSR[TRM] bit is set, the TCSR[TE] bit is set to clear the counter and enable the timer. The counter is repeatedly loaded and incremented until the timer is disabled. If the TCSR[TRM] bit is cleared, the counter continues to increment until it overflows.

#### **Freescale Semiconductor, Inc.**



NOTE: If INV = 1, a 1-to-0 edge on TIO loads the counter, and a 0-to-1 edge on TIO loads TCR with count and the counter with N.





NOTE: If INV = 1, a 1-to-0 edge on TIO loads the counter, and a 0-to-1 edge on TIO loads TCR with count and the counter with N.

#### Figure 9-14. Period Measurement Mode, TRM = 0

DSP56311 User's Manual

#### 9.3.2.3 Measurement Capture (Mode 6)

|     | Bit Se | ettings |     | Mode Characteristics         |         |             |       |          |
|-----|--------|---------|-----|------------------------------|---------|-------------|-------|----------|
| TC3 | TC2    | TC1     | TC0 | Mode Name Function TIO Clock |         |             |       |          |
| 0   | 1      | 1       | 0   | 6                            | Capture | Measurement | Input | Internal |

In Mode 6, the timer counts the number of clocks that elapse between when the timer starts and when an external signal is received. At the first appropriate transition of the external clock detected on the TIO signal, TCSR[TCF] is set and, if the TCSR[TCIE] bit is set, a compare interrupt is generated. The counter halts. The contents of the counter are loaded into the TCR. The value of the TCR represents the delay between the setting of the TCSR[TE] bit and the detection of the first clock edge signal on the TIO signal. The value of the INV bit determines whether a high-to-low (1 to 0) or low-to-high (0 to 1) transition of the external clock signals the end of the timing period. If INV bit is set, a high-to-low transition signals the end of the timing period.



NOTE: If INV = 1, a 1-to-0 edge on TIO loads TCR with count and stops the counter.



#### 9.3.3 Pulse Width Modulation (PWM, Mode 7)

|     | Bit Se | ettings |     | Mode Characteristics         |                        |     |        |          |
|-----|--------|---------|-----|------------------------------|------------------------|-----|--------|----------|
| TC3 | TC2    | TC1     | TC0 | Mode Name Function TIO Clock |                        |     |        |          |
| 0   | 1      | 1       | 1   | 7                            | Pulse width modulation | PWM | Output | Internal |

In Mode 7, the timer generates periodic pulses of a preset width. When the counter equals the value in the TCPR, the TIO output signal is toggled and TCSR[TCF] is set. The contents of the counter are placed into the TCR. If the TCSR[TCIE] bit is set, a compare interrupt is generated. The counter continues to increment on each timer clock.

If counter overflow occurs, the TIO output signal is toggled, TCSR[TOF] is set, and an overflow interrupt is generated if the TCSR[TOIE] bit is set. If the TCSR[TRM] bit is set, the counter is loaded with the TLR value on the next timer clock and the count resumes. If the TCSR[TRM] bit is cleared, the counter continues to increment on each timer clock. This process repeats until the timer is disabled.

When the TCSR[TE] bit is set and the counter starts, the TIO signal assumes the value of INV. On each subsequent toggle of the TIO signal, the polarity of the TIO signal is reversed. For example, if the INV bit is set, the TIO signal generates the following signal: 1010. If the INV bit is cleared, the TIO signal generates the following signal: 0101.

The value of the TLR determines the output period (FFFFFF - TLR + 1). The timer counter increments the initial TLR value and toggles the TIO signal when the counter value exceeds FFFFFF. The duty cycle of the TIO signal is determined by the value in the TCPR. When the value in the TLR increments to a value equal to the value in the TCPR, the TIO signal is toggled. The duty cycle is equal to (FFFFFF - TCPR) divided by (FFFFFF - TLR + 1). For a 50 percent duty cycle, the value of TCPR is equal to (FFFFFF + TLR + 1)/2.

**Note:** The value in TCPR must be greater than the value in TLR.

Mode 7 (internal clock): TRM = 1

**Operating Modes** 





Figure 9-16. Pulse Width Modulation Toggle Mode, TRM = 1

**Operating Modes** 

Period = \$FFFFFF - TLR + 1 Duty cycle = (\$FFFFFF - TCPR) Ensure that TCPR > TLR for correct functionality



NOTE: On overflow, TCR is loaded with the value of TLR.



# 9.3.4 Watchdog Modes

The following watchdog timer modes are provided:

- Watchdog Pulse
- Watchdog Toggle

#### 9.3.4.1 Watchdog Pulse (Mode 9)

|     | Bit Settings |     |     | Mode Characteristics         |       |          |        |          |
|-----|--------------|-----|-----|------------------------------|-------|----------|--------|----------|
| TC3 | TC2          | TC1 | TC0 | Mode Name Function TIO Clock |       |          |        |          |
| 1   | 0            | 0   | 1   | 9                            | Pulse | Watchdog | Output | Internal |

In Mode 9, the timer generates an external signal at a preset rate. The signal period is equal to the period of one timer clock. After the counter reaches the value in the TCPR, if the TCSR[TRM] bit is set, the counter is loaded with the TLR value on the next timer clock and the count resumes. Therefore TRM = 1 is not useful for watchdog functions. If the TCSR[TRM] bit is cleared, the counter continues to increment on each subsequent timer clock. This process repeats until the timer is disabled (that is, TCSR[TE] is cleared). If the counter overflows, a pulse is output on the TIO signal with a pulse width equal to the timer clock period. If the INV bit is set, the pulse polarity is high (logical 1). If INV is cleared, the pulse polarity is low (logical 0). The counter reloads when the TLR is written with a new value while the TCSR[TE] bit is set. In Mode 9, internal logic preserves the TIO value and direction for an additional 2.5 internal clock cycles after the hardware RESET signal is asserted. This convention ensures that a valid RESET signal is generated when the TIO signal resets the DSP56311.



TIO can connect to the  $\overrightarrow{\text{RESET}}$  pin, internal hardware preserves the TIO value and direction for an additional 2.5 clocks to ensure a reset of valid length.

#### Figure 9-18. Watchdog Pulse Mode

#### 9.3.4.2 Watchdog Toggle (Mode 10)

|     | Bit Se | ettings |     |      | Mode Characteristics |          |        |          |  |
|-----|--------|---------|-----|------|----------------------|----------|--------|----------|--|
| TC3 | TC2    | TC1     | TC0 | Mode | Name                 | Function | τιο    | Clock    |  |
| 1   | 0      | 1       | 0   | 10   | Toggle               | Watchdog | Output | Internal |  |

In Mode 10, the timer toggles an external signal after a preset period. The TIO signal is set to the value of the INV bit. When the counter equals the value in the TCPR, TCSR[TCF] is set, and a compare interrupt is generated if the TCSR[TCIE] bit is also set. If the TCSR[TRM] bit is set, the counter loads with the TLR value on the next timer clock and the count resumes. Therefore, TRM = 1 is not useful for watchdog functions. If the TCSR[TRM] bit is cleared, the counter continues to increment on each subsequent timer clock. When a counter overflow occurs, the polarity of the TIO output signal is inverted. The counter is reloaded whenever the TLR is written with a new value while the TCSR[TE] bit is set. This process repeats until the timer is disabled. In Mode 10, internal logic preserves the TIO value and direction for an additional 2.5 internal clock cycles after the hardware RESET signal is asserted. This convention ensures that a valid reset signal is generated when the TIO signal resets the DSP56311.



TIO can connect to the RESET pin, internal hardware preserves the TIO value and direction for an additional 2.5 clocks to ensure a reset of valid length.

#### Figure 9-19. Watchdog Toggle Mode

#### 9.3.4.3 Reserved Modes

Modes 8, 11, 12, 13, 14, and 15 are reserved.

#### 9.3.5 Special Cases

The following special cases apply during wait and stop state.

- Timer behavior during wait Timer clocks are active during the execution of the WAIT instruction and timer activity is undisturbed. If a timer interrupt is generated, the DSP56311 leaves the wait state and services the interrupt.
- Timer behavior during stop During execution of the STOP instruction, the timer clocks are disabled, timer activity stops, and the TIO signals are disconnected. Any external changes that happen to the TIO signals are ignored when the DSP56311 is in stop state. To ensure correct operation, disable the timers before the DSP56311 is placed in stop state.

# 9.3.6 DMA Trigger

Each timer can also trigger DMA transfers if a DMA channel is programmed to be triggered by a timer event. The timer issues a DMA trigger on every event in all modes of operation. To ensure that all DMA triggers are serviced, provide for the preceding DMA trigger to be serviced before the DMA channel receives the next trigger.

# 9.4 Triple Timer Module Programming Model

The timer programmer's model in Figure 9-20 shows the structure of the timer registers.

# 9.4.1 Prescalar Counter

The prescalar counter is a 21-bit counter that decrements on the rising edge of the prescalar input clock. The counter is enabled when at least one of the three timers is enabled (that is, one or more of the timer enable bits are set) and is using the prescalar output as its source (that is, one or more of the PCE bits are set).

#### Freescale Semiconductor, Inc.



- Reserved bit. Read as 0. Write with 0 for future compatibility
  - Figure 9-20. Timer Module Programmer's Model

## 9.4.2 Timer Prescalar Load Register (TPLR)

The TPLR is a read/write register that controls the prescalar divide factor (i. e., the number that the prescalar counter loads and begins counting from) and the source for the prescalar input clock.

| 23   | 22   | 21  | 20   | 19   | 18   | 17   | 16   | 15   | 14   | 13   | 12   |
|------|------|-----|------|------|------|------|------|------|------|------|------|
|      | PS1  | PS0 | PL20 | PL19 | PL18 | PL17 | PL16 | PL15 | PL14 | PL13 | PL12 |
|      |      |     |      |      |      |      |      |      |      |      |      |
| 11   | 10   | 9   | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| PL11 | PL10 | PL9 | PL8  | PL7  | PL6  | PL5  | PL4  | PL3  | PL2  | PL1  | PL0  |

- Reserved bit. Read as 0. Write with 0 for future compatibility

Figure 9-21. Timer Prescalar Load Register (TPLR)

| Bit Number | Bit Name   | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                    |                        |  |  |
|------------|------------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------|------------------------|--|--|
| 23         |            | 0           | Reserved. Write                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | to zero for future | compatibility.         |  |  |
| 22 – 21    | PS[1 – 0]  | 0           | Prescalar Source<br>Control the source of the prescalar clock. The prescalar's use of a TIO<br>signal is not affected by the TCSR settings of the timer of the<br>corresponding TIO signal. If the prescalar source clock is external, the<br>prescalar counter is incremented by signal transitions on the TIO signal.<br>The external clock is internally synchronized to the internal clock. The<br>external clock frequency must be lower than the DSP56311 internal<br>operating frequency divided by 4 (that is, CLK/4).<br>NOTE: To ensure proper operation, change the PS[1 – 0] bits only<br>when the prescalar counter is disabled. Disable the prescalar counter<br>by clearing TCSR[TE] of each of three timers. |                    |                        |  |  |
|            |            |             | PS1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | PS0                | Prescalar Clock Source |  |  |
|            |            |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0                  | Internal CLK/2         |  |  |
|            |            |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 1                  | TIO0                   |  |  |
|            |            |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 0                  | TIO1                   |  |  |
|            |            |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 1                  | TIO2                   |  |  |
| 20 – 0     | PL[20 – 0] | 0           | Prescalar Preload ValueContains the prescalar preload value, which is loaded into the prescalar<br>counter when the counter value reaches 0 or the counter switches state<br>from disabled to enabled. If $PL[20 - 0] = N$ , then the prescalar counts<br>N+1 source clock cycles before generating a prescalar clock pulse.<br>Therefore, the prescalar divide factor = (preload value) + 1.                                                                                                                                                                                                                                                                                                                                |                    |                        |  |  |

# 9.4.3 Timer Prescalar Count Register (TPCR)

The TPCR is a read-only register that reflects the current value in the prescalar counter.

| 23   | 22   | 21  | 20   | 19   | 18   | 17   | 16   | 15   | 14   | 13   | 12   |
|------|------|-----|------|------|------|------|------|------|------|------|------|
|      |      |     | PC20 | PC19 | PC18 | PC17 | PC16 | PC15 | PC14 | PC13 | PC12 |
|      |      |     |      |      |      |      |      |      |      |      |      |
| 11   | 10   | 9   | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| PC11 | PC10 | PC9 | PC8  | PC7  | PC6  | PC5  | PC4  | PC3  | PC2  | PC1  | PC0  |

Reserved bit; read as 0; should be written with 0 for future compatibility

```
Figure 9-22. Timer Prescalar Count Register (TPCR)
```

| Table 9-2. Timer Prescalar Count Register (TPCR) Bit Definitions |
|------------------------------------------------------------------|
|------------------------------------------------------------------|

| Bit Number | Bit Name   | Reset Value | Description                                                                    |
|------------|------------|-------------|--------------------------------------------------------------------------------|
| 23 – 21    |            | 0           | Reserved. Write to zero for future compatibility.                              |
| 20 – 0     | PC[20 – 0] | 0           | Prescalar Counter Value<br>Contain the current value of the prescalar counter. |

# 9.4.4 Timer Control/Status Register (TCSR)

The TCSR is a read/write register controlling the timer and reflecting its status.

| 23 | 22 | 21  | 20  | 19 | 18 | 17 | 16 | 15  | 14 | 13 | 12 |
|----|----|-----|-----|----|----|----|----|-----|----|----|----|
|    |    | TCF | TOF |    |    |    |    | PCE |    | DO | DI |
| 11 | 10 | 9   | 8   | 7  | 6  | 5  | 4  | 3   | 2  | 1  | 0  |
|    |    |     |     |    |    |    |    |     |    |    |    |

Reserved. Read as 0. Write with 0 for future compatibility

Figure 9-23. Timer Control/Status Register (TCSR)

| Bit Number | Bit Name | Reset Value | Description                                       |
|------------|----------|-------------|---------------------------------------------------|
| 23 – 22    |          | 0           | Reserved. Write to zero for future compatibility. |

#### Table 9-3. Timer Control/Status Register (TCSR) Bit Definitions (Continued)

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|----------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21         | TCF      | 0           | <b>Timer Compare Flag</b><br>Indicate that the event count is complete. In timer, PWM, and watchdog<br>modes, the TCF bit is set after $(M - N + 1)$ events are counted. (M is the<br>value in the compare register and N is the TLR value.) In measurement<br>modes, the TCF bit is set when the measurement completes. Writing a<br>one to the TCF bit clears it. A zero written to the TCF bit has no effect.<br>The bit is also cleared when the timer compare interrupt is serviced. The<br>TCF bit is cleared by a hardware RESET signal, a software RESET<br>instruction, the STOP instruction, or by clearing the TCSR[TE] bit to<br>disable the timer.<br>NOTE: The TOF and TCF bits are cleared by a 1 written to the specific<br>bit. To ensure that only the target bit is cleared, do not use the BSET<br>command. The proper way to clear these bits is to write 1, using a<br>MOVEP instruction, to the flag to be cleared and 0 to the other flag. |
| 20         | TOF      | 0           | <b>Timer Overflow Flag</b><br>Indicates that a counter overflow has occurred. This bit is cleared by a<br>one written to the TOF bit. A zero written to TOF has no effect. The bit is<br>also cleared when the timer overflow interrupt is serviced. The TOF bit is<br>cleared by a hardware RESET signal, a software RESET instruction, the<br>STOP instruction, or by clearing the TCSR[TE] bit to disable the timer.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 19 – 16    |          | 0           | Reserved. Write to zero for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 15         | PCE      | 0           | <b>Prescalar Clock Enable</b><br>Selects the prescalar clock as the timer source clock. When PCE is<br>cleared, the timer uses either an internal (CLK/2) signal or an external<br>(TIO) signal as its source clock. When PCE is set, the prescalar output is<br>the timer source clock for the counter, regardless of the timer operating<br>mode. To ensure proper operation, the PCE bit is changed only when the<br>timer is disabled. The PS[1 – 0] bits of the TPLR determine which source<br>clock is used for the prescalar. A timer can be clocked by a prescalar<br>clock that is derived from the TIO of another timer.                                                                                                                                                                                                                                                                                                                                 |
| 14         |          | 0           | Reserved. Write to zero for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 13         | DO       | 0           | <b>Data Output</b><br>The source of the TIO value when it is a data output signal. The TIO<br>signal is a data output when the GPIO mode is enabled and DIR is set. A<br>value written to the DO bit is written to the TIO signal. If the INV bit is set,<br>the value of the DO bit is inverted when written to the TIO signal. When<br>the INV bit is cleared, the value of the DO bit is written directly to the TIO<br>signal. When GPIO mode is disabled, writing to the DO bit has no effect.                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 12         | DI       | 0           | <b>Data Input</b><br>Reflects the value of the TIO signal. If the INV bit is set, the value of the<br>TIO signal is inverted before it is written to the DI bit. If the INV bit is<br>cleared, the value of the TIO signal is written directly to the DI bit.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

#### Table 9-3. Timer Control/Status Register (TCSR) Bit Definitions (Continued)

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------|----------|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11         | DIR      | 0           | <b>Direction</b><br>Determines the behavior of the TIO signal when it functions as a GPIO signal. When DIR is set, the TIO signal is an output; when DIR is cleared, the TIO signal is an input. The TIO signal functions as a GPIO signal only when the $TC[3 - 0]$ bits are cleared. If any of the $TC[3 - 0]$ bits are set, then the GPIO function is disabled, and the DIR bit has no effect.                                                                                                                                                                                                                                                                                                                                                          |
| 10         |          | 0           | Reserved. Write to zero for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 9          | TRM      | 0           | <b>Timer Reload Mode</b><br>Controls the counter preload operation. In timer (0–3) and watchdog<br>(9–10) modes, the counter is preloaded with the TLR value after the<br>TCSR[TE] bit is set and the first internal or external clock signal is<br>received. If the TRM bit is set, the counter is reloaded each time after it<br>reaches the value contained by the TCR. In PWM mode (7), the counter<br>is reloaded each time counter overflow occurs. In measurement (4–5)<br>modes, if the TRM and the TCSR[TE] bits are set, the counter is<br>preloaded with the TLR value on each appropriate edge of the input<br>signal. If the TRM bit is cleared, the counter operates as a free running<br>counter and is incremented on each incoming event. |
| 8          | INV      | 0           | Inverter<br>Affects the polarity definition of the incoming signal on the TIO signal<br>when TIO is programmed as input. It also affects the polarity of the<br>output pulse generated on the TIO signal when TIO is programmed as<br>output. See <b>Table 9-4</b> , "Inverter (INV) Bit Operation," on page 9-28. The<br>INV bit does not affect the polarity of the prescalar source when the TIO<br>is input to the prescalar.<br>NOTE: The INV bit affects both the timer and GPIO modes of operation.<br>To ensure correct operation, change this bit only when one or both of the<br>following conditions is true: the timer is disabled (the TCSR[TE] bit is<br>cleared). The timer is in GPIO mode.                                                |

| Bit Number | Bit Name  | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |        |        |     |                |                             |                   |          |
|------------|-----------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--------|-----|----------------|-----------------------------|-------------------|----------|
| 7 – 4      | TC[3 – 0] | 0           | Timer ControlControl the source of the timer clock, the behavior of the TIO signal, and<br>the Timer mode of operation. Section 9.3, "Operating Modes," on page<br>9-4 describes the timer operating modes in detail.NOTE: To ensure proper operation, the TC[3 – 0] bits should be changed<br>only when the timer is disabled (that is, when the TCSR[TE] bit is<br>cleared)NOTE: If the clock is external, the counter is incremented by the<br>transitions on the TIO signal. The external clock is internally<br>synchronized to the internal clock, and its frequency should be lower<br>than the internal operating frequency divided by 4 (that is, CLK/4). |        |        |     |                |                             |                   |          |
|            |           |             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Bit Se | ttings |     | Ν              | Node Characte               | ristics           |          |
|            |           |             | тсз                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | TC2    | TC1    | тс0 | Mode<br>Number | Mode<br>Function            | τιο               | Clock    |
|            |           |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0      | 0      | 0   | 0              | Timer and<br>GPIO           | GPIO <sup>1</sup> | Internal |
|            |           |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0      | 0      | 1   | 1              | Timer pulse                 | Output            | Internal |
|            |           |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0      | 1      | 0   | 2              | Timer toggle                | Output            | Internal |
|            |           |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0      | 1      | 1   | 3              | Event counter               | Input             | External |
|            |           |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1      | 0      | 0   | 4              | Input width<br>measurement  | Input             | Internal |
|            |           |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1      | 0      | 1   | 5              | Input period<br>measurement | Input             | Internal |
|            |           |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1      | 1      | 0   | 6              | Capture event               | Input             | Internal |
|            |           |             | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1      | 1      | 1   | 7              | Pulse width modulation      | Output            | Internal |
|            |           |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0      | 0      | 0   | 8              | Reserved                    | —                 | —        |
|            |           |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0      | 0      | 1   | 9              | Watchdog<br>pulse           | Output            | Internal |
|            |           |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0      | 1      | 0   | 10             | Watchdog<br>Toggle          | Output            | Internal |
|            |           |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 0      | 1      | 1   | 11             | Reserved                    | —                 | —        |
|            |           |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1      | 0      | 0   | 12             | Reserved                    | —                 | —        |
|            |           |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1      | 0      | 1   | 13             | Reserved                    | —                 |          |
|            |           |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1      | 1      | 0   | 14             | Reserved                    | —                 | —        |
|            |           |             | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 1      | 1      | 1   | 15             | Reserved                    | —                 | _        |
|            |           |             | Note 1 : The GPIO function is enabled only if all of the $TC[3 - 0]$ b 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |        |        |     |                | ] bits are                  |                   |          |
| 3          |           | 0           | Reserved. Write to zero for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        |        |     |                |                             |                   |          |

#### Table 9-3. Timer Control/Status Register (TCSR) Bit Definitions (Continued)

#### Table 9-3. Timer Control/Status Register (TCSR) Bit Definitions (Continued)

| Bit Number | Bit Name | Reset Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|----------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2          | TCIE     | 0           | <b>Timer Compare Interrupt Enable</b><br>Enables/disables the timer compare interrupts. When set, TCIE enables the compare interrupts. In the timer, pulse width modulation (PWM), or watchdog modes, a compare interrupt is generated after the counter value matches the value of the TCPR. The counter starts counting up from the number loaded from the TLR and if the TCPR value is M, an interrupt occurs after (M – N + 1) events, where N is the value of TLR. When cleared, the TCSR[TCIE] bit disables the compare interrupts.                           |
| 1          | TOIE     | 0           | <b>Timer Overflow Interrupt Enable</b><br>Enables timer overflow interrupts. When set, TOIE enables overflow<br>interrupt generation. The timer counter can hold a maximum value of<br>\$FFFFFF. When the counter value is at the maximum value and a new<br>event causes the counter to be incremented to \$000000, the timer<br>generates an overflow interrupt. When cleared, the TOIE bit disables<br>overflow interrupt generation.                                                                                                                            |
| 0          | TE       | 0           | Timer EnableEnables/disables the timer. When set, TE enables the timer and clearsthe timer counter. The counter starts counting according to the modeselected by the timer control $(TC[3 - 0])$ bit values. When clear, TE bitdisables the timer.NOTE: When all three timers are disabled and the signals are not inGPIO mode, all three TIO signals are tri-stated. To prevent undesiredspikes on the TIO signals when you switch from tri-state into active state,these signals should be tied to the high or low signal state by pull-up orpull-down resistors. |

| Table 9-4. | Inverter (INV) Bit Operation |
|------------|------------------------------|
|------------|------------------------------|

| Mode | TIO Program                                                                               | med as Input                                                                               | TIO Programmed as Output                              |                                                           |  |
|------|-------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|-------------------------------------------------------|-----------------------------------------------------------|--|
|      | INV = 0                                                                                   | INV = 1                                                                                    | INV = 0                                               | INV = 1                                                   |  |
| 0    | GPIO signal on the TIO signal read directly.                                              | GPIO signal on the TIO signal inverted.                                                    | Bit written to GPIO<br>put on TIO signal<br>directly. | Bit written to GPIO<br>inverted and put on<br>TIO signal. |  |
| 1    | Counter is incremented on<br>the <b>rising</b> edge of the<br>signal from the TIO signal. | Counter is incremented on<br>the <b>falling</b> edge of the<br>signal from the TIO signal. |                                                       |                                                           |  |
| 2    | Counter is incremented on the <b>rising</b> edge of the signal from the TIO signal.       | Counter is incremented on<br>the <b>falling</b> edge of the<br>signal from the TIO signal. | Initial output put on TIO signal directly.            | Initial output inverted and put on TIO signal.            |  |
| 3    | Counter is incremented on<br>the <b>rising</b> edge of the<br>signal from the TIO signal. | Counter is incremented on<br>the <b>falling</b> edge of the<br>signal from the TIO signal. |                                                       |                                                           |  |

| Mode | TIO Program                                                                    | med as Input                                                                    | TIO Programmed as Output                                   |                                                            |  |
|------|--------------------------------------------------------------------------------|---------------------------------------------------------------------------------|------------------------------------------------------------|------------------------------------------------------------|--|
| wode | INV = 0                                                                        | INV = 1                                                                         | INV = 0                                                    | INV = 1                                                    |  |
| 4    | Width of the <b>high</b> input pulse is measured.                              | Width of the <b>low</b> input pulse is measured.                                | _                                                          | _                                                          |  |
| 5    | Period is measured<br>between the <b>rising</b> edges<br>of the input signal.  | Period is measured<br>between the <b>falling</b> edges<br>of the input signal.  | _                                                          | _                                                          |  |
| 6    | Event is captured on the <b>rising</b> edge of the signal from the TIO signal. | Event is captured on the <b>falling</b> edge of the signal from the TIO signal. |                                                            |                                                            |  |
| 7    |                                                                                | _                                                                               | Pulse generated by the timer has <b>positive</b> polarity. | Pulse generated by the timer has <b>negative</b> polarity. |  |
| 9    |                                                                                | _                                                                               | Pulse generated by the timer has <b>positive</b> polarity. | Pulse generated by the timer has <b>negative</b> polarity. |  |
| 10   |                                                                                | _                                                                               | Pulse generated by the timer has <b>positive</b> polarity. | Pulse generated by the timer has <b>negative</b> polarity. |  |

| Table 9-4. | Inverter (INV) | <b>Bit Operation</b> | (Continued) |
|------------|----------------|----------------------|-------------|
|------------|----------------|----------------------|-------------|

# 9.4.5 Timer Load Register (TLR)

The TLR is a 24-bit write-only register. In all modes, the counter is preloaded with the TLR value after the TCSR[TE] bit is set and a first event occurs.

- In timer modes, if the TCSR[TRM] bit is set, the counter is reloaded each time after it reaches the value contained by the timer compare register and the new event occurs.
- In measurement modes, if TCSR[TRM] and TCSR[TE] are set, the counter is reloaded with the value in the TLR on each appropriate edge of the input signal.
- In PWM modes, if TCSR[TRM] is set, the counter is reloaded each time after it overflows and the new event occurs.
- In watchdog modes, if TCSR[TRM] is set, the counter is reloaded each time after it reaches the value contained by the timer compare register and the new event occurs. In this mode, the counter is also reloaded whenever the TLR is written with a new value while TCSR[TE] is set.
- In all modes, if TCSR[TRM] is cleared (TRM = 0), the counter operates as a free-running counter.

Triple Timer Module Programming Model

#### 9.4.6 Timer Compare Register (TCPR)

The TCPR is a 24-bit read/write register that contains the value to be compared to the counter value. These two values are compared every timer clock after TCSR[TE] is set. When the values match, the timer compare flag bit is set and an interrupt is generated if interrupts are enabled (that is, the timer compare interrupt enable bit in the TCSR is set). The TCPR is ignored in measurement modes.

# 9.4.7 Timer Count Register (TCR)

The TCR is a 24-bit read-only register. In timer and watchdog modes, the contents of the counter can be read at any time from the TCR register. In measurement modes, the TCR is loaded with the current value of the counter on the appropriate edge of the input signal, and its value can be read to determine the width, period, or delay of the leading edge of the input signal. When the timer is in measurement mode, the TIO signal is used for the input signal.

# **Chapter 10** Enhanced Filter Coprocessor (EFCOP)

The EFCOP peripheral module functions as a general-purpose, fully programmable filter. It has optimized modes of operation to perform real and complex finite impulse response (FIR) filtering, infinite impulse response (IIR) filtering, adaptive FIR filtering, and multichannel FIR filtering. EFCOP filter operations complete concurrently with DSP56300 core operations, with minimal CPU intervention. For optimal performance, the EFCOP has one dedicated Filter Multiplier Accumulator (FMAC) unit. Thus, for filtering, the combination Core/EFCOP offers dual MAC capabilities. Its dedicated modes make the EFCOP a very flexible filter coprocessor with operations optimized for cellular base station applications. The EFCOP architecture also allows adaptive FIR filtering in which the filter coefficient update is performed using any fixed-point standard or non-standard adaptive algorithms—for example, the well-known Least Mean Square (LMS) algorithm, the Normalized LMS, and customized update algorithms. In a transceiver base station, the EFCOP can perform complex matched filtering to maximize the signal-to-noise ratio (SNR) within an equalizer. In a transcoder base station or a mobile switching center, the EFCOP can perform all types of FIR and IIR filtering within a vocoder, as well as LMS-type echo cancellation.

The first half of this chapter describes the structure and function of the EFCOP, examining its features, architecture, and programming model. The remainder of the chapter covers programming topics, such as transferring data to and from the EFCOP, using it in different modes, and examples of usage.

# **10.1** Features

- Fully programmable real/complex filter machine with 24-bit resolution
- FIR filter options
  - Four modes of operation with optimized performance:
    - Mode 0, FIR machine with real taps
    - Mode 1, FIR machine with complex taps
    - Mode 2, Complex FIR machine generating pure real/imaginary outputs alternately
    - Mode 3—Magnitude (calculate the square of each input sample)

- 4-bit decimation factor in FIR filters providing up to 1:16 decimation ratio
- Easy to use adaptive mode supporting true or delayed LMS-type algorithms
- K-constant input register for coefficient updates (in adaptive mode)
- IIR filter options:
  - Direct form 1 (DFI) and direct form 2 (DFII) configurations<sup>1</sup>
  - Three optional output scaling factors (1, 8, or 16)
- Multichannel mode to process multiple, equal-length filter channels (up to 64) simultaneously with minimal core intervention
- Optional input scaling for both FIR and IIR filters
- Two filter initialization modes
  - No initialization
  - Data initialization
- Sixteen-bit arithmetic mode support
- Three rounding options available:
  - No rounding
  - Convergent rounding
  - Two's complement rounding
- Arithmetic saturation mode support for bit-exact applications
- Sticky saturation status bit indication
- Sticky data/coefficient transfer contention status bit
- 4-word deep input data buffer for maximum performance
- EFCOP-shared and core-shared 10K-word filter data memory bank and 10K-word filter coefficient memory bank
- Two memory bank base address pointers, one for data memory (shared with X memory) and one for coefficient memory (shared with Y memory)
- I/O data transfers via core or DMA with minimal core intervention
- Core-concurrent operation with minimal core intervention

<sup>1.</sup> For details on DFI and DFII modes, refer to the Motorola application note entitled *Implementing IIR/FIR Filters with Motorola's DSP56000/DSP56001* (APR7/D).

# **10.2** Architecture Overview

As **Figure 10-1** shows, the EFCOP comprises these main functional blocks:

- Peripheral module bus (PMB) interface, including:
  - Data input buffer
  - Constant input buffer
  - Output buffer
  - Filter counter
- Filter data memory (FDM) bank
- Filter coefficient memory (FCM) bank
- Filter multiplier accumulator (FMAC) machine
- Address generator
- Control logic



Figure 10-1. EFCOP Block Diagram

## **10.2.1** PMB Interface

The PMB interface block contains control and status registers, buffers the internal bus from the PMB, decodes and generates addresses, and controls the handshake signals required for DMA and interrupt operations. The block generates interrupt and DMA trigger signals for data transfers. The interface registers accessible to the DSP56300 core through the PMB are summarized in **Table 10-1**.

| Register Name                                      | Description                                                                                                                                                                                                            |
|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Filter Data Input<br>Register (FDIR)               | A 4-word-deep 24-bit-wide FIFO used for DSP-to-EFCOP data transfers. Data from the FDIR is transferred to the FDM for filter processing.                                                                               |
| Filter Data Output<br>Register (FDOR)              | A 24-bit-wide register used for EFCOP-to-DSP data transfers. Data is transferred to FDOR after processing of all filter taps is completed for a specific set of input samples.                                         |
| Filter K-Constant Input<br>Register (FKIR)         | A 24-bit register for DSP-to-EFCOP constant transfers.                                                                                                                                                                 |
| Filter Count (FCNT)<br>Register                    | A 24-bit register that specifies the number of filter taps. The count stored in the FCNT register is used by the EFCOP address generation logic to generate correct addressing to the FDM and FCM.                     |
| EFCOP Control Status<br>Register (FCSR)            | A 24-bit read/write register used by the DSP56300 core to program the EFCOP and to examine the status of the EFCOP module.                                                                                             |
| EFCOP ALU Control<br>Register (FACR)               | A 24-bit read/write register used by the DSP56300 core to program the EFCOP data ALU operating modes.                                                                                                                  |
| EFCOP Data Buffer<br>Base Address (FDBA)           | A 16-bit read/write register used by the DSP56300 core to indicate the EFCOP the data buffer base start address pointer in FDM RAM.                                                                                    |
| EFCOP Coefficient<br>Buffer Base Address<br>(FCBA) | A 16-bit read/write register by which the DSP56300 core indicates the EFCOP coefficient buffer base start address pointer in FCM RAM.                                                                                  |
| Decimation/<br>Channel Count<br>Register (FDCH)    | A 24-bit register that sets the number of channels in multichannel mode and the filter decimation ratio. The EFCOP address generation logic uses this information to supply the correct addressing to the FDM and FCM. |

|  | Table 10-1. | <b>EFCOP</b> Registers | Accessible Through the PMB |
|--|-------------|------------------------|----------------------------|
|--|-------------|------------------------|----------------------------|

# 10.2.2 EFCOP Memory Banks

The EFCOP contains two memory banks:

Filter Data Memory (FDM)—This 24-bit-wide memory bank is mapped as X memory and stores input data samples for EFCOP filter processing. The FDM is written via a 4-word FIFO (FDIR), and its addressing is generated by the EFCOP address generation logic. The input data samples are read sequentially from the FDM into the MAC. The FDM is accessible for writes by the core, and the DMA controller and is shared with the 10K lowest locations (\$0–\$2800) of the on-chip internal X memory.

- Filter Coefficient Memory (FCM)—This 24-bit-wide memory bank is mapped as Y memory and stores filter coefficients for EFCOP filter processing. The FCM is written via the DSP56300 core, and the EFCOP address generation logic generates its addressing. The filter coefficients are read sequentially from the FCM into the MAC. The FCM is accessible for writes only by the core. The FCM is shared with the 10K lowest locations (\$0-\$2800 of the on-chip internal Y memory.
- **Note:** The filter coefficients, H(n), are stored in "reverse order," where H(N-1) is stored at the lowest address of the FCM register as shown in **Figure 10-2**.

|        | D(0) |
|--------|------|
|        | D(1) |
|        | D(2) |
| Data   | D(3) |
| Memory | D(4) |
| Bank   | D(5) |
| (FDM)  | -    |
|        | -    |
|        |      |



Figure 10-2. Storage of Filter Coefficients

The EFCOP connects to the shared memory in place of the DMA bus. Simultaneous core and EFCOP accesses to the same memory module block (256 locations) of shared memory are not permitted. It is your responsibility to prevent such simultaneous accesses. **Figure 10-3** illustrates the memory shared between the core and the EFCOP.



Figure 10-3. EFCOP Memory Organization

## **10.2.3** Filter Multiplier and Accumulator (FMAC)

The FMAC machine can perform a 24-bit  $\times$  24-bit multiplication with accumulation in a 56-bit accumulator. The FMAC operates a pipeline: the multiplication is performed in one clock cycle, and the accumulation occurs in the following clock cycle. Throughput is one MAC result per clock cycle. The two MAC operands are read from the FDM and from the FCM. The full 56-bit width of the accumulator is used for intermediate results during the filter calculations.

For operations in which saturation mode is disabled, the final result is rounded according to the selected rounding mode and limited to the most positive number (\$7FFFFF, if overflow occurred) or most negative number (\$800000, if underflow occurred) after processing of all filter taps is completed. In saturation mode, the result is limited to the most positive number (\$7FFFFF, if overflow occurred), or the most negative number (\$800000, if underflow occurred) after each MAC operation. The 24-bit result from the FMAC is stored in the EFCOP output buffer, FDOR.

Operating in sixteen-bit arithmetic mode, the FMAC performs a 16-bit  $\times$  16-bit multiplication with accumulation into a 40-bit accumulator. As with 24-bit operations, if saturation mode is disabled, the result is rounded according to the selected rounding mode and limited to the most positive number (\$7FFF, if overflow occurred) or the most negative number (\$8000, if underflow occurred) after processing of all filter taps is completed. In saturation mode, the result is limited to the most positive number (\$7FFF, if overflow occurred) or the most overflow occurred) or the most negative number (\$8000, if underflow occurred) after processing of all filter taps is completed. In saturation mode, the result is limited to the most positive number (\$7FFF, if overflow occurred) or the most negative number (\$8000, if underflow occurred) after every MAC operation. The 16-bit result from the FMAC is stored in the EFCOP output buffer, FDOR.

# **10.3 EFCOP Programming Model**

This section documents the registers for configuring and operating the EFCOP. The EFCOP registers available to the DSP programmer are listed in **Table 10-2**. The following paragraphs describe these registers in detail.

| Address   | EFCOP Register Name                    |
|-----------|----------------------------------------|
| Y:\$FFFB0 | Filter data input register (FDIR)      |
| Y:\$FFFB1 | Filter data output register (FDOR)     |
| Y:\$FFFB2 | Filter K-constant register (FKIR)      |
| Y:\$FFFB3 | Filter count register (FCNT)           |
| Y:\$FFFB4 | Filter control status register (FCSR)  |
| Y:\$FFFB5 | Filter ALU control register (FACR)     |
| Y:\$FFFB6 | Filter data buffer base address (FDBA) |

| Table 10-2.         EFCOP Registers and Base Addresses |
|--------------------------------------------------------|
|--------------------------------------------------------|

Semiconductor, Inc

eescale

| Address                                                        | EFCOP Register Name                    |  |  |  |  |
|----------------------------------------------------------------|----------------------------------------|--|--|--|--|
| Y:\$FFFB7                                                      | Filter coefficient base address (FCBA) |  |  |  |  |
| Y:\$FFFB8 Filter decimation/channel register (FDCH)            |                                        |  |  |  |  |
| NOTE: The EFCOP registers are mapped onto Y data memory space. |                                        |  |  |  |  |

Table 10-2. EFCOP Registers and Base Addresses (Continued)

10.3.1 Filter Data Input Register (FDIR)

The FDIR is a 4-word deep, 24-bit wide FIFO for DSP-to-EFCOP data transfers. Up to four data samples can be written into the FDIR at the same address. Data from the FDIR is transferred to the FDM for filter processing. For proper operation, write data to the FDIR only if the FDIBE status bit is set, indicating that the FIFO is empty. A write to the FDIR clears the FDIBE bit. Data transfers can be triggered by an interrupt request (for core transfers) or a DMA request (for DMA transfers). The FDIR is accessible for writes by the DSP56300 core and the DMA controller.

# 10.3.2 Filter Data Output Register (FDOR)

The FDOR is a 24-bit read-only register for EFCOP-to-DSP data transfers. The result of the filter processing is transferred from the FMAC to the FDOR. For proper operation, read data from the FDOR only if the FDOBF status bit is set, indicating that the FDOR contains data. A read from the FDOR clears the FDOBF bit. Data transfers can be triggered by an interrupt request (for core transfers) or a DMA request (DMA transfers). The FDOR is accessible for reads by the DSP56300 core and the DMA controller.

# **10.3.3** Filter K-Constant Input Register (FKIR)

The Filter K-Constant Input Register (FKIR) is a 24-bit write-only register for DSP-to-EFCOP data transfers in adaptive mode where the value stored in FKIR represents the weight update multiplier. FKIR is accessible only to the DSP core for reads or writes. When adaptive mode is enabled, the EFCOP immediately starts the coefficient update if a K-Constant value is written to FKIR. If no value is written to FKIR for the current data sample, the EFCOP halts processing until the K-Constant is written to FKIR. After the weight update multiplier is written to FKIR, the EFCOP transfers it to the FMAC unit and starts updating the filter coefficients according to the following equation:

```
New_coefficients = Old_coefficients + FKIR * Input_buffer
```

# 10.3.4 Filter Count (FCNT) Register

The FCNT register is a read/write register that selects the filter length (number of filter taps). Always write the initial count into the FCNT register before you enable the EFCOP

(that is, before you set FEN). The number stored in FCNT is used to generate the correct addressing for the FDM and for the FCM.

Note: To ensure correct operation, never change the contents of the FCNT register unless the EFCOP is in the individual reset state (that is, FEN = 0). In the individual reset state (that is, FEN = 0), the EFCOP module is inactive, but the contents of the FCNT register are preserved.

| 23     | 22     | 21    | 20    | 19    | 18    | 17    | 16    | 15    | 14    | 13    | 12    |
|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|        |        |       |       |       |       |       |       |       |       |       |       |
| 11     | 10     | 9     | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| FCNT11 | FCNT10 | FCNT9 | FCNT8 | FCNT7 | FCNT6 | FCNT5 | FCNT4 | FCNT3 | FCNT2 | FCNT1 | FCNT0 |

= Reserved bit; read as 0; should be written with 0 for future compatibility

| Figure 10-4. | Filter Count (FCNT) Register |
|--------------|------------------------------|
|--------------|------------------------------|

| Table 10-3. | Filter Count FCNT | <b>Register Bits</b> |
|-------------|-------------------|----------------------|
|-------------|-------------------|----------------------|

| Bit # | Abbr. | Description                                                                                                                                                                                                                                                                                                                                                                                           |
|-------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23–12 |       | These bits are reserved and unused. They are read as 0 and should be written with 0 for future compatibility.                                                                                                                                                                                                                                                                                         |
| 11–0  |       | <b>Filter Count</b> —The actual value written to the FCNT register must be the number of coefficient values minus one. The number of coefficient values is the number of locations used in the FCM. For a real FIR filter, the number of coefficient values is identical to the number of filter taps. For a complex FIR filter, the number of coefficient values is twice the number of filter taps. |

# **10.3.5** EFCOP Control Status Register (FCSR)

The FCSR is a 24-bit read/write register by which the DSP56300 core controls the main operation modes of the EFCOP and monitors the EFCOP status.

| 23    | 22    | 21 | 20   | 19   | 18   | 17   | 16   | 15    | 14    | 13    | 12   |
|-------|-------|----|------|------|------|------|------|-------|-------|-------|------|
|       |       |    |      |      |      |      |      | FDOBF | FDIBE | FCONT | FSAT |
| 11    | 10    | 9  | 8    | 7    | 6    | 5    | 4    | 3     | 2     | 1     | 0    |
| FDOIE | FDIIE |    | FSCO | FPRC | FMLC | FOM1 | FOM0 | FUPD  | FADP  | FLT   | FEN  |

Reserved bit; read as 0; should be written with 0 for future compatibility

#### Table 10-4.FCSR Bits

| Bit<br>Number | Bit Name | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|---------------|----------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23–16         |          | 0              | These bits are reserved and unused. They are read as 0 and should be written with 0 for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 15            | FDOBF    | 0              | <b>Filter Data Output Buffer Full</b> — When set, this read-only status bit indicates that the FDOR is full and the DSP can read data from the FDOR. The FDOBF bit is set when a result from FMAC is transferred to the FDOR. For proper operation, read data from the FDOR only if the FDOBF status bit is set. When FDOBF is set, the EFCOP generates an FDOBF interrupt request to the DSP56300 core if that interrupt is enabled (that is, FDOIE = 1). A DMA request is always generated when the FDOBF bit is set, but a DMA transfer takes place only if a DMA channel is activated and triggered by this event. A read from the FDOR clears the FDOBF bit.                                                                        |
| 14            | FDIBE    | 0              | <b>Filter Data Input Buffer Empty</b> —When set, this read-only status bit indicates that the FDIR is empty and the DSP can write data to the FDIR. The FDIBE bit is set when all four FDIR locations are empty. For proper operation, write data to the FDIR only if FDIBE is set. After the EFCOP is enabled by setting FEN, FDIBE is set, indicating that the FDIR is empty. When FDIBE is set, the EFCOP generates an FDIR empty interrupt request to the DSP56300 core, if enabled (that is, FDIIE = 1). A DMA request is always generated when the FDIBE bit is set, but a DMA transfer takes place only if a DMA channel is activated and triggered by this event. A write to the FDIR clears the FDIBE bit.                      |
| 13            | FCONT    | 0              | <b>Filter Contention</b> —When set, this read-only status bit indicates an attempt by both the DSP56300 core and the EFCOP to access the same 256-word bank in either the shared FDM or FCM. A dual access could result in faulty data output in the FDOR. Once set, the FCONT bit is a sticky bit that can only be cleared by a hardware RESET signal, a software RESET instruction, or an individual reset.                                                                                                                                                                                                                                                                                                                            |
| 12            | FSAT     | 0              | <b>Filter Saturation</b> —When set, this read-only status bit indicates that an overflow or underflow occurred in the MAC result. When an overflow occurs, the FSAT bit is set, and the result is saturated to the most positive number (that is, \$7FFFFF). When an underflow occurs, the FSAT bit is set, and the result is saturated to the most negative number (that is, \$800000). FSAT is a sticky status bit that is set by hardware and can be cleared only by a hardware RESET signal, a software RESET instruction, or an individual reset.                                                                                                                                                                                   |
| 11            | FDOIE    | 0              | Filter Data Output Interrupt Enable—This read/write control bit enables the filter data output interrupt. If FDOIE is cleared, the filter data output interrupt is disabled, and the FDOBF status bit should be polled to determine whether the FDOR is full. If both FDOIE and FDOBF are set, the EFCOP requests a data output buffer full interrupt service from the DSP56300 core. A DMA transfer is enabled if a DMA channel is activated and triggered by this event.<br>NOTE: For proper operation, enable the interrupt service routine and the corresponding interrupt for core processing <i>or</i> enable the DMA transfer and configure the proper trigger for the selected channel. <i>Never</i> enable both simultaneously. |

|               |             | _              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------|-------------|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit<br>Number | Bit Name    | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 10            | FDIIE       | 0              | <b>Filter Data Input Interrupt Enable</b> —This read/write control bit enables the data input buffer empty interrupt. If FDIIE is cleared, the data input buffer empty interrupt is disabled, and the FDIBE status bit should be polled to determine whether the FDIR is empty. If both FDIIE and FDIBE are set, the EFCOP requests a data input buffer empty interrupt service from the DSP56300 core. DMA transfer is enabled if a DMA channel is activated and triggered by this event.                                      |
|               |             |                | NOTE: For proper operation, enable the interrupt service routine and the corresponding interrupt for core processing <i>or</i> enable the DMA transfer and configure the proper trigger for the selected channel. <i>Never</i> enable both simultaneously.                                                                                                                                                                                                                                                                      |
| 9             |             | 0              | Reserved. It is read as 0 and should be written with 0 for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 8             | FSCO        | 0              | <b>Filter Shared Coefficients Mode</b> —This read/write control bit is valid only when<br>the EFCOP is operating in multichannel mode (that is, FMLC is set). When<br>FSCO is set, the EFCOP uses the coefficients in the same memory area (that is,<br>the same coefficients) to implement the filter for each channel. This mode is used<br>when several channels are filtered through the same filter. When the FSCO bit is<br>cleared, the EFCOP filter coefficients are stored sequentially in memory for each<br>channel. |
|               |             |                | NOTE: To ensure proper operation, never change the FSCO bit unless the EFCOP is in individual reset state (that is, $FEN = 0$ ).                                                                                                                                                                                                                                                                                                                                                                                                |
| 7             | FPRC        | 0              | Filter Processing (FPRC) State Initialization Mode—This read/write control bit defines the EFCOP processing initialization mode. When this bit is cleared, the EFCOP starts processing after a state initialization. (The EFCOP machine starts computing once the FDM bank contains N input samples for an N tap filter). When this bit is set, the EFCOP starts processing with no state initialization. (The EFCOP machine starts computing as soon as the first data sample is available in the input buffer.)               |
|               |             |                | NOTE: To ensure proper operation, never change the FPRC bit unless the EFCOP is in individual reset state (that is, FEN = 0).                                                                                                                                                                                                                                                                                                                                                                                                   |
| 6             | FMLC        | 0              | Filter Multichannel (FMLC) Mode—This read/write control bit enables<br>multichannel mode, allowing the EFCOP to process several filters (defined by<br>FCHL[5:0] bits in FDCH register) concurrently by sequentially entering a different<br>sample to each filter. If FMLC is cleared, multichannel mode is disabled, and the<br>EFCOP operates in single filter mode.<br>NOTE: To ensure proper operation, never change the FMLC bit unless the<br>EFCOP is in individual reset state (that is, FEN = 0).                     |
|               | <b>E014</b> |                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 5–4           | FOM         | 0              | Filter Operation Mode—This pair of read/write control bits defines one of four<br>operation modes if the FIR filter is selected (that is, FLT is cleared):<br>FOM = 00—Mode 0: Real FIR filter<br>FOM = 01—Mode 1: Full complex FIR filter<br>FOM = 10—Mode 2: Complex FIR filter with alternate real and imaginary outputs<br>FOM = 11—Mode 3: Magnitude<br>NOTE: To ensure proper operation, never change the FOM bits unless the<br>EFCOP is in the individual reset state (that is, FEN = 0).                               |

| Table 10-4. | FCSR Bits | (Continued) |
|-------------|-----------|-------------|
|-------------|-----------|-------------|

| Bit<br>Number | Bit Name | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|---------------|----------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3             | FUPD     | 0              | <b>Filter Update</b> —This read/write control/status bit enables the EFCOP to start a single coefficient update session. Upon completion of the session, the FUPD bit is automatically cleared. FUPD is automatically set when the EFCOP is in adaptive mode (that is, FADP = 1).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 2             | FADP     | 0              | <b>Filter Adaptive (FADP) Mode</b> —This read/write control bit enables adaptive mode. Adaptive mode is an efficient way to implement a LMS-type filter, and therefore it is used when the EFCOP operates in FIR filter mode (FLT = 0). In adaptive mode, processing of every input data sample consists of FIR processing followed by a coefficient update. When FADP is set, the EFCOP completes the FIR processing on the current data sample and immediately starts the coefficient update assuming that a K-constant value is written to the FKIR. If no value is written to the FKIR for the current data sample, the EFCOP halts processing until the K-constant is written to the FKIR. During the coefficient update, the FUPD bit is automatically set to indicate an update session. After completion of the update, the EFCOP starts processing the next data sample. |
| 1             | FLT      | 0              | <b>Filter (FLT) Type</b> —This read/write control bit selects one of two available filter<br>types:<br>FLT = 0—FIR filter<br>FLT = 1—IIR filter<br>NOTE: To ensure proper operation, never change the FLT bit unless the EFCOP<br>is in the individual reset state (that is, FEN = 0).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 0             | FEN      | 0              | <b>Filter Enable</b> —This read/write control bit enables the operation of the EFCOP.<br>When FEN is cleared, operation is disabled and the EFCOP is in the individual reset state.<br>In the individual reset state, the EFCOP is inactive; inter <u>nal logic</u> and status bits assume the same state as that produced by a hardware RESET signal or a software RESET instruction; the contents of the FCNT, FDBA, and FCBA registers are preserved; and the control bits in FCSR and FACR remain unchanged.                                                                                                                                                                                                                                                                                                                                                                  |

| Table 10-4. | FCSR Bits | (Continued) |
|-------------|-----------|-------------|
|-------------|-----------|-------------|

# **10.3.6** EFCOP ALU Control Register (FACR)

The FACR is a read/write register by which the DSP56300 core controls the main operation modes of the EFCOP ALU.



| Table 10-5. | EFCOP ALU Control Register (FACR) Bits |
|-------------|----------------------------------------|
|-------------|----------------------------------------|

| Bit<br>Number | Bit<br>Name | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------|-------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23–16         |             | 0              | Reserved. They are read as 0 and should be written with 0 for future compatibility.                                                                                                                                                                                                                                                                                                                                                                        |
| 15–12         |             | 0              | Reserved for internal use. Written as 0 for proper operation.                                                                                                                                                                                                                                                                                                                                                                                              |
| 11–7          |             | 0              | Reserved and unused. They are read as 0 and should be written with 0 for future compatibility.                                                                                                                                                                                                                                                                                                                                                             |
| 6             | FISL        | 0              | <b>Filter Input Scale</b> —When set, this read/write control bit directs the EFCOP ALU to scale the IIR feedback terms but not the IIR input. When cleared, the EFCOP ALU scales both the IIR feedback terms and the IIR input. The scaling value in both cases is determined by the FSCL[1:0] bits.                                                                                                                                                       |
| 5             | FSA         | 0              | <b>Filter Sixteen-bit Arithmetic (FSA) Mode</b> —When set, this read/write control bit enables FSA mode. In this mode, the rounding of the arithmetic operation is performed on Bit 31 of the 56-accumulator instead of the usual bit 23 of the 56-bit accumulator. The scaling of the EFCOP data ALU is affected accordingly.                                                                                                                             |
| 4             | FSM         | 0              | <b>Filter Saturation Mode</b> —When set, this read/write control bit selects automatic saturation on 48 bits for the results going to the accumulator. A special circuit inside the EFCOP MAC unit then saturates those results. The purpose of this bit is to provide arithmetic saturation mode for algorithms that do not recognize or cannot take advantage of the extension accumulator.                                                              |
| 3–2           | FRM         | 0              | Filter Rounding Mode—These read/write control bits select the type of rounding<br>performed by the EFCOP data ALU during arithmetic operation:<br>FRM = 00—Convergent rounding<br>FRM = 01—Two's complement rounding<br>FRM = 10—Truncation (no rounding)<br>FRM = 11—Reserved for future expansion<br>These bits affect operation of the EFCOP data ALU.                                                                                                  |
| 1–0           | FSCL        | 0              | Filter Scaling (FSCL)—These read/write control bits select the scaling factor of<br>the FMAC result:<br>FSCL = 00—Scaling factor = 1 (no shift)<br>FSCL = 01—Scaling factor = 8 (3-bit arithmetic left shift)<br>FSCL = 10—Scaling factor = 16 (4-bit arithmetic left shift)<br>FSCL = 11—Reserved for future expansion<br>To ensure proper operation, never change the FSCL bits unless the EFCOP is in<br>the individual reset state (that is, FEN = 0). |

# **10.3.7** EFCOP Data Base Address (FDBA)

The FDBA is a 16-bit read/write counter register used as an address pointer to the EFCOP FDM bank. FDBA points to the location to write the next data sample. The FDBA points to a modulo delay buffer of size M, defined by the filter length (M = FCNT[11:0] + 1). The address range of this modulo delay buffer is defined by lower and upper address boundaries. The lower address boundary is the FDBA value with 0 in the k-LSBs, where  $2^k \ge M \ge 2^{k-1}$ ; it therefore must be a multiple of  $2^k$ . The upper boundary is equal to the lower boundary plus (M – 1). Since  $M \le 2^k$ , once M has been chosen (that is, FCNT has been assigned), a sequential series of data memory blocks (each of length  $2^k$ ) will be created where multiple circular buffers for multichannel filtering can be located. If  $M < 2^k$ ,

there will be a space between sequential circular buffers of  $2^k - M$ . The address pointer is not required to start at the lower address boundary or to end on the upper address boundary. It can point anywhere within the defined modulo address range. If the data address pointer (FDBA) increments and reaches the upper boundary of the modulo buffer, it will wrap around to the lower boundary.

# **10.3.8** EFCOP Coefficient Base Address (FCBA)

The FCBA is a 16-bit read/write counter register used as an address pointer to the EFCOP FCM bank. FCBA points to the first location of the coefficient table. The FCBA points to a modulo buffer of size M, defined by the filter length (M = FCNT[11:0] + 1). The address range of this modulo buffer is defined by lower and upper address boundaries. The lower address boundary is the FCBA value with 0 in the k-LSBs, where  $2^k \ge M \ge 2^{k-1}$ ; it therefore must be a multiple of  $2^k$ . The upper boundary is equal to the lower boundary plus (M – 1). Since  $M \le 2^k$ , once M has been chosen (that is, FCNT has been assigned), a sequential series of coefficient memory blocks (each of length  $2^k$ ) is created where multiple circular buffers for multichannel filtering can be located. If  $M < 2^k$ , there will be a space between sequential circular buffers of  $2^k - M$ . The FCBA address pointer must be assigned to the lower address boundary (that is, it must have 0 in its k-LSBs). In a compute session, the coefficient address pointer always starts at the lower boundary and ends at the upper address boundary. Therefore, a FCBA read always gives the value of the lower address boundary.

# 10.3.9 Decimation/Channel Count Register (FDCH)

The FDCH is a read/write register that sets the number of channels used in multichannel mode (FCHL) and sets the decimation ratio in FIR filter mode. FDCH must be written before the FEN enables the EFCOP. FDCH should be changed only when the EFCOP is in individual reset state (FEN = 0); otherwise, improper operation may result. The number stored in FCHL is used by the EFCOP address generation logic to generate the correct address for the FDM bank and for the FCM bank in multichannel mode. When the EFCOP enable bit (FEN) is cleared, the EFCOP is in individual reset state. In this state, the EFCOP is inactive, and the contents of FDCH register are preserved.



#### Table 10-6. Decimation/Channel Count Register (FDCH) Bits

| Bit<br>Number | Bit<br>Name | Reset<br>Value | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------|-------------|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23–12         |             | 0              | These bits are reserved and unused. They are read as 0 and should be written with 0 for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                       |
| 11–8          | FDCM        | 0              | Filter Decimation—These read/write control bits select the decimation function.<br>There are 16 decimation factor options (from 1 to 16).<br>NOTE: To ensure proper operation, never change the FDCM bits unless the<br>EFCOP is in the individual reset state (FEN = 0).                                                                                                                                                                                                                           |
| 7–6           |             | 0              | Reserved and unused. They are read as 0 and should be written with 0 for future compatibility.                                                                                                                                                                                                                                                                                                                                                                                                      |
| 5–0           | FCHL        | 0              | <b>Filter Channels</b> —These read/write control bits determine the number of filter channels to process simultaneously (from 1 to 64) in multichannel mode. The number represented by the FCHL bits is one less than the number of channels to be processed; that is, if FCHL = 0, then 1 channel is processed; if FCHL =1, then 2 channels are processed; and so on.<br>NOTE: To ensure proper operation, never change the FCHL bits unless the EFCOP is in the individual reset state (FEN = 0). |

## **10.3.10** EFCOP Interrupt Vectors

**Table 10-7** shows the EFCOP interrupt vectors, and **Table 10-8** shows the DMA request sources.

| Table 10-7. | EFCOP | Interrupt | Vectors |
|-------------|-------|-----------|---------|
|-------------|-------|-----------|---------|

| Interrupt<br>Address | Interrupt Vector        | Priority | Interrupt<br>Enable | Interrupt<br>Conditions |
|----------------------|-------------------------|----------|---------------------|-------------------------|
| VBA + \$68           | Data input buffer empty | Highest  | FDIIE               | FDIBE = 1               |
| VBA + \$6A           | Data output buffer full | Lowest   | FDOIE               | FDOBF = 1               |

| Table 10-8. | EFCOP DMA Request Sources |
|-------------|---------------------------|
|-------------|---------------------------|

| Requesting Device Number | Request Conditions | Peripheral Request<br>MDRQ |  |
|--------------------------|--------------------|----------------------------|--|
| EFCOP input buffer empty | FDIBE = 1          | MDRQ11                     |  |
| EFCOP output buffer full | FDOBF = 1          | MDRQ12                     |  |

# **10.4** EFCOP Programming

The DSP56311 Enhanced Filter Coprocessor (EFCOP) supports both Finite Impulse Response (FIR) filters and Infinite Impulse Response (IIR) filters.<sup>1</sup> This section discusses the different ways data can be transferred in and out of the EFCOP and presents some programming examples in which such transfers are performed for FIR and IIR filters.

<sup>1.</sup> For details on FIR and IIR filters, refer to the Motorola application note entitled *Implementing IIR/FIR Filters with Motorola's DSP56000/DSP56001* (APR7/D).

EFCOP operation is determined by the control bits in the EFCOP Control/Status Register (FCSR), described in **Section 10.3.5**. Further filtering operations are enabled via the appropriate bits in the FACR and FDCH registers. After the FCSR is configured to the mode of choice, enable the EFCOP by setting FCSR[FEN]. To ensure proper EFCOP operation, most FCSR bits must not be changed while the EFCOP is enabled. **Table 10-9** summarizes the EFCOP operating modes.

| 6<br>FMLC | 5–4<br>FOM                                                    | 3                 | 2                                                                         | 1                                                      | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------|---------------------------------------------------------------|-------------------|---------------------------------------------------------------------------|--------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| x         |                                                               | FUPD <sup>2</sup> | FADP <sup>2</sup>                                                         | FLT                                                    | 0<br>FEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|           | х                                                             | х                 | x                                                                         | x                                                      | 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0         | 00                                                            | 0                 | 0                                                                         | 0                                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0         | 00                                                            | 0                 | 1                                                                         | 0                                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0         | 00                                                            | 1                 | 0                                                                         | 0                                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0         | 00                                                            | 1                 | 1                                                                         | 0                                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1         | 00                                                            | 0                 | 0                                                                         | 0                                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1         | 00                                                            | 0                 | 1                                                                         | 0                                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1         | 00                                                            | 1                 | 0                                                                         | 0                                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1         | 00                                                            | 1                 | 1                                                                         | 0                                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0         | 01                                                            | 0                 | 0                                                                         | 0                                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0         | 10                                                            | 0                 | 0                                                                         | 0                                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0         | 11                                                            | 0                 | 0                                                                         | 0                                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 0         | 00                                                            | 0                 | 0                                                                         | 1                                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 1         | 00                                                            | 0                 | 0                                                                         | 1                                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|           | 0<br>0<br>0<br>1<br>1<br>1<br>1<br>1<br>0<br>0<br>0<br>0<br>0 |                   | $\begin{array}{c c c c c c c c c } & & & & & & & & & & & & & & & & & & &$ | $\begin{array}{c c c c c c c c c c c c c c c c c c c $ | $\begin{array}{ c c c c c c c c } \hline 0 & 00 & 0 & 0 & 0 \\ \hline 0 & 00 & 0 & 1 & 0 \\ \hline 0 & 00 & 1 & 0 & 0 \\ \hline 0 & 00 & 1 & 0 & 0 \\ \hline 0 & 00 & 1 & 1 & 0 \\ \hline 1 & 00 & 0 & 0 & 0 \\ \hline 1 & 00 & 0 & 1 & 0 \\ \hline 1 & 00 & 1 & 0 & 0 \\ \hline 1 & 00 & 1 & 0 & 0 \\ \hline 1 & 00 & 1 & 0 & 0 \\ \hline 0 & 01 & 0 & 0 & 0 \\ \hline 0 & 10 & 0 & 0 & 0 \\ \hline 0 & 11 & 0 & 0 & 0 \\ \hline 0 & 00 & 0 & 0 & 0 \\ \hline \end{array}$ |

| Table 10-9. | <b>EFCOP Operating Modes</b> |
|-------------|------------------------------|
|-------------|------------------------------|

NOTES:

1. An  $\boldsymbol{x}$  indicates that the specified value can be 1 or 0.

2. If the user sets the FUPD bit, the EFCOP updates the coefficients and clears the FUPD bit. The adaptive mode (that is, FADP = 1) sets the FUPD bit, which causes the EFCOP to update the coefficients and then automatically clear the FUPD bit. Therefore, the value assigned to the FUPD bit in this table refers only to its initial setting and not its dynamic state during operation.

3. All bit combinations not defined by this table are reserved for future development.

# **10.5** Operation Summary

The EFCOP is very easy to use. To define the type of filtering to perform, you need only set the following registers (the settings in the FDCH and FACR are optional) and then enable the EFCOP by setting FCSR[FEN]:

- FCNT
- FDBA
- FCBA
- FCSR

Polling, DMA, or interrupts can then be used to write data to the FDIR and read data from the FDOR. As **Table 10-9** shows, the EFCOP operates in many different modes based on the settings of the control registers. However, the EFCOP performs only two basic types of processing, FIR filter type and IIR filter type processing. Various sub-options are available with each filter type, as described in the following sections.

## 10.5.1 FIR Filter Type

To select the FIR filter type clear FCSR[FLT] and perform the processing shown in **Figure 10-7** based on the equation shown below. The EFCOP takes an input, x(n), from

$$w(n) = \sum_{i=0}^{N} B_i x(n-i)$$

the FDIR, saves the input while shifting the previous inputs down in the FDM, multiplies each input in the FDM by the corresponding coefficient,  $B_i$ , stored in the FCM, accumulates the multiplication results, and places accumulation result, w(n), in the FDOR. This is done for each sample input to the FDIR.



Figure 10-7. FIR Filter Type Processing

There are four operating modes available with the FIR filter type: real, complex, alternating complex, and magnitude mode.

## 10.5.1.1 Real Mode

Real mode performs FIR type filtering with real data and is selected by clearing both FOM bits in the FCSR. One sample, the real input, is written to the FDIR, and the EFCOP processes the data. Then one sample, the real output, is read from the FDOR. Two other options are available with the real FIR filter type: adaptive and multichannel modes. These modes can be used individually or together.

#### 10.5.1.1.1 Adaptive Mode

Adaptive mode provides a way to update the coefficients based on filter input, x(n), using the following equation,

$$h_{n+1}(i) = h_n(i) + K_e(n)x(n-i)$$

where  $h_n(i)$  is the *i*th coefficient at time *n*. The coefficients are updated when FSCR[FUPD] is set. The EFCOP checks to see if a value has been written to the FKIR. If no value is written, the EFCOP halts processing until a value is written to the FKIR. When a value is written to the FKIR, the EFCOP updates all the coefficients based on the above equation using the value in the FKIR for  $K_e(n)$ . The EFCOP automatically clears FSCR[FUPD] when the coefficient update is complete.

If the coefficients are to be updated after every input sample, Adaptive mode is enabled by setting the FCSR[FADP]. In Adaptive mode, the EFCOP automatically sets the FUDP bit after each input sample is processed. This allows for continuous processing using interrupts that includes a filter session and a coefficient update session with minimal core intervention.

## 10.5.1.1.2 Multichannel Mode

Multichannel mode allows several channels of data to be processed concurrently and is selected by setting the FCSR[FMLC]. The number of channels to process is one plus the number in the FDCH[FDCM] bits. For each time period, the EFCOP expects to receive the samples for each channel sequentially. This is repeated for consecutive time periods.

Filtering can be done with the same filter or different filters for each channel by using the FCSR[FSCO] bit. If FCSR[FSCO] is set, the same set of coefficients are used for all channels. If FSCO is clear, the coefficients for each filter are stored sequentially in memory for each channel.

### 10.5.1.1.3 Complex Mode

Complex mode performs FIR type filtering with complex data based on the following equations: N-1

$$Re(F(n)) = \sum_{\substack{i,j=0\\k \neq -0}} Re(H(i)) \cdot Re(D(n-i)) - Im(H(i)) \cdot Im(D(n-i))$$
$$Im(F(n)) = \sum_{\substack{i=0\\k \neq -0}} Re(H(i)) \cdot Im(D(n-i)) + Im(H(i)) \cdot Re(D(n-i))$$

where H(n) is the coefficients, D(n) is the input data, and F(n) is the output data at time n. Two samples, the real part then the imaginary part of the input, are written to the FDIR. The EFCOP processes the data, and then two samples—the real and then the imaginary part of the output—are read from the FDOR.

Complex mode is selected by setting the FCSR[FOM] bits to 01. In Complex mode, the number written to the FCNT register should be twice the number of filter coefficients. Also, the coefficients are stored in the FCM with the real part of the coefficient in the memory location preceding the memory location holding the imaginary part of the coefficient.

#### 10.5.1.1.4 Alternating Complex Mode

Alternating Complex mode performs FIR type filtering with complex data, providing alternating real and complex results based on the following equations

$$Re(F(n|_{even})) = \sum_{\substack{N=1\\N-1}} Re(H(i)) \cdot Re(D(n-i)) - Im(H(i)) \cdot Im(D(n-i))$$
$$Im(F(n|_{odd})) = \sum_{\substack{i=0\\i=0}} Re(H(i)) \cdot Im(D(n-i)) + Im(H(i)) \cdot Re(D(n-i))$$

where H(n) is the coefficients, D(n) is the input data, and F(n) is the output data at time n. Two samples, the real part then the imaginary part of the input, are written to the FDIR. The EFCOP processes the data. Then one sample, alternating between the real part and the imaginary part of the output, is read from the FDOR.

Alternating Complex mode is selected by setting the FCSR[FOM] bits to 10. In Alternating Complex mode, the number written to the FCNT register should be twice the number of filter coefficients. Also, the coefficients should be stored in the FCM with the real part of the coefficient in the memory location preceding the memory location holding the imaginary part of the coefficient.

## 10.5.1.1.5 Magnitude Mode

Magnitude mode calculates the magnitude of an input signal based on the following equation:

$$F(n) = \sum_{i=0}^{N-1} D(n-i)^2$$

where D(n) is the input data and F(n) is the output data at time *n*. One sample, the real input, is written to the FDIR. The EFCOP processes the data. Then one sample, the real magnitude of the input signal, is read from the FDOR. Magnitude mode is selected by setting both the FCSR[FOM] bits.

#### 10.5.1.1.6 Initialization

Before the first sample is processed, the EFCOP filter must be initialized; that is, the input samples for times before n = 0 (assuming that time starts at 0) must be loaded into the FDM. The number of samples needed to initialize the filter is the number of filter coefficients minus one. To select Initialization mode, clear the FCSR[FPRC] bit. If FCSR[FPRC] is set, initialization is disabled and the EFCOP assumes that the core wrote the initial input values to the FDM before the EFCOP was enabled. Thus, the first value written to FDIR is the first sample to be filtered.

If FCSR[FPRC] is clear, initialization mode is enabled and the EFCOP initializes the FDM by receiving the number of coefficients minus one samples through the FDIR. After samples are loaded, the next value written to the FDIR is the first sample to be filtered.

### 10.5.1.1.7 Decimation

Decimation is another option that can be used with any four of the modes available with the FIR filter type. Decimation cannot be used in conjunction with Adaptive and Multichannel modes. Decimation decreases (downsamples) the sampling rate. The decimation ratio defines the number of input samples per output sample. The decimation ratio is one plus the number in the FDCH[FDCM] bits. The decimation ratio can be programmed from 1 to 16.

For Real and Magnitude modes the decimation ratio number of samples must be written to the FDIR before an output sample is read from the FDOR. For Complex mode, two times the decimation ratio number of samples (one for the real part and one for the imaginary part of the input) must be written to the FDIR before two output samples (one for the real part and one for the imaginary part of the output) can be read from the FDOR. For Alternating Complex mode, two times the decimation ratio number of samples must be written to the FDIR (one for the real part and one for the imaginary part of the input) before one output sample (alternating between the real part and the imaginary part of the output) can be read from the FDOR.

## 10.5.2 IIR Filter Type

To select the IIR filter type, set the FCSR[FLT] bit and perform the processing shown in **Figure 10-8** based on the equation shown here. The EFCOP multiplies each previous

$$y(n) = S\left(w(n) + \sum_{j=1}^{M} A_j y(n-j)\right)$$

output value in the FDM by the corresponding coefficient, *A*, stored in the FCM; accumulates the multiplication results; adds the input, w(n), from the FDIR (which is optionally not scaled by S, depending on the FACR[FISL] bit setting); places the accumulation result, y(n), in the FDOR; and saves the output while shifting the previous outputs down in the FDM. This is done for each sample input to the FDIR. To process a complete IIR filter, a FIR filter type session followed by an IIR filter type session is needed.



Figure 10-8. IIR Filter Type Processing

Real mode is one of two operating modes available with the IIR filter type. Thus, the FCSR[FOM] bits are ignored when the IIR filter type is in use. Real mode performs IIR type filtering with real data. One sample, the real input, is written to the FDIR, and the EFCOP processes the data. Then one sample, the real output, is read from the FDOR. Another option available for the IIR filter type is Multichannel mode. Multichannel mode for IIR filter type works exactly the same as it does for FIR filter type, as explained in **Section 10.5.1.1.2**, "Multichannel Mode," on page 10-17. Decimation and Adaptive modes are not available with the IIR filter type. Initialization is always disabled with the IIR filter type, and the FCSR[FPRC] bit is ignored. Thus, the DSP56300 core must write the initial input values before the EFCOP is enabled. The first value written to FDIR is always the first sample to be filtered.

# **10.6** Data Transfer

This section describes how to transfer data to and from the EFCOP using an FIR filter configuration. Here, we provide background information to help you understand the examples in **Section 10.7**, "Examples of Use in Different Modes," on page 10-22. The examples employ the following notations:

- D(n): Data sample at time n
- H(n): Filter coefficient at time n
- F(n): Output result at time n
- #filter\_count: Number of coefficient values in the coefficient memory bank FCM; it is equal to the initial value written to the FCNT register plus 1.
- Compute: Perform all calculations to determine one filter output F(n) for a specific set of input data samples

To transfer data to/from the EFCOP input/output registers, the Filter Data Input Register (FDIR) and the Filter Data Output Register (FDOR) are triggered by three different methods:

- Direct Memory Access (DMA)
- Interrupts
- Polling

Two FCSR bits (FDIBE and FDOBF) indicate the status of the FDIR and the FDOR, respectively. All three data transfer methods use these two FCSR bits as their control mechanism. If FDIBE is set, the input buffer is empty; if FDOBF is set, the output buffer is full. Because these bits come into full operation only when the EFCOP is enabled (FCSR:FEN is set), the polling, DMA, or interrupt methods can be initialized either before or after the EFCOP is enabled. No service request is issued until the EFCOP is enabled, since FDIBE and FDOBF are cleared while the EFCOP is in the Individual Reset state.

The most straightforward EFCOP data transfer method uses the core processor to poll the status flags, monitoring for input/output service requests. The disadvantage of this approach is that it demands large amounts of (if not all of) the core's processing time. The interrupt and DMA methods are more efficient in their use of the core processor. Interrupts intervene on the core processor infrequently to service input/output data.

DMA can operate concurrently with the processor core and demands only minimal core resource for setup. DMA transfers are recommended when the EFCOP is in FIR/IIR filtering mode since the core can operate independently of the EFCOP while DMA transfers data to the FDIR and from the FDOR. Since the EFCOP input buffer (FDIR) is four words deep, the DMA can input in blocks of up to four words. A combination of DMA transfer for input and an interrupt request for processing the output is recommended for adaptive FIR mode. This combination gives the following benefits:

- Input data transfers to the FDIR can occur independently of the core.
- There is minimal intervention of the core while the weight update multiplier is updated.

If the initialization mode is enabled (that is, if the FCSR[FPRC] bit is cleared), the core can initialize the coefficient bank while the DMA controller concurrently transfers initial data values to the data bank. The EFCOP state machine starts computation as soon as #filter\_count data samples are input. If no initialization mode is used (the FCSR[FPRC] bit is set), the EFCOP starts computation as soon as the first data sample is available in the input buffer. The filter coefficient bank must therefore be initialized before an input data transfer starts. The DMA input channel can continue transferring data whenever the input FIFO becomes empty, while the EFCOP state machine takes data words from the FIFO whenever required.

# **10.7** Examples of Use in Different Modes

The following sections provide examples of how to use the EFCOP in Real FIR Filter (Mode 0) and Adaptive FIR filter mode.

# 10.7.1 Real FIR Filter: Mode 0

In this example, an N tap FIR filter is represented as follows: N-1

$$F(n) = \sum_{i=0}^{\infty} H(i) \cdot D(n-i)$$

The filter is implemented with three different data transfers using the EFCOP in data initialization mode:

- **1.** DMA input/DMA output
- **2.** DMA input/Polling output
- **3.** DMA input/Interrupt output

This transfer combination is only one of many possible combinations.<sup>1</sup>

<sup>1.</sup>For information on DMA transfers, refer to the Motorola application note entitled *Using the DSP56300 Direct Memory Access Controller* (APR23/D).

#### **10.7.1.1** DMA Input/DMA Output

A 20-tap FIR filter using a 28-input sample signal is implemented in the following stages:

Setup:

- **1.** Set the filter count register (FCNT) to the length of the filter coefficients –1 (i.e N-1).
- 2. Set the Data and Coefficient Base Address pointers (FDBA, FCBA).
- **3.** Set the operation mode (FCSR[5:4] = FOM[00]).
- **4.** Set Initialization mode (FCSR[7] = FPRC = 0).
- 5. Set DMA registers:

DMA input: A two-dimensional (2D) DMA transfer fills up the FDM bank via channel 0. The DMA input control registers are initialized as shown in **Table 10-10**.

| Register Setting                | Description                                                                                                                                |  |  |
|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| DCR0 bit values are as follows: | DMA Control Register 0                                                                                                                     |  |  |
| DIE = 0                         | Disables end-of-transfer interrupt.                                                                                                        |  |  |
| DTM = 2                         | Chooses line transfer triggered by request; DE auto clear on end of transfer.                                                              |  |  |
| DPR = 2                         | Priority 2                                                                                                                                 |  |  |
| DCON = 0                        | Disables continuous mode.                                                                                                                  |  |  |
| DRS = \$15                      | Chooses DMA to trigger on EFCOP input buffer empty.                                                                                        |  |  |
| D3D = 0                         | Chooses non-3D mode.                                                                                                                       |  |  |
| DAM = \$20                      | Sets the following DMA Address Mode:<br>source address - 2D<br>counter mode B<br>offset DOR0<br>destination address - no update, no offset |  |  |
| DDS = 1                         | Destination in Y memory space (because the EFCOP is in Y memory).                                                                          |  |  |
| DSS = 0                         | Source in X memory space.                                                                                                                  |  |  |
| DOR0=1                          | DMA Offset Register 0                                                                                                                      |  |  |
| DCO0= \$006003                  | DMA Counter Register 0<br>Gives transfer of 7 * 4 = 28 items (input sequence length).                                                      |  |  |
| DSR0 = Address of source data   | DMA Source Address Register 0                                                                                                              |  |  |
| DDR0 = \$FFFFB0                 | DMA Destination Address Register for Channel 0                                                                                             |  |  |

Table 10-10. DMA Channel 0 Regisister Initialization

DMA output: Channel 1 is used, with a configuration similar to that of the DMA input channel, except for a 1D transfer. The DMA output control registers are initialized as shown in Table 10-11.

| Register Setting                              | Description                                                                                                                                                               |
|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DCR1 bit values are as follows:               | DMA Control Register 1                                                                                                                                                    |
| DIE = 0                                       | Disables end-of-transfer interrupt.                                                                                                                                       |
| DTM = 1                                       | Chooses word transfer triggered by request, DE auto clear on end of transfer.                                                                                             |
| DPR = 3                                       | Priority 3.                                                                                                                                                               |
| DCON = 0                                      | Disables continuous mode.                                                                                                                                                 |
| DRS = \$16                                    | Chooses DMA to trigger on EFCOP output buffer full.                                                                                                                       |
| D3D = 0                                       | Chooses non-3D mode.                                                                                                                                                      |
| DAM = \$2C                                    | <ul> <li>Sets the following DMA address mode</li> <li>source address - no update, no offset</li> <li>destination address - 1D, post-increment by 1, no offset.</li> </ul> |
| DDS = 0                                       | Destination in X memory space.                                                                                                                                            |
| DSS = 1                                       | Source in Y memory space (because EFCOP is in Y memory).                                                                                                                  |
| DCO1 = \$12                                   | DMA Counter Register 1<br>Gives transfer of 9 items.                                                                                                                      |
| DSR1 = address of FDOR =<br>\$FFFFFB1         | DMA Source Address Register 1                                                                                                                                             |
| DDR1 = address of destination<br>memory space | DMA Destination Address Register 1                                                                                                                                        |

Table 10-11. DMA Channel 1 Register Initialization

- **Note:** Setting the DCO0 and DCO1 must be considered carefully. These registers must be loaded with one less than the number of items to be transferred. Also, the following equality must hold: DCO1=input length filter length.
  - **6.** Initialization:
    - Enable DMA channel 1 (output) DCR1[23] DE=1
    - Enable EFCOP FCSR[0] FEN=1
    - Enable DMA channel 0. (input) DCR0[23] DE=1

#### 7. Processing:

- Whenever the Input Data Buffer (FDIR) is empty (that is, FDIBE = 1), the EFCOP triggers DMA input to transfer up to four new data words to FDIR.
- Compute F(n); The result is stored in FDOR, and this triggers the DMA for an output data transfer.

Semiconductor, Inc.

eescale

Note: The filter coefficients are stored in "reverse order," as Figure 10-9 shows.





| INCLUDE ':                              | ioequ.asm  | ۱ <i>′</i>                |                                               |  |
|-----------------------------------------|------------|---------------------------|-----------------------------------------------|--|
| ;;************************************* |            |                           |                                               |  |
| ; equates                               |            |                           |                                               |  |
| ;;*****************                     | ******     | * * * * * * * * * * * * * | * * * * * * * * * * * * * * * * * * * *       |  |
| Start                                   | equ        | \$00100                   | ; main program starting address               |  |
| FCON                                    | equ        | \$001                     | ; EFCOP FSCR register contents:               |  |
|                                         |            |                           | ; enable the EFCOP                            |  |
| FIR_LEN                                 | equ        | 20                        | ; EFCOP FIR length                            |  |
| SRC_ADDRS                               | equ        | \$3040;                   | ; DMA source address point to DATA bank       |  |
| DST_ADDRS                               | equ        | \$3000                    | ; address at which to begin output            |  |
| SRC_COUNT                               | equ        | \$006003                  | ; DMA0 count (7*4 word transfers)             |  |
| DST_COUNT                               | equ        | 8                         | ; number of outputs generated.                |  |
| FDBA_ADDRS                              | equ        | 0                         | ; Input samples Start Address x:\$0           |  |
| FCBA_ADDRS                              | equ        | 0                         | ; Coeff. Start Address y:\$0                  |  |
| ;;*****************                     | ******     | * * * * * * * * * * * * * | **************                                |  |
| ; main program                          |            |                           |                                               |  |
| ;;****************                      | ******     | * * * * * * * * * * * * * | * * * * * * * * * * * * * * * * * * * *       |  |
|                                         |            |                           |                                               |  |
| ORG                                     | p:Start    |                           |                                               |  |
| move                                    | #FDBA_A    | DDRS,r0                   | ; FDM memory area                             |  |
| move                                    | #0,x0      |                           |                                               |  |
| rep                                     | #DST_COUNT |                           |                                               |  |
| move                                    | x0,x:(r    | ) +                       | ; clear FDM memory area                       |  |
| ; ** DMA channel 1 i                    | nitialis   | ation – outp              | ut from EFCOP **                              |  |
| movep                                   | #M_FDOR    | ,x:M_DSR1                 | ; DMA source address points to the EFCOP FDIR |  |
| movep                                   | #DST_AD    | DRS,x:M_DDR1              | ; Init DMA destination address.               |  |
| movep                                   | #DST_CO    | JNT,x:M_DCO1              | ; Init DMA count.                             |  |
| movep                                   | #\$8EB2C   | l,x:M_DCR1                | ; Start DMA 1 with FDOBF request.             |  |
| ; ** EFCOP initialis                    | sation **  |                           |                                               |  |
| movep                                   | #FIR_LE    | N-1,y:M_FCNT              | ; FIR length                                  |  |
| movep                                   | #FDBA_A    | DDRS,y:M_FDBA             | ; FIR input samples Start Address             |  |
| movep                                   | #FCBA_A    | DDRS,y:M_FCBA             | ; FIR Coeff. Start Address                    |  |
| movep                                   | #FCON,y    | M_FCSR                    | ; Enable EFCOP                                |  |
|                                         |            |                           |                                               |  |

#### Freescale Semiconductor, Inc.

#### Examples of Use in Different Modes

```
; ** DMA channel 0 initialisation - input to EFCOP **
                   #SRC ADDRS, x:M DSR0 ; DMA source address points to the DATA bank.
         movep
                   #M_FDIR,x:M_DDR0 ; Init DMA destination address.
         movep
                   #SRC_COUNT,x:M_DCO0 ; Init DMA count to line mode.
         movep
         movep
                   #$1,x:M_DOR0 ; DMA offset reg. is 1.
                   #$94AA04,x:M_DCR0 ; Init DMA control reg to line mode FDIBE
         movep
request.
         nop
         nop
                            * * * * * * * * * * * * *
          jclr #0,x:M_DSTR,*
          jclr #1,x:M_DSTR,*
         nop
         nop
stop_label
         nop
          jmp stop_label
          org x:SRC ADDRS
         INCLUDE 'input.asm'
          org y:FCBA_ADDRS
          INCLUDE 'coefs.asm'
```

#### **10.7.1.2** DMA Input/Polling Output

The different stages of input/polling are as follows:

1. Setup:

Semiconductor, Inc.

eescale

- Set the filter count register (FCNT) to the length of the filter coefficients –1 (i.e N-1).
- Set the data and coefficient base address pointers (FDBA, FCBA).
- Set the operation mode (FCSR[5:4] = FOM[00],), = 1).
- Set the initialization mode (FCSR[7] = FPRC = 0).
- Set DMA registers: DMA input: as per channel 0 in Section 10.7.1.1
- 2. Initialization:
  - Enable EFCOP FCSR[0] FEN=1.
  - Enable DMA input channel, DCR0[23] DE=1.
- 3. Processing:
  - Whenever the Input Data Buffer (FDIR) is empty (that is, FDIBE = 1), the EFCOP triggers DMA input to transfer up to four new data words to FDM via FDIR.
  - Compute F(n); the result is stored in FDOR.
  - The core keeps polling the FCSR[FDOBF] bit and stores the data in memory.

| Example 10-2. | Real FIR Filtering | a using DMA i | nput/Polling output |
|---------------|--------------------|---------------|---------------------|
|               |                    |               |                     |

| ;;*****             | * * * * * * * * * * *       | *********                   | **********************                                        |  |  |  |  |
|---------------------|-----------------------------|-----------------------------|---------------------------------------------------------------|--|--|--|--|
| ; equate            |                             |                             |                                                               |  |  |  |  |
|                     |                             |                             | ***************************************                       |  |  |  |  |
| Start               | equ                         | \$00100                     |                                                               |  |  |  |  |
| FCON                | eq                          | u \$001                     | 5                                                             |  |  |  |  |
| ETD TEM             | 00                          | u 20                        | ; enable the EFCOP                                            |  |  |  |  |
| FIR_LEN<br>SRC ADDF | -                           |                             | ; EFCOP FIR length<br>; DMA source address point to DATA bank |  |  |  |  |
| DST ADDF            | -                           |                             | ; address at which to begin output                            |  |  |  |  |
| SRC_COUN            | -                           |                             | )3 ; DMA0 count (7*4 word transfers)                          |  |  |  |  |
| DST_COUN            | -                           | u 8                         | ; number of outputs generated.                                |  |  |  |  |
| FDBA_ADI            | -                           |                             | ; Input samples Start Address x:\$0                           |  |  |  |  |
| FCBA ADI            | -                           |                             | ; Coeff. Start Address y:\$0                                  |  |  |  |  |
| _                   | -                           |                             | ****                                                          |  |  |  |  |
| ; main p            | orogram                     |                             |                                                               |  |  |  |  |
| _                   | -                           |                             |                                                               |  |  |  |  |
| *****               | ********                    | **********                  | <*************************************                        |  |  |  |  |
| ,,                  |                             |                             |                                                               |  |  |  |  |
|                     |                             |                             |                                                               |  |  |  |  |
|                     |                             |                             |                                                               |  |  |  |  |
|                     | ORG                         | p:Start                     |                                                               |  |  |  |  |
|                     | move                        | #0,b                        |                                                               |  |  |  |  |
|                     | move                        | #0,a                        |                                                               |  |  |  |  |
|                     | move                        | #DST_COUN                   |                                                               |  |  |  |  |
|                     | move                        | #FDBA_ADD                   | RS,r0 ; FDM memory area                                       |  |  |  |  |
|                     | move                        | #0,x0                       |                                                               |  |  |  |  |
|                     | rep                         | #DST_COUN                   |                                                               |  |  |  |  |
|                     | move                        | x0,x:(r0)                   |                                                               |  |  |  |  |
| • ** एए⁄            | move<br>COP initial         | #DST_ADDR                   | S,r0 ; Destination address                                    |  |  |  |  |
| , EFC               | movep                       |                             | 1,y:M_FCNT ; FIR length                                       |  |  |  |  |
|                     | movep                       |                             | RS,y:M_FDBA ; FIR input samples Start Address                 |  |  |  |  |
|                     | movep                       |                             | RS,y:M_FCBA ; FIR Coeff. Start Address                        |  |  |  |  |
|                     | movep                       | #FCON, y:M                  |                                                               |  |  |  |  |
|                     | шотер                       | #PCON, y •P                 |                                                               |  |  |  |  |
| : ** DMZ            | A channel O                 | initialicat                 | tion - input to EFCOP **                                      |  |  |  |  |
| , DII               | movep                       |                             | RS,x:M_DSR0 ; DMA source address points to the DATA bank      |  |  |  |  |
|                     | movep                       | #M FDIR,x                   |                                                               |  |  |  |  |
|                     | movep                       | /                           | T,x:M_DCO0 ; Init DMA count to line mode.                     |  |  |  |  |
|                     | movep                       | #\$1,x:M_D                  |                                                               |  |  |  |  |
|                     | movep                       | #\$94AA04,                  | _                                                             |  |  |  |  |
| request.            | _                           |                             |                                                               |  |  |  |  |
| - 1                 | nop                         |                             |                                                               |  |  |  |  |
|                     | nop                         |                             |                                                               |  |  |  |  |
|                     | -                           | ******                      | *******                                                       |  |  |  |  |
| ;;*****             | do                          | #DST_COUNT,                 | endd                                                          |  |  |  |  |
| ;;*****             | ao                          |                             |                                                               |  |  |  |  |
| ;;*****             | nop                         | jclr #15,y:M_FCSR,*         |                                                               |  |  |  |  |
| ;;*****             | nop                         | ,y:M_FCSR,*                 |                                                               |  |  |  |  |
| ;;****              | nop<br>jclr #15             | 5,y:M_FCSR,*<br>M_FDOR,x:(r | C)+                                                           |  |  |  |  |
| ;;*****<br>endd     | nop<br>jclr #15             | -                           | 0)+                                                           |  |  |  |  |
|                     | nop<br>jclr #15             | -                           | 0)+                                                           |  |  |  |  |
|                     | nop<br>jclr #15<br>movep y: | -                           | 0)+                                                           |  |  |  |  |

```
Freescale Semiconductor, Inc.
```

```
nop
jmp stop_label
org x:SRC_ADDRS
INCLUDE `input.asm'
org y:FCBA_ADDRS
```

INCLUDE `coefs.asm'

#### 10.7.1.3 DMA Input/Interrupt Output

The different stages of DMA input and interrupt output are as follows:

- 1. Setup:
  - Set the filter count register (FCNT) to the length of the filter coefficients –1 (i.e N-1).
  - Set the Data and Coefficient Base Address pointers (FDBA, FCBA).
  - Set the operation mode (FCSR[5:4] = FOM[00],).
  - Set Initialization mode (FCSR[7] = FPRC = 0).
  - Set Filter Data Output Interrupt Enable FSCR[11]=FDOIE=1.
  - Set DMA register with DMA input as per channel 0 in Section 10.7.1.1.
- 2. Initialization:
  - Enable interrupts in the Interrupt Priority Register IPRP[10:11]=E0L=11.
  - Enable interrupts in the Status Register SR[8:9]=00.
  - Enable EFCOP FCSR[0]=FEN=1.
  - Enable the DMA input channel, DCR0[23]=DE=1.
- 3. Processing:
  - Whenever the Input Data Buffer (FDIR) is empty (that is, FDIBE = 1), the EFCOP triggers DMA, which loads the next input into the FDIR.
  - Compute F(n); the result is stored in FDOR; The core is interrupted when FDOBF is set and stores the data in memory.

#### Example 10-3. Real FIR Filter DMA Input/Interrupt Output

| INCLUDE 'ioequ.asm'<br>;;*********************************** |                       |            |    |                                       |  |
|--------------------------------------------------------------|-----------------------|------------|----|---------------------------------------|--|
| ; equates                                                    |                       |            |    |                                       |  |
| ;;*******                                                    | * * * * * * * * * * * | ********** | ** | *************                         |  |
| Start                                                        | equ                   | \$00100    | ;  | main program starting address         |  |
| FCON                                                         | equ                   | \$801      | ;  | EFCOP FSCR register contents:         |  |
|                                                              |                       |            | ;  | enable output interrupt               |  |
|                                                              |                       |            | ;  | enable the EFCOP                      |  |
| FIR_LEN                                                      | equ                   | 20         | ;  | EFCOP FIR length                      |  |
| SRC_ADDRS                                                    | equ                   | \$3040     | ;  | DMA source address point to DATA bank |  |

DSP56311 User's Manual

```
$3000
DST_ADDRS equ
                             ; address at which to begin output
                   $006003
                            ; DMA0 count (7*4 word transfers)
SRC COUNT equ
DST_COUNT equ
                            ; number of outputs generated.
                   8
FDBA_ADDRS equ
                   0
                             ; Input samples Start Address x:$0
FCBA ADDRS equ
                   0
                             ; Coeff. Start Address y:$0
; ; * * * * * * * * * * * * * *
                           org P:$0
         jmp
                   Start
         ORG
                   p:$6a
         jsr
                   >kdo
         nop
         nop
; ; * * * * * * * * * * *
                  ; main program
; ; * * * * * * * * * * * * * * *
                   ORG
                   p:Start
; ** interrupt initialisation **
         bset
                   #10,x:M IPRP
                                      ;
         bset
                   #11,x:M_IPRP
                                      ; enable EFCOP interrupts in IPRP
         bclr
                   #8,SR
                                      ;
         bclr
                   #9,SR
                                      ; enable interrupts in SR
                   #0,b
         move
         move
                   #0,a
         move
                   #DST_COUNT,b0
                                      ; counter for output interrupt
                   #FDBA_ADDRS,r0
         move
                                      ; FDM memory area
                   #0,x0
         move
                   #DST_COUNT
         rep
         move
                   x0,x:(r0)+
                                      ; clear FDM memory area
                   #DST_ADDRS,r0
                                      ; Destination address
         move
; ** EFCOP initialisation **
         movep
                   #FIR_LEN-1,y:M_FCNT ; FIR length
         movep
                   #FDBA_ADDRS,y:M_FDBA ; FIR input samples Start Address
                   #FCBA_ADDRS,y:M_FCBA ; FIR Coeff. Start Address
         movep
         movep
                   #FCON,y:M_FCSR
                                     ; Enable EFCOP
; ** DMA channel 0 initialisation - input to EFCOP **
         movep
                   #SRC_ADDRS,x:M_DSR0 ; DMA source address points to the DATA bank.
         movep
                   #M_FDIR,x:M_DDR0
                                     ; Init DMA destination address.
                   #SRC_COUNT, x:M_DCO0 ; Init DMA count to line mode.
         movep
                   #$1,x:M_DOR0
                                     ; DMA offset req. is 1.
         movep
                   #$94AA04,x:M_DCR0 ; Init DMA control req to line mode FDIBE
         movep
request.
         nop
         nop
wait1
                                     ; Wait until FDOIE is cleared.
                   #11,y:M_FCSR,*
         jset
         do
                   #40, endd
         nop
endd
         nop
         nop
stop_label
         nop
         jmp stop_label
```

#### Freescale Semiconductor, Inc.

Examples of Use in Different Modes

```
::************
                                     ; Interrupt handler for EFCOP output
kdo
                y:M_FDOR,x:(r0)+ ; Get y(k) from FDOR
         movep
                                     ; Store in destination memory space.
         nop
                  b
         dec
         jne
                  cont
         nop
                  #11,y:M_FCSR
                                  ; Disable output interrupt
         bclr
cont
         rti
         nop
         nop
         nop
                  x:SRC_ADDRS
         org
         INCLUDE
                  'input.asm'
                  y:FCBA ADDRS
         org
         INCLUDE
                  `coefs.asm'
```

## **10.7.2** Real FIR Filter With Decimation by M

An N tap real FIR filter with decimation by M of a sequence of real numbers is represented by,

$$F(n|_{\mathbf{M}}) = \sum_{i=0}^{N-1} H(i) \cdot D(n-i)$$

A DMA data transfer occurs in the following stages for both input and output. The stages are the similar to the ones described in **Section 10.7.1.1**. The difference is: set FDCH[11:8] = FDCM =M.

Processing:

- **1.** Whenever the Input Data Buffer (FDIR) is empty (that is, FDIBE = 1), the EFCOP triggers DMA input to transfer up to four new data words to FDM via FDIR.
- 2. Compute F(n); the result is stored in FDOR; the EFCOP triggers DMA output for an output data transfer.
- 3. Repeat M times:

Get new data word; EFCOP increments data memory pointer.





#### 10.7.3 Adaptive FIR Filter

An adaptive FIR filter is represented in **Figure 10-11**. The goal of the FIR filter is to adjust the filter coefficients so that the output, F(n), becomes as close as possible to the desired signal, R(n)—that is,  $E(n) \rightarrow 0$ .



Figure 10-11. Adaptive FIR Filter

The adaptive FIR filter typically comprises four stages, which are performed for each input sample at time n:

• Stage 1. The FIR filter output value is calculated for the EFCOP FIR session according to this equation:

$$F(n) = \sum_{i=0}^{N-1} H_n(i)D(n-i)$$

where  $H_n(i)$  are the filter coefficients at time n, D(n) is the input signal and F(n) is the filter output at time n. This stage requires N MAC operations, calculated by the EFCOP FMAC unit.

**Stage 2.** The core calculates the error signal, E(n), in software according to the following equation:

$$E(n) = R(n) - F(n)$$

where R(n) is the desired signal at time n. This stage requires a single arithmetic operation.

**Stage 3.** The core calculates the weight multiplier, Ke(n), in software according to the following equation:

$$\mathbf{K}_{\mathbf{e}}(\mathbf{n}) = \mathbf{K} * \mathbf{E}(\mathbf{n})$$

where K is the convergence factor of the algorithm. After calculating the weight multiplier,  $K_e$ , the core must write it into the FKIR.

**Stage 4.** The coefficients are updated by the EFCOP update session:

$$H_{n+1}(i) = H_n(i) + K_e D(n-i)$$

where  $H_{n+1}(i)$  are the adaptive filter coefficients at time n+1,  $K_e(n)$  is the weight multiplier at time n, and D(n) is the input signal. This stage starts immediately after  $K_e(n)$  is written in the FKIR (if Adaptive mode is enabled).

#### **10.7.3.1** Implementation Using Polling

**Figure 10-12** shows a flowchart for an adaptive FIR filter that uses polling to transfer data.



Figure 10-12. Adaptive FIR Filter Using Polling

## **10.7.3.2** Implementation Using DMA Input and Interrupt Output

**Figure 10-13** shows a flowchart for an adaptive FIR filter that uses DMA and an interrupt to transfer data.



Figure 10-13. Adaptive FIR Filter Using DMA Input and Interrupt Output

### 10.7.3.3 Updating an FIR Filter

The following example shows an FIR adaptive filter that is updated using the LMS algorithm.

Example 10-4. FIR Adaptive Filter Update Using the LMS Algorithm

|           | TITLE 'ADAPTI<br>INCLUDE 'ioec |                  |       |                                         |  |  |
|-----------|--------------------------------|------------------|-------|-----------------------------------------|--|--|
| ;;******  | * * * * * * * * * * * * * * *  | ****             | ***   | ****************                        |  |  |
| ; equates |                                |                  |       |                                         |  |  |
| ;;******  | * * * * * * * * * * * * * * *  | *****            | * * * | *************************************** |  |  |
| Start     | equ                            | \$00100          | ;     | main program starting address           |  |  |
| FCON      | equ                            | \$805            | ;     | EFCOP FSCR register contents:           |  |  |
|           | ; enable output interrupt      |                  |       |                                         |  |  |
|           | ; Choose adap                  | ptive real FIR m | ode   |                                         |  |  |
|           | ; enable the                   | EFCOP            |       |                                         |  |  |
| FIR_LEN   | equ                            | 20               | ;     | EFCOP FIR length                        |  |  |
|           |                                |                  |       |                                         |  |  |

DSP56311 User's Manual

| DES_ADDRS<br>SRC_ADDRS<br>DST_ADDRS<br>SRC_COUNT<br>DST_COUNT<br>MU2<br>FDBA_ADDRS<br>FCBA_ADDRS<br>;;******** | e<br>e<br>e<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6<br>6 |               | \$3200<br>\$3100<br>\$3000<br>\$06003<br>8<br>\$100000<br>0<br>0 | ;;;;;;; | Desired signal R(n)<br>Reference signal D(n)<br>address at which to begin output (signal F(n))<br>DMA0 count (7*4 word transfers)<br>number of outputs generated.<br>stepsize mu = 0.0625 (that is 2mu = 0.125)<br>Input samples Start Address x:\$0<br>Coeff. Start Address y:\$0 |
|----------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|---------------|------------------------------------------------------------------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                | jmp<br>ORG p:                                                                                    | Start<br>\$6a | :                                                                |         |                                                                                                                                                                                                                                                                                    |
|                                                                                                                | jsr<br>nop<br>nop                                                                                | >kdo          |                                                                  |         |                                                                                                                                                                                                                                                                                    |
|                                                                                                                |                                                                                                  | * * * * * * * | * * * * * * * * * * * * * * * * * *                              | * * *   | ***************************************                                                                                                                                                                                                                                            |
| ; main pro;;;*******                                                                                           | 5                                                                                                | * * * * * * * | * * * * * * * * * * * * * * * * *                                | * * *   | ***************                                                                                                                                                                                                                                                                    |
|                                                                                                                | ORG p:                                                                                           | Start         |                                                                  |         |                                                                                                                                                                                                                                                                                    |
| ; ** inter                                                                                                     | rrupt ir                                                                                         | nitiali       | sation **                                                        |         |                                                                                                                                                                                                                                                                                    |
|                                                                                                                | bset                                                                                             |               | :M_IPRP                                                          |         | ;                                                                                                                                                                                                                                                                                  |
|                                                                                                                | bset                                                                                             | #11,x         | K:M_IPRP                                                         |         | ; enable EFCOP interrupts in IPRP                                                                                                                                                                                                                                                  |
|                                                                                                                | bclr                                                                                             | #8,SF         | ξ                                                                |         | ;                                                                                                                                                                                                                                                                                  |
|                                                                                                                | bclr                                                                                             | #9,SF         |                                                                  |         | ; enable interrupts in SR                                                                                                                                                                                                                                                          |
|                                                                                                                |                                                                                                  |               |                                                                  |         |                                                                                                                                                                                                                                                                                    |
|                                                                                                                | move                                                                                             | #0,b          |                                                                  |         |                                                                                                                                                                                                                                                                                    |
|                                                                                                                | move<br>move                                                                                     | #0,a<br>#DST  | COUNT, b0                                                        |         | ; counter for output interrupt                                                                                                                                                                                                                                                     |
|                                                                                                                |                                                                                                  | 1201_         |                                                                  |         | , composi isi onopuo incertapo                                                                                                                                                                                                                                                     |
| ; ** FDM n                                                                                                     | nemory i                                                                                         | initial       | isation **                                                       |         |                                                                                                                                                                                                                                                                                    |
|                                                                                                                | move                                                                                             |               | A_ADDRS,r0                                                       |         | ; FDM memory area                                                                                                                                                                                                                                                                  |
|                                                                                                                | move                                                                                             | #0,x0<br>#FIR |                                                                  |         |                                                                                                                                                                                                                                                                                    |
|                                                                                                                | rep<br>move                                                                                      |               | _LEN<br>= (r0)+                                                  |         | ; clear FDM memory area                                                                                                                                                                                                                                                            |
| ; ** addre                                                                                                     |                                                                                                  |               | nitialisation **                                                 |         |                                                                                                                                                                                                                                                                                    |
|                                                                                                                | move                                                                                             | #DST          | ADDRS,r0                                                         |         | ; Destination address                                                                                                                                                                                                                                                              |
|                                                                                                                | move                                                                                             |               | _ADDRS,r1                                                        |         | ; Desired signal address                                                                                                                                                                                                                                                           |
|                                                                                                                | rep<br>move                                                                                      |               | LEN-1                                                            |         | ; Set reference pointer correctly                                                                                                                                                                                                                                                  |
| ; ** EFCOE                                                                                                     | ? initia                                                                                         | alisati       | on **                                                            |         |                                                                                                                                                                                                                                                                                    |
|                                                                                                                | movep<br>movep                                                                                   | #FDBA         | LEN-1,y:M_FCNT<br>A_ADDRS,y:M_FDBA<br>A_ADDRS,y:M_FCBA           |         | ; FIR length<br>; FIR input samples Start Address<br>; FIR Coeff. Start Address                                                                                                                                                                                                    |

#### Freescale Semiconductor, Inc.

#### Examples of Use in Different Modes

```
#FCON,y:M_FCSR
         movep
                                    ; Enable EFCOP
; ** DMA channel 0 initialisation - input to EFCOP **
               #SRC ADDRS, x:M DSR0
                                   ; DMA source address points to the DATA bank.
        movep
                                  ; Init DMA destination address.
               #M_FDIR,x:M_DDR0
        movep
                                  ; Init DMA count to line mode.
        movep
               #SRC_COUNT, x:M_DCO0
        movep
               #$1,x:M_DOR0
                                   ; DMA offset req. is 1.
               #$94AA04,x:M_DCR0
                                   ; Init DMA control reg to line mode FDIBE
        movep
request.
        nop
        nop
wait1
               #11,y:M_FCSR,* ; Wait until FDOIE is cleared.
         jset
               #40, endd
        do
        nop
endd
        nop
        nop
stop_label
        nop
         jmp stop_label
kdo
                                   ; Interrupt handler for EFCOP output
              y:M_FDOR,x:(r0)
                                   ; Get F(n) from FDOR
        movep
                                   ; Store in destination memory space.
;****** Calculate Ke ********
        move
               x:(r1)+,a
                                   ; Retrieve desired value R(n)
        move
               x:(r0)+,y0
                                   ;
         sub
               y0,a
                                   ; calculate E(n) = R(n) - F(n)
               #MU2,y0
                                   ;
        move
               a,yl
        move
                                   ;
               y0,y1,a
                                   ; calculate Ke = mu * 2 * E(n)
        mpy
al,y:M_FKIR
                                   ; store Ke in FKIR
        movep
        dec
               b
         jne
               cont
        nop
                                 ; Disable output interrupt
        bclr
               #11,y:M_FCSR
cont
        rti
        nop
        nop
        nop
```

#### 

#### ORG y:FCBA\_ADDRS

| dc       | \$000000     |           |        |      |
|----------|--------------|-----------|--------|------|
| dc       | \$00000      |           |        |      |
| dc       | \$000000     |           |        |      |
| dc       | \$00000      |           |        |      |
| dc       | \$00000      |           |        |      |
| dc       | \$000000     |           |        |      |
| dc       | \$00000      |           |        |      |
| dc       | \$00000      |           |        |      |
| dc       | \$000000     |           |        |      |
|          |              |           |        |      |
| ORG x:SF | RC_ADDRS     |           |        |      |
|          |              |           |        |      |
| INCLUDE  | 'input.asm'; | Reference | signal | D(n) |
|          |              |           |        |      |
|          |              |           |        |      |

ORG x:DES\_ADDRS

INCLUDE 'desired.asm'; Desired signal R(n)

# **10.8** Verification For All Exercises

#### **10.8.1** Input Sequence (input.asm)

| dc | \$000000 |
|----|----------|
| dc | \$37cc8a |
| dc | \$343fae |
| dc | \$0b63b1 |
| dc | \$0595b4 |
| dc | \$38f46e |
| dc | \$6a4ea2 |
| dc | \$5e8562 |
| dc | \$2beda5 |
| dc | \$1b3cd0 |
| dc | \$42£452 |

| dc | \$684ca0 |
|----|----------|
| dc | \$5093b0 |
| dc | \$128ab8 |
| dc | \$f74eel |
| dc | \$15c13a |
| dc | \$336e48 |
| dc | \$15e98e |
| dc | \$d428d2 |
| dc | \$b76af5 |
| dc | \$d69eb3 |
| dc | \$f749b6 |
| dc | \$dee460 |
| dc | \$a43601 |
| dc | \$903d59 |
| dc | \$b9999a |
| dc | \$e5744e |
|    |          |

## **10.8.2** Filter Coefficients (coefs.asm)

\$F8125C dc \$F77839 dc dc \$F4E9EE dc \$F29373 dc \$F2DC9A \$F51D6E dc dc \$F688CE \$F6087E dc dc \$F5B5D3 \$F7E65E dc dc \$FBE0F8 \$FEC8B7 dc dc \$FF79F5 \$000342 dc dc \$02B24F \$06C977 dc \$096ADD dc \$097556 dc dc \$08FD54 dc \$0A59A5

Freescale

Semiconductor, Inc.

#### 10.8.3 Output Sequence for Examples D-1, D-2, and D-3

\$d69ea9 \$ccae36 \$c48f2a \$be8b28 \$bad8c5 \$b9998c \$bad8cb

\$be8b2d

\$c7b906

#### **Desired Signal for Example D-4** 10.8.4

| dc | \$000000 |
|----|----------|
| dc | \$0D310F |
| dc | \$19EA7C |
| dc | \$25B8E2 |
| dc | \$30312E |
| dc | \$38F46D |
| dc | \$3FB327 |
| dc | \$443031 |
| dc | \$4642D6 |
| dc | \$45D849 |
| dc | \$42F452 |
| dc | \$3DB126 |
| dc | \$363E7F |
| dc | \$2CDFE8 |
| dc | \$21EA5B |
| dc | \$15C13A |
| dc | \$08D2CE |
| dc | \$FB945D |
| dc | \$EE7E02 |
| dc | \$E2066F |
| dc | \$D69EB2 |
| dc | \$CCAE3C |
| dc | \$C48F2F |
| dc | \$BE8B32 |
| dc | \$BAD8D3 |
| dc | \$B99999 |
|    |          |

Verification For All Exercises

dc \$BAD8D3 dc \$BE8B32

## **10.8.5** Output Sequence for Example D-4

\$000000 \$f44c4c \$ee54b3

\$e7cd6b

\$daed26

\$cc1071

\$c7db1c

\$cdfe45

# Appendix A Bootstrap Program

This appendix lists the bootstrap program for the DSP56311. Motorola posts updates to the bootstrap program on the Worldwide Web at the following URL:

http://www.mot.com/SPS/DSP/software/other.html#56301

# A.1 Bootstrap Code

; BOOTSTRAP CODE FOR DSP56311 - (C) Copyright 1999 Motorola Inc. ; Revised March, 18 1999.

; Bootstrap through the Host Interface, External EPROM or SCI.

; This is the Bootstrap program contained in the DSP56311 192-word Boot

; ROM. This program can load any program RAM segment from an external

; EPROM, from the Host Interface or from the SCI serial interface.

; If MD:MC:MB:MA=x000, then the Boot ROM is bypassed and the DSP56311 ; starts fetching instructions, beginning with address \$C00000 (MD=0) ; or \$008000 (MD=1) assuming that an external memory of SRAM type is ; used. The accesses are performed using 31 wait states with no ; address attributes selected (default area).

; Operation modes MD:MC:MB:MA=0001-0111 are reserved.

; If MD:MC:MB:MA=1001, then it loads a program RAM segment from consecutive

; byte-wide P memory locations, starting at P \$D00000 (bits 7-0).

; The memory is selected by the Address Attribute AA1 and is accessed with

; 31 wait states.

; The EPROM bootstrap code expects to read 3 bytes

; specifying the number of program words, 3 bytes specifying the address

- ; to start loading the program words, and then 3 bytes for each program
- ; word to be loaded. The number of words, the starting address, and the
- ; program words are read least significant byte first followed by the

; mid and then by the most significant byte.

- ; The program words are condensed into 24-bit words and stored in
- ; contiguous PRAM memory locations starting at the specified starting address.

Bootstrap Program

Bootstrap Code

; After the program words are read, program execution starts from the same ; address where loading started. ; If MD MC MB MA=1010, then the program RAM is loaded from the SCI interface. ; The number of program words to be loaded and the starting address must ; be specified. The SCI bootstrap code expects to receive 3 bytes ; specifying the number of program words, 3 bytes specifying the address ; to start loading the program words, and then 3 bytes for each program ; word to be loaded. The number of words, the starting address, and the ; program words are received least significant byte first followed by the ; mid and then by the most significant byte. After the ; program words are received, program execution starts in the same address where ; loading started. The SCI is programmed to work in asynchronous mode ; with 8 data bits, 1 stop bit, and no parity. The clock source is external and the clock frequency must be 16x the baud rate. ; After each byte is received, it is echoed back through the SCI transmitter Operation mode MD MC MB MA=1011 is reserved ; If MD:MC:MB:MA=1100, then the program RAM is loaded from the Host ; Interface programmed to operate in the ISA mode. ; The HOST ISA bootstrap code expects to read a 24-bit word ; specifying the number of program words, a 24-bit word specifying the address ; to start loading the program words, and then a 24-bit word for each program ; word to be loaded. The program words are stored in ; contiguous PRAM memory locations starting at the specified starting address. ; After the program words are read, program execution starts from the same ; address where loading started. ; The Host Interface bootstrap load program can be stopped by ; setting the Host Flag 0 (HF0). This starts execution of the loaded ; program from the specified starting address. ; If MD MC MB MA=1101, then the program RAM is loaded from the Host ; Interface programmed to operate in the HC11 non-multiplexed mode. ; The HOST HC11 bootstrap code expects to read a 24-bit word ; specifying the number of program words, a 24-bit word specifying the address ; to start loading the program words, and then a 24-bit word for each program ; word to be loaded. The program words is stored in ; contiguous PRAM memory locations starting at the specified starting address. ; After the program words are read, program execution starts from the same ; address where loading started. ; The Host Interface bootstrap load program can be stopped by ; setting the Host Flag 0 (HF0). This starts execution of the loaded ; program from the specified starting address.

DSP56311 User's Manual

| ; If MD:MC:MB:MA=1110, then the program RAM is loaded from the Host<br>; Interface programmed to operate in the 8051 multiplexed bus mode,<br>; in double-strobe pin configuration.<br>; The HOST 8051 bootstrap code expects accesses that are byte wide.                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                               |  |  |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| ; The HOST 8051 bootstrap code expects accesses that are of<br>; The HOST 8051 bootstrap code expects to read 3 bytes form<br>; specifying the number of program words, 3 bytes forming a<br>; specifying the address to start loading the program words, a<br>; forming 24-bit words for each program word to be loaded.                                                                                                                                                                                                                                                                                                                                    | ming a 24-bit word<br>a 24-bit word                                                                                           |  |  |  |
| ; The program words are stored in contiguous PRAM memo<br>; starting at the specified starting address.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                                                               |  |  |  |
| <ul> <li>; After the program words are read, program execution starts from the same</li> <li>; address where loading started.</li> <li>; The Host Interface bootstrap load program can be stopped by setting the</li> <li>; Host Flag 0 (HF0). This starts execution of the loaded program from</li> <li>; the specified starting address.</li> </ul>                                                                                                                                                                                                                                                                                                        |                                                                                                                               |  |  |  |
| The base address of the HI08 in multiplexed mode is 0x80 and is not<br>modified by the bootstrap code. All the address lines are enabled<br>and should be connected accordingly.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                               |  |  |  |
| ,<br>; If MD:MC:MB:MA=1111, then the program RAM is loaded from the Host<br>; Interface programmed to operate in the MC68302 (IMP) bus mode,<br>; in single-strobe pin configuration.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                               |  |  |  |
| ; The HOST MC68302 bootstrap code expects accesses that are byte wide.<br>; The HOST MC68302 bootstrap code expects to read 3 bytes forming a 24-bit word<br>; specifying the number of program words, 3 bytes forming a 24-bit word<br>; specifying the address to start loading the program words, and then 3 bytes<br>; forming 24-bit words for each program word to be loaded.                                                                                                                                                                                                                                                                          |                                                                                                                               |  |  |  |
| ; specifying the number of program words, 3 bytes forming a<br>; specifying the address to start loading the program words, a<br>; forming 24-bit words for each program word to be loaded.                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | es forming a 24-bit word<br>a 24-bit word<br>and then 3 bytes                                                                 |  |  |  |
| ; specifying the number of program words, 3 bytes forming a<br>; specifying the address to start loading the program words, a<br>; forming 24-bit words for each program word to be loaded.<br>; The program words are stored in contiguous PRAM memo<br>; starting at the specified starting address.<br>; After the program words are read, program execution starts                                                                                                                                                                                                                                                                                       | es forming a 24-bit word<br>a 24-bit word<br>and then 3 bytes<br>ory locations                                                |  |  |  |
| ; specifying the number of program words, 3 bytes forming a<br>; specifying the address to start loading the program words, a<br>; forming 24-bit words for each program word to be loaded.<br>; The program words are stored in contiguous PRAM memory<br>; starting at the specified starting address.                                                                                                                                                                                                                                                                                                                                                     | es forming a 24-bit word<br>a 24-bit word<br>and then 3 bytes<br>ory locations<br>s from the same<br>by setting the           |  |  |  |
| <ul> <li>; specifying the number of program words, 3 bytes forming a</li> <li>; specifying the address to start loading the program words, a</li> <li>; forming 24-bit words for each program word to be loaded.</li> <li>; The program words are stored in contiguous PRAM memo</li> <li>; starting at the specified starting address.</li> <li>; After the program words are read, program execution starts</li> <li>; address where loading started.</li> <li>; The Host Interface bootstrap load program can be stopped I</li> <li>; Host Flag 0 (HF0). This starts execution of the loaded program</li> </ul>                                           | es forming a 24-bit word<br>a 24-bit word<br>and then 3 bytes<br>ory locations<br>s from the same<br>by setting the           |  |  |  |
| <ul> <li>; specifying the number of program words, 3 bytes forming a</li> <li>; specifying the address to start loading the program words, a</li> <li>; forming 24-bit words for each program word to be loaded.</li> <li>; The program words are stored in contiguous PRAM memory</li> <li>; starting at the specified starting address.</li> <li>; After the program words are read, program execution starts</li> <li>; address where loading started.</li> <li>; The Host Interface bootstrap load program can be stopped I</li> <li>; Host Flag 0 (HF0). This starts execution of the loaded prog</li> <li>; the specified starting address.</li> </ul> | es forming a 24-bit word<br>a 24-bit word<br>and then 3 bytes<br>ory locations<br>s from the same<br>by setting the           |  |  |  |
| <pre>; specifying the number of program words, 3 bytes forming a<br/>; specifying the address to start loading the program words, a<br/>; forming 24-bit words for each program word to be loaded.<br/>; The program words are stored in contiguous PRAM memo<br/>; starting at the specified starting address.<br/>; After the program words are read, program execution starts<br/>; address where loading started.<br/>; The Host Interface bootstrap load program can be stopped I<br/>; Host Flag 0 (HF0). This starts execution of the loaded prog<br/>; the specified starting address.<br/>;<br/>page 132,55,0,0,0<br/>opt mex</pre>                 | es forming a 24-bit word<br>a 24-bit word<br>and then 3 bytes<br>ory locations<br>from the same<br>by setting the<br>ram from |  |  |  |

;;

**Freescale Semiconductor, Inc.** 

Bootstrap Program

Bootstrap Code

; \$DFFFFF, active low

```
..
;;
..
,,
M SSR EQU
              $FFFF93
                          ; SCI Status Register
                          ; SCI Transmit Data Register (low)
M STXL EQU
               $FFFF95
M SRXL EQU
               $FFFF98
                          ; SCI Receive Data Register (low)
M SCCR EQU
                           ; SCI Clock Control Register
               $FFFF9B
M SCR EQU
                          ; SCI Control Register
              $FFFF9C
M PCRE EQU
               $FFFF9F
                          ; Port E Control register
                           ; Address Attribute Register 1
M AAR1 EQU
               $FFFF8
M HPCR EQU
               $FFFFC4
                           ; Host Polarity Control Register
M HSR EQU
              $FFFFC3
                          ; Host Status Register
                           ; Host Receive Register
M HRX EQU
              $FFFFC6
HRDF EQU
                      ; Host Receive Data Full
             $0
HF0 EQU
            $3
                     ; Host Flag 0
                     ; Host Enable
HEN EQU
            $6
```

ORG PL \$ff0000,PL \$ff0000 ; bootstrap code starts at \$ff0000

#### START

reescale Semiconductor, Inc.

```
clr a #$0,r5
               ; clear a and init R5 with 0
iclr #3,omr,OMR0XXX , If MD MC MB MA=0xxx go to OMR0XXX
jclr #2,omr,EPRSCILD ; If MD MC MB MA=10xx, go load from EPROM/SCI
jclr #1,omr,OMR1IS0 ; IF MD MC MB MA=110x, go to look for ISA/HC11
jclr #0,omr,I8051HOSTLD; If MD:MC:MB:MA=1110, go load from 8051 Host
            ; If MD MC MB MA=1111, go load from MC68302 Host
```

- ; The program is downloaded from the host MCU with the following rules:
- ; 1) 3 bytes Define the program length.
- ; 2) 3 bytes Define the address to which to start loading the program.
- ; 3) 3n bytes (while n is any integer number)
- ; The program words is strobed in contiguous PRAM memory locations starting
- ; at the specified starting address.
- ; After the program words are read, program execution starts from the same
- ; address where loading started.
- ; The host MCU can terminate the loading process by setting the HF1=0 and HF0=1.
- ; When the downloading is terminated, the program starts executing the
- ; loaded program from the specified starting address.

; The HI08 boot ROM program enables the following buses to download programs ; through the HI08 port:

| ; 1 - ISA   | - Dual-strobe non-multiplexed bus with negative strobe    |
|-------------|-----------------------------------------------------------|
| ;           | pulses dual positive request                              |
| ; 2 - HC11  | - Single strobe non-multiplexed bus with positive strobe  |
| ;           | pulse single negative request.                            |
| ; 4 - i8051 | - Dual strobe multiplexed bus with negative strobe pulses |
| ;           | dual negative request.                                    |

<sup>;</sup> This routine loads a program through the HI08 host port.

| MC68302HO                           |                                                                                |
|-------------------------------------|--------------------------------------------------------------------------------|
| movep                               | #%000000000111000,x:M_HPCR                                                     |
|                                     | ; Configure the following conditions:                                          |
|                                     | HAP = 0 Negative host acknowledge                                              |
|                                     | HRP = 0 Negative host request                                                  |
|                                     | ; $HCSP = 0$ Negative chip select input                                        |
|                                     | ; HD/HS = 0 Single strobe bus ( $R/W \sim and DS$ )                            |
|                                     | ; HMUX = 0 Non multiplexed bus                                                 |
|                                     | ; HASP = 0 (address strobe polarity has no                                     |
|                                     | ; meaning in non-multiplexed bus)                                              |
|                                     | ; HDSP = 0 Negative data strobes polarity                                      |
|                                     | ; HROD = 0 Host request is active when enabled $0.711 + 114$ has a to $0.6$    |
|                                     | ; spare = 0 This bit should be set to 0 for                                    |
|                                     | ; future compatability                                                         |
|                                     | ; HEN = 0 When the HPCR register is modified<br>HEN should be cleared          |
|                                     | ,                                                                              |
|                                     | ; HAEN = 1 Host acknowledge is enabled<br>; HREN = 1 Host requests are enabled |
|                                     | ; HCSEN = 1 Host chip select input enabled                                     |
|                                     | ; HA9EN = 0 (address 9 enable bit has no                                       |
|                                     | ; meaning in non-multiplexed bus)                                              |
|                                     | ; HA8EN = 0 (address 8 enable bit has no                                       |
|                                     | ; meaning in non-multiplexed bus)                                              |
|                                     | ; HGEN = 0 Host GPIO pins are disabled                                         |
| bra <h< td=""><td>I08CONT</td></h<> | I08CONT                                                                        |
| OMR1IS0                             |                                                                                |
|                                     | nr,HC11HOSTLD; If MD:MC:MB:MA=1101, go load from HC11 Host                     |
| J8 <b>22</b> // 0,01                | ; If MD:MC:MB:MA=1100, go load from ISA HOST                                   |
|                                     | , , , , , , , , , , , , , , , , , , , ,                                        |
| ISAHOSTLD                           |                                                                                |
| movep =                             | #%010100000011000,x:M HPCR                                                     |
| -                                   | ; Configure the following conditions:                                          |
|                                     | ; HAP = 0 Negative host acknowledge                                            |
|                                     | ; HRP = 1 Positive host request                                                |
|                                     | ; $HCSP = 0$ Negative chip select input                                        |
|                                     | ; $HD/HS = 1$ Dual strobes bus (RD and WR)                                     |
|                                     | ; HMUX = 0 Non multiplexed bus                                                 |
|                                     | ; HASP = 0 (address strobe polarity has no                                     |
|                                     | ; meaning in non-multiplexed bus)                                              |
|                                     | ; HDSP = 0 Negative data strobes polarity                                      |
|                                     | ; HROD = 0 Host request is active when enabled                                 |
|                                     | ; spare = 0 This bit should be set to 0 for                                    |
|                                     | ; future compatability                                                         |
|                                     | ; HEN $= 0$ When the HPCR register is modified                                 |
|                                     | ; HEN should be cleared                                                        |
|                                     | ; HAEN = 0 Host acknowledge is disabled                                        |
|                                     | ; HREN = 1 Host requests are enabled                                           |
|                                     | ; HCSEN = 1 Host chip select input enabled                                     |
|                                     |                                                                                |
|                                     | ; HA9EN = 0 (address 9 enable bit has no                                       |

Bootstrap Program

|                                         | ; HA8EN = 0 (address 8 enable bit has no                                                    |
|-----------------------------------------|---------------------------------------------------------------------------------------------|
|                                         | ; meaning non-multiplexed bus)                                                              |
|                                         | ; HGEN = 0 Host GPIO pins are disabled                                                      |
| bra <hi08c< td=""><td>ONT</td></hi08c<> | ONT                                                                                         |
| HC11HOSTLD                              |                                                                                             |
| movep #%00                              | 00001000011000,x:M_HPCR                                                                     |
|                                         | ; Configure the following conditions:                                                       |
|                                         | ; HAP = $0$ Negative host acknowledge                                                       |
|                                         | ; HRP = 0 Negative host request                                                             |
|                                         | ; $HCSP = 0$ Negatice chip select input                                                     |
|                                         | ; $HD/HS = 0$ Single strobe bus (R/W~ and DS)                                               |
|                                         | ; HMUX = 0 Non-multiplexed bus                                                              |
|                                         | ; HASP = 0 (address strobe polarity has no $m_{\text{eff}}$ in particular multiple address) |
|                                         | ; meaning in non-multiplexed bus)<br>: HDSP = 1 Negative data strobas polarity              |
|                                         | ; HDSP = 1 Negative data strobes polarity<br>; HROD = 0 Host request is active when enabled |
|                                         | ; spare = 0 This bit should be set to 0 for                                                 |
|                                         | ; future compatability                                                                      |
|                                         | ; HEN = 0 When the HPCR register is modified                                                |
|                                         | HEN should be cleared                                                                       |
|                                         | ; HAEN $= 0$ Host acknowledge is disabled                                                   |
|                                         | ; HREN = 1 Host requests are enabled                                                        |
|                                         | ; HCSEN = 1 Host chip select input enabled                                                  |
|                                         | ; HA9EN = $0$ (address 9 enable bit has no                                                  |
|                                         | ; meaning in non-multiplexed bus)                                                           |
|                                         | ; HA8EN = 0 (address 8 enable bit has no                                                    |
|                                         | ; meaning in non-multiplexed bus)                                                           |
|                                         | ; HGEN = $0$ Host GPIO pins are disabled                                                    |
| bra <hi08c< td=""><td>ONT</td></hi08c<> | ONT                                                                                         |
| I8051HOSTLD                             |                                                                                             |
| movep #%00                              | 01110000011110,x:M_HPCR                                                                     |
|                                         | ; Configure the following conditions:                                                       |
|                                         | ; HAP = 0 Negative host acknowledge                                                         |
|                                         | ; HRP = 0 Negative host request<br>; HCSP = 0 Negative chip select input                    |
|                                         | ; HD/HS = 1 Dual strobes bus (RD and WR)                                                    |
|                                         | ; HMUX = 1 Multiplexed bus                                                                  |
|                                         | ; HASP = 1 Positive address strobe polarity                                                 |
|                                         | ; HDSP = 0 Negative data strobes polarity                                                   |
|                                         | ; HROD = 0 Host request is active when enabled                                              |
|                                         | ; spare = 0 This bit should be set to 0 for                                                 |
|                                         | ; future compatability                                                                      |
|                                         | ; HEN = 0 When the HPCR register is modified                                                |
|                                         | ; HEN should be cleared                                                                     |
|                                         | ; HAEN $= 0$ Host acknowledge is disabled                                                   |
|                                         | ; HREN = 1 Host requests are enabled                                                        |
|                                         | ; HCSEN = 1 Host chip select input enabled                                                  |
|                                         | ; HA9EN = 1 Enable address 9 input                                                          |
|                                         | ; HA8EN = 1 Enable address 8 input                                                          |
|                                         | ; HGEN = $0$ Host GPIO pins are disabled                                                    |
| HINGCONT                                |                                                                                             |
| HI08CONT<br>bset #HEN.x                 | M HPCP Enable the UI08 to operate as host                                                   |
| USEL #HEIN,X                            | :M_HPCR ; Enable the HI08 to operate as host<br>; interface (set HEN=1)                     |
|                                         | , monace (set man=1)                                                                        |

Bootstrap Code

```
jclr #HRDF,x M HSR,*
                               ; wait for the program length to be
                     ; written
    movep x:M HRX,a0
    jclr #HRDF,x M HSR,*
                                ; wait for the program starting address
                     ; to be written
    movep x M HRX,r0
    move r0,r1
         a0,HI08LOOP
    do
                                                  ; set a loop with the downloaded length
HI08LL
         #HRDF,x M HSR,HI08NW ; If new word was loaded then jump to
    jset
                     ; read that word
         #HF0,x:M HSR,HI08LL
                                 ; If HF0=0 then continue with the
    jclr
                     ; downloading
    enddo
                        ; Must terminate the do loop
    bra
         <HI08LOOP
HI08NW
    movep x M HRX, p(r0)+
                                                  ; Move the new word into its destination
                     ; location in the program RAM
                       ; pipeline delay
    nop
HI08LOOP
    bra <FINISH
EPRSCILD
    jclr #1,omr,EPROMLD ; If MD MC MB MA=1001, go load from EPROM
                 ; If MD MC MB MA=1011, reserved, default to SCI
          _____
; This is the routine that loads from the SCI.
```

; MD MC MB MA=1010 - external SCI clock

#### SCILD

movep #\$0302,X:M\_SCR ; Configure SCI Control Reg movep #\$C000,X:M\_SCCR ; Configure SCI Clock Control Reg movep #7,X:M PCRE ; Configure SCLK, TXD and RXD

| do #6,_LOOP6 ; get 3 bytes for number of<br>; program words and 3 bytes<br>; for the starting address |
|-------------------------------------------------------------------------------------------------------|
| jclr #2,X:M_SSR,* ; Wait for RDRF to go high                                                          |
| movep X M_SRXL,A2 , Put 8 bits in A2                                                                  |
| jclr #1,X M_SSR,* ; Wait for TDRE to go high                                                          |
| movep A2,X:M_STXL ; echo the received byte                                                            |
| asr #8,a,a                                                                                            |
| LOOP6                                                                                                 |
| move a1,r0 ; starting address for load                                                                |
| move a1,r1 ; save starting address                                                                    |
| do a0,_LOOP7 ; Receive program words<br>do #3, LOOP8                                                  |
| jclr #2,X:M_SSR,* ; Wait for RDRF to go high<br>movep X:M_SRXL,A2 ; Put 8 bits in A2                  |
| jclr #1,X:M_SSR,* ; Wait for TDRE to go high                                                          |
| movep a2,X:M_STXL ; echo the received byte asr #8,a,a                                                 |
|                                                                                                       |

Bootstrap Program

Bootstrap Code

| LOOP8<br>movem a1,p:(r0)+ ; Store 24-bit result in P mem.<br>nop ; pipeline delay<br>LOOP7<br>bra <finish ;="" boot="" done<="" from="" sci="" td=""></finish>                                                                                                                                                                            |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ;=====================================                                                                                                                                                                                                                                                                                                    |
| EPROMLD<br>move #BOOT,r2 ; r2 = address of external EPROM<br>movep #AARV,X:M_AAR1 ; aar1 configured for SRAM types of access                                                                                                                                                                                                              |
| do #6,_LOOP9; read number of words and starting addressmovem p:(r2)+,a2; Get the 8 LSB from ext. P mem.asr #8,a,a; Shift 8 bit data into A1LOOP9;move a1,r0; starting address for loadmove a1,r1; save it in r1; a0 holds the number of words                                                                                             |
| do a0,_LOOP10; read program wordsdo #3,_LOOP11; Each instruction has 3 bytesmovem p:(r2)+,a2; Get the 8 LSB from ext. P mem.asr #8,a,a; Shift 8 bit data into A1LOOP11; Go get another byte.movem a1,p:(r0)+; Store 24-bit result in P mem.nop; pipeline delayLOOP10; and go get another 24-bit word.; Boot from EPROM done               |
| ;=====================================                                                                                                                                                                                                                                                                                                    |
| ; This is the exit handler that returns execution to normal<br>; expanded mode and jumps to the RESET vector.                                                                                                                                                                                                                             |
| andi #\$0,ccr; Clear CCR as if RESET to 0.jmp (r1); Then go to starting Prog addr.                                                                                                                                                                                                                                                        |
| ; The following modes are reserved, some of which are used for internal testing<br>; Can be implemented in future.<br>;<br>OMR0XXX<br>jclr #2,omr,RESERVED ; MD:MC:MB:MA=00xx is reserved<br>jclr #1,omr,RESERVED ; MD:MC:MB:MA=010x is reserved<br>jclr #0,omr,RESERVED ; MD:MC:MB:MA=0110 is reserved<br>; MD:MC:MB:MA=0111 is reserved |
| , WE WE WE WE WIT IS RECOVED                                                                                                                                                                                                                                                                                                              |

<\* bra end

**Freescale Semiconductor, Inc.** 

# A.2 Internal I/O Equates

EQUATES for DSP56311 I/O registers and ports

Last update: February 20 1999

page opt 132,55,0,0,0 mex

ioequ ident 1,0

· ·

EQUATES for I/O Port Programming

;------

; Register Addresses

| M_HDDR EQU | \$FFFFC9 | ; Host port GPIO direction Register |
|------------|----------|-------------------------------------|
| M_HDR_EQU  | \$FFFFC8 | ; Host port GPIO data Register      |
| M_PCRC EQU | \$FFFFBF | ; Port C Control Register           |
| M_PRRC EQU | \$FFFFBE | ; Port C Direction Register         |
| M_PDRC EQU | \$FFFFBD | ; Port C GPIO Data Register         |
| M_PCRD_EQU | \$FFFFAF | ; Port D Control register           |
| M_PRRD_EQU | \$FFFFAE | ; Port D Direction Data Register    |
| M_PDRD_EQU | \$FFFFAD | ; Port D GPIO Data Register         |
| M_PCRE EQU | \$FFFF9F | ; Port E Control register           |
| M_PRRE EQU | \$FFFF9E | ; Port E Direction Register         |
| M_PDRE EQU | \$FFFF9D | ; Port E Data Register              |
| M_OGDB EQU | \$FFFFFC | ; OnCE GDB Register                 |

\_\_\_\_\_

EQUATES for Host Interface

; Register Addresses

| M_HCR EQU  | \$FFFFC2 | ; Host Control Register          |
|------------|----------|----------------------------------|
| M_HSR EQU  | \$FFFFC3 | ; Host Status Register           |
| M_HPCR EQU | \$FFFFC4 | ; Host Polarity Control Register |
| M_HBAR_EQU | \$FFFFC5 | ; Host Base Address Register     |
| M_HRX EQU  | \$FFFFC6 | ; Host Receive Register          |
| M_HTX EQU  | \$FFFFC7 | ; Host Transmit Register         |
|            |          |                                  |

-----

; HCR bits definition

Internal I/O Equates

| M_HTIE EQU \$1 ;<br>M_HCIE EQU \$2 ;<br>M_HF2 EQU \$3 ; I<br>M_HF3 EQU \$4 ; I<br>; HSR bits definition<br>M_HRDF EQU \$0<br>M_HTDE EQU \$1                                                                                                                                   | Host Receive interrupts Enable<br>Host Transmit Interrupt Enable<br>Host Command Interrupt Enable<br>Host Flag 2<br>Host Flag 3<br>; Host Receive Data Full<br>; Host Receive Data Empty<br>Host Command Pending                                                                                                                                                                                                                       |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| M_HF0 EQU \$3 ; I                                                                                                                                                                                                                                                             | Host Flag 0                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| M_HF1 EQU \$4 ; I                                                                                                                                                                                                                                                             | Host Flag 1                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| M_HA8EN EQU \$1<br>M_HA9EN EQU \$2<br>M_HCSEN EQU \$3<br>M_HREN EQU \$3<br>M_HREN EQU \$4<br>M_HAEN EQU \$5<br>M_HEN EQU \$6<br>M_HOD EQU \$8<br>M_HDSP EQU \$9<br>M_HASP EQU \$9<br>M_HASP EQU \$A<br>M_HMUX EQU \$B<br>M_HD_HS EQU \$C<br>M_HCSP EQU \$D<br>M_HRP EQU \$E ; | ; Host Port GPIO Enable<br>; Host Address 8 Enable<br>; Host Address 9 Enable<br>; Host Chip Select Enable<br>; Host Request Enable<br>; Host Acknowledge Enable<br>Host Enable<br>Host Request Open Drain mode<br>Host Data Strobe Polarity<br>; Host Address Strobe Polarity<br>; Host Multiplexed bus select<br>; Host Double/Single Strobe select<br>; Host Chip Select Polarity<br>Host Request Polarity<br>Host Request Polarity |  |  |
| ;                                                                                                                                                                                                                                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| ; EQUATES for Serial Communications Interface (SCI)                                                                                                                                                                                                                           |                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| ; Register Addresses                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| M_STXH EQU \$FFFF97<br>M_STXM EQU \$FFFF96<br>M_STXL EQU \$FFFF95<br>M_SRXH EQU \$FFFF98<br>M_SRXM EQU \$FFFF99<br>M_SRXL EQU \$FFFF98<br>M_STXA EQU \$FFFF94<br>M_SCR EQU \$FFFF92<br>M_SSR EQU \$FFFF93<br>M_SCCR EQU \$FFFF9B                                              | ; SCI Transmit Data Register (high)<br>; SCI Transmit Data Register (middle)<br>; SCI Transmit Data Register (low)<br>; SCI Receive Data Register (high)<br>; SCI Receive Data Register (middle)<br>; SCI Receive Data Register (low)<br>; SCI Transmit Address Register<br>; SCI Control Register<br>; SCI Status Register<br>; SCI Clock Control Register                                                                            |  |  |
| ; SCI Control Register Bit I                                                                                                                                                                                                                                                  | Flags                                                                                                                                                                                                                                                                                                                                                                                                                                  |  |  |
|                                                                                                                                                                                                                                                                               | ; Word Select Mask (WDS0-WDS3)<br>; Word Select 0                                                                                                                                                                                                                                                                                                                                                                                      |  |  |

**Freescale Semiconductor, Inc.** 

DSP56311 User's Manual

| M_WDS1 EQU 1<br>M_WDS2 EQU 2 | ; Word Select 1<br>; Word Select 2  |
|------------------------------|-------------------------------------|
| M_SSFTD EQU 3                | ; SCI Shift Direction               |
| M_SBK EQU 4                  | ; Send Break                        |
| M_WAKE EQU 5                 | ; Wakeup Mode Select                |
| M_RWU EQU 6                  | ; Receiver Wakeup Enable            |
| M_WOMS EQU 7                 | ; Wired-OR Mode Select              |
| M_SCRE EQU 8                 | ; SCI Receiver Enable               |
| M_SCTE EQU 9                 | ; SCI Transmitter Enable            |
| M_ILIE EQU 10                | ; Idle Line Interrupt Enable        |
| M_SCRIE EQU 11               | ; SCI Receive Interrupt Enable      |
| M_SCTIE EQU 12               | ; SCI Transmit Interrupt Enable     |
| M_TMIE EQU 13                | ; Timer Interrupt Enable            |
| M_TIR EQU 14                 | ; Timer Interrupt Rate              |
| M_SCKP EQU 15                | ; SCI Clock Polarity                |
| M_REIE EQU 16                | ; SCI Error Interrupt Enable (REIE) |

; SCI Status Register Bit Flags

| M_TRNE EQU 0 | ; Transmitter Empty            |
|--------------|--------------------------------|
| M_TDRE EQU 1 | ; Transmit Data Register Empty |
| M_RDRF EQU 2 | ; Receive Data Register Full   |
| M_IDLE EQU 3 | ; Idle Line Flag               |
| M_OR EQU 4   | ; Overrun Error Flag           |
| M_PE EQU 5   | ; Parity Error                 |
| M_FE EQU 6   | ; Framing Error Flag           |
| M_R8 EQU 7   | ; Received Bit 8 (R8) Address  |
|              |                                |

; SCI Clock Control Register

| M_CD  | EQU | \$FFF | ; Clock Divider Mask (CD0-CD11) |
|-------|-----|-------|---------------------------------|
| M_COD | EQU | 12    | ; Clock Out Divider             |
| M_SCP | EQU | 13    | ; Clock Prescaler               |
| M_RCM | EQU | 14    | ; Receive Clock Mode Source Bit |
| M_TCM | EQU | 15    | ; Transmit Clock Source Bit     |
|       |     |       |                                 |

------

EQUATES for Synchronous Serial Interface (SSI)

Register Addresses Of SSI0 M TX00 EQU \$FFFFBC ; SSI0 Transmit Data Register 0 ; SSIO Transmit Data Register 1 M\_TX01 EQU \$FFFFBB M TX02 EQU \$FFFFBA ; SSIO Transmit Data Register 2 M TSR0 EQU \$FFFFB9 ; SSI0 Time Slot Register M RX0 EQU \$FFFFB8 ; SSI0 Receive Data Register M\_SSISR0 EQU ; SSI0 Status Register \$FFFFB7 ; SSI0 Control Register B M CRB0 EQU \$FFFFB6 M CRA0 EQU \$FFFFB5 ; SSI0 Control Register A M TSMA0 EQU \$FFFFB4 ; SSI0 Transmit Slot Mask Register A ; SSI0 Transmit Slot Mask Register B M TSMB0 EQU \$FFFFB3

Bootstrap Program

Internal I/O Equates

| M_RSMA0 EQU \$FFFFB2 ; SSI0 Receive Slot Mask Register A<br>M_RSMB0 EQU \$FFFFB1 ; SSI0 Receive Slot Mask Register B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |    |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| <ul> <li>Register Addresses Of SSII</li> <li>M_TX10 EQU \$FFFFAC ; SSI1 Transmit Data Register 0</li> <li>M_TX11 EQU \$FFFFAB ; SSI1 Transmit Data Register 1</li> <li>M_TX12 EQU \$FFFFAA ; SSI1 Transmit Data Register 2</li> <li>M_TSR1 EQU \$FFFFA9 ; SSI1 Time Slot Register</li> <li>M_RX1 EQU \$FFFFA8 ; SSI1 Receive Data Register</li> <li>M_SSISR1 EQU \$FFFFA7 ; SSI1 Status Register</li> <li>M_CRB1 EQU \$FFFFA6 ; SSI1 Control Register B</li> <li>M_CRA1 EQU \$FFFFA5 ; SSI1 Control Register A</li> <li>M_TSMA1 EQU \$FFFFA3 ; SSI1 Transmit Slot Mask Register A</li> <li>M_RSMA1 EQU \$FFFFA2 ; SSI1 Receive Slot Mask Register A</li> <li>M_RSMB1 EQU \$FFFFA1 ; SSI1 Receive Slot Mask Register B</li> </ul>                                                                                                                                                                                                 |    |
| ; SSI Control Register A Bit Flags                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |
| M_PMEQU\$FF; Prescale Modulus Select Mask (PM0-PM7)M_PSREQU11; Prescaler RangeM_DCEQU\$1F000; Frame Rate Divider Control Mask (DC0-DC7)M_ALCEQU18; Alignment Control (ALC)M_WLEQU\$380000; Word Length Control Mask (WL0-WL7)M_SSC1EQU22; Select SC1 as TR #0 drive enable (SSC1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1) |
| ; SSI Control Register B Bit Flags                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |    |
| M_OFEQU\$3; Serial Output Flag MaskM_OF0EQU0; Serial Output Flag 0M_OF1EQU1; Serial Output Flag 1M_SCDEQU\$1C; Serial Control Direction MaskM_SCD0EQU2; Serial Control DirectionM_SCD1EQU3; Serial Control DirectionM_SCD2EQU4; Serial Control 2 DirectionM_SCD2EQU4; Serial Control 2 DirectionM_SCD4EQU5; Clock Source DirectionM_SCD5EQU6; Shift DirectionM_SLEEQU\$180; Frame Sync Length Mask (FSL0-FSL1)M_FSLEQU7; Frame Sync Length 1M_FSL1EQU8; Frame Sync Length 1M_FSREQU9; Frame Sync Relative TimingM_FSPEQU10; Frame Sync PolarityM_CKPEQU11; Clock PolarityM_SYNEQU12; Sync/Async ControlM_MODEQU13; SSI Mode SelectM_SSTE2EQU14; SSI Transmit enable MaskM_SSTE1EQU15; SSI Transmit #2 EnableM_SSTE0EQU16; SSI Transmit #0 EnableM_SSREEQU18; SSI Receive EnableM_SSTEEQU19; SSI Receive Interrupt EnableM_SRLEEQU19; SSI Transmit Last Slot Interrupt EnableM_SRLEEQU20; SSI Transmit Last Slot Interrupt Enable |    |

**Freescale Semiconductor, Inc.** 

DSP56311 User's Manual

| M_STEIE EQU22; SSI Transmit Error Interrupt EnableM_SREIE EQU23; SSI Receive Error Interrupt Enable                                                                                                                                                                                                                                                                                                                            |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ; SSI Status Register Bit Flags                                                                                                                                                                                                                                                                                                                                                                                                |
| M_IFEQU\$3; Serial Input Flag MaskM_IF0EQU0; Serial Input Flag 0M_IF1EQU1; Serial Input Flag 1M_TFSEQU2; Transmit Frame Sync FlagM_RFSEQU3; Receive Frame Sync FlagM_TUEEQU4; Transmitter Underrun Error FLagM_ROEEQU5; Receiver Overrun Error FlagM_TDEEQU6; Transmit Data Register EmptyM_RDFEQU7; Receive Data Register Full                                                                                                |
| ; SSI Transmit Slot Mask Register A                                                                                                                                                                                                                                                                                                                                                                                            |
| M_SSTSA EQU \$FFFF ; SSI Transmit Slot Bits Mask A (TS0-TS15)                                                                                                                                                                                                                                                                                                                                                                  |
| ; SSI Transmit Slot Mask Register B                                                                                                                                                                                                                                                                                                                                                                                            |
| M_SSTSB EQU \$FFFF ; SSI Transmit Slot Bits Mask B (TS16-TS31)                                                                                                                                                                                                                                                                                                                                                                 |
| ; SSI Receive Slot Mask Register A                                                                                                                                                                                                                                                                                                                                                                                             |
| M_SSRSA EQU \$FFFF ; SSI Receive Slot Bits Mask A (RS0-RS15)                                                                                                                                                                                                                                                                                                                                                                   |
| ; SSI Receive Slot Mask Register B                                                                                                                                                                                                                                                                                                                                                                                             |
| M_SSRSB EQU \$FFFF ; SSI Receive Slot Bits Mask B (RS16-RS31)                                                                                                                                                                                                                                                                                                                                                                  |
| EQUATES for Exception Processing                                                                                                                                                                                                                                                                                                                                                                                               |
| ; Register Addresses                                                                                                                                                                                                                                                                                                                                                                                                           |
| M_IPRC EQU \$FFFFFF ; Interrupt Priority Register Core<br>M IPRP EQU \$FFFFFE ; Interrupt Priority Register Peripheral                                                                                                                                                                                                                                                                                                         |
| ; Interrupt Priority Register Core (IPRC)                                                                                                                                                                                                                                                                                                                                                                                      |
| M_IALEQU\$7; IRQA Mode MaskM_IAL0EQU0; IRQA Mode Interrupt Priority Level (low)M_IAL1EQU1; IRQA Mode Interrupt Priority Level (high)M_IAL2EQU2; IRQA Mode Trigger ModeM_IBLEQU\$38; IRQB Mode MaskM_IBL0EQU3; IRQB Mode Interrupt Priority Level (low)M_IBL1EQU4; IRQB Mode Interrupt Priority Level (high)M_IBL2EQU5; IRQB Mode Trigger ModeM_ICLEQU\$1C0; IRQC Mode MaskM_ICL0EQU6; IRQC Mode Interrupt Priority Level (low) |

Bootstrap Program

#### For More Information On This Product, Go to: www.freescale.com

Internal I/O Equates

| M_ICL1 EQU      | 7           | ; IRQC Mode Interrupt Priority Level (high) |
|-----------------|-------------|---------------------------------------------|
| M_ICL2 EQU      | 8           | ; IRQC Mode Trigger Mode                    |
| M_IDL EQU       | \$E00       | ; IRQD Mode Mask                            |
| M_IDL0 EQU      | 9           | ; IRQD Mode Interrupt Priority Level (low)  |
| M_IDL1 EQU      | 10          | ; IRQD Mode Interrupt Priority Level (high) |
| M_IDL2 EQU      | 11          | ; IRQD Mode Trigger Mode                    |
| M_DOL EQU       | \$3000      | ; DMA0 Interrupt priority Level Mask        |
| M_DOL0 EQU      | 12          | ; DMA0 Interrupt Priority Level (low)       |
| M_D0L1 EQU      | 13          | ; DMA0 Interrupt Priority Level (high)      |
| M_D1L EQU       | \$C000      | ; DMA1 Interrupt Priority Level Mask        |
| M_D1L0 EQU      | 14          | ; DMA1 Interrupt Priority Level (low)       |
| M_D1L1 EQU      | 15          | ; DMA1 Interrupt Priority Level (high)      |
| M_D2L EQU       | \$30000     | ; DMA2 Interrupt priority Level Mask        |
| M_D2L0 EQU      | 16          | ; DMA2 Interrupt Priority Level (low)       |
| M_D2L1 EQU      | 17          | ; DMA2 Interrupt Priority Level (high)      |
| M_D3L EQU       | \$C0000     | ; DMA3 Interrupt Priority Level Mask        |
| M_D3L0 EQU      | 18          | ; DMA3 Interrupt Priority Level (low)       |
| M_D3L1 EQU      | 19          | ; DMA3 Interrupt Priority Level (high)      |
| M_D4L EQU       | \$300000    | ; DMA4 Interrupt priority Level Mask        |
| M_D4L0 EQU      | 20          | ; DMA4 Interrupt Priority Level (low)       |
| M_D4L1 EQU      | 21          | ; DMA4 Interrupt Priority Level (high)      |
| M_D5L EQU       | \$C00000    | ; DMA5 Interrupt priority Level Mask        |
| M_D5L0 EQU      | 22          | ; DMA5 Interrupt Priority Level (low)       |
| M_D5L1 EQU      | 23          | ; DMA5 Interrupt Priority Level (high)      |
|                 |             |                                             |
| : Interrupt Pri | ority Regis | ter Peripheral (IPRP)                       |

Interrupt Priority Register Peripheral (IPRP)

| MIDI FOU    | ф <b>э</b> |                                         |
|-------------|------------|-----------------------------------------|
| _ `         | \$3        | ; Host Interrupt Priority Level Mask    |
| M_HPL0_EQU  | 0          | ; Host Interrupt Priority Level (low)   |
| M_HPL1_EQU  | 1          | ; Host Interrupt Priority Level (high)  |
| M_SOL EQU S | \$C        | ; SSI0 Interrupt Priority Level Mask    |
| M_SOLO EQU  | 2          | ; SSI0 Interrupt Priority Level (low)   |
| M_SOL1 EQU  | 3          | ; SSI0 Interrupt Priority Level (high)  |
| M_S1L EQU S | \$30       | ; SSI1 Interrupt Priority Level Mask    |
| M_S1L0 EQU  | 4          | ; SSI1 Interrupt Priority Level (low)   |
| M_S1L1 EQU  | 5          | ; SSI1 Interrupt Priority Level (high)  |
| M_SCL EQU   | \$C0       | ; SCI Interrupt Priority Level Mask     |
| M_SCL0 EQU  | 6          | ; SCI Interrupt Priority Level (low)    |
| M_SCL1 EQU  | 7          | ; SCI Interrupt Priority Level (high)   |
| M_TOL EQU S | \$300      | ; TIMER Interrupt Priority Level Mask   |
| M_TOLO EQU  | 8          | ; TIMER Interrupt Priority Level (low)  |
| M_TOL1 EQU  | 9          | ; TIMER Interrupt Priority Level (high) |
| M_EPL EQU   | \$C00      | ; EFCOP Interrupt Priority Level Mask   |
| M_EPL0 EQU  | 10         | ; EFCOP Interrupt Priority Level (low)  |
| M EPL1 EQU  | 11         | ; EFCOP Interrupt Priority Level (high) |

\_\_\_\_\_

EQUATES for TIMER

;

;

**A-**14

;-----

Register Addresses Of TIMER0

| M_TCSR0 EQU\$FFFF8F; TIMER0 Control/Status RegisterM_TLR0 EQU\$FFFF8E; TIMER0 Load RegM_TCPR0 EQU\$FFFF8D; TIMER0 Compare RegisterM_TCR0 EQU\$FFFF8C; TIMER0 Count Register                                                                                                                                                                                                 |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ; Register Addresses Of TIMER1                                                                                                                                                                                                                                                                                                                                              |
| M_TCSR1 EQU\$FFFF8B; TIMER1 Control/Status RegisterM_TLR1 EQU\$FFFF8A; TIMER1 Load RegM_TCPR1 EQU\$FFFF89; TIMER1 Compare RegisterM_TCR1 EQU\$FFFF88; TIMER1 Count Register                                                                                                                                                                                                 |
| ; Register Addresses Of TIMER2                                                                                                                                                                                                                                                                                                                                              |
| M_TCSR2 EQU\$FFFF87; TIMER2 Control/Status RegisterM_TLR2 EQU\$FFFF86; TIMER2 Load RegM_TCPR2 EQU\$FFFF85; TIMER2 Compare RegisterM_TCR2 EQU\$FFFF84; TIMER2 Count RegisterM_TPLR EQU\$FFFF83; TIMER Prescaler Load RegisterM_TPCR EQU\$FFFF82; TIMER Prescaler Count Register                                                                                              |
| ; Timer Control/Status Register Bit Flags                                                                                                                                                                                                                                                                                                                                   |
| M_TEEQU0; Timer EnableM_TOIEEQU1; Timer Overflow Interrupt EnableM_TCIEEQU2; Timer Compare Interrupt EnableM_TCEQU\$F0; Timer Control Mask (TC0-TC3)M_INVEQU8; Inverter BitM_TRMEQU9; Timer Restart ModeM_DIREQU11; Direction BitM_DIEQU12; Data InputM_DOEQU13; Data OutputM_PCEEQU15; Prescaled Clock EnableM_TOFEQU20; Timer Overflow FlagM_TCFEQU21; Timer Compare Flag |
| ; Timer Prescaler Register Bit Flags                                                                                                                                                                                                                                                                                                                                        |
| M_PSEQU \$600000; Prescaler Source MaskM_PS0EQU21M_PS1EQU22                                                                                                                                                                                                                                                                                                                 |

| ; Time | er Contr | ol Bits |                   |
|--------|----------|---------|-------------------|
| M_TC0  | EQU      | 4       | ; Timer Control 0 |
| M_TC1  | EQU      | 5       | ; Timer Control 1 |
| M_TC2  | EQU      | 6       | ; Timer Control 2 |
| M_TC3  | EQU      | 7       | ; Timer Control 3 |

Internal I/O Equates

\_\_\_\_\_ EQUATES for Direct Memory Access (DMA) \_\_\_\_\_ Register Addresses Of DMA M DSTR EQU \$FFFFF4 ; DMA Status Register M DOR0 EQU \$FFFFF3 ; DMA Offset Register 0 M DOR1 EQU ; DMA Offset Register 1 \$FFFFF2 M DOR2 EQU \$FFFFF1 ; DMA Offset Register 2 M DOR3 EQU ; DMA Offset Register 3 \$FFFFF0 Register Addresses Of DMA0 M DSR0 EQU \$FFFFEF ; DMA0 Source Address Register M DDR0 EQU ; DMA0 Destination Address Register \$FFFFEE M DCO0 EQU \$FFFFED ; DMA0 Counter M DCR0 EQU \$FFFFEC ; DMA0 Control Register Register Addresses Of DMA1 M DSR1 EQU ; DMA1 Source Address Register \$FFFFEB M DDR1 EQU \$FFFFEA ; DMA1 Destination Address Register M DCO1 EQU \$FFFFE9 ; DMA1 Counter M DCR1 EQU ; DMA1 Control Register \$FFFFE8 Register Addresses Of DMA2 M DSR2 EQU ; DMA2 Source Address Register \$FFFFE7 M DDR2 EQU ; DMA2 Destination Address Register \$FFFFE6 M DCO2 EQU ; DMA2 Counter \$FFFFE5 M DCR2 EQU \$FFFFE4 ; DMA2 Control Register Register Addresses Of DMA4 M DSR3 EQU ; DMA3 Source Address Register \$FFFFE3 M DDR3 EQU \$FFFFE2 ; DMA3 Destination Address Register M DCO3 EQU \$FFFFE1 ; DMA3 Counter M DCR3 EQU \$FFFFE0 ; DMA3 Control Register Register Addresses Of DMA4 M DSR4 EQU ; DMA4 Source Address Register \$FFFFDF M DDR4 EQU ; DMA4 Destination Address Register \$FFFFDE M DCO4 EQU \$FFFFDD ; DMA4 Counter M DCR4 EQU ; DMA4 Control Register \$FFFFDC Register Addresses Of DMA5 M DSR5 EQU \$FFFFDB ; DMA5 Source Address Register M DDR5 EQU ; DMA5 Destination Address Register \$FFFFDA M DCO5 EQU \$FFFFD9 ; DMA5 Counter

Semiconductor, Inc

eescale

DSP56311 User's Manual

Internal I/O Equates

| М   | DCR5 | EQU |  |
|-----|------|-----|--|
| TAT | DURJ | LQU |  |

\$FFFFD8

; DMA5 Control Register

; DMA Control Register

| M DSS EQU             | \$3           | ; DMA Source Space Mask (DSS0-Dss1)     |
|-----------------------|---------------|-----------------------------------------|
| M DSS0 EQU            | 0             | , DMA Source Memory space 0             |
| M_DSS1_EQU            | 1             | , DMA Source Memory space 1             |
| M DDS EQU             | \$C           | , DMA Destination Space Mask (DDS-DDS1) |
| M DDS0 EQU            | 2             | ; DMA Destination Memory Space 0        |
| M DDS1 EQU            | 3             | ; DMA Destination Memory Space 1        |
| m dam equ             | <b>\$3f</b> 0 | , DMA Address Mode Mask (DAM5-DAM0)     |
| m damo equ            | 4             | ; DMA Address Mode 0                    |
| m dami equ            | 5             | , DMA Address Mode 1                    |
| M DAM2 EQU            | 6             | , DMA Address Mode 2                    |
| M DAM3 EQU            | 7             | , DMA Address Mode 3                    |
| M DAM4 EQU            | 8             | , DMA Address Mode 4                    |
| M DAM5 EQU            | 9             | , DMA Address Mode 5                    |
| M D3D EQU             | 10            | ; DMA Three Dimensional Mode            |
| M_DRS_EQU             | \$F800        | ; DMA Request Source Mask (DRS0-DRS4)   |
| M_DCON EQU            | 16            | ; DMA Continuous Mode                   |
| M_DPR EQU             | \$60000       | ; DMA Channel Priority                  |
| M_DPR0 EQU            | 17            | ; DMA Channel Priority Level (low)      |
| M_DPR1 EQU            | 18            | ; DMA Channel Priority Level (high)     |
| M_DTM EQU             | \$380000      | , DMA Transfer Mode Mask (DTM2-DTM0)    |
| M_DTM0 EQU            | 19            | ; DMA Transfer Mode 0                   |
| M_DTM1 EQU            | 20            | ; DMA Transfer Mode 1                   |
| M_DTM2 EQU            | 21            | ; DMA Transfer Mode 2                   |
| M_DIE EQU             | 22            | ; DMA Interrupt Enable bit              |
| M_DE EQU              | 23            | ; DMA Channel Enable bit                |
|                       |               |                                         |
| ; DMA Status Register |               |                                         |
| M DTD EQU             | <b>\$3</b> F  | ; Channel Transfer Done Status MASK     |
| M_DTD0 EQU            | 0             | ; DMA Channel Transfer Done Status 0    |
| M_DTD1 EQU            | 1             | ; DMA Channel Transfer Done Status 1    |
| M_DTD2 EQU            | 2             | ; DMA Channel Transfer Done Status 2    |
| M_DTD3 EQU            | 3             | ; DMA Channel Transfer Done Status 3    |
| M_DTD4 EQU            | 4             | ; DMA Channel Transfer Done Status 4    |
| M_DTD5 EQU            | 5             | ; DMA Channel Transfer Done Status 5    |
| M_DACT EQU            | 8             | ; DMA Active State                      |
| M_DCH EQU             | \$E00         | ; DMA Active Channel Mask (DCH0-DCH2)   |
| M_DCH0 EQU            | 9             | ; DMA Active Channel 0                  |
| M_DCH1 EQU            | 10            | ; DMA Active Channel 1                  |
| M_DCH2 EQU            | 11            | ; DMA Active Channel 2                  |
|                       |               |                                         |

\_\_\_\_\_

EQUATES for Enhanced Filter Coprocessor (EFCOP)

, ·\_\_\_\_\_

| M_FDIR EQU | \$FFFFB0 | ; EFCOP Data Input Register  |
|------------|----------|------------------------------|
| M_FDOR EQU | \$FFFFB1 | ; EFCOP Data Output Register |
| M_FKIR EQU | \$FFFFB2 | ; EFCOP K-Constant Register  |

Bootstrap Program

#### For More Information On This Product, Go to: www.freescale.com

Internal I/O Equates

| M_FCNTEQU\$FFFFB3; EFCOP Filter CounterM_FCSREQU\$FFFFB4; EFCOP Control Status RegisterM_FACREQU\$FFFFB5; EFCOP ALU Control RegisterM_FDBAEQU\$FFFFB6; EFCOP Data Base AddressM_FCBAEQU\$FFFFB7; EFCOP Coefficient Base AddressM_FDCHEQU\$FFFFB8; EFCOP Decimation/Channel Register                                                      |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EQUATES for Phase Locked Loop (PLL)                                                                                                                                                                                                                                                                                                      |
| ; Register Addresses Of PLL                                                                                                                                                                                                                                                                                                              |
| M_PCTL EQU \$FFFFFD ; PLL Control Register                                                                                                                                                                                                                                                                                               |
| ; PLL Control Register                                                                                                                                                                                                                                                                                                                   |
| M_MFEQU\$FFF; Multiplication Factor Bits Mask (MF0-MF11)M_DFEQU\$7000; Division Factor Bits Mask (DF0-DF2)M_XTLREQU15; XTAL Range select bitM_XTLDEQU16; XTAL Disable BitM_PSTPEQU17; STOP Processing State BitM_PENEQU18; PLL Enable BitM_PCODEQU19; PLL Clock Output Disable BitM_PDEQU\$F00000; PreDivider Factor Bits Mask (PD0-PD3) |
| EQUATES for BIU                                                                                                                                                                                                                                                                                                                          |
| ; Register Addresses Of BIU                                                                                                                                                                                                                                                                                                              |
| M_BCREQU\$FFFFB; Bus Control RegisterM_DCREQU\$FFFFFA; DRAM Control RegisterM_AAR0EQU\$FFFF9; Address Attribute Register 0M_AAR1EQU\$FFFFF8; Address Attribute Register 1M_AAR2EQU\$FFFFF7; Address Attribute Register 2M_AAR3EQU\$FFFFF6; Address Attribute Register 3M_IDREQU\$FFFF5; ID Register                                      |
| ; Bus Control Register                                                                                                                                                                                                                                                                                                                   |
| M_BA0WEQU\$1F; Area 0 Wait Control Mask (BA0W0-BA0W4)M_BA1WEQU\$3E0; Area 1 Wait Control Mask (BA1W0-BA14)M_BA2WEQU\$1C00; Area 2 Wait Control Mask (BA2W0-BA2W2)M_BA3WEQU\$E000; Area 3 Wait Control Mask (BA3W0-BA3W3)                                                                                                                 |

DSP56311 User's Manual

| M_BCWEQU\$3; In Page Wait States Bits Mask (BCW0-BCW1)M_BRWEQU\$C; Out Of Page Wait States Bits Mask (BRW0-BRW1)M_BPSEQU\$300; DRAM Page Size Bits Mask (BPS0-BPS1)M_BPLEEQU11; Page Logic EnableM_BMEEQU12; Mastership Enable |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| M_BRWEQU\$C; Out Of Page Wait States Bits Mask (BRW0-BRW1)M_BPSEQU\$300; DRAM Page Size Bits Mask (BPS0-BPS1)M_BPLEEQU11; Page Logic EnableM_BMEEQU12; Mastership Enable                                                       |
| M_BPSEQU\$300; DRAM Page Size Bits Mask (BPS0-BPS1)M_BPLEEQU11; Page Logic EnableM_BMEEQU12; Mastership Enable                                                                                                                 |
| M_BPLEEQU11; Page Logic EnableM_BMEEQU12; Mastership Enable                                                                                                                                                                    |
| M_BME EQU 12 ; Mastership Enable                                                                                                                                                                                               |
|                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                |
| M_BRE EQU 13 ; Refresh Enable                                                                                                                                                                                                  |
| M_BSTR EQU 14 ; Software Triggered Refresh                                                                                                                                                                                     |
| M_BRF EQU \$7F8000 ; Refresh Rate Bits Mask (BRF0-BRF7)                                                                                                                                                                        |
| M_BRP EQU 23 ; Refresh prescaler                                                                                                                                                                                               |
| ; Address Attribute Registers                                                                                                                                                                                                  |
| M_BAT EQU \$3 ; External Access Type and Pin Definition Bits                                                                                                                                                                   |
| ; Mask (BAT0-BAT1)                                                                                                                                                                                                             |
| M_BAAP EQU 2 ; Address Attribute Pin Polarity                                                                                                                                                                                  |
| M_BPEN EQU 3 ; Program Space Enable                                                                                                                                                                                            |
| M BXEN EQU 4 ; X Data Space Enable                                                                                                                                                                                             |
| M_BYEN EQU 5 ; Y Data Space Enable                                                                                                                                                                                             |
| M_BAM_EQU_6 ; Address Muxing                                                                                                                                                                                                   |
| M_BPAC EQU 7 ; Packing Enable                                                                                                                                                                                                  |
| M_BNC EQU \$F00 ; Number of Address Bits to Compare Mask                                                                                                                                                                       |
| M_BAC EQU \$FFF000 ; Address to Compare Bits Mask (BAC0-BAC11)                                                                                                                                                                 |
|                                                                                                                                                                                                                                |
| ; control and status bits in SR                                                                                                                                                                                                |
| M CD FOU \$200000                                                                                                                                                                                                              |
| M_CP_EQU \$c00000 ; mask for CORE-DMA priority bits in SR                                                                                                                                                                      |
| M_CA EQU 0 ; Carry                                                                                                                                                                                                             |
| M_V EQU 1 ; Overflow                                                                                                                                                                                                           |
| M_Z EQU 2 ; Zero                                                                                                                                                                                                               |
| M_N EQU 3 ; Negative                                                                                                                                                                                                           |
| M_U EQU 4 ; Unnormalized                                                                                                                                                                                                       |
| M_E EQU 5 ; Extension                                                                                                                                                                                                          |
| M_L EQU 6 ; Limit                                                                                                                                                                                                              |
| M_S EQU 7 ; Scaling Bit                                                                                                                                                                                                        |
| M_I0 EQU 8 ; Interrupt Mask Bit 0                                                                                                                                                                                              |
| M_I1 EQU 9 ; Interrupt Mask Bit 1                                                                                                                                                                                              |
| M_S0 EQU 10 ; Scaling Mode Bit 0                                                                                                                                                                                               |
| M_S1 EQU 11 ; Scaling Mode Bit 1                                                                                                                                                                                               |
| M_SC EQU 13 ; Sixteen_Bit Compatibility                                                                                                                                                                                        |
| M_DM_EQU_14 ; Double Precision Multiply                                                                                                                                                                                        |
| M_LF EQU 15 ; DO-Loop Flag                                                                                                                                                                                                     |
| M_FV EQU 16 ; DO-Forever Flag                                                                                                                                                                                                  |
| M_SA_EQU_17 ; Sixteen-Bit Arithmetic                                                                                                                                                                                           |
| M_CE EQU 19 ; Instruction Cache Enable                                                                                                                                                                                         |
| M_SM_EQU_20 ; Arithmetic Saturation                                                                                                                                                                                            |
| M_RM_EQU_21 ; Rounding Mode                                                                                                                                                                                                    |
| M_CP0 EQU 22 ; bit 0 of priority bits in SR                                                                                                                                                                                    |
| M_CP1 EQU 23 ; bit 1 of priority bits in SR                                                                                                                                                                                    |
|                                                                                                                                                                                                                                |

M\_CDP EQU \$300

Bootstrap Program

; mask for CORE-DMA priority bits in OMR

| M_MA EQU0    | ; Operating Mode A                         |
|--------------|--------------------------------------------|
| M_MB EQU1    | ; Operating Mode B                         |
| M_MC EQU2    | ; Operating Mode C                         |
| M_MD EQU3    | ; Operating Mode D                         |
| M_EBD EQU 4  | ; External Bus Disable bit in OMR          |
| M_SD EQU 6   | ; Stop Delay                               |
| M_MS EQU 7   | ; Memory Switch bit in OMR                 |
| M_CDP0 EQU 8 | ; bit 0 of priority bits in OMR            |
| M_CDP1 EQU 9 | ; bit 1 of priority bits in OMR            |
| M_BEN EQU 10 | ; Burst Enable                             |
| M_TAS EQU 11 | ; TA Synchronize Select                    |
| M_BRT EQU 12 | ; Bus Release Timing                       |
| M_ATE EQU 15 | ; Address Tracing Enable bit in OMR.       |
| M_XYS EQU 16 | ; Stack Extension space select bit in OMR. |
| M_EUN EQU 17 | ; Extended stack UNderflow flag in OMR.    |
| M_EOV EQU 18 | ; Extended stack OVerflow flag in OMR.     |
| M_WRP EQU 19 | ; Extended WRaP flag in OMR.               |
| M_SEN EQU 20 | ; Stack Extension Enable bit in OMR.       |

# A.3 Interrupt Equates

EQUATES for 56311 interrupts Last update: February 20 1999 \*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\*\* 132,55,0,0,0 page opt mex intequ ident 1,0 if @DEF(I\_VEC) ;leave user definition as is. else I VEC EQU \$0 endif .\_\_\_\_\_ ; Non-Maskable interrupts ·-----I\_RESET EQU I\_VEC+\$00 ; Hardware RESET I STACK EQU I VEC+\$02 ; Stack Error I ILL EQU I VEC+\$04 ; Illegal Instruction I\_DBG EQU I\_VEC+\$06 ; Debug Request I TRAP EQU I VEC+\$08 ; Trap I NMI EQU I VEC+\$0A ; Non Maskable Interrupt \*\_\_\_\_\_ ; Interrupt Request Pins \*\_\_\_\_\_ I\_IRQA EQU I\_VEC+\$10 ; IRQA I\_IRQB EQU I\_VEC+\$12 ; IRQB

I IRQC EQU I VEC+\$14 ; IRQC I IRQD EQU I VEC+\$16 ; IRQD . ; DMA Interrupts · \_\_\_\_\_ I\_DMA0 EQU I\_VEC+\$18 ; DMA Channel 0 I DMA1 EQU I\_VEC+\$1A ; DMA Channel 1 I DMA2 EQU I VEC+\$1C ; DMA Channel 2 I DMA3 EQU I VEC+\$1E ; DMA Channel 3 I\_DMA4 EQU I\_VEC+\$20 ; DMA Channel 4 I DMA5 EQU I VEC+\$22 ; DMA Channel 5 ; Timer Interrupts •\_\_\_\_\_ I TIMOC EQU I VEC+\$24 ; TIMER 0 compare I\_TIM0OF EQU I\_VEC+\$26 ; TIMER 0 overflow I\_TIM1C EQU I\_VEC+\$28 ; TIMER 1 compare I TIM1OF EQU I VEC+\$2A ; TIMER 1 overflow I TIM2C EQU I VEC+\$2C ; TIMER 2 compare I TIM2OF EQU I VEC+\$2E ; TIMER 2 overflow :-----; ESSI Interrupts . I SIORD EQU I VEC+\$30 ; ESSI0 Receive Data I SIORDE EQU I VEC+\$32 ; ESSIO Receive Data With Exception Status I\_SIORLSEQU\_I\_VEC+\$34 ; ESSIO Receive last slot I\_SIOTD EQU I\_VEC+\$36 ; ESSI0 Transmit data I SIOTDE EQU I VEC+\$38 ; ESSIO Transmit Data With Exception Status I SIOTLS EQU I VEC+\$3A ; ESSIO Transmit last slot I\_SI1RD EQU I\_VEC+\$40 ; ESSI1 Receive Data I SIIRDE EQU I VEC+\$42 ; ESSII Receive Data With Exception Status I\_SI1RLS EQU I\_VEC+\$44 ; ESSI1 Receive last slot I SIITD EQU I VEC+\$46 ; ESSII Transmit data I SIITDE EQU I VEC+\$48 ; ESSII Transmit Data With Exception Status I SIITLS EQU I VEC+\$4A ; ESSII Transmit last slot ·\_\_\_\_\_ ; SCI Interrupts I SCIRD EQU I VEC+\$50 ; SCI Receive Data I\_SCIRDE EQU I\_VEC+\$52 ; SCI Receive Data With Exception Status I SCITD EQU I VEC+\$54 ; SCI Transmit Data I SCIIL EQU I\_VEC+\$56 ; SCI Idle Line I SCITM EQU I VEC+\$58 ; SCI Timer ;-----; HOST Interrupts ·-----I HRDF EQU I VEC+\$60 ; Host Receive Data Full I HTDE EQU I VEC+\$62 ; Host Transmit Data Empty I HC EQU I VEC+\$64 ; Default Host Command

Semiconductor, Inc

0

eescal

Bootstrap Program

Interrupt Equates

;-----

; EFCOP Interrupts

I\_FDIBE EQU I\_VEC+\$68 ; EFCOP Input Buffer Empty I FDOBF EQU I VEC+\$6A ; EFCOP Output Buffer Full

;-----

; INTERRUPT ENDING ADDRESS

;-----I\_INTEND EQU I\_VEC+\$FF ; last address of interrupt vector space

# Appendix B Programming Reference

This reference for programmers includes a table showing the addresses of all DSP memory-mapped peripherals, an exception priority table, and programming sheets for the major programmable DSP registers. The programming sheets are grouped in the following order: central processor, Phase Lock Loop, (PLL), Host Interface (HI08), Enhanced Synchronous Serial Interface (ESSI), Serial Communication Interface (SCI), Timer, GPIO, and EFCOP. Each sheet provides room to write in the value of each bit and the hexadecimal value for each register. You can photocopy these sheets and reuse them for each application development project. For details on the instruction set of the DSP56300 family of DSPs, see the *DSP56300 Family Manual*.

- **Table B-2**, "Internal X I/O Memory Map," on page B-2 and **Table B-3**, "Internal Y I/O Memory Map," on page B-7 list the memory addresses of all on-chip peripherals.
- **Table B-4**, "Interrupt Sources," on page B-8 lists the interrupt starting addresses and sources.
- **Table B-5**, "Interrupt Source Priorities Within an IPL," on page B-10 lists the priorities of specific interrupts within interrupt priority levels.
- The programming sheets appear in this manual as figures (listed in **Table B-1**); they show the major programmable registers on the DSP56311.

| Module    | Programming Sheet                                               | Page      |
|-----------|-----------------------------------------------------------------|-----------|
| Central   | Figure B-1, "Status Register (SR)"                              | page B-12 |
| Processor | Figure B-2, "Operating Mode Register"                           | page B-13 |
|           | Figure B-3, "Address Attribute Registers (AAR3 - AAR0)"         | page B-14 |
|           | Figure B-4, "Bus Control Register (BCR)"                        | page B-15 |
|           | Figure B-5, "DMA Control Register (DCR)"                        | page B-16 |
|           | Figure B-6, "Interrupt Priority Register–Core (IPR–C)"          | page B-17 |
|           | Figure B-7, "Interrupt Priority Register – Peripherals (IPR–P)" | page B-18 |
| PLL       | Figure B-8, "Phase Lock Loop Control Register (PCTL)"           | page B-19 |

Table B-1. Guide to Programming Sheets

| HI08   | Figure B-9, "Host Receive and Host Transmit Data Registers"               | page B-20 |
|--------|---------------------------------------------------------------------------|-----------|
|        | Figure B-10, "Host Control and Host Status Registers"                     | page B-21 |
|        | Figure B-11, "Host Base Address and Host Port Control Registers"          | page B-22 |
|        | Figure B-12, "Interrupt Control and Interrupt Status Registers"           | page B-23 |
|        | Figure B-13, "Interrupt Vector and Command Vector Registers"              | page B-24 |
|        | Figure B-14, "Host Receive and Host Transmit Data Registers"              | page B-25 |
| ESSI   | Figure B-15, "ESSI Control Register A (CRA)"                              | page B-26 |
|        | Figure B-16, "ESSI Control Register B (CRB)"                              | page B-27 |
|        | Figure B-17, "ESSI Status Register (SSISR)"                               | page B-28 |
|        | Figure B-18, "ESSR Transmit and Receive Slot Mask Registers (TSM, RSM)"   | page B-29 |
| SCI    | Figure B-19, "SCI Control Register (SCR)"                                 | page B-30 |
|        | Figure B-20, "SCI Status and Clock Control Registers (SSR, SCCR)"         | page B-31 |
|        | Figure B-21, "SCI Receive and Transmit Data Registers (SRX, TRX)"         | page B-32 |
| Timers | Figure B-22, "Timer Prescaler Load/Count Register (TPLR, TPCR)"           | page B-33 |
|        | Figure B-23, "Timer Control/Status Register (TCSR)"                       | page B-34 |
|        | Figure B-24, "Timer Load, Compare, Count Registers (TLR, TCPR, TCR)"      | page B-35 |
| GPIO   | Figure B-25, "Host Data Direction and Host Data Registers (HDDR, HDR)"    | page B-36 |
|        | Figure B-26, "Port C Registers (PCRC, PRRC, PDRC)"                        | page B-37 |
|        | Figure B-27, "Port D Registers (PCRD, PRRD, PDRD)"                        | page B-38 |
|        | Figure B-28, "Port E Registers (PCRE, PRRE, PDRE)"                        | page B-39 |
| EFCOP  | Figure B-29, "EFCOP Counter and Control Status Registers (FCNT and FCSR)" | page B-40 |
|        | Figure B-30, "EFCOP FACR, FDBA, FCBA, and FDCH Registers"                 | page B-41 |
|        |                                                                           |           |

#### Table B-1. Guide to Programming Sheets

# **B.1** Internal I/O Memory Map

| Table B-2. | Internal X I/O Memory Map |
|------------|---------------------------|
|------------|---------------------------|

| Peripheral | 16-Bit Address | 24-Bit Address | Register Name                                  |
|------------|----------------|----------------|------------------------------------------------|
| IPR        | \$FFFF         | \$FFFFF        | Interrupt Priority Register Core (IPR-C)       |
|            | \$FFFE         | \$FFFFE        | Interrupt Priority Register Peripheral (IPR-P) |
| PLL        | \$FFFD         | \$FFFFD        | PLL Control Register (PCTL)                    |
| OnCE       | \$FFFC         | \$FFFFC        | OnCE GDB Register (OGDB)                       |

| Peripheral | 16-Bit Address | 24-Bit Address | Register Name                           |
|------------|----------------|----------------|-----------------------------------------|
| BIU        | \$FFFB         | \$FFFFB        | Bus Control Register (BCR)              |
|            | \$FFFA         | \$FFFFFA       | DRAM Control Register (DCR)             |
|            | \$FFF9         | \$FFFFF9       | Address Attribute Register 0 (AAR0)     |
|            | \$FFF8         | \$FFFF8        | Address Attribute Register 1 (AAR1)     |
|            | \$FFF7         | \$FFFF7        | Address Attribute Register 2 (AAR2)     |
|            | \$FFF6         | \$FFFF6        | Address Attribute Register 3 (AAR3)     |
|            | \$FFF5         | \$FFFF5        | ID Register (IDR)                       |
| DMA        | \$FFF4         | \$FFFFF4       | DMA Status Register (DSTR)              |
|            | \$FFF3         | \$FFFFF3       | DMA Offset Register 0 (DOR0)            |
|            | \$FFF2         | \$FFFFF2       | DMA Offset Register 1 (DOR1)            |
|            | \$FFF1         | \$FFFFF1       | DMA Offset Register 2 (DOR2)            |
|            | \$FFF0         | \$FFFFF0       | DMA Offset Register 3 (DOR3)            |
| DMA0       | \$FFEF         | \$FFFFEF       | DMA Source Address Register (DSR0)      |
|            | \$FFEE         | \$FFFFEE       | DMA Destination Address Register (DDR0) |
|            | \$FFED         | \$FFFFED       | DMA Counter (DCO0)                      |
|            | \$FFEC         | \$FFFFEC       | DMA Control Register (DCR0)             |
| DMA1       | \$FFEB         | \$FFFFEB       | DMA Source Address Register (DSR1)      |
|            | \$FFEA         | \$FFFFEA       | DMA Destination Address Register (DDR1) |
|            | \$FFE9         | \$FFFFE9       | DMA Counter (DCO1)                      |
|            | \$FFE8         | \$FFFFE8       | DMA Control Register (DCR1)             |
| DMA2       | \$FFE7         | \$FFFFE7       | DMA Source Address Register (DSR2)      |
|            | \$FFE6         | \$FFFFE6       | DMA Destination Address Register (DDR2) |
| •          | \$FFE5         | \$FFFFE5       | DMA Counter (DCO2)                      |
|            | \$FFE4         | \$FFFFE4       | DMA Control Register (DCR2)             |
| DMA3       | \$FFE3         | \$FFFFE3       | DMA Source Address Register (DSR3)      |
|            | \$FFE2         | \$FFFFE2       | DMA Destination Address Register (DDR3) |
|            | \$FFE1         | \$FFFFE1       | DMA Counter (DCO3)                      |
|            | \$FFE0         | \$FFFFE0       | DMA Control Register (DCR3)             |

Internal I/O Memory Map

| Peripheral | 16-Bit Address | 24-Bit Address | Register Name                            |
|------------|----------------|----------------|------------------------------------------|
| DMA4       | \$FFDF         | \$FFFFDF       | DMA Source Address Register (DSR4)       |
|            | \$FFDE         | \$FFFFDE       | DMA Destination Address Register (DDR4)  |
|            | \$FFDD         | \$FFFFDD       | DMA Counter (DCO4)                       |
|            | \$FFDC         | \$FFFFDC       | DMA Control Register (DCR4)              |
| DMA5       | \$FFDB         | \$FFFFDB       | DMA Source Address Register (DSR5)       |
|            | \$FFDA         | \$FFFFDA       | DMA Destination Address Register (DDR5)  |
|            | \$FFD9         | \$FFFFD9       | DMA Counter (DCO5)                       |
|            | \$FFD8         | \$FFFFD8       | DMA Control Register (DCR5)              |
|            | \$FFD7         | \$FFFFD7       | Reserved                                 |
|            | \$FFD6         | \$FFFFD6       | Reserved                                 |
|            | \$FFD5         | \$FFFFD5       | Reserved                                 |
|            | \$FFD4         | \$FFFFD4       | Reserved                                 |
|            | \$FFD3         | \$FFFFD3       | Reserved                                 |
|            | \$FFD2         | \$FFFFD2       | Reserved                                 |
|            | \$FFD1         | \$FFFFD1       | Reserved                                 |
|            | \$FFD0         | \$FFFFD0       | Reserved                                 |
|            | \$FFCF         | \$FFFFCF       | Reserved                                 |
|            | \$FFCE         | \$FFFFCE       | Reserved                                 |
|            | \$FFCD         | \$FFFFCD       | Reserved                                 |
|            | \$FFCC         | \$FFFFCC       | Reserved                                 |
|            | \$FFCB         | \$FFFFCB       | Reserved                                 |
|            | \$FFCA         | \$FFFFCA       | Reserved                                 |
| Port B     | \$FFC9         | \$FFFFC9       | Host Port GPIO Data Register (HDR)       |
|            | \$FFC8         | \$FFFFC8       | Host Port GPIO Direction Register (HDDR) |
| HI08       | \$FFC7         | \$FFFFC7       | Host Transmit Register (HTX)             |
|            | \$FFC6         | \$FFFFC6       | Host Receive Register (HRX)              |
|            | \$FFC5         | \$FFFFC5       | Host Base Address Register (HBAR)        |
|            | \$FFC4         | \$FFFFC4       | Host Port Control Register (HPCR)        |
|            | \$FFC3         | \$FFFFC3       | Host Status Register (HSR)               |
|            | \$FFC2         | \$FFFFC2       | Host Control Register (HCR)              |

| Peripheral | 16-Bit Address | 24-Bit Address | Register Name                                   |
|------------|----------------|----------------|-------------------------------------------------|
|            | \$FFC1         | \$FFFFC1       | Reserved                                        |
|            | \$FFC0         | \$FFFFC0       | Reserved                                        |
| Port C     | \$FFBF         | \$FFFFBF       | Port C Control Register (PCRC)                  |
|            | \$FFBE         | \$FFFFBE       | Port C Direction Register (PRRC)                |
|            | \$FFBD         | \$FFFFBD       | Port C GPIO Data Register (PDRC)                |
| ESSI 0     | \$FFBC         | \$FFFFBC       | ESSI 0 Transmit Data Register 0 (TX00)          |
|            | \$FFBB         | \$FFFFBB       | ESSI 0 Transmit Data Register 1 (TX01)          |
|            | \$FFBA         | \$FFFFBA       | ESSI 0 Transmit Data Register 2 (TX02)          |
|            | \$FFB9         | \$FFFFB9       | ESSI 0 Time Slot Register (TSR0)                |
|            | \$FFB8         | \$FFFFB8       | ESSI 0 Receive Data Register (RX0)              |
|            | \$FFB7         | \$FFFFB7       | ESSI 0 Status Register (SSISR0)                 |
|            | \$FFB6         | \$FFFFB6       | ESSI 0 Control Register B (CRB0)                |
|            | \$FFB5         | \$FFFFB5       | ESSI 0 Control Register A (CRA0)                |
|            | \$FFB4         | \$FFFFB4       | ESSI 0 Transmit Slot Mask Register A<br>(TSMA0) |
|            | \$FFB3         | \$FFFFB3       | ESSI 0 Transmit Slot Mask Register B<br>(TSMB0) |
|            | \$FFB2         | \$FFFFB2       | ESSI 0 Receive Slot Mask Register A<br>(RSMA0)  |
|            | \$FFB1         | \$FFFFB1       | ESSI 0 Receive Slot Mask Register B<br>(RSMB0)  |
|            | \$FFB0         | \$FFFFB0       | Reserved                                        |
| Port D     | \$FFAF         | \$FFFFAF       | Port D Control Register (PCRD)                  |
|            | \$FFAE         | \$FFFFAE       | Port D Direction Register (PRRD)                |
|            | \$FFAD         | \$FFFFAD       | Port D GPIO Data Register (PDRD)                |

| Table B-2. Internal X //O Memory Map (Continued) |                |                |                                                 |
|--------------------------------------------------|----------------|----------------|-------------------------------------------------|
| Peripheral                                       | 16-Bit Address | 24-Bit Address | Register Name                                   |
| ESSI 1                                           | \$FFAC         | \$FFFFAC       | ESSI 1 Transmit Data Register 0 (TX10)          |
|                                                  | \$FFAB         | \$FFFFAB       | ESSI 1 Transmit Data Register 1 (TX11)          |
|                                                  | \$FFAA         | \$FFFFAA       | ESSI 1 Transmit Data Register 2 (TX12)          |
|                                                  | \$FFA9         | \$FFFFA9       | ESSI 1 Time Slot Register (TSR1)                |
|                                                  | \$FFA8         | \$FFFFA8       | ESSI 1 Receive Data Register (RX1)              |
|                                                  | \$FFA7         | \$FFFFA7       | ESSI 1 Status Register (SSISR1)                 |
|                                                  | \$FFA6         | \$FFFFA6       | ESSI 1 Control Register B (CRB1)                |
|                                                  | \$FFA5         | \$FFFFA5       | ESSI 1 Control Register A (CRA1)                |
|                                                  | \$FFA4         | \$FFFFA4       | ESSI 1 Transmit Slot Mask Register A<br>(TSMA1) |
|                                                  | \$FFA3         | \$FFFFA3       | ESSI 1 Transmit Slot Mask Register B<br>(TSMB1) |
|                                                  | \$FFA2         | \$FFFFA2       | ESSI 1 Receive Slot Mask Register A<br>(RSMA1)  |
|                                                  | \$FFA1         | \$FFFFA1       | ESSI 1 Receive Slot Mask Register B<br>(RSMB1)  |
|                                                  | \$FFA0         | \$FFFFA0       | Reserved                                        |
| Port E                                           | \$FF9F         | \$FFFF9F       | Port E Control Register (PCRE)                  |
|                                                  | \$FF9E         | \$FFFF9E       | Port E Direction Register (PRRE)                |
|                                                  | \$FF9D         | \$FFFF9D       | Port E GPIO Data Register (PDRE)                |
| SCI                                              | \$FF9C         | \$FFFF9C       | SCI Control Register (SCR)                      |
|                                                  | \$FF9B         | \$FFFF9B       | SCI Clock Control Register (SCCR)               |
|                                                  | \$FF9A         | \$FFFF9A       | SCI Receive Data Register - High (SRXH)         |
|                                                  | \$FF99         | \$FFFF99       | SCI Receive Data Register - Middle (SRXM)       |
|                                                  | \$FF98         | \$FFFF98       | SCI Recieve Data Register - Low (SRXL)          |
|                                                  | \$FF97         | \$FFFF97       | SCI Transmit Data Register - High (STXH)        |
|                                                  | \$FF96         | \$FFFF96       | SCI Transmit Data Register - Middle (STXM)      |
|                                                  | \$FF95         | \$FFFF95       | SCI Transmit Data Register - Low (STXL)         |
|                                                  | \$FF94         | \$FFFF94       | SCI Transmit Address Register (STXA)            |
|                                                  | \$FF93         | \$FFFF93       | SCI Status Register (SSR)                       |
|                                                  | \$FF92         | \$FFFF92       | Reserved                                        |
|                                                  | \$FF91         | \$FFFF91       | Reserved                                        |
|                                                  | \$FF90         | \$FFFF90       | Reserved                                        |
|                                                  |                |                |                                                 |

| Peripheral   | 16-Bit Address | 24-Bit Address | Register Name                           |
|--------------|----------------|----------------|-----------------------------------------|
| Triple Timer | \$FF8F         | \$FFFF8F       | Timer 0 Control/Status Register (TCSR0) |
|              | \$FF8E         | \$FFFF8E       | Timer 0 Load Register (TLR0)            |
|              | \$FF8D         | \$FFFF8D       | Timer 0 Compare Register (TCPR0)        |
|              | \$FF8C         | \$FFFF8C       | Timer 0 Count Register (TCR0)           |
|              | \$FF8B         | \$FFFF8B       | Timer 1 Control/Status Register (TCSR1) |
|              | \$FF8A         | \$FFFF8A       | Timer 1 Load Register (TLR1)            |
|              | \$FF89         | \$FFFF89       | Timer 1 Compare Register (TCPR1)        |
|              | \$FF88         | \$FFFF88       | Timer 1 Count Register (TCR1)           |
|              | \$FF87         | \$FFFF87       | Timer 2 Control/Status Register (TCSR2) |
|              | \$FF86         | \$FFFF86       | Timer 2 Load Register (TLR2)            |
|              | \$FF85         | \$FFFF85       | Timer 2 Compare Register (TCPR2)        |
|              | \$FF84         | \$FFFF84       | Timer 2 Count Register (TCR2)           |
|              | \$FF83         | \$FFFF83       | Timer Prescaler Load Register (TPLR)    |
|              | \$FF82         | \$FFFF82       | Timer Prescaler Count Register (TPCR)   |
|              | \$FF81         | \$FFFF81       | Reserved                                |
|              | \$FF80         | \$FFFF80       | Reserved                                |

#### Table B-3. Internal Y I/O Memory Map

| Peripheral | 16-Bit<br>Address | 24-Bit<br>Address | Register Name |
|------------|-------------------|-------------------|---------------|
|            | \$FFBF            | \$FFFBF           | Reserved      |
|            | \$FFBE            | \$FFFFBE          | Reserved      |
|            | \$FFBD            | \$FFFFBD          | Reserved      |
|            | \$FFBC            | \$FFFBC           | Reserved      |
|            | \$FFBB            | \$FFFFBB          | Reserved      |
|            | \$FFBA            | \$FFFFBA          | Reserved      |
|            | \$FFB9            | \$FFFFB9          | Reserved      |

Interrupt Sources and Priorities

| Peripheral             | 16-Bit<br>Address | 24-Bit<br>Address     | Register Name                            |
|------------------------|-------------------|-----------------------|------------------------------------------|
| Enhanced Filter        | \$FFB8            | \$FFFFB8              | EFCOP Decimation/Channel (FDCH) Register |
| Coprocessor<br>(EFCOP) | \$FFB7            | \$FFFFB7              | EFCOP Coefficient Base Address (FCBA)    |
|                        | \$FFB6            | \$FFFFB6              | EFCOP Data Base Address (FDBA)           |
|                        | \$FFB5            | \$FFFFB5              | EFCOP ALU Control Register (FACR)        |
|                        | \$FFB4            | \$FFFFB4              | EFCOP Control Status Register (FCSR)     |
|                        | \$FFB3            | \$FFFFB3              | EFCOP Filter Count (FCNT) Register       |
|                        | \$FFB2            | \$FFFFB2              | EFCOP K-Constant Register (FKIR)         |
|                        | \$FFB1            | \$FFFFB1              | EFCOP Data Output Register (FDOR)        |
|                        | \$FFB0            | \$FFFFB0              | EFCOP Data Input Register (FDIR)         |
|                        | \$FFAF–<br>\$FF80 | \$FFFFAF–<br>\$FFFF80 | Reserved                                 |

#### Table B-3. Internal Y I/O Memory Map

# **B.2** Interrupt Sources and Priorities

### Table B-4. Interrupt Sources

| Interrupt<br>Starting Address | Interrupt<br>Priority<br>Level Range | Interrupt Source             |
|-------------------------------|--------------------------------------|------------------------------|
| VBA:\$00                      | 3                                    | Hardware RESET               |
| VBA:\$02                      | 3                                    | Stack Error                  |
| VBA:\$04                      | 3                                    | Illegal Instruction          |
| VBA:\$06                      | 3                                    | Debug Request Interrupt      |
| VBA:\$08                      | 3                                    | Тгар                         |
| VBA:\$0A                      | 3                                    | Non-Maskable Interrupt (NMI) |
| VBA:\$0C                      | 3                                    | Reserved                     |
| VBA:\$0E                      | 3                                    | Reserved                     |
| VBA:\$10                      | 0–2                                  | ĪRQĀ                         |
| VBA:\$12                      | 0–2                                  | IRQB                         |
| VBA:\$14                      | 0–2                                  | IRQC                         |
| VBA:\$16                      | 0–2                                  | ĪRQD                         |
| VBA:\$18                      | 0–2                                  | DMA Channel 0                |
| VBA:\$1A                      | 0–2                                  | DMA Channel 1                |
| VBA:\$1C                      | 0–2                                  | DMA Channel 2                |

| Table B-4. | nterrupt Sources | (Continued) |
|------------|------------------|-------------|
|------------|------------------|-------------|

| Interrupt<br>Starting Address | Interrupt<br>Priority<br>Level Range | Interrupt Source                          |
|-------------------------------|--------------------------------------|-------------------------------------------|
| VBA:\$1E                      | 0–2                                  | DMA Channel 3                             |
| VBA:\$20                      | 0–2                                  | DMA Channel 4                             |
| VBA:\$22                      | 0–2                                  | DMA Channel 5                             |
| VBA:\$24                      | 0–2                                  | Timer 0 Compare                           |
| VBA:\$26                      | 0–2                                  | Timer 0 Overflow                          |
| VBA:\$28                      | 0–2                                  | Timer 1 Compare                           |
| VBA:\$2A                      | 0–2                                  | Timer 1 Overflow                          |
| VBA:\$2C                      | 0–2                                  | Timer 2 Compare                           |
| VBA:\$2E                      | 0–2                                  | Timer 2 Overflow                          |
| VBA:\$30                      | 0–2                                  | ESSI0 Receive Data                        |
| VBA:\$32                      | 0–2                                  | ESSI0 Receive Data With Exception Status  |
| VBA:\$34                      | 0–2                                  | ESSI0 Receive Last Slot                   |
| VBA:\$36                      | 0–2                                  | ESSI0 Transmit Data                       |
| VBA:\$38                      | 0–2                                  | ESSI0 Transmit Data With Exception Status |
| VBA:\$3A                      | 0–2                                  | ESSI0 Transmit Last Slot                  |
| VBA:\$3C                      | 0–2                                  | Reserved                                  |
| VBA:\$3E                      | 0–2                                  | Reserved                                  |
| VBA:\$40                      | 0–2                                  | ESSI1 Receive Data                        |
| VBA:\$42                      | 0–2                                  | ESSI1 Receive Data With Exception Status  |
| VBA:\$44                      | 0–2                                  | ESSI1 Receive Last Slot                   |
| VBA:\$46                      | 0–2                                  | ESSI1 Transmit Data                       |
| VBA:\$48                      | 0–2                                  | ESSI1 Transmit Data With Exception Status |
| VBA:\$4A                      | 0–2                                  | ESSI1 Transmit Last Slot                  |
| VBA:\$4C                      | 0–2                                  | Reserved                                  |
| VBA:\$4E                      | 0–2                                  | Reserved                                  |
| VBA:\$50                      | 0–2                                  | SCI Receive Data                          |
| VBA:\$52                      | 0–2                                  | SCI Receive Data With Exception Status    |
| VBA:\$54                      | 0–2                                  | SCI Transmit Data                         |
| VBA:\$56                      | 0–2                                  | SCI Idle Line                             |
| VBA:\$58                      | 0–2                                  | SCI Timer                                 |
| VBA:\$5A                      | 0–2                                  | Reserved                                  |
| VBA:\$5C                      | 0–2                                  | Reserved                                  |
| VBA:\$5E                      | 0–2                                  | Reserved                                  |

Interrupt Sources and Priorities

| Interrupt<br>Starting Address | Interrupt<br>Priority<br>Level Range | Interrupt Source              |
|-------------------------------|--------------------------------------|-------------------------------|
| VBA:\$60                      | 0–2                                  | Host Receive Data Full        |
| VBA:\$62                      | 0–2                                  | Host Transmit Data Empty      |
| VBA:\$64                      | 0–2                                  | Host Command (Default)        |
| VBA:\$66                      | 0–2                                  | Reserved                      |
| VBA:\$68                      | 0–2                                  | EFCOP Data Input Buffer Empty |
| VBA:\$6A                      | 0–2                                  | EFCOP Data Output Buffer Full |
| VBA:\$6C                      | 0–2                                  | Reserved                      |
| VBA:\$6E                      | 0–2                                  | Reserved                      |
| :                             | :                                    |                               |
| VBA:\$FE                      | 0–2                                  | Reserved                      |

### Table B-4. Interrupt Sources (Continued)

#### Table B-5. Interrupt Source Priorities Within an IPL

| Priority | Interrupt Source          |
|----------|---------------------------|
|          | Level 3 (Nonmaskable)     |
| Highest  | Hardware RESET            |
|          | Stack Error               |
|          | Illegal Instruction       |
|          | Debug Request Interrupt   |
|          | Тгар                      |
| Lowest   | Non-Maskable Interrupt    |
|          | Levels 0, 1, 2 (Maskable) |
| Highest  | IRQA (External Interrupt) |
|          | IRQB (External Interrupt) |
|          | IRQC (External Interrupt) |
|          | IRQD (External Interrupt) |
|          | DMA Channel 0 Interrupt   |
|          | DMA Channel 1 Interrupt   |
|          | DMA Channel 2 Interrupt   |
|          | DMA Channel 3 Interrupt   |
|          | DMA Channel 4 Interrupt   |

| Priority | Interrupt Source                          |
|----------|-------------------------------------------|
|          | DMA Channel 5 Interrupt                   |
|          | Host Command Interrupt                    |
|          | Host Transmit Data Empty                  |
|          | Host Receive Data Full                    |
|          | ESSI0 RX Data with Exception Interrupt    |
|          | ESSI0 RX Data Interrupt                   |
|          | ESSI0 Receive Last Slot Interrupt         |
|          | ESSI0 TX Data With Exception Interrupt    |
|          | ESSI0 Transmit Last Slot Interrupt        |
|          | ESSI0 TX Data Interrupt                   |
|          | ESSI1 RX Data With Exception Interrupt    |
|          | ESSI1 RX Data Interrupt                   |
|          | ESSI1 Receive Last Slot Interrupt         |
|          | ESSI1 TX Data With Exception Interrupt    |
|          | ESSI1 Transmit Last Slot Interrupt        |
|          | ESSI1 TX Data Interrupt                   |
|          | SCI Receive Data With Exception Interrupt |
| Lowest   | SCI Receive Data                          |
| Highest  | SCI Transmit Data                         |
|          | SCI Idle Line                             |
|          | SCI Timer                                 |
|          | Timer0 Overflow Interrupt                 |
|          | Timer0 Compare Interrupt                  |
|          | Timer1 Overflow Interrupt                 |
|          | Timer1 Compare Interrupt                  |
|          | Timer2 Overflow Interrupt                 |
|          | Timer2 Compare Interrupt                  |
|          | EFCOP Data Input Buffer Empty             |
| Lowest   | EFCOP Data Output Buffer Full             |

# **B.3** Programming Sheets



Figure B-1. Status Register (SR)







Figure B-3. Address Attribute Registers (AAR3 - AAR0)

**Programming Sheets** 



Figure B-4. Bus Control Register (BCR)





Semiconductor, Inc.

**Besca** 



Figure B-6. Interrupt Priority Register–Core (IPR–C)







Figure B-8. Phase Lock Loop Control Register (PCTL)

**Programming Sheets** 

| HC                              | )5                                               | ST             | ]           |            |     |    |    |    |             |              |                  |            |        |   |     |   |     |      |            |      |   |   |
|---------------------------------|--------------------------------------------------|----------------|-------------|------------|-----|----|----|----|-------------|--------------|------------------|------------|--------|---|-----|---|-----|------|------------|------|---|---|
|                                 | Host Receive Data (usually Read by program)<br>↓ |                |             |            |     |    |    |    |             |              |                  |            |        |   |     |   |     |      |            |      |   |   |
| 23 22                           | 2 21                                             | 1 20<br>eceive | _19<br>⊎iab | 18<br>Byte | 17  | 16 | 15 | 14 | 13<br>Boog  | 12           | <br>11<br>/iddle | 10<br>Byte | 9      | 8 | 7   | 6 | 5   |      | 3<br>Low I | 2    | 1 | 0 |
|                                 |                                                  |                |             | Буге       |     |    |    |    | Rece        |              |                  | Dyte       | ;      |   |     |   | Rec | eive |            | Syle |   |   |
| 23 22                           | <u> </u>                                         | 1 20           | 10          | 18         | 17  |    |    |    |             |              | ally L           |            |        |   | am) | 6 | 5   | 4    | . 2        | 2    | 1 | 0 |
| 23 22                           | Tra                                              | nsmit          | 19<br>High  | 18<br>Byte | 17  | 16 | 15 | 14 | 13<br>Trans | 12<br>smit N | 11<br>/iddle     | 10<br>Byte | 9<br>; | 8 | /   | 6 |     |      | 3<br>Low   |      | 1 | 0 |
|                                 |                                                  |                |             |            |     |    |    |    |             |              |                  |            |        |   |     |   |     |      |            |      |   |   |
| Host Tra<br>X:\$FFE0<br>Reset = | C7 W                                             | rite On        |             | ster (     | HTΧ | )  |    |    |             |              |                  |            |        |   |     |   |     |      |            |      |   |   |
|                                 |                                                  |                |             |            |     |    |    |    |             |              |                  |            |        |   |     |   |     |      |            |      |   |   |
|                                 |                                                  |                |             |            |     |    |    |    |             |              |                  |            |        |   |     |   |     |      |            |      |   |   |
|                                 |                                                  |                |             |            |     |    |    |    |             |              |                  |            |        |   |     |   |     |      |            |      |   |   |

Figure B-9. Host Receive and Host Transmit Data Registers



Figure B-10. Host Control and Host Status Registers



Figure B-11. Host Base Address and Host Port Control Registers



Figure B-12. Interrupt Control and Interrupt Status Registers



Figure B-13. Interrupt Vector and Command Vector Registers



Figure B-14. Host Receive and Host Transmit Data Registers



Figure B-15. ESSI Control Register A (CRA)

**Programming Sheets** 

Figure B-16. ESSI Control Register B (CRB)



Figure B-17. ESSI Status Register (SSISR)



Figure B-18. ESSR Transmit and Receive Slot Mask Registers (TSM, RSM)



Figure B-19. SCI Control Register (SCR)



Figure B-20. SCI Status and Clock Control Registers (SSR, SCCR)



Figure B-21. SCI Receive and Transmit Data Registers (SRX, TRX)



Figure B-22. Timer Prescaler Load/Count Register (TPLR, TPCR)



Motorola

| Timers                                                                                                 | 5                 |              |              |    |    |    |     |    |    |         |   |       |   |   |   |          |   |   |   |   |
|--------------------------------------------------------------------------------------------------------|-------------------|--------------|--------------|----|----|----|-----|----|----|---------|---|-------|---|---|---|----------|---|---|---|---|
| 23 22 21 20                                                                                            | 19                | 18           | 17           | 16 | 15 | 14 | 13  | 12 | 11 | 10      | 9 | 8     | 7 | 6 | 5 | 4        | 3 | 2 | 1 | 0 |
| Timer Reload Value                                                                                     |                   |              |              |    |    |    |     |    |    |         |   |       |   |   |   |          |   |   |   |   |
|                                                                                                        |                   |              |              |    |    |    |     |    |    |         |   |       |   |   |   |          |   |   |   |   |
| Timer Load Rev                                                                                         | niste             | ər           |              |    |    |    |     |    |    |         |   |       |   |   |   |          |   |   |   |   |
| Timer Load Register<br>TLR0:\$FFF8E Write Only<br>TLR1:\$FFF78A Write Only<br>TLR2:\$FFF786 Write Only |                   |              |              |    |    |    |     |    |    |         |   |       |   |   |   |          |   |   |   |   |
| Reset = \$00000                                                                                        | 0                 |              |              |    |    |    |     |    |    |         |   |       |   |   |   |          |   |   |   |   |
| 23 22 21 20                                                                                            | 19                | 18           | 17           | 16 | 15 | 14 | 13  | 12 | 11 | 10      | 9 | 8     | 7 | 6 | 5 | 4        | 3 | 2 | 1 | 0 |
|                                                                                                        | 10                | 10           | 17           |    |    |    |     |    |    | Count   |   |       |   | 0 | 0 | <u> </u> | 0 | 2 |   |   |
|                                                                                                        |                   |              |              |    |    |    | mpt |    |    | - Curri |   | / alu | - |   |   |          |   |   |   |   |
|                                                                                                        |                   |              |              |    |    |    |     |    |    |         |   |       |   |   |   |          |   |   |   |   |
| Timer Compare<br>TCPR0:\$FFFF8<br>TCPR1:\$FFFF8<br>TCPR2:\$FFFF8<br>Reset = \$00000                    | D R<br>9 R<br>5 R | ead          | l/Wr<br>/Wri | te |    |    |     |    |    |         |   |       |   |   |   |          |   |   |   |   |
| 23 22 21 20                                                                                            | 19                | 18           | 17           | 16 | 15 | 14 | 13  | 12 | 11 | 10      | 9 | 8     | 7 | 6 | 5 | 4        | 3 | 2 | 1 | 0 |
| Timer Count Value                                                                                      |                   |              |              |    |    |    |     |    |    |         |   |       |   |   |   |          |   |   |   |   |
|                                                                                                        |                   |              |              |    |    |    |     |    |    |         |   |       |   |   |   |          |   |   |   |   |
| Timer Count Re<br>TCR0:\$FFFF8C<br>TCR1:\$FFFF88<br>TCR2:\$FFFF84<br>Reset = \$00000                   | Rea<br>Rea<br>Rea | ad (<br>ad C | Dnly         |    |    |    |     |    |    |         |   |       |   |   |   |          |   |   |   |   |



Figure B-25. Host Data Direction and Host Data Registers (HDDR, HDR)



Go to: www.freescale.com



Figure B-27. Port D Registers (PCRD, PRRD, PDRD)





Figure B-29. EFCOP Counter and Control Status Registers (FCNT and FCSR)



Go to: www.freescale.com

# Index

## A

AAR see Address Attribute Registers adaptive filter 10-1 adder modulo 1-7 offset 1-7 reverse-carry 1-7 Address Arithmetic Logic Unit (Address ALU) 1-7 Address Attribute Registers (AAR1-AAR4) 4-22 Address Generation Unit 1-7 Address Mode Wakeup 8-3 addressing modes 1-7 AGU see Address Generation Unit ALC bit 7-16 Alignment Control bit (ALC) 7-16 ALU see Address Arithmetic Logic Unit see Data Arithmetic Logic Unit asynchronous data transfer 8-2 Asynchronous mode 7-10, 8-2, 8-15, 8-17, 8-18, 8-19, 8-20 Asynchronous modes 8-19 Asynchronous Multidrop mode 8-17

## B

barrel shifter 1-6 **BCHG 5-2** BCLR 5-2 bit 6-15, 6-30, 6-31 bit, sticky 10-2 bit-oriented instructions (BCHG, BCLR, BSET, BTST, BRCLR, BRSET, BSCLR, BSSET, JCLR, JSET, JSCLR, AND JSSET) 5-2 bootstrap 3-1, 3-3, 4-4 program 4-4 program options, invoking 4-4 bootstrap code 8-7 Bootstrap mode 7 4-3 Boundary Scan Register (BSR) 4-25 BRCLR 5-2 break 8-16 BRSET 5-2 BSCLR 5-2 BSET 5-2 BSR see Boundary Scan Register BSSET 5-2

#### BTST 5-2

bus address 2-3 data 2-3 external address 2-6 external data 2-6 internal 1-10 multiplexed 2-3 non-multiplexed 2-3

#### С

Capture Measurement mode 9-15 cellular base station 10-1 Central Processing Unit (CPU) 1-1 chip select signal 6-4 Chip-Select logic 6-17 clock 1-5, 2-5 Clock Generator (CLKGEN) 1-8 clock generator features 8-19 clock generator, ESSI 7-11 Clock Out Divider bit (COD) 8-21 **CMOS 1-5** COD bit 8-21 code compatible 1-5 real FIR filter with polling 10-25 codec systems 7-4 codecs 7-10, 7-13 Command Vector Register (CVR) 6-27 Compare register (TCPR) 9-3 configure an ESSI exception 7-9 configure interrupt trigger 9-4 configuring a timer exception 9-4 control HI08 operating mode 6-17 Control Register A 7-14 bit 18-Alignment Control bit (ALC) 7-16 see also ESSI Control Register B 7-18 see also ESSI counter overflow 9-25 counter preload operation 9-26 CRA see Control Register A CRB see Control Register B cross-correlation filtering 10-1 crystal frequency 8-6 CVR see Command Vector Register

#### D

data and control host processor registers 6-13 Data Arithmetic Logic Unit 1-6 Multiplier-Accumulator (MAC) 1-6 registers 1-6 data strobe 6-4 data transfer methods 5-3 interrupts 5-3 polling 5-3 data/coefficient transfer contention bit 10-2 Debug mode entering 2-21 external indication 2-21 warning 3-8 decimation 10-1, 10-4, 10-7, 10-13, 10-14 example (sequence of even real numbers) 10-30 Decimation/Channel Count Register 10-13, 10-14 DFI 10-2 **DFII 10-2** Direct Form 1 10-2 Direct Form 2 10-2 Direct Memory Access (DMA) 6-9 EFCOP and 10-2 Request Source bits (DRS4-DRS0) 4-10 restrictions on EFCOP 10-5 triggered by timer 9-21 DMA 6-6 DMA see Direct Memory Access DMA transfers and host bus 6-9 DO loop 1-8 Double Data Strobe 2-3 Double Host Request bit (HDRQ) 6-25 **DRAM 1-10** DS 2-3 DSP core programming model 6-13 DSP transmit interrupt 7-20 DSP56300 core 1-1 DSP56300 Family Manual 1-1, 1-5, 6-9, 6-21, 6-31 DSP56307 Technical Data 1-1 DSP-to-host transfers 6-6 dual host requests enabled 6-10 dynamic memory configuration switching 3-7

## E

echo cancellation 10-1 echo cancellation filter 10-31 EFCOP 1-2, 1-14 control and status registers 10-4 core transfers 10-2 DMA restrictions 10-4 DMA transfers 10-2 FACR 10-11, 10-12

FCBA 10-13 FCM 10-4 FCNT 10-7 FCSR 10-8 FDBA 10-12 FDCH 10-13, 10-14 FDIR 10-7 FDM 10-4 FDOR 10-7 Filter Coefficient Memory bank 10-2 Filter Data Memory 10-2 FKIR 10-7 FMAC 10-6 initialization 10-2 input data buffer 10-2 interrupt vector table 10-6 memory bank base address pointers 10-2 memory banks 10-4 memory organization 10-4 PMB 10-4 programming model 10-6 Saturation mode 10-6 Sixteen-bit Arithmetic mode 10-6 enable/disable receive portion of ESSI 7-21 enable/disablesan interrupt at beginning of last slot of a frame when ESSI is in Network mode 7-20 Enhanced Filter Coprocessor (EFCOP) 1-4, 1-14 Enhanced Synchronous Serial Interface (ESSI) 2-15, 2-17, 7-1 see also ESSI ensure proper operation of the ESSI 7-7 equalization 10-1 ESSI 1-13, 2-3, 2-15, 2-17, 5-2, 7-1 after reset 7-6 Asynchronous mode 7-21 Asynchronous modes 7-11 asynchronous operating mode 7-11 audio enhancements 7-3 byte format 7-13 Clock Generator 7-17 clock generator 7-11 Clock Sources 7-4 codecs 7-13 configure an ESSI exception 7-9 control and time slot registers 7-6 control direction of SC2 I/O signal 7-23 control divide ratio for programmable frame rate dividers 7-16 control fixed divide-by-eight prescaler in series with variable prescaler 7-16 Control functionality of SC1 signal 7-15 Control Register A 7-14 Control Register A (CRA) Alignment Control 7-16

Frame Rate Divider Control 7-16 Prescale Modulus Select 7-17 Prescaler Range 7-16 Select SC1 7-15 Word Length Control 7-15 Control Register A (CRA) bit definitions 7-14 Control Register B 7-18 Control Register B (CRB) Clock Polarity 7-22 Clock Source Direction 7-23 Frame Sync Length 7-23 Frame Sync Polarity 7-22 Frame Sync Relative Timing 7-23 Mode Select 7-22 Receive Enable 7-21 **Receive Exception Interrupt Enable 7-19** Receive Interrupt Enable 7-20 Receive Last Slot Interrupt Enable 7-20 Serial Control Direction 0 7-24 Serial Control Direction 1 7-24 Serial Control Direction 2 7-23 Serial Output Flag 0 7-24 Serial Output Flag 1 7-24 Shift Direction 7-23 Synchronous/Asynchronous 7-22 Transmit 0 Enable 7-21 Transmit 1 Enable 7-21 Transmit 2 Enable 7-22 Transmit Exception Interrupt Enable 7-20 Transmit Interrupt Enable 7-20 Transmit Last Slot Interrupt Enable 7-20 Control Register B bit definitions 7-19 control whether the receive and transmit functions occur synchronously or asynchronously with respect to each other 7-22 control which bit clock edge data and frame sync are clocked out and latched i 7-22 CRA and CRB 7-10 data and control signals 7-3 determine polarity of the receive and transmit frame sync signals 7-22 determine relative timing of the receive and transmit frame sync signal 7-23 determine shift direction of the transmit or receive shift register 7-23 DMA services the transmitters 7-7 DSP receive data interrupt request 7-29 enable transfer of data from TX1 to Transmit Shift Register 0 7-21 enable transfer of data from TX1 to Transmit Shift Register 1 7-21 enable transfer of data from TX2 to Transmit Shift Register 2 7-22 enable/disable a DSP transmit interrupt 7-20

enable/disable DSP receive data interrupt 7-20 enable/disable receive portion 7-21 exceptions 7-8 receive data 7-8 receive data with exception status 7-8 receive last slot interrupt 7-8 transmit data 7-9 transmit data with exception status 7-8 transmit last slot interrupt 7-8 flags 7-13 frame rate divider 7-10 Frame Sync Generator 7-18 frame sync I/O signal 7-6 frame sync length 7-12 frame sync polarity 7-12 frame sync selection 7-11 frame sync signal 7-7, 7-10 frame sync signal format 7-11 frame sync word length 7-12 frame synchronization signals 7-18 Gated clock mode 7-3 GPIO 7-6 GPIO functionality 7-36 handle 24-bit fractional data 7-16 initialization 7-6 initialization example 7-7 internally generated clock and frame sync 7-7 interrupt service routine 7-9 interrupt trigger 7-9 interrupt trigger event 7-9 interrupts 7-8 multiple serial device selection 7-5 Network enhancements 7-2 Network mode 7-1, 7-8, 7-10, 7-22 Normal and Network mode 7-21 Normal and On-Demand modes 7-21 Normal mode 7-1, 7-10 On-Demand mode 7-10, 7-15, 7-21 operating modes 7-6, 7-10 polling, interrupts, DMA 7-7 Port Control Register (PCR) 7-7, 7-36 Port Control Registers (C and D) 7-36 Port Data Register (PDR) 7-38 Port Data Registers (C and D) 7-38 Port Direction Register (PRR) 7-37 Port Direction Registers (C and D) 7-37 programming model 7-14 receive and transmit interrupts 7-11 Receive Data Register 7-31 receive frame sync edge 7-12 receive frame sync occurred during reception of word in serial receive data register 7-30 Receive Shift Register 7-31 Receive Slot Mask Registers 7-14, 7-35

Received Data Register 7-14 reset 7-6 RX frame sync 7-11 RX frame sync pulses active 7-11 SC0 7-4 SC1 7-5 SC2 7-6 SCD2 bit in the CRB 7-6 SCK 7-3 select length of data words transferred via ESSI 7-15 select length of frame sync to be generated or recognized, 7-23 select source of clock signal 7-23 Serial Control Direction 1 bit 7-5 serial flag signal or receive clock signal 7-4 serial output flag 0 (OF0) bit in the CRB 7-4 single codec with asynchronous transmit and receive 7-5 specify divide ratio of prescale divider in ESSI clock generator 7-17 SPI protocol 7-1 SRD 7-3 SSISR 7-6 Status Register 7-29 status register 7-14 Status Register (SSISR) Receive Data Register Full 7-29 Receive Frame Sync Flag 7-30 Receiver Overrun Error Flag 7-29 Serial Input Flag 0 7-31 Serial Input Flag 1 7-30 Transmit Data Register Empty 7-29 Transmit Frame Sync Flag 7-30 Transmitter Underrun Error Flag 7-30 STD 7-3 SYN bit 7-11 Synchronous mode 7-13 synchronous mode, multiple active transmitters 7-4 Synchronous modes 7-11 synchronous operating mode 7-11 synchronous or asynchronous mode 7-4, 7-5 TE bit 7-19 Time Slot Register 7-34 Transmit Data Registers 7-34 transmit data signal 7-4 transmit enable bits 7-19 transmit enable sequence in On-Demand mode 7-22 transmit interrupt is enabled 7-9 Transmit Shift Registers 7-31 Transmit Slot Mask Registers 7-14, 7-34 transmitter data out signal of transmit shift register TX2 7-5

**TSR 7-9** TX and RX clocks 7-11 variable prescaler 7-16 word length frame sync 7-12 word length frame sync timing 7-12 ESSI Control Register A (CRA) 7-14 **ESSI** Control Registers 7-14 see also Control Register A, B ESSI data and control signals SC0 7-4 SCK 7-3 SRD 7-3 STD 7-3 ESSI programming model 7-14 ESSI Receive Data Register (RX) 7-31 ESSI Receive Exception Interrupt Enable bit (REIE) 7-19 ESSI Receive Shift Register 7-31 ESSI Receive Slot Mask Registers (RSMA, **RSMB**) 7-35 ESSI Status Register (SSISR) 7-29 ESSI Status Register (SSISR) bit definitions 7-29 ESSI Time Slot Register (TSR) 7-34 ESSI Transmit Data Registers 7-14 ESSI Transmit Data registers (TX2, TX1, TX0) 7-34 ESSI Transmit Exception Interrupt Enable bit (TEIE) 7-20 ESSI Transmit Shift Registers 7-31 ESSI Transmit Slot Mask Registers (TSMA, TSMB) 7-34 ESSI0 (GPIO) 5-7 ESSI1 (GPIO) 5-8 ESSI-related program the GPIO pins as outputs or configure the pins in the PCR as ESSI signals 7-23 Programming the ESSI to use an internal frame sync 7-23 example of how to initialize the ESSI 7-7 expansion memory 3-1 external address bus 2-6 external bus control 2-6, 2-8, 2-9 external data bus 2-6 external memory expansion port 2-6 external Y I/O space 3-7

#### F

FCM 10-2 FDM 10-2 features of clock generator 8-19 filter adaptive 10-1 cross-correlation 10-1 echo cancellation 10-31

FIR 10-1 IIR 10-1, 10-2 multichannel 10-1 Filter ALU Control Register 10-11, 10-12 Filter Coefficient Base Address 10-13 Filter Coefficient Memory 10-2 Filter Control Status Register 10-8 Filter Count Register 10-7 Filter Data Base Address 10-12 Filter Data Input Register 10-7 Filter Data Memory bank 10-2 Filter Data Output Register 10-7 Filter K-Constant Input Register 10-7 Filter Multiplier and Accumulator 10-6 Finite Impulse Response filter 10-1 FIR decimation by 2 10-30 filter 10-1 mode 10-1 no decimation 10-22 no decimation/polling 10-25 Real mode (0) 10-22, 10-25, 10-30 single channel Adaptive mode no decimation 10-31 DMA and interrupts 10-34 polling 10-33 single channel 10-22, 10-25, 10-30 frame rate divider 7-10 frame sync I/O signal 7-6 frame sync length, ESSI 7-12 frame sync selection ESSI 7-11 frame sync signal 7-7, 7-10 frame sync signal format, ESSI 7-11 frame synchronization signals, ESSI 7-18 frequency operation 1-5 functional groups 2-3

## G

Global Data Bus 1-10 GPIO 1-12, 2-3 Timers 2-3 GPIO (ESSI0, Port C) 5-7 GPIO (ESSI1, Port D) 5-8 GPIO (ESSI1, Port D) 5-6 GPIO (SCI, Port E) 5-8 GPIO (SCI, Port E) 5-8 GPIO (Timer) 5-9 GPIO functionality on ESSI 7-36 GPIO functions 6-4 GPIO Port Direction Register (PRR) 7-23 Ground 2-4 PLL 2-4

## Η

HA8EN bit 6-20 HA9EN bit 6-20 handshaking mechanisms, HI08 6-6 hardware stack 1-8 HASP bit 6-19 CVR 6-15 HI08 HSR Reflect status of the CVR 6-15 HCSEN bit 6-20 HCSP bit 6-18 HDDR 6-4 HDDS bit 6-18 HDR and HDDR Functionality 6-16 HDR register 6-16 HDRQ bit 6-25 HDSP bit 6-19 HEN bit 6-19 HI08 1-12, 2-3, 2-11, 2-12, 2-13, 2-14, 5-2, 6-1 (GPIO) 5-6 cause the chip to execute an interrupt 6-27 CAUTION 6-29 Chip-Select logic 6-17 Command Vector Register (CVR) 6-8 configuring for host requests 6-9 control HI08 operating mode 6-17 control host request signals 6-20 control HREQ signal for host receive data transfers 6-26 control output drive of host request signals 6-19 control polarity of host request signals 6-18 control register (ICR) 6-23 controls direction of data flow for each HI08 signal configured as GPIO 6-16 core communication with HI08 registers 6-13 core interrupts host command 6-8 receive data register full 6-8 transmit data empty 6-8 **CVR** Host Command 6-27 Host Vector 6-27 data registers (RXH/TXH, RXM/TXM, and **RXL/TXL) 6-23** data strobe 6-4 Direct Memory Access (DMA) 6-9 DMA transfers and host bus 6-9 double-buffered mechanism 6-6

DSP core 6-6 DSP core interrupts 6-7 DSP interrupt routines 6-23 DSP side control registers 6-13 DSP side data registers 6-13 DSP side registers after reset 6-22 DSP to host data word 6-2 handshaking protocols 6-2 interrupts 6-2 mapping 6-2 transfer modes 6-2 DSP-side conrol registers Host status register (HSR) 6-13 DSP-side control registers Host base address register (HBAR) 6-13 Host control register (HCR) 6-13 Host GPIO data direction register (HDDR) 6-13 Host GPIO data register (HDR) 6-13 Host Port Control Register (HPCR) 6-13 DSP-side registers after reset 6-22 DSP-to-host data transfers 6-21 DSP-to-host transfers 6-6 dual host requests enabled 6-10 dual-strobe bus 6-21 enable host requests via host request (HREQ or HTRQ) signal 6-26 enable/disable signals configured as GPIO 6-20 enabling host requests 6-9 external host address inputs 6-30 external host programmer's model 6-23 force execution of any interrupt handler 6-8 force initialization of HI08 hardware 6-25 four kinds of reset 6-31 four reset types 6-22 free core to use its processing power on functions other than polling or interrupt routines 6-9 general-purpose flag for host-to-DSP communication 6-25 general-purpose flags for communication between the host and the DSP 6-7 GPIO configuration options 6-16 HACK signal 6-19 HACK/HRRQ handshake flags 6-23 handshake the execution of host command interrupts 6-27 handshaking mechanisms 6-6 handshaking protocol 6-6 handshaking protocols 6-6 Core DMA access 6-6 host requests 6-6 software polling 6-6 handshaking protocols, choosing 6-6

handshaking protocols, pros and cons of polling 6-7 hardware reset 6-22, 6-31 HBAR Base Address 6-17 HCR General-purpose flags for DSP-to-host communication 6-14 Generate a host command interrupt request 6-14 Generate a host receive data interrupt request 6-15 Generate a host transmit data interrupt request 6-14 Host Receive Interrupt Enable 6-15 HDDR 6-4 HDDR and HDR, GPIO mode 6-4 HDR and HDDR functionality 6-16 HI08 to DSP core interface 6-1 HI08 to host processor interface 6-2 hold data value of corresponding bits of HI08 signals configured as GPIO signals 6-16 Host Base Address Register (HBAR) 6-17 host can access the HI08 in Big-Endian byte order 6-25 host can access the HI08 in Little-Endian byte order 6-25 host command 6-23 host commands 6-8 Host Control Register Host Command Interrupt Enable 6-14 Host control Register Host Transmit Interrupt Enable 6-14 Host Control Register (HCR) Host Flags 2, 3 6-14 Host Data Direction Register (HDDR) 6-16 Host Data Register (HDR) 6-16 host interrupt request pins (IRQx) 6-9 host issues command requests to DSP 6-8 host issues vectored interrupt requests 6-23 host performs multiple reads from the HI08 port Receive Byte Registers 6-6 Host Port Control Register (HPCR) 2-11, 2-12, 2-13, 2-14, 6-17, 6-22, 6-32, 6-33, B-4, B-23 host processor registers 6-13 Host Receive Data Register (HRX) 6-6, 6-22 Host Receive Request (HRRQ 6-9 host request line 6-4 host request pins 6-10 host side Command Vector Register (CVR) 6-27 Interface Control Register (ICR) 6-24 Interface Status Register (ISR) 6-28 Interface Vector Register (IVR) 6-30

Receive Byte Registers (RXH, RXM, RXL) 6-30 registers after reset 6-31 Transmit Byte Registers (TXH, TXM, TXL) 6-30 Host Status Register (HSR) 6-15 host to DSP data word 6-1 handshaking protocols 6-1 instructions 6-1 mapping 6-1 Host Transmit Data Register (HTX) 6-21 Host Transmit Data register (HTX) 6-7 host-side register map 6-24 host-to-DSP data transfers 6-6, 6-22 HPCR 6-4 Host Acknowledge Enable 6-19 Host Acknowledge Polarity 6-18 Host Address Line 8 Enable 6-20 Host Address Line 9 Enable 6-20 Host Address Strobe Polarity 6-19 Host Chip Select Enable 6-20 Host Chip Select Polarity 6-18 Host Data Strobe Polarity 6-19 Host Dual Data Strobe 6-18 Host Enable 6-19 Host GPIO Port Enable 6-20 Host Multiplexed Bus 6-19 Host Request Enable 6-20 Host Request Open Drain 6-19 Host Request Polarity 6-18 HREQ pin when a single request line is used 6-10 HREQ/HTRQ handshake flags 6-23 HSR General-purpose flags for host-to-DSP communication 6-15 Host Command Pending 6-15 Host Flags 0, 1 6-15 Host Receive Data Full 6-16 Host Transmit Data Empty 6-15 indicate that host transmit data register (HTX) is empty and can be written by DSP core 6-15 indicates that host receive data register (HRX) contains data from host processor 6-16 HTX register 6-30 ICR Double Host Request 6-25 Host Flag 0 6-25 Host Flag 1 6-25 Host Little Endian 6-25 Initialize 6-25 Receive Request Enable 6-26 Transmit Request Enable 6-26

ICR Double Host Request bit 6-9 indicate state of HF2 in the HCR on DSP side 6-28 indicate that TXH TXM TXL and HRX registers are empty 6-29 instructions and addressing modes. 6-4 Interface Control Register (ICR) 6-24 Interface Status Registe (ISR) 6-28 interrupt routines 6-8 interrupt vector number used with MC68000 family processor vectored interrupts 6-30 Interrupt Vector Register (IVR) 6-30 interrupt-based techniques 6-23 ISR Host Flag 2 6-28 Host Flag 3 6-28 Host Request 6-28 Receive Data Register Full 6-29 Transmit Data Register Empty 6-29 Transmitter Ready 6-29 masking interrupts 6-8 **MOVEP** instruction 6-13 multiplexed bus mode 6-20 multiplexed bus modes 6-17 multiplexed mode 6-4 non-multiplexed bus mode 6-20 non-multiplexed mode 6-4 pipeline 6-6 polling techniques 6-23, 6-29 receive and transmit data paths 6-4 Receive Byte Registers 6-6 Receive Byte Registers (RXH RXM RXL) 6-30 receive byte registers (RXH **RXM** RXL) contain data from DSP to be read by host processor 6-29 Receive Data Full bit in the Interface Status Register 6-7 Receive Data Registers 6-4 Receive Registers (RXH RHM RHL) 6-7 register banks 6-4 request service from host 6-9 reserved interrupt vector addresses for application-specific service routines 6-8 resets, hardware and software 6-4, 6-13 RREQ and RXDF 6-26 select host command interrupt address for use by host command interrupt logic 6-27

select the interrupt address to be used 6-8 software polling 6-7 software reset 6-31 status register (ISR) 6-23 STOP command 6-24 STOP instruction 6-31 Stop mode 6-24 timing requirements 6-6 Transmit Byte Registers 6-6 Transmit Byte Registers (TXH TXM TXL) 6-30 transmit byte registers (TXH TXM TXL) are empty and can be written by host processor 6-29 Transmit Data Empty bit in the Interface Status Register 6-7 Transmit Data Registers 6-4 Transmit Registers (TXH TXM TXL) 6-7 **TRDY 6-29** vector registers (CVR and IVR) 6-23 HI08 GPIO functions 6-4 HI08 ICR 6-30, 6-31 HLEND bit 6-25 HMUX bit 6-19 Host Address Line 8 Enable bit (HA8EN) 6-20 Host Address Line 9 Enable bit (HA9EN) 6-20 Host Address Strobe Polarity bit (HASP) 6-19 Host Base Address Register (HBAR) 6-17 Host base address register (HBAR) 6-13 Host Chip Select Enable 6-20 Host Chip Select Enable bit (HCSEN) 6-20 Host Chip Select Polarity bit (HCSP) 6-18 Host Control Register (HCR) 6-14 Host control register (HCR) 6-13 Host Data Direction Register (HDDR) 6-16 Host data receive register (HRX) 6-13 Host Data Register (HDR) 6-16 Host Data Strobe Polarity bit (HDSP) 6-19 Host data transmit register (HTX) 6-13 Host Dual Data Strobe bit (HDDS) 6-18 Host Enable bit (HEN) 6-19 Host GPIO data direction register (HDDR) 6-13 Host GPIO data register (HDR) 6-13 Host Interface 2-3, 2-11, 2-12, 2-13, 2-14, 6-1 Host Little Endian bit (HLEND) 6-25 Host Multiplexed Bus bit (HMUX) 6-19 Host Port Control Register (HPCR) 2-11, 2-12, 2-13, 2-14, 6-13, 6-17, 6-22, 6-32, 6-33, B-4, B-23

host processor address space 6-23 Host Receive Data Full bit 6-7 Host Receive Data Register (HRX) 6-6, 6-22 Host Receive Request (HRRQ 6-9 Host Request Double 2-3 Single 2-3 host request line 6-4 host request pins 6-10 host requests 6-6 host requests, enabling 6-9 Host Status Register (HSR) 6-15 Host status register (HSR) 6-13 Host Transmit Data Empty bit 6-7 Host Transmit Data Register (HTX) 6-21 Host Transmit Data register (HTX) 6-7 host-to-DSP transfers 6-6 HPCR 6-4 HPCR register 2-11-2-14, ??-6-22, 6-32, 6-33, B-4, B-23 HR 2-3 HREO bit 6-28 HREQ signal 6-26 HRX register 6-22 HSR register 6-15 HTX register 6-21

I/O space external Y data Memory 3-7 X data Memory 3-5 Y data Memory 3-7 ICR Double Host Request bit 6-9 ICR register 6-24 Idle Line Interrupt Enable bit (ILIE) 8-13 Idle Line Wakeup mode 8-3 IF0 bit 7-31 IIR filter 10-1, 10-2 scaling 10-2 ILIE bit 8-13 Indicate state of HF3 in HCR on DSP side 6-28 Infinite Impulse Response filter 10-1 INIT bit 6-25 initialization **EFCOP 10-2** Initialize bit (INIT) 6-25 initializing the timer 9-2, 9-3 Instruction Cache 3-3 instruction cache 3-1 instruction set 1-5 Interface Control Register (ICR) 6-24 Interface Status Register (ISR) 6-28

Interface Vector Register (IVR) 6-30 internal buses 1-10 internal program memory 3-1 internal Y data Memory 3-5 Internal Y I/O space 3-7 interrupt 1-8 **ESSI 7-8** HI08 6-7 priority levels 4-7 sources 4-4, 4-5 interrupt and mode control 2-9 interrupt conditions 5-2 interrupt control 2-9 interrupt DSP after last slot in frame ends regardless of receive mask register setting 7-20 interrupt handler, forcing execution 6-8 Interrupt Priority Levels 4-7 Interrupt Priority Register P (IPR-P) 4-7 interrupt routines, HI08 6-8 interrupt service routine 7-9 interrupt service routine (ISR) 9-4 **Interrupt Source Priorities 4-8** Interrupt Sources 4-5 interrupt trigger event 7-9 interrupt trigger, configuring 7-9 interrupts 5-3 interrupts, HI08 HI08 handshaking protocols interrupts 6-6 interrupts, receive and transmit 7-11 IPR-P 4-7 ISR Host Request bit (HREQ) 6-28 ISR register 6-28 IVR register 6-30

## J

JCLR 5-2 Joint Test Action Group (JTAG) 1-5, 1-9 BSR 4-25 interface 2-20 JSCLR 5-2 JSET 5-2 JSSET 5-2 JTAG 1-9

## Κ

K-constant 10-1

## L

LA register 1-8

LC register 1-8 Load register (TLR) 9-3 logic 1-5 Loop Address register (LA) 1-8 Loop Counter register (LC) 1-8

## Μ

M68HC11 SCI interface 8-16 MAC 1-6 Manual Conventions 1-2 mapping control registers 5-2 MC68000 family 6-30 MC68681 DUART 8-16 Measurement 9-11 Measurement capture (Mode 6) 9-11 Measurement input period (Mode 5) 9-11 Measurement input width (Mode 4) 9-11 memory allocation switching 3-2 configuration 3-7 dynamic switching 3-7 expansion 1-10, 3-1 external expansion port 1-10 maps 3-8 off-chip 1-10 on-chip 1-9 shared 10-2 memory maps 3-8, 3-9, 3-10, 3-11, 3-12, 3-13, 3-14, 3-15, 3-16, 3-17, 3-18, 3-19, 3-20, 3-21, 3-22, 3-23, 3-24, 3-25, 3-26, 3-27, 3-28 Memory Switch mode 3-2 X data Memory 3-4 Y data Memory 3-6 **MIPS 1-5** mobile switching center 10-1 MODD, MODC, MODB, and MODA 8-7 mode control 2-9 modulo adder 1-7 move (MOVE, MOVEP) instructions 5-2 **MOVEP** instruction 6-13 multichannel filter 10-1 Multidrop mode 8-2 multiple serial device selection 7-5 multiplexed bus 2-3 multiplexed bus mode 6-20 multiplexed bus modes 6-17 multiplexed mode 6-4 Multiplier-Accumulator (MAC) 1-6

## Ν

network enhancements to ESSI 7-2 Network mode 7-8

DSP56311 User's Manual For More Information On This Product, Go to: www.freescale.com

Network mode interrupt, ESSI 7-20 non-multiplexed bus 2-3 non-multiplexed mode 6-4

## 0

OF0-OF1 bits 7-19 off-chip memory expansion 3-1 offset adder 1-7 OMR 1-8, 4-11 OnCE 1-5 OnCE module 1-9 interface 2-20 OnCE/JTAG 2-3 On-Chip Emulation (OnCE) module 1-9 on-chip memory 1-9 On-Demand mode 7-10 Operating 4-1 operating mode 4-1, 4-2 ESSI 7-10 synchronous, ESSI 7-11 Operating Mode Register 4-11 Operating Mode Register (OMR) 1-8 operating mode, HI08 6-17 operating modes 4-1 operational mode select, ESSI 7-22

#### Ρ

PAB 1-10 PAG 1-7 Parity Error bit (PE) 8-17 PC register 1-8 PCRC register 7-36 PCRD register 7-36 PCRE register 8-25 PCTL 4-21 PCTL register 4-21 PCU 1-7 PDB 1-10 PDC 1-7 PDRC register 7-38 PDRD register 7-38 PDRE register 8-26 PE bit 8-17 Peripheral I/O Expansion Bus 1-10 peripherals programming bit-oriented instructions 5-2 data transfer methods 5-3 individual reset state 5-1 initializat steps 5-1 interrupts 5-3 mapping control registers 5-2 move (MOVE, MOVEP) instructions 5-2

polling 5-3 reading status registers 5-2 peripherals programming, guidelines 5-1 PIC 1-7 PLL 1-8, 2-5 PLL Control Register 4-21 PLL control register (PCTL) 4-21 PMB 10-4 pointers EFCOP memory bank base address 10-2 polling 5-3 Port A 2-6 Port B 2-3, 2-13, 5-6 Port C 2-3, 2-15, 5-7 Port C and D control registers 7-36 Port C Control Register (PCRC) 7-36 Port C Data Register (PDRC) 7-38 Port C Direction Register (PRRC) 7-37 Port Control Register 7-23 Port D 2-3, 2-17, 5-8 Port D Control Register (PCRD) 7-36 Port D Data Register (PDRD) 7-38 Port D Direction Register (PRRD) 7-37 Port E 5-8 Port E Control Register (PCRE) 8-25 Port E Data Register (PDRE) 8-26 Port E Direction Register (PRRE) 8-26 position independent code 1-7 power 2-4 low 1-5 management 1-5 standby modes 1-5 prescale divider. ESSI 7-17 Prescaler Counter 9-21 Prescaler Load Register (TPLR) 9-3 Program Address Bus (PAB) 1-10 Program Address Generator (PAG) 1-7 Program Control Unit (PCU) 1-7 Program Counter register (PC) 1-8 Program Data Bus (PDB) 1-10 Program Decode Controller (PDC) 1-7 Program Interrupt Controller (PIC) 1-7 Program Memory Expansion Bus 1-10 Program RAM 3-1 Program ROM bootstrap 3-1 programming model EFCOP 10-6 ESSI 7-14 SCI 8-9 PRRC register 7-37 PRRD register 7-37 PRRE register 8-26 ESSI

CRA 7-3 Pulse width modulation mode (Mode 7) 9-11

#### R

R8 bit 8-17 RAM Program 3-1 RCM bit 8-21 RE bit 8-14 reading status registers 5-2 receive and transmit data paths 6-4 Receive Byte Registers 6-6 Receive Byte Registers (RXH, RXM, RXL) 6-30 Receive Clock Mode Source bit (RCM) 8-21 Receive Data Register (RX) 7-31 Receive Data signal (RXD) 8-4 Receive Exception Interrupt Enable bit (REIE) 7-19 Receive Exception Interrupt, enable 7-19 receive frame sync edge, ESSI 7-12 Receive Frame Sync Flag bit (RFS) 7-30 Receive Shift Register 7-31 Receive Slot Mask Registers (RSMA, RSMB) 7-35 Received Bit 8 Address bit (R8) 8-17 Receiver Enable bit (RE) 8-14 Receiver Wakeup Enable bit (SBK) 8-15 register banks 6-4 REIE bit 7-19 RESET 2-10 reset bus signals 2-6, 2-7 clock signals 2-5 essi signals 2-15, 2-17 host interface signals 2-11 interrupt signals 2-10 JTAG signals 2-21 mode control 2-10 OnCE signals 2-21 phase lock loop signals 2-6 sci signals 2-19 timers 2-20 resets, hardware and software 6-4 reverse-carry adder 1-7 RFS bit 7-30 ROM bootstrap 3-1, 3-3 RSMA and RSMB 7-14, 7-35 RSMA, RSMB registers 7-35 RWU bit 8-15 RX 7-14, 7-31 RX register 7-31 **RXD 8-4** RXD signal 8-4 RXH, RXM, RXL registers 6-30

#### S

saturation status bit 10-2 SBK bit 8-16 SC register 1-8 SC0 7-4 SC0 signal 7-4, 7-5 SC1 7-5 SC2 7-6 SC2 and SC1 signals programmed as outputs 7-23 SCCR 8-19 SCD0 bit 7-24 SCD1 bit 7-24 SCI 1-13, 2-3, 2-19, 5-2, 8-9 Clock Control Register 8-19 Control Register 8-12 data registers 8-22 exceptions 8-8 Idle Line 8-8 Receive Data 8-8 **Receive Data with Exception Status 8-8** Timer 8-8 Transmit Data 8-8 GPIO functionality 8-25 I/O signals 8-3 initialization 8-6 operating mode Asynchronous 8-1 Synchronous 8-1 operating modes 8-1 Asynchronous 8-1 programming model 8-9 Receive Data 8-4 Receive Register 8-23 reset 8-4 state after reset 8-5 Serial Clock 8-4 Status Register 8-17 transmission priority preamble, break, and data 8-7 Transmit Data 8-4 Transmit Register 8-24 SCI (GPIO) 5-8 SCI Clock Control Register 8-7 SCI Clock Control Register (SCCR) 8-9, 8-19 Clock Divider 8-21 Clock Out Divider 8-21 Receive Clock Mode Source 8-21 Transmit Clock Source 8-21 SCI Clock Control register (SCCR) Clock Prescaler 8-21 SCI Clock Control Register (SCCR) Bit **Definitions 8-21** SCI Control Register 8-7

SCI Control Register (SCR) 8-9, 8-12 Idle Line Interrupt Enable 8-13 Receive with Exception Interrupt Enable 8-12 Receiver Wakeup Enable 8-15 SCI Clock Polarity 8-12 SCI Receive Interrupt Enable 8-13 SCI Shift Direction 8-16 SCI Transmit Interrupt Enable 8-13 Send Break 8-16 Timer Interrupt Enable 8-13 Timer Interrupt Rate 8-12 Transmitter Enable 8-14 Wakeup Mode Select 8-15 Word Select 8-16 SCI Control Register (SCR) Bit Definitions 8-12 SCI Data Registers 8-22 SCI Data Word Formats 8-10 SCI exceptions Receive Data 8-8 SCI pins RXD, TXD, SCLK 8-3 SCI Programming Model - Data Registers 8-23 SCI Receive Data Registers (SRX) 8-9 SCI Receive Register (SRX) 8-23 SCI Serial Clock signal (SCLK) 8-4 SCI Status Register (SSR) 8-9, 8-17 Idle Line Flag 8-18 Overrun Error Flag 8-18 Parity Error 8-17 Receive Data Register Full 8-18 Received Bit 8 8-17 Transmit Data Register Empty 8-18 Transmitter Empty 8-19 SCI Status Register (SSR) Bit Definitions 8-17 SCI Transmit Data Address Register (STXA) 8-9 SCI Transmit Data Registers (STX) 8-9 SCI Transmit Register (STX) STX register 8-24 SCK 7-3 SCK signal 7-3 SCLK 8-4 SCLK pin 8-2, 8-6 SCLK signal 8-4 SCR 8-12 SCR Control Register (SCR) Receiver Enable 8-14 SCR register 8-12 select operational mode of the ESSI 7-22 Send Break bit (SBK) 8-16 Serial Clock 7-3 Serial Clock signal (SCK) 7-3 Serial Communication Interface (SCI) indicate whether received byte is an address or data 8-17

Serial Communication Interface 2-19 Asynchronous mode 8-2 enable/disable SCI timer interrupt 8-13 Serial Communication Interface (SCI) Address Mode Wakeup 8-3 bootstrap loading 8-7 byte is ready to transfer from receive shift register to receive data register 8-18 clock generator features 8-19 control clock polarity sourced or received on the clock signal (SCLK) 8-12 control divide-by-32 in the SCI Timer interrupt generator 8-12 crystal frequency 8-6 determine order in which SCI data shift registers shift data in or out 8-16 empty SCI transmit data register 8-18 enable receiver 8-14 enable transmitter 8-14 enable wakeup function 8-15 enable/disable SCI receive data interrupt 8-13 enable/disable SCI receive data with exception interrupt 8-12 enable/disables SCI transmit data interrupt. 8-13 establish a periodic interrupt 8-20 Idle Line Wakeup mode 8-3 incorrect parity bit is detected in received character 8-17 individual reset state (PCR = \$0) 8-6 Inter-processor messages 8-2 interrupts 8-6 maximum internal clock 8-19 Multidrop mode 8-2 recover synchronization 8-2 SCR. SCCR 8-6 select format of transmitted and received data 8-16 select wakeup on idle line mode 8-15 select whether internal or external clock is used for transmitter 8-21 Serial Clock 8-20 STX or STXA 8-22 transmit and receive shift registers 8-2 Wired-OR mode 8-3 Serial Communications Interface (SCI) 1-13, 8-1 Synchronous mode 8-2 Serial Control 0 7-4 Serial Control 0 Direction bit (SCD0) 7-24 serial control 0 signal (SC0) 7-4, 7-5 Serial Control 1 7-5 Serial Control 1 Direction bit (SCD1) 7-24 Serial Control 2 7-6 serial flag signal or receive clock signal 7-4 Serial Input Flag 0 bit (IF0) 7-31 Serial Output Flag bits (OF0-OF1) 7-19

Serial Receive Data 7-3 Serial Receive Data signal (SRD) 7-3 serial receive shift register is filled and ready to transfer to receive data register (RX) but RX is full 7-29 Serial Transmit Data 7-3 Serial Transmit Data signal (STD) 7-3 set timer operating mode 9-3 shared memory 10-2 signal measurement modes 9-11 signals ESSI data and control 7-3 functional grouping 2-3 Single Data Strobe 2-3 single-strobe bus 6-21 Sixteen-bit Compatibility mode 3-8 Size register (SZ) 1-8 software polling 6-6 SP 1-8 SR register 1-8 SRAM interfacing 1-10 SRD 7-3 SRD signal 7-3 SRX 8-23 read as SRXL, SRXM, SRXH 8-23 SRX register 8-23 SSISR 7-6, 7-14, 7-29 SSISR register 7-29 SSR 8-17 SSR register 8-17 Stack Counter register (SC) 1-8 Stack Pointer (SP) 1-8 standby mode Stop 1-5 Wait 1-5 Status Register (SR) 1-8 status registers, reading 5-2 STD 7-3 STD signal 7-3 sticky bits 10-2 stop standby mode 1-5 STOP instruction 6-22, 8-6 STX 8-24 STX register read as STXL, STXM. STXH, and STXA 8-24 switching memory configuration dynamically 3-7 switching memory sizes 3-2 Synchronous mod 8-19 Synchronous mode 7-10, 7-11, 7-13, 8-2, 8-18 synchronous mode 7-4 SZ register 1-8

## Т

TAP 1-9 TCPR register 9-30 TCR register 9-30 TCSR register 9-24 TE bit 8-14, 9-24 TEIE bit 7-20 Test Access Port (TAP) 1-9 TFS bit 7-30 Time Slot Register (TSR) 7-34 timer control counter preload operation 9-26 control timer clock source, behavior of TIO signal, and timer mode of operation 9-27 indicate a counter overflow 9-25 indicate that event count is complete 9-25 operating modes 9-4 polarity definition of the incoming signal on the TIO signal 9-26 reflect value of TIO signal 9-25 select prescalar clock as the timer source clock 9-25 source of TIO value when it is a data output signal 9-25 special cases 9-21 timer compare interrupts, enable 9-28 Timer (GPIO) 5-9 timer after Reset 9-2 Timer Compare exception 9-3 Timer Compare Register (TCPR) 9-3, 9-30 Timer Control Register 9-2 Timer Control/Status Register (TCSR) 9-24 Data Input 9-25 Data Output 9-25 Direction 9-26 Inverter 9-26 Prescalar Clock Enable 9-25 Timer Compare Flag 9-25 Timer Compare Interrupt Enable 9-28 Timer Control 9-27 Timer Enable 9-28 Timer Overflow Flag 9-25 Timer Overflow Interrupt Enable 9-28 Timer Reload Mode 9-26 Timer Control/Status Register (TCSR) bit definitions 9-24 Timer Count Register (TCR) 9-30 Timer Enable bit (TE) 9-24 timer exception, configuring 9-4 timer exceptions 9-3 Timer GPIO (Mode 0) 9-5 timer initialization 9-2, 9-3 Timer Load Register (TLR) 9-29 timer mode

mode 5-measurement input period 9-13 mode 6-measurement capture 9-15 mode 7—pulse width modulation 9-16 mode 8-reserved 9-19 mode 9-watchdog pulse 9-19 mode 10-measurement toggle 9-20 modes 11-15-reserved 9-21 Timer module 1-14 architecture 9-1 timer block diagram 9-1 timer opeating modes PWM, mode 7 9-5 timer operating mode, setting 9-3 timer operating modes Event Counter (Mode 3) 9-10 Event counter, mode 3 9-4 GPIO (Mode 0) 9-5 GPIO, mode 0 9-4 Input pulse, mode 5 9-5 Input width, mode 4 9-5 Measurement Capture (Mode 6) 9-15 Measurement Input Width (Mode 4) 9-12 overview 9-5 Pulse (Mode 1) 9-7 Pulse Width Modulation (PWM, Mode 7) 9-16 Pulse, mode 1 9-4 Pulse, mode 9 9-5 reserved modes 9-20, 9-21 signal measurement modes 9-11 Toggle (Mode 2) 9-8 Toggle, mode 10 9-5 Toggle, mode 2 9-4 Watchdog 9-5 Watchdog modes 9-18 Watchdog Pulse 9-18 Watchdog Pulse (Mode 9) 9-19 Watchdog Pulse mode 9-19 Watchdog Toggle 9-18 Watchdog Toggle (Mode 10) 9-20 Timer Overflow exception 9-3 Timer Prescalar Count Register (TPCR) Prescalar Counter Value 9-24 Timer Prescaler Count Register (TPCR) 9-24 Timer Prescaler Count Register (TPCR) bit definitions 9-24 Timer Prescaler Load Register (TPLR) 9-23 Prescaler Preload Value 9-23 Timer Prescaler Load Register (TPLR) bit definitions 9-23 timer, enabling 9-3 Timers 2-3, 2-19 TLR register 9-29 TPCR register 9-24

**TPLR** register 9-23 transcoder basestation 10-1 Transmit Byte Registers 6-6 Transmit Byte Registers (TXH, TXM, TXL) 6-30 Transmit Data signal (TXD) 8-4 transmit data signal, ESSI 7-4 Transmit Exception Interrupt Enable bit (TEIE) 7-20 Transmit Frame Sync Flag bit (TFS) 7-30 transmit interrupt enable, ESSI 7-20 Transmit Shift Registers 7-31 Transmit Slot Mask Registers (TSMA, TSMB) 7-34 Transmitter Enable bit (TE) 8-14 HI08 ICR 6-31 triple timer 5-2 triple timer module 1-14 TSMA and TSMB 7-14, 7-34 TSMA, TSMB registers 7-34 TSR 7-34 TSR register 7-34 TX0-TX2 7-14, 7-34 TX2, TX1, TX0 registers 7-34 TXD 8-4 TXD signal 8-4 HI08 HSR 6-31 TXH, TXM, TXL registers 6-30

## V

VBA register 1-8 Vector Base Address register (VBA) 1-8 vocoder 10-1

## W

wait standby mode 1-5 see also reset
WAKE bit 8-15
Wakeup Mode Select bit (WAKE) 8-15
Watchdog pulse 9-18
Watchdog Toggle 9-18
Wired-OR Select bit (WOMS) 8-14
WOMS bit 8-14
word length frame sync 7-12

## Х

X data memory 3-3 X I/O space 3-5 X Memory Address Bus (XAB) 1-10 X Memory Data Bus (XDB) 1-10 X Memory Expansion Bus 1-10

XAB 1-10 XDB 1-10

## Υ

Y data Memory 3-5 internal 3-5 Y I/O space 3-7 Y Memory Address Bus (YAB) 1-10 Y Memory Data Bus (YDB) 1-10 Y Memory Expansion Bus 1-10 YAB 1-10 YDB 1-10