Revision 2 Published 09/00 DSP56362UM/D (Motorola Order Number)

# **DSP56362**

# 24-Bit Digital Signal Processor User's Manual

Motorola, Incorporated Semiconductor Products Sector 6501 William Cannon Drive West Austin, TX 78735-8598 This document (and other documents) can be viewed on the World Wide Web at the following URL:

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

This manual is one of a set of three documents. You need the following manuals to have complete product information:

**Family Manual** 

**User's Manual** 

**Technical Data** 

OnCE<sup>TM</sup> is a trademark of Motorola, Inc. © MOTOROLA INC., 1998, 1999, 2000

Rev. 1.2; published 09/00 Order this document by <u>DSP56362UM</u>/AD

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, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters which may be provided in Motorola data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. Motorola does not convey any license under its patent rights nor the rights of others. Motorola products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support life, or for any other application in which the failure of the Motorola product could create a situation where personal injury or death may occur. Should Buyer purchase or use Motorola products for any such unintended or unauthorized application, Buyer shall indemnify and hold Motorola and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Motorola was negligent regarding the design or manufacture of the part. Motorola and was registered trademarks of Motorola, Inc. is an Equal Opportunity/Affirmative Action Employer.

| Paragrap<br>Number | I ITIE                                  | Page<br>Number |
|--------------------|-----------------------------------------|----------------|
| Section            | <b>1</b> DSP56362 Overview              | 1-1            |
| 1.1                | Introduction                            | 1-1            |
| 1.2                | DSP56362 Core Description               | 1-1            |
| 1.3                | DSP56362 Block Diagram                  | 1-3            |
| 1.4                | DSP56300 Core Functional Blocks         | 1-4            |
| 1.5                | DSP56362 Peripheral Overview            | . 1-10         |
| Section            | <b>2</b> Signal/Connection Descriptions | 2-1            |
| 2.1                | Signal Groupings                        | 2-1            |
| 2.2                | Power                                   | 2-3            |
| 2.3                | Ground                                  | 2-4            |
| 2.4                | Clock and PLL                           | 2-4            |
| 2.5                | External Memory Expansion Port (Port A) | 2-5            |
| 2.6                | Interrupt and Mode Control              |                |
| 2.7                | Host Interface (HDI08)                  | . 2-10         |
| 2.8                | Serial Host Interface                   | . 2-14         |
| 2.9                | Enhanced Serial Audio Interface         | . 2-16         |
| 2.10               | Digital Audio Interface (DAX)           | . 2-20         |
| 2.11               | Timer                                   |                |
| 2.12               | JTAG/OnCE Interface                     | . 2-21         |
| Section            | <b>3</b> Memory Configuration           | 3-1            |
| 3.1                | Memory Spaces                           | 3-1            |
| 3.2                | Memory Space Configuration              | 3-4            |
| 3.3                | Internal Memory Configuration           | 3-5            |
| 3.4                | Dynamic Memory Configuration Switching  | 3-8            |
| 3.5                | Patch Mode                              | 3-9            |
| 3.6                | Memory Maps                             | . 3-11         |
| 3.7                | External Memory Support                 | . 3-15         |
| 3.8                | Internal I/O Memory Map                 | . 3-15         |
| Section            | <b>4</b> Core Configuration             | 4-1            |
| 4.1                | Introduction                            | 4-1            |
| 4.2                | Operating Mode Register (OMR)           | 4-1            |
| 4.3                | Operating Modes                         | 4-2            |
| 4.4                | Bootstrap Program                       | 4-4            |
| 4.5                | Interrupt Priority Registers            |                |
| 4.6                | DMA Request Sources                     | . 4-13         |
| 4.7                | PLL Initialization                      | . 4-14         |
| 4.8                | Device Identification (IDR) Register    | . 4-15         |
| 4.9                | JTAG Identification (ID) Register       |                |
| 4.10               | JTAG Boundary Scan Register (BSR)       |                |

MOTOROLA

| Paragrap<br>Number | oh Title                                    | Page<br>Number |
|--------------------|---------------------------------------------|----------------|
| Section            | <b>5</b> General Purpose Input/Output       | 5-1            |
| 5.1                | Introduction                                | 5-1            |
| 5.2                | Programming Model                           | 5-1            |
| Section            | 6 Host Interface (HDI08)                    |                |
| 6.1                | Introduction                                | 6-1            |
| 6.2                | HDI08 Features                              | 6-1            |
| 6.3                | HDI08 Host Port Signals                     | 6-4            |
| 6.4                | HDI08 Block Diagram                         | 6-5            |
| 6.5                | HDI08 – DSP-Side Programmer's Model         | 6-6            |
| 6.6                | HDI08 – External Host Programmer's Model    | 6-19           |
| 6.7                | Servicing The Host Interface                | 6-30           |
| Section            | <b>7</b> Serial Host Interface              | 7-1            |
| 7.1                | Introduction                                | 7-1            |
| 7.2                | Serial Host Interface Internal Architecture | 7-2            |
| 7.3                | SHI Clock Generator                         | 7-3            |
| 7.4                | Serial Host Interface Programming Model     |                |
| 7.5                | Characteristics Of The SPI Bus              | 7-18           |
| 7.6                | Characteristics Of The I <sup>2</sup> C Bus | 7-18           |
| 7.7                | SHI Programming Considerations              |                |
| Section            | 8 Enhanced Serial AUDIO Interface (ESAI)    | 8-1            |
| 8.1                | Introduction                                | 8-1            |
| 8.2                | ESAI Data and Control Pins                  | 8-3            |
| 8.3                | ESAI Programming Model                      | 8-9            |
| 8.4                | Operating Modes                             | 8-48           |
| 8.5                | GPIO - Pins and Registers                   | 8-53           |
| 8.6                | ESAI Initialization Examples                | 8-56           |
| Section            | <b>9</b> Timer/ Event Counter               | 9-1            |
| 9.1                | Introduction                                |                |
| 9.2                | Timer/Event Counter Architecture            |                |
| 9.3                | Timer/Event Counter Programming Model       | 9-3            |
| 9.4                | Timer Modes of Operation                    |                |
| Section            | <b>10</b> Digital Audio Transmitter         | 10-1           |
| 10.1               | Introduction                                | 10-1           |
| 10.2               | DAX Signals                                 | 10-2           |
| 10.3               | DAX Functional Overview                     | 10-3           |
| 10.4               | DAX Programming Model                       | 10-4           |
| 10.5               | DAX Internal Architecture                   |                |
| 10.6               | DAX Programming Considerations              |                |

ii MOTOROLA

| Paragrap<br>Number | h     |      | Title                               | Page<br>Number |
|--------------------|-------|------|-------------------------------------|----------------|
| 10.7               | GPIC  | ) (F | PORT D) - Pins and Registers        | 10-15          |
|                    |       |      | Bootstrap ROM Contents              |                |
| Appendix           | (     | В    | Equates                             | B-1            |
| Appendix           | (     | С    | JTAG BSDL                           | C-1            |
| Appendix           | (     | D    | Programmer's Reference              | D-1            |
| D.1                | Intro | duc  | tion                                | D-1            |
| D.2                | Inter | nal  | I/O Memory MAp                      | D-2            |
| D.3                | Inter | rup  | t Vector Addresses                  | D-6            |
| D.4                | Inter | rup  | t Source Priorities (within an IPL) | D-8            |
| D.5                | Host  | Int  | erface—Quick Reference              | D-10           |
| D.6                | Prog  | ram  | ming Sheets                         | D-13           |

MOTOROLA

Paragraph Title Page Number

iv MOTOROLA

| Figure<br>Number | Title                                            | Page<br>Number |  |
|------------------|--------------------------------------------------|----------------|--|
| 1-1              | DSP56362 Block Diagram                           | 1-3            |  |
| 2-1              | Signals Identified by Functional Group           | 2-2            |  |
| 3-1              | Memory Maps CE=0, MS=0, SC=0                     | 3-11           |  |
| 3-2              | Memory Maps CE=0, MS=1, SC=0                     | 3-12           |  |
| 3-3              | Memory Maps for CE=1, MS=0, SC=0                 |                |  |
| 3-4              | Memory Maps for CE=1, MS=1, SC=0                 | 3-13           |  |
| 3-5              | Memory Maps for CE=0, MS=0, SC=1                 | 3-13           |  |
| 3-6              | Memory Maps for CE=0, MS=1, SC=1                 | 3-14           |  |
| 3-7              | Memory Maps for CE=1, MS=0, SC=1                 | 3-14           |  |
| 3-8              | Memory Maps for CE=1, MS=1, SC=1                 | 3-15           |  |
| 4-1              | Operating Mode Register (OMR)                    | 4-2            |  |
| 4-2              | Interrupt Priority Register C                    | 4-12           |  |
| 4-3              | Interrupt Priority Register P                    | 4-13           |  |
| 4-4              | Identification Register Configuration            | 4-15           |  |
| 4-5              | JTAG Identification Register Configuration       | 4-15           |  |
| 6-1              | HDI08 Block Diagram                              | 6-5            |  |
| 6-2              | Host Control Register (HCR) (X:\$FFFFC2)         | 6-7            |  |
| 6-3              | Host Status Register (HSR) (X:FFFFC3)            | 6-10           |  |
| 6-5              | Self Chip Select logic                           | 6-12           |  |
| 6-4              | Host Base Address Register (HBAR) (X:\$FFFFC5)   | 6-12           |  |
| 6-6              | Host Port Control Register (HPCR) (X:\$FFFFC4)   | 6-13           |  |
| 6-7              | Single strobe bus                                | 6-15           |  |
| 6-8              | Dual strobes bus                                 | 6-15           |  |
| 6-9              | Host Data Direction Register (HDDR) (X:\$FFFFC8) | 6-16           |  |
| 6-10             | Host Data Register (HDR) (X:\$FFFFC9)            | 6-17           |  |
| 6-11             | HSR-HCR Operation                                | 6-19           |  |
| 6-12             | Interface Control Register (ICR)                 | 6-21           |  |
| 6-13             | Command Vector Register (CVR)                    | 6-25           |  |
| 6-14             | Interface Status Register (ISR)                  | 6-26           |  |
| 6-15             | Interrupt Vector Register (IVR)                  | 6-27           |  |
| 6-16             | HDI08 Host Request Structure                     | 6-31           |  |
| 7-1              | Serial Host Interface Block Diagram              |                |  |
| 7-2              | SHI Clock Generator                              |                |  |
| 7-3              | SHI Programming Model—Host Side                  | 7-4            |  |
| 7-4              | SHI Programming Model—DSP Side                   |                |  |
| 7-5              | SHI I/O Shift Register (IOSR)                    |                |  |
| 7-6              | SPI Data-To-Clock Timing Diagram                 | 7-9            |  |

MOTOROLA v

| Figure<br>Number | Title                                              | Page<br>Number |
|------------------|----------------------------------------------------|----------------|
| 7-7              | I <sup>2</sup> C Bit Transfer                      |                |
| 7-8              | I <sup>2</sup> C Start and Stop Events             |                |
| 7-9              | Acknowledgment on the I <sup>2</sup> C Bus         |                |
| 7-10             | I <sup>2</sup> C Bus Protocol For Host Write Cycle |                |
| 7-11             | I <sup>2</sup> C Bus Protocol For Host Read Cycle  |                |
| 8-1              | ESAI Block Diagram                                 | 8-2            |
| 8-2              | ESAI Clock Generator Functional Block Diagram      | 8-11           |
| 8-3              | ESAI Frame Sync Generator Functional Block Diagram | 8-13           |
| 8-4              | Normal and Network Operation                       | 8-20           |
| 8-5              | Frame Length Selection                             | 8-23           |
| 8-6              | SAICR SYN Bit Operation                            | 8-37           |
| 8-7              | ESAI Data Path Programming Model ([R/T]SHFD=0)     | 8-42           |
| 8-8              | ESAI Data Path Programming Model ([R/T]SHFD=1)     | 8-43           |
| 9-1              | Timer/Event Counter Block Diagram                  |                |
| 9-2              | Timer Block Diagram                                | 9-3            |
| 9-3              | Timer Module Programmer's Model                    |                |
| 9-4              | Timer Prescaler Load Register (TPLR)               | 9-5            |
| 9-5              | Timer Prescaler Count Register (TPCR)              | 9-6            |
| 10-1             | Digital Audio Transmitter (DAX) Block Diagram      |                |
| 10-2             | DAX Programming Model                              |                |
| 10-3             | DAX Relative Timing                                | 10-10          |
| 10-4             | Preamble sequence                                  |                |
| 10-5             | Clock Multiplexer Diagram                          |                |
| 10-6             | Examples of data organization in memory            | 10-15          |
| 10-7             | Port D Control Register (PCRD)                     |                |
| 10-8             | Port D Direction Register (PRRD)                   |                |
| 10-9             | Port D Data Register (PDRD)                        |                |
| D-1              | Status Register (SR)                               |                |
| D-2              | Operating Mode Register (OMR)                      |                |
| D-3              | Interrupt Priority Register–Core (IPR–C)           |                |
| D-4              | Interrupt Priority Register – Peripherals (IPR–P)  |                |
| D-5              | Phase Lock Loop Control Register (PCTL)            |                |
| D-6              | Host Receive and Host Transmit Data Registers      |                |
| D-7              | Host Control and Status Registers                  |                |
| D-8              | Host Base Address and Host Port Control            |                |
| D-9              | Host Interrupt Control and Interrupt Status        |                |
| D-10             | Host Interrupt Vector and Command Vector           |                |
| D-11             | Host Receive and Transmit Byte Registers           | D-24           |

vi MOTOROLA

| Figure<br>Number | Title                                                           | Page<br>Number |  |
|------------------|-----------------------------------------------------------------|----------------|--|
| D-12             | SHI Slave Address and Clock Control Registers                   | D-25           |  |
| D-13             | SHI Transmit and Receive Data Registers                         | D-26           |  |
| D-14             | SHI Host Control/Status Register                                | D-27           |  |
| D-15             | ESAI Transmit Clock Control Register                            | D-28           |  |
| D-16             | ESAI Transmit Control Register                                  | D-29           |  |
| D-17             | ESAI Receive Clock Control Register                             | D-30           |  |
| D-18             | ESAI Receive Control Register                                   | D-31           |  |
| D-19             | ESAI Common Control Register                                    | D-32           |  |
| D-20             | ESAI Status Register                                            | D-33           |  |
| D-21             | DAX Non-Audio Data Register                                     | D-34           |  |
| D-22             | DAX Control and Status Registers                                | D-35           |  |
| D-23             | Timer Prescaler Load and Prescaler Count Registers (TPLR, TPCR) | D-36           |  |
| D-24             | Timer Control/Status Register                                   | D-37           |  |
| D-25             | Timer Load, Compare and Count Registers                         | D-38           |  |
| D-26             | GPIO Port B                                                     | D-39           |  |
| D-27             | GPIO Port C                                                     | D-40           |  |
| D-28             | GPIO Port D                                                     | D-41           |  |

MOTOROLA vii

Figure Page Number Title Number

viii MOTOROLA

| Table<br>Number | Title                                                    |      |  |  |
|-----------------|----------------------------------------------------------|------|--|--|
| 1-1             | On-Chip Memory                                           | 1-9  |  |  |
| 2-1             | DSP56362 Functional Signal Groupings                     | 2-1  |  |  |
| 2-2             | Power Inputs                                             |      |  |  |
| 2-3             | Grounds                                                  |      |  |  |
| 2-4             | Clock and PLL Signals                                    | 2-4  |  |  |
| 2-5             | External Address Bus Signals                             | 2-6  |  |  |
| 2-6             | External Data Bus Signals                                | 2-6  |  |  |
| 2-7             | External Bus Control Signals                             | 2-6  |  |  |
| 2-8             | Interrupt and Mode Control                               | 2-8  |  |  |
| 2-9             | Host Interface                                           | 2-10 |  |  |
| 2-10            | Serial Host Interface Signals                            | 2-14 |  |  |
| 2-11            | Enhanced Serial Audio Interface Signals                  | 2-16 |  |  |
| 2-12            | Digital Audio Interface (DAX) Signals                    | 2-20 |  |  |
| 2-13            | Timer Signal                                             | 2-20 |  |  |
| 2-14            | JTAG/OnCE <sup>TM</sup> Interface                        |      |  |  |
| 3-1             | Memory Space Configuration Bit Settings for the DSP56362 | 3-4  |  |  |
| 3-2             | RAM Configuration Bit Settings for the DSP56362          |      |  |  |
| 3-3             | Internal Memory Size Configurations                      |      |  |  |
| 3-4             | RAM Memory Locations                                     |      |  |  |
| 3-5             | On-Chip ROM Memory Locations                             |      |  |  |
| 4-1             | DSP56362 Operating Modes                                 |      |  |  |
| 4-2             | Expanded Mode                                            |      |  |  |
| 4-3             | Bootstrap From External Memory                           |      |  |  |
| 4-4             | Jump To PROM Starting Address                            |      |  |  |
| 4-5             | Mode 3 (Reserved)                                        |      |  |  |
| 4-6             | Mode 4 (Reserved)                                        |      |  |  |
| 4-7             | Bootstrap From SHI (Slave SPI)                           | 4-7  |  |  |
| 4-8             | Mode 6 Bootstrap From SHI (Slave I2C)                    |      |  |  |
| 4-9             | Mode 7 Bootstrap From SHI (Slave I2C)                    | 4-8  |  |  |
| 4-10            | Mode 8 (Expanded Mode)                                   |      |  |  |
| 4-11            | Mode 9 (Reserved)                                        |      |  |  |
| 4-12            | Mode A (Reserved)                                        | 4-9  |  |  |
| 4-13            | Mode B (Reserved)                                        | 4-9  |  |  |
| 4-14            | Mode C Bootstrap Through HDI08 (ISA Mode)                |      |  |  |
| 4-15            | Bootstrap Through HDI08 (Non-multiplexed Mode)           |      |  |  |
| 4-16            | Bootstrap Through HDI08 (8051 Multiplexed Bus Mode)      |      |  |  |
| 4-17            | Bootstrap Through HDI08 (68302/68360 Bus Mode)           | 4-11 |  |  |
| 4-18            | Interrupt Priority Level Bits                            |      |  |  |
| 4-19            | DMA Request Sources                                      |      |  |  |
| 4-20            | DSP56362 BSR Bit Definition                              |      |  |  |
| 6-1             | HDI08 Signal Summary                                     |      |  |  |
| 6-2             | Strobe Signals Support signals                           |      |  |  |
| 6-3             | Host request support signals                             |      |  |  |
|                 |                                                          |      |  |  |

ix MOTOROLA

| Table<br>Number | Title                                                  |      |  |  |
|-----------------|--------------------------------------------------------|------|--|--|
| 6-4             | HDI08 IRQ                                              | 6-8  |  |  |
| 6-5             | HDM[2:0] Functionality                                 | 6-9  |  |  |
| 6-6             | HDR and HDDR Functionality                             | 6-17 |  |  |
| 6-7             | DSP-Side Registers after Reset                         | 6-18 |  |  |
| 6-8             | HDI08 Host Side Register Map                           | 6-20 |  |  |
| 6-9             | TREQ RREQ Interrupt Mode (HDM[2:0]=000 or HM[1:0]=00). | 6-22 |  |  |
| 6-10            | TREQ RREQ DMA Mode (HM11/40 or HM01/40)                | 6-22 |  |  |
| 6-11            | HDRQ                                                   | 6-22 |  |  |
| 6-12            | Host Mode Bit Definition                               | 6-23 |  |  |
| 6-13            | INIT Command Effect                                    | 6-24 |  |  |
| 6-14            | Host Request Status (HREQ)                             | 6-27 |  |  |
| 6-15            | Host Side Registers After Reset                        | 6-29 |  |  |
| 7-1             | SHI Interrupt Vectors                                  | 7-6  |  |  |
| 7-2             | SHI Internal Interrupt Priorities                      | 7-6  |  |  |
| 7-3             | SHI Noise Reduction Filter Mode                        |      |  |  |
| 7-4             | SHI Data Size                                          | 7-12 |  |  |
| 7-5             | HREQ Function In SHI Slave Modes                       | 7-14 |  |  |
| 7-6             | HCSR Receive Interrupt Enable Bits                     | 7-16 |  |  |
| 8-1             | Receiver Clock Sources (asynchronous mode only)        | 8-6  |  |  |
| 8-2             | Transmitter Clock Sources                              | 8-7  |  |  |
| 8-3             | TCCR Register                                          | 8-10 |  |  |
| 8-4             | Transmitter High Frequency Clock Divider               | 8-14 |  |  |
| 8-5             | TCR Register                                           | 8-15 |  |  |
| 8-6             | Transmit Network Mode Selection                        | 8-19 |  |  |
| 8-7             | ESAI Transmit Slot and Word Length Selection           | 8-21 |  |  |
| 8-8             | RCCR Register                                          | 8-26 |  |  |
| 8-9             | Receiver High Frequency Clock Divider                  | 8-27 |  |  |
| 8-10            | SCKR Pin Definition Table                              | 8-28 |  |  |
| 8-11            | FSR Pin Definition Table                               | 8-29 |  |  |
| 8-12            | HCKR Pin Definition Table                              | 8-29 |  |  |
| 8-13            | RCR Register                                           |      |  |  |
| 8-14            | ESAI Receive Network Mode Selection                    | 8-32 |  |  |
| 8-15            | ESAI Receive Slot and Word Length Selection            | 8-32 |  |  |
| 8-16            | SAICR Register                                         | 8-35 |  |  |
| 8-17            | SAISR Register                                         | 8-38 |  |  |
| 8-18            | TSMA Register                                          | 8-45 |  |  |
| 8-19            | TSMB Register                                          | 8-45 |  |  |
| 8-20            | RSMA Register                                          | 8-47 |  |  |
| 8-21            | RSMB Register                                          | 8-47 |  |  |
| 8-22            | PCRC and PRRC Bits Functionality                       | 8-54 |  |  |
| 8-23            | PCRC Register                                          | 8-54 |  |  |
| 8-24            | PRRC Register                                          | 8-54 |  |  |
| 8-25            | PDRC Register                                          | 8-55 |  |  |

X MOTOROLA

| Table<br>Number | Title                                        | Page<br>Number |  |
|-----------------|----------------------------------------------|----------------|--|
| 9-1             | Prescaler Source Selection                   | 9-6            |  |
| 9-2             | Timer Control Bits for Timer 0               | 9-8            |  |
| 9-3             | Timer Control Bits for Timers 1 and 2        | 9-9            |  |
| 9-4             | Inverter (INV) Bit Operation                 | 9-9            |  |
| 10-1            | DAX Interrupt Vectors                        | 10-4           |  |
| 10-2            | DAX Interrupt Priority                       | 10-4           |  |
| 10-3            | Clock Source Selection                       | 10-8           |  |
| 10-4            | Preamble Bit Patterns                        | 10-11          |  |
| 10-5            | Examples of DMA configuration                | 10-14          |  |
| 10-6            | DAX Port GPIO Control Register Functionality | 10-17          |  |
| D-1             | Internal I/O Memory Map                      | D-2            |  |
| D-2             | DSP56362 Interrupt Vectors                   | D-6            |  |
| D-3             | Interrupt Sources Priorities Within an IPL   | D-8            |  |
| D-4             | HDI08 Programming Model                      | D-10           |  |

MOTOROLA xi

Table Page Number Title Page

xii MOTOROLA

## **Preface**

This manual contains the following sections and appendices.

#### SECTION 1—DSP56362 OVERVIEW

Provides a brief description of the DSP56362, including a features list and block diagram.
 Lists related documentation needed to use this chip and describes the organization of this manual.

#### SECTION 2—SIGNAL/CONNECTION DESCRIPTIONS

• Describes the signals on the DSP56362 pins and how these signals are grouped into interfaces.

#### **SECTION 3—MEMORY CONFIGURATION**

• Describes the DSP56362 memory spaces, RAM and ROM configuration, memory configurations and their bit settings, and memory maps.

#### **SECTION 4—CORE CONFIGURATION**

 Describes the registers used to configure the DSP56300 core when programming the DSP56362, in particular the interrupt vector locations and the operation of the interrupt priority registers. Explains the operating modes and how they affect the processor's program and data memories.

#### SECTION 5—GENERAL PURPOSE INPUT/OUTPUT (GPIO)

• Describes the DSP56362 GPIO capability and the programming model for the GPIO signals (operation, registers, and control).

#### **SECTION 6—HOST INTERFACE (HDI08)**

• Describes the HDI08, including a quick reference to the HDI08 programming model.

#### **SECTION 7—SERIAL HOST INTERFACE (SHI)**

 Describes the serial input/output interface providing a path for communication and program/coefficient data transfers between the DSP and an external host processor. The SHI can also communicate with other serial peripheral devices.

#### **SECTION 8—ENHANCED SERIAL AUDIO INTERFACE (ESAI)**

 Describes the full-duplex serial port for serial communication with a variety of serial devices.

#### SECTION 9—TIMER/EVENT COUNTER MODULE

• Describes the internal timer/event counter devices.

#### SECTION 10—DIGITAL AUDIO TRANSMITTER (DAX)

• Describes the serial audio interface module that outputs digital audio data.

#### APPENDIX A—BOOTSTRAP PROGRAM

• Lists the bootstrap code used for the DSP56362.

#### **APPENDIX B—EQUATES**

• Lists the equates (I/O, HDI08, ESAI, SHI, DAX, Exception Processing, TEC, DMA, PLL, BIU, and Interrupts) for the DSP56362.

#### APPENDIX C—BSDL LISTING

• Provides the BSDL listing for the DSP56362.

#### APPENDIX D—PROGRAMMING REFERENCE

Lists peripheral addresses, interrupt addresses, and interrupt priorities for the DSP56362.
 Contains programming sheets listing the contents of the major DSP56362 registers for programmer reference.

#### **Manual Conventions**

The following conventions are used in this manual:

- Bits within registers are always listed from most significant bit (MSB) to least significant bit (LSB).
- When several related bits are detailed, they are referenced as AA[n:m], where n>m. 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 .

#### **High True/Low True Signal Conventions**

| Signal/Symbol    | Logic State | Signal State | Voltage                      |
|------------------|-------------|--------------|------------------------------|
| PIN <sup>1</sup> | 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                       |

Note:

- 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) have the following attributes:
  - In text, they have an overbar (e.g.,  $\overline{RESET}$  is asserted low).
  - In code examples, they have a tilde in front of their names.
  - In the following sample code listing, line 3 refers to the  $\overline{SSO}$  pin (shown as ~SSO).
- Sets of pins or signals are indicated by the first and last pins or signals in the set (e.g., HA1–HA8).
- Code examples are displayed in a monospaced font, as shown in .

#### **Sample Code Listing**

| BFSET #\$0007,X:PCC; Configure:     | line 1 |
|-------------------------------------|--------|
| ; MISO0, MOSI0, SCK0 for SPI master | line 2 |
| ; ~SS0 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 (IPR-C).
- The word "reset" is used in four different contexts in this manual:
- 1. Reset signal Written as "RESET"
- 2. Reset instruction Written as "RESET"
- 3. Reset operating state Written as "Reset"
- 4. Reset function Written as "reset"

# SECTION 1 DSP56362 OVERVIEW

#### 1.1 INTRODUCTION

This manual describes the DSP56362 24-bit digital signal processor (DSP), its memory, operating modes, and peripheral modules. The DSP56362 is a member of the DSP56300 family of programmable CMOS DSPs. Changes in core functionality specific to the DSP56362 are also described in this manual.

The DSP56362 is targeted to applications that require digital audio compression and decompression, sound field processing, acoustic equalization, and other digital audio algorithms.

This manual is intended to be used with the following publications:

- The *DSP56300 Family Manual (DSP56300FM/AD)*, which describes the CPU, core programming models, and instruction set details.
- The *DSP56362 Technical Data Sheet (DSP56362/D)*, which provides electrical specifications, timing, pinout, and packaging descriptions of the DSP56362.

These documents, as well as Motorola's DSP development tools, can be obtained 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.2 DSP56362 CORE DESCRIPTION

The DSP56362 uses the DSP56300 core. The DSP56300 core is a high-performance, single clock cycle per instruction engine that provides up to twice the performance of Motorola's popular DSP56000 core family. The DSP56300 core retains code compatibility with the DSP56000 core family.

The DSP56300 core family offers a new level of performance in speed and power, provided by its rich instruction set and low power dissipation. This enables a new generation of

wireless, telecommunications, and multimedia products. For a description of the DSP56300 core, see Section **1.4 DSP56300 Core Functional Blocks on page 1-4**. Significant architectural enhancements to the DSP56300 core family include a barrel shifter, 24-bit addressing, an instruction cache, and direct memory access (DMA).

The 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 may 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. Refer to Section 3, Memory Configuration for more information.

Core features are described in detail in the *DSP56300 Family Manual*. Pinout, memory, and peripheral features are described in this manual.

#### 1.2.1 GENERAL FEATURES

- 120 million instructions per second (MIPS) with a 120-MHz clock at 3.3 V
- Object code compatible with the DSP56000 core
- Highly parallel instruction set

#### 1.2.2 HARDWARE/SOFTWARE DEBUGGING SUPPORT

- On-Chip Emulation (OnCE<sup>TM</sup>) module
- Joint Action Test Group (JTAG) test access port (TAP)

#### 1.2.3 REDUCED POWER DISSIPATION

- Very low-power CMOS design
- Wait and stop low-power standby modes
- Fully-static logic, operation frequency down to 0 Hz (dc)
- Optimized power management circuitry (instruction-dependent, peripheral-dependent, and mode-dependent)

#### 1.3 DSP56362 BLOCK DIAGRAM



Figure 1-1 DSP56362 Block Diagram

Memory sizes in the block diagram are defaults. Memory can be partitioned differently, according to the memory mode of the chip. See Section **1.4.8 On-Chip Memory on page 1-9** for more details about memory size.

#### 1.4 DSP56300 CORE FUNCTIONAL BLOCKS

The DSP56300 core provides the following functional blocks:

- Data arithmetic logic unit (Data ALU)
- Address generation unit (AGU)
- Program control unit (PCU)
- Bus interface unit (BIU)
- DMA controller (with six channels)
- Instruction cache controller
- PLL-based clock oscillator
- OnCE module
- JTAG TAP
- Memory

In addition, the DSP56362 provides a set of on-chip peripherals, described in **Section 1.5 DSP56362 Peripheral Overview on page 1-10**.

#### 1.4.1 DATA ALU

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

- Fully pipelined 24-bit × 24-bit parallel multiplier-accumulator (MAC)
- Bit field unit, comprising a 56-bit parallel barrel shifter (fast shift and normalization; bit stream generation and parsing)
- Conditional ALU instructions
- 24-bit or 16-bit arithmetic support under software control
- Four 24-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.4.1.1 Data ALU Registers

The Data ALU registers can be read or written over the X memory data bus (XDB) and the Y memory data bus (YDB) as 24- or 48-bit operands (or as 16- or 32-bit operands in 16-bit arithmetic mode). The source operands for the Data ALU, which can be 24, 48, or 56 bits (16, 32, or 40 bits in 16-bit arithmetic mode), always originate from Data ALU registers. The results of all Data ALU operations are stored in an accumulator.

All the Data ALU operations are performed in two clock cycles in pipeline fashion so that a new instruction can be initiated in every clock, yielding an effective execution rate of one instruction per clock cycle. The destination of every arithmetic operation can be used as a source operand for the immediately following arithmetic operation without a time penalty (i.e., without a pipeline stall).

#### 1.4.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. In the case of 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 two's-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 can either be truncated or rounded into the MSP. Rounding is performed if specified.

## 1.4.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 used to 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 two halves, each with its own Address ALU. Each Address ALU has four sets of register triplets, and each register triplet is composed of an address register, an offset register, and a modifier register. The two Address ALUs are identical. 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.

#### **DSP56300 Core Functional Blocks**

The offset adder and the reverse-carry adder are 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 respective address register file during one instruction cycle. The contents of the associated modifier register specifies the type of arithmetic to be used in the address register update calculation. The modifier value is decoded in the Address ALU.

#### 1.4.3 PROGRAM CONTROL UNIT (PCU)

The PCU performs instruction prefetch, instruction decoding, hardware DO loop control, and exception processing. The PCU implements a seven-stage pipeline and controls the different processing states of the DSP56300 core. The PCU consists of the following three hardware blocks:

- Program decode controller (PDC)
- Program address generator (PAG)
- Program interrupt controller (PIC)

The PDC decodes the 24-bit instruction loaded into the instruction latch and generates all signals necessary for pipeline control. The PAG contains all the hardware needed for program address generation, system stack, and loop control. The PIC arbitrates among all interrupt requests (internal interrupts, as well as the five external requests:  $\overline{IRQA}$ ,  $\overline{IRQB}$ ,  $\overline{IRQC}$ ,  $\overline{IRQD}$ , and  $\overline{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

The PCU implements its functions using the following registers:

- PC—program counter register
- SR—Status register

#### **DSP56300 Core Functional Blocks**

- LA—loop address register
- LC—loop counter register
- VBA—vector base address register
- SZ—stack size register
- SP—stack pointer
- OMR—operating mode register
- SC—stack counter register

The PCU also includes a hardware system stack (SS).

#### 1.4.4 INTERNAL BUSES

To provide data exchange between blocks, the following buses are implemented:

- Peripheral input/output expansion bus (PIO\_EB) to peripherals
- Program memory expansion bus (PM\_EB) to program memory
- X memory expansion bus (XM\_EB) to X memory
- Y memory expansion bus (YM\_EB) to Y memory
- Global data bus (GDB) between registers in the DMA, AGU, OnCE, PLL, BIU, and PCU as well as the memory-mapped registers in the peripherals
- DMA data bus (DDB) for carrying DMA data between memories and/or peripherals
- DMA address bus (DAB) for carrying DMA addresses to memories and peripherals
- Program Data Bus (PDB) for carrying program data throughout the core
- X memory Data Bus (XDB) for carrying X data throughout the core
- Y memory Data Bus (YDB) for carrying Y data throughout the core
- Program address bus (PAB) for carrying program memory addresses throughout the core
- X memory address bus (XAB) for carrying X memory addresses throughout the core
- Y memory address bus (YAB) for carrying Y memory addresses throughout the core

All internal buses on the DSP56300 family members are 24-bit buses. See **Figure 1-1 DSP56362 Block Diagram on page 1-3**.

### 1.4.5 DIRECT MEMORY ACCESS (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.4.6 PLL-BASED CLOCK OSCILLATOR

The clock generator in the DSP56300 core is composed of two main blocks: the PLL, which performs clock input division, frequency multiplication, and skew elimination; and the clock generator (CLKGEN), which performs low-power division and clock pulse generation. PLL-based clocking:

- Allows change of low-power divide factor (DF) without loss of lock
- Provides output clock with skew elimination
- Provides a wide range of frequency multiplications (1 to 4096), predivider factors (1 to 16), and a power-saving clock divider ( $2^i$ : i = 0 to 7) to reduce clock noise

The PLL allows the processor to operate at a high internal clock frequency using a low frequency clock input. This feature 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.4.7 JTAG TAP AND ONCE MODULE

The DSP56300 core provides a dedicated user-accessible TAP fully compatible with the *IEEE 1149.1 Standard Test Access Port and Boundary Scan Architecture*. Problems associated with testing high-density circuit boards led to developing this standard under the sponsorship of the Test Technology Committee of IEEE and JTAG. The DSP56300 core implementation supports circuit-board test strategies based on this standard.

#### **DSP56300 Core Functional Blocks**

The test logic includes a TAP consisting of 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. More information on the JTAG port is provided in the *DSP56300 Family Manual*.

The OnCE module provides a nonintrusive means of interacting with the DSP56300 core and its peripherals so a user 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. More information on the OnCE module is provided in the *DSP56300 Family Manual*.

#### 1.4.8 ON-CHIP MEMORY

The memory space of the DSP56300 core is partitioned into program memory space, X data memory space, 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.

Table 1-1 describes program RAM, instruction cache, X data RAM, and Y data RAM memory sizes, which are programmable:

| Instruction<br>Cache | Switch Mode | Program RAM Size    | Instruction Cache<br>Size | X Data RAM Size | Y Data RAM Size |
|----------------------|-------------|---------------------|---------------------------|-----------------|-----------------|
| disabled             | disabled    | $3K \times 24$ -bit | 0                         | 5.5K × 24-bit   | 5.5K × 24-bit   |
| enabled              | disabled    | $2K \times 24$ -bit | 1K × 24-bit               | 5.5K × 24-bit   | 5.5K × 24-bit   |
| disabled             | enabled     | 5K × 24-bit         | 0                         | 5.5K × 24-bit   | 3.5K × 24-bit   |
| enabled              | enabled     | 4K × 24-bit         | 1K × 24-bit               | 5.5K × 24-bit   | 3.5K × 24-bit   |

**Table 1-1 On-Chip Memory** 

There is an instruction cache, made using program RAM. The patch mode (which uses instruction cache space) is used to patch program ROM. The memory switch mode is used to increase the size of program RAM as needed (at the expense of Y data RAM).

There are on-chip ROMs for program memory (30K x 24-bit), bootstrap memory (192 words x 24-bit), X data memory (6K x 24-bit), and Y data memory (6K x 24-bit).

More information on the internal memory is provided in Section 3, **Memory Configuration** on page 3-1.

#### 1.4.9 OFF-CHIP MEMORY EXPANSION

Memory can be expanded off-chip as follows:

- Data memory can be expanded to two 16 M × 24-bit word memory spaces in 24-bit address mode (64K in 16-bit address mode).
- Program memory can be expanded to one 16 M × 24-bit word memory space in 24-bit address mode (64K in 16-bit address mode).

Other features of external memory expansion include the following:

- External memory expansion port
- Chip-select logic glueless interface to static random access memory (SRAM)
- On-chip dynamic RAM (DRAM) controller for glueless interface to DRAM
- Eighteen external address lines

#### 1.5 DSP56362 PERIPHERAL OVERVIEW

The DSP56362 is designed to perform a wide variety of fixed-point digital signal processing functions. In addition to the core features previously discussed, the DSP56362 provides the following peripherals:

- 8-bit parallel host interface (HDI08, with DMA support) to external hosts
- As many as 31 user-configurable general purpose input/output (GPIO) signals
- Timer/event counter (TEC) module, containing three independent timers
- Memory switch mode in on-chip memory
- Four external interrupt/mode control lines and one external non-maskable interrupt line
- Enhanced serial audio interface (ESAI) with up to four receivers and up to six transmitters, master or slave, using the I<sup>2</sup>S, Sony, AC97, network, and other programmable protocols

- Serial host interface (SHI) using SPI and I<sup>2</sup>C protocols, with multi-master capability, 10-word receive FIFO, and support for 8-, 16-, and 24-bit words
- Digital audio transmitter (DAX): a serial transmitter capable of supporting the SPDIF, IEC958, CP-340, and AES/EBU digital audio formats

#### 1.5.1 HOST INTERFACE (HDI08)

The host interface (HDI08) is a byte-wide, full-duplex, double-buffered, parallel port that can be connected directly to the data bus of a host processor. The HDI08 supports a variety of buses and provides glueless connection with a number of industry-standard DSPs, microcomputers, microprocessors, and DMA hardware.

The DSP core treats the HDI08 as a memory-mapped peripheral, using either standard polled or interrupt programming techniques. Separate transmit and receive data registers are double-buffered to allow the DSP and host processor to efficiently transfer data at high speed. Memory mapping allows DSP core communication with the HDI08 registers to be accomplished using standard instructions and addressing modes.

Since the host bus may operate asynchronously with the DSP core clock, the HDI08 registers are divided into 2 banks. The "host side" bank is accessible to the external host, and the "DSP side" bank is accessible to the DSP core.

The HDI08 supports the following three classes of interfaces:

- Host processor/MCU connection
- DMA controller
- GPIO port

Host port pins not in use may be configured as GPIO pins. The host interface provides up to 16 GPIO pins. These pins can be programmed to function as either GPIO or host interface.

For more information on the HDI08, see Section 6, Host Interface (HDI08).

## 1.5.2 GENERAL PURPOSE INPUT/OUTPUT (GPIO)

The GPIO port consists of as many as 31 programmable signals, all of which are also used by the peripherals (HDI08, ESAI, DAX, and TEC). There are no dedicated GPIO signals. The signals are configured as GPIO after hardware reset. Register programming techniques for all

GPIO functionality among these interfaces are very similar. For more information on the GPIO, see Section 5, **General Purpose Input/Output**.

#### 1.5.3 TIMER/EVENT COUNTER (TEC)

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

Timer 0 has a single signal that can be used as a GPIO or timer signal. Timer 0 can use internal or external clocking. It can interrupt the DSP after a specified number of events (clocks) or can signal an external device after counting internal events. Timer 0 connects to the external world through one bidirectional signal. Timer 1 and Timer 2 do not have direct connection to the external world. When this signal is configured as an input, the TEC can function as an external event counter or measure the external pulse width/signal period. When the signal is used as an output, the TEC can function either as a timer, a watchdog, or a pulse width modulator (PWM). For more information on the TEC, see **Section 9**, **Timer/ Event Counter**.

#### 1.5.4 ENHANCED SERIAL AUDIO INTERFACE (ESAI)

The ESAI 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 that implement the Motorola SPI serial protocol. The ESAI consists of independent transmitter and receiver sections, each with its own clock generator. It is a superset of the DSP56300 family ESSI peripheral and of the DSP56000 family SAI peripheral. For more information on the ESAI, see Section 8, **Enhanced Serial AUDIO Interface (ESAI)**.

## 1.5.5 SERIAL HOST INTERFACE (SHI)

The SHI is a serial input/output interface providing a path for communication and program/coefficient data transfers between the DSP and an external host processor. The SHI can also communicate with other serial peripheral devices. The SHI can interface directly to either of two well-known and widely used synchronous serial buses: the Motorola serial peripheral interface (SPI) bus and the Philips inter-integrated-circuit control (I<sup>2</sup>C) bus. The SHI supports either the SPI or I<sup>2</sup>C bus protocol, as required, from a slave or a single-master device. To minimize DSP overhead, the SHI supports single-, double-, and triple-byte data transfers. The SHI has a 10-word receive FIFO that permits receiving up to 30 bytes before

generating a receive interrupt, reducing the overhead for data reception. For more information on the SAI, see Section 7, **Serial Host Interface** .

## 1.5.6 DIGITAL AUDIO TRANSMITTER (DAX)

The DAX is a serial audio interface module that outputs digital audio data in the AES/EBU, CP-340 and IEC958 formats. For more information on the DAX, see Section 10, **Digital Audio Transmitter**.

# SECTION 2

# SIGNAL/CONNECTION DESCRIPTIONS

#### 2.1 SIGNAL GROUPINGS

The input and output signals of the DSP56362 are organized into functional groups, which are listed in Table 2-1 and illustrated in Figure 2-1.

The DSP56362 is operated from a 3.3 V supply; however, some of the inputs can tolerate 5 V. A special notice for this feature is added to the signal descriptions of those inputs.

Table 2-1 DSP56362 Functional Signal Groupings

| Functional Group                |                     | Number of Signals | Detailed Description |
|---------------------------------|---------------------|-------------------|----------------------|
| Power (V <sub>CC</sub> )        |                     | 20                | Table 2-2            |
| Ground (GND)                    | 19                  | Table 2-3         |                      |
| Clock and PLL                   | 4                   | Table 2-4         |                      |
| Address bus                     |                     | 18                | Table 2-5            |
| Data bus                        | Port A <sup>1</sup> |                   | Table 2-6            |
| Bus control                     |                     | 11                | Table 2-7            |
| Interrupt and mode control      |                     | 5                 | Table 2-8            |
| HDI08                           | Port B <sup>2</sup> | 16                | Table 2-9            |
| SHI                             |                     | 5                 | Table 2-10           |
| ESAI                            | Port C <sup>3</sup> | 12                | Table 2-11           |
| Digital audio transmitter (DAX) | Port D <sup>4</sup> | 2                 | Table 2-12           |
| Timer                           | 1                   | Table 2-13        |                      |
| JTAG/OnCE Port                  |                     | 6                 | Table 2-14           |

Note:

- 1. Port A is the external memory interface port, including the external address bus, data bus, and control signals.
- 2. Port B signals are the GPIO port signals which are multiplexed with the HDI08 signals.
- 3. Port C signals are the GPIO port signals which are multiplexed with the ESAI signals.
- 4. Port D signals are the GPIO port signals which are multiplexed with the DAX signals.



Notes:

- The HDI08 port supports a nonmultiplexed 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 HDI08 signals can also be configured alternately as GPIO signals (PB0-PB15). Signals with dual designations (e.g., HAS/HAS) have configurable polarity.
- 2. The ESAI signals are multiplexed with the port C GPIO signals (PC0–PC11). The DAX signals are multiplexed with the Port D GPIO signals (PD0–PD1). The timer 0 signal can be configured alternately as the timer GPIO signal (TIO0).

Figure 2-1 Signals Identified by Functional Group

### 2.2 POWER

Table 2-2 Power Inputs

| Power Name            | Description                                                                                                                                                                                                                                                                      |  |  |
|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| V <sub>CCP</sub>      | <b>PLL Power</b> — $V_{CCP}$ is $V_{CC}$ dedicated for PLL use. The voltage should be well-regulated and the input should provided with an extremely low impedance path to the $V_{CC}$ power rail. There is one $V_{CCP}$ input.                                                |  |  |
| V <sub>CCQL</sub> (4) | Quiet Core (Low) Power— $V_{CCQL}$ is an isolated power for the core processing logic. This input must be tied externally to all other chip power inputs. The user must provide adequate external decoupling capacitors. There are four $V_{CCQ}$ inputs.                        |  |  |
| V <sub>CCQH</sub> (3) | Quiet External (High) Power— $V_{CCQH}$ is a quiet power source for I/O lines. This input must be tied externally to all other chip power inputs. The user must provide adequate decoupling capacitors. There are three $V_{CCQH}$ inputs.                                       |  |  |
| V <sub>CCA</sub> (3)  | Address Bus Power— $V_{CCA}$ is an isolated power for sections of the address bus I/O drivers. This input must be tied externally to all other chip power inputs. The user must provide adequate external decoupling capacitors. There are three $V_{CCA}$ inputs.               |  |  |
| V <sub>CCD</sub> (4)  | <b>Data Bus Power</b> — $V_{CCD}$ is an isolated power for sections of the data bus I/O drivers. This input must be tied externally to all other chip power inputs. The user must provide adequate external decoupling capacitors. There are four $V_{CCD}$ inputs.              |  |  |
| V <sub>CCC</sub> (2)  | <b>Bus Control Power</b> — $V_{CCC}$ is an isolated power for the bus control I/O drivers. This input must be tied externally to all other chip power inputs. The user must provide adequate external decoupling capacitors. There are two $V_{CCC}$ inputs.                     |  |  |
| V <sub>CCH</sub>      | <b>Host Power</b> — $V_{CCH}$ is an isolated power for the HDI08 I/O drivers. This input must be tied externally to all other chip power inputs. The user must provide adequate external decoupling capacitors. There is one $V_{CCH}$ input.                                    |  |  |
| V <sub>CCS</sub> (2)  | SHI, ESAI, DAX, and Timer Power— $V_{CCS}$ is an isolated power for the SHI, ESAI, DAX, and Timer I/O drivers. This input must be tied externally to all other chip power inputs. The user must provide adequate external decoupling capacitors. There are two $V_{CCS}$ inputs. |  |  |

#### 2.3 GROUND

Table 2-3 Grounds

| Ground Name          | Description                                                                                                                                                                                                                                                                                                                              |  |  |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| GND <sub>P</sub>     | <b>PLL Ground</b> —GND <sub>P</sub> is a ground dedicated for PLL use. The connection should be provided with an extremely low-impedance path to ground. $V_{CCP}$ should be bypassed to GND <sub>P</sub> by a 0.47 $\mu$ F capacitor located as close as possible to the chip package. There is one GND <sub>P</sub> connection.        |  |  |
| GND <sub>P1</sub>    | PLL Ground 1—GND $_{P1}$ is a ground dedicated for PLL use. The connection should be provided with an extremely low-impedance path to ground. There is one GND $_{P1}$ connection.                                                                                                                                                       |  |  |
| GND <sub>Q</sub> (4) | $\label{eq:Quiet Ground} \begin{split} & \textbf{Quiet Ground} - \textbf{GND}_Q \text{ is 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. There are four \textbf{GND}_Q connections.$ |  |  |
| GND <sub>A (4)</sub> | <b>Address Bus Ground</b> —GND <sub>A</sub> is 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.                                 |  |  |
| GND <sub>D</sub> (4) |                                                                                                                                                                                                                                                                                                                                          |  |  |
| GND <sub>C</sub> (2) | <b>Bus Control Ground</b> — $GND_C$ is 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. There are two $GND_C$ connections.                                                               |  |  |
| GND <sub>H</sub>     | <b>Host Ground</b> —GND $_{\rm H}$ is an isolated ground for the HDI08 I/O drivers. This connection must be tied externally to all other chip ground connections. The user must provide adequate external decoupling capacitors. There is one GND $_{\rm H}$ connection.                                                                 |  |  |
| GND <sub>S</sub> (2) | SHI, ESAI, DAX, and Timer Ground—GND <sub>S</sub> is an isolated ground for the SHI, ESAI, DAX, 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. There are two GND <sub>S</sub> connections.                          |  |  |

## 2.4 CLOCK AND PLL

Table 2-4 Clock and PLL Signals

| Signal<br>Name | Туре  | State during Reset | Signal Description                                                                                                                                                                          |
|----------------|-------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EXTAL          | Input | Input              | <b>External Clock</b> Input—An external clock source must be connected to EXTAL in order to supply the clock to the internal clock generator and PLL. <i>This input cannot tolerate 5V.</i> |

#### **External Memory Expansion Port (Port A)**

Table 2-4 Clock and PLL Signals (Continued)

| Signal<br>Name | Туре   | State during Reset | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                        |  |
|----------------|--------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| CLKOUT         | Output | Chip-driven        | Clock Output—CLKOUT provides an output clock synchronized to the internal core clock phase.                                                                                                                                                                                                                                                                                                                                                               |  |
|                |        |                    | If the PLL is enabled and both the multiplication and division factors equal one, then CLKOUT is also synchronized to EXTAL.                                                                                                                                                                                                                                                                                                                              |  |
|                |        |                    | If the PLL is disabled, the CLKOUT frequency is half the frequency of EXTAL. CLKOUT is not functional at frequencies of 100 MHz and above.                                                                                                                                                                                                                                                                                                                |  |
| 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}$ .                                                                                                                                                                                                                                                                                   |  |
|                |        |                    | If the PLL is not used, PCAP may be tied to $V_{CC}$ , GND, or left floating.                                                                                                                                                                                                                                                                                                                                                                             |  |
| PINIT/NMI      | Input  | Input              | PLL Initial/Non maskable Interrupt—During assertion of RESET, the value of PINIT/NMI is written into the PLL Enable (PEN) bit of the PLL control register, determining whether the PLL is enabled or disabled. After RESET deassertion and during normal instruction processing, the PINIT/NMI Schmitt-trigger input is a negative-edge-triggered non maskable interrupt (NMI) request internally synchronized to CLKOUT.  PINIT/NMI cannot tolerate 5 V. |  |

## 2.5 EXTERNAL MEMORY EXPANSION PORT (PORT A)

When the DSP56362 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/RAS0–AA3/RAS3, RD, WR, BB, CAS.

#### 2.5.1 EXTERNAL ADDRESS BUS

Table 2-5 External Address Bus Signals

| Signal Name | Туре   | State during Reset | Signal Description                                                                                                                                                                                                                                                                                      |
|-------------|--------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| A0–A17      | Output | Tri-stated         | Address Bus—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

Table 2-6 External Data Bus Signals

| Signal Name | Туре         | State during 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. |

#### 2.5.3 EXTERNAL BUS CONTROL

**Table 2-7 External Bus Control Signals** 

| Signal Name           | Туре   | State during Reset | Signal Description                                                                                                                                                                                                                                                                   |
|-----------------------|--------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| AA0–AA3/RA<br>S0–RAS3 | Output | Tri-stated         | Address Attribute or Row Address Strobe—When defined as AA, these signals can be used as chip selects or additional address lines. When defined as RAS, these signals can be used as RAS for DRAM interface. These signals are can be tri-stated outputs with programmable polarity. |
| CAS                   | Output | Tri-stated         | Column Address Strobe—When the DSP is the bus master, $\overline{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.                       |
| 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{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)

Table 2-7 External Bus Control Signals (Continued)

| Signal Name | Туре   | State during Reset     | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------|--------|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TA          | Input  | Ignored Input          | <b>Transfer Acknowledge</b> —If the DSP56362 is the bus master and there is no external bus activity, or the DSP56362 is not the bus master, the $\overline{TA}$ input is ignored. The $\overline{TA}$ input is a data transfer acknowledge (DTACK) function that can extend an external bus cycle indefinitely. Any number of wait states (1, 2 infinity) may be added to the wait states inserted by the BCR by keeping $\overline{TA}$ deasserted. In typical operation, $\overline{TA}$ is deasserted at the start of a bus cycle, is asserted to enable completion of the bus cycle, and is deasserted before the next bus cycle. The current bus cycle completes one clock period after $\overline{TA}$ is asserted synchronous to CLKOUT. The number of wait states is determined by the $\overline{TA}$ input or by the bus control register (BCR), whichever is longer. The BCR can be used to set the minimum number of wait states in external bus cycles.                                                                       |
|             |        |                        | In order to use the $\overline{TA}$ functionality, the BCR must be programmed to at least one wait state. A zero wait state access cannot be extended by $\overline{TA}$ deassertion, otherwise improper operation may result. $\overline{TA}$ can operate synchronously or asynchronously, depending on the setting of the TAS bit in the operating mode register (OMR).                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|             |        |                        | TA functionality may not be used while performing DRAM type accesses, otherwise improper operation may result.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| BR          | Output | Output<br>(deasserted) | Bus Request— $\overline{BR}$ is an active-low output, never tri-stated. $\overline{BR}$ is asserted when the DSP requests bus mastership. $\overline{BR}$ is deasserted when the DSP no longer needs the bus. $\overline{BR}$ may be asserted or deasserted independent of whether the DSP56362 is a bus master or a bus slave. Bus "parking" allows $\overline{BR}$ to be deasserted even though the DSP56362 is the bus master. (See the description of bus "parking" in the $\overline{BB}$ signal description.) The bus request hold (BRH) bit in the BCR allows $\overline{BR}$ to be asserted under software control even though the DSP does not need the bus. $\overline{BR}$ is typically sent to an external bus arbitrator that controls the priority, parking, and tenure of each master on the same external bus. $\overline{BR}$ is only affected by DSP requests for the external bus, never for the internal bus. During hardware reset, $\overline{BR}$ is deasserted and the arbitration is reset to the bus slave state. |
| BG          | Input  | Ignored Input          | Bus Grant— $\overline{BG}$ is an active-low input. $\overline{BG}$ is asserted by an external bus arbitration circuit when the DSP56362 becomes the next bus master. When $\overline{BG}$ is asserted, the DSP56362 must wait until $\overline{BB}$ is deasserted before taking bus mastership. When $\overline{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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|             |        |                        | The default mode of operation of this signal requires a setup and hold time referred to CLKOUT. But CLKOUT operation is not guaranteed from 100MHz and up, so the asynchronous bus arbitration must be used for clock frequencies 100MHz and above. The asynchronous bus arbitration is enabled by setting the ABE bit in the OMR register.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |

#### **Interrupt and Mode Control**

**Table 2-7 External Bus Control Signals (Continued)** 

| Signal Name | Туре             | State during Reset | Signal Description |
|-------------|------------------|--------------------|--------------------|
| BB          | Input/<br>Output | Input              |                    |

#### 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{RESET}$  is deasserted, these inputs are hardware interrupt request lines.

**Table 2-8 Interrupt and Mode Control** 

| Signal Name | Туре  | State during Reset | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-------------|-------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MODA/ĪRQA   | Input | Input              | Mode Select A/External Interrupt Request A—MODA/IRQA is an active-low Schmitt-trigger input, internally synchronized to the DSP clock. MODA/IRQA selects the initial chip operating mode during hardware reset and becomes a level-sensitive or negative-edge-triggered, maskable interrupt request input during normal instruction processing. MODA, MODB, MODC, and MODD select one of 16 initial chip operating modes, latched into the OMR when the RESET signal is deasserted. If IRQA is asserted synchronous to CLKOUT, 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 the MODA/IRQA pin is pulled to GND, the processor will exit the stop state.  This input is 5 V tolerant. |

**Table 2-8 Interrupt and Mode Control (Continued)** 

| Signal Name | Туре  | State during Reset | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------|-------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MODB/ĪRQB   | Input | Input              | Mode Select B/External Interrupt Request B—MODB/IRQB is an active-low Schmitt-trigger input, internally synchronized to the DSP clock. MODB/IRQB selects the initial chip operating mode during hardware reset and becomes a level-sensitive or negative-edge-triggered, maskable interrupt request input during normal instruction processing. MODA, MODB, MODC, and MODD select one of 16 initial chip operating modes, latched into OMR when the RESET signal is deasserted. If IRQB is asserted synchronous to CLKOUT, multiple processors can be re-synchronized using the WAIT instruction and asserting IRQB to exit the wait state.  This input is 5 V tolerant.                                                             |
| MODC/ĪRQC   | Input | Input              | Mode Select C/External Interrupt Request C—MODC/IRQC is an active-low Schmitt-trigger input, internally synchronized to the DSP clock. MODC/IRQC selects the initial chip operating mode during hardware reset and becomes a level-sensitive or negative-edge-triggered, maskable interrupt request input during normal instruction processing. MODA, MODB, MODC, and MODD select one of 16 initial chip operating modes, latched into OMR when the RESET signal is deasserted. If IRQC is asserted synchronous to CLKOUT, multiple processors can be resynchronized using the WAIT instruction and asserting IRQC to exit the wait state.  This input is 5 V tolerant.                                                              |
| MODD/ĪRQD   | Input | Input              | Mode Select D/External Interrupt Request D—MODD/IRQD is an active-low Schmitt-trigger input, internally synchronized to the DSP clock. MODD/IRQD selects the initial chip operating mode during hardware reset and becomes a level-sensitive or negative-edge-triggered, maskable interrupt request input during normal instruction processing. MODA, MODB, MODC, and MODD select one of 16 initial chip operating modes, latched into OMR when the RESET signal is deasserted. If IRQD is asserted synchronous to CLKOUT, multiple processors can be resynchronized using the WAIT instruction and asserting IRQD to exit the wait state.  This input is 5 V tolerant.                                                              |
| RESET       | Input | Input              | Reset—RESET is an active-low, Schmitt-trigger input. When asserted, the chip is placed in the reset state and the internal phase generator is reset. The Schmitt-trigger input allows a slowly rising input (such as a capacitor charging) to reset the chip reliably. If RESET is deasserted synchronous to CLKOUT, exact start-up timing is guaranteed, allowing multiple processors to start synchronously and operate together in "lock-step." When the RESET signal is deasserted, the initial chip operating mode is latched from the MODA, MODB, MODC, and MODD inputs. The RESET signal must be asserted during power up. A stable EXTAL signal must be supplied while RESET is being asserted.  This input is 5 V tolerant. |

#### 2.7 HOST INTERFACE (HDI08)

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

#### 2.7.1 HOST PORT CONFIGURATION

Signal functions associated with the HDI08 vary according to the interface operating mode as determined by the HDI08 port control register (HPCR). See **6.5.6 Host Port Control Register (HPCR)** on page 6-13 for detailed descriptions of this register and (See **Host Interface (HDI08)** on page Section 6-1.) for descriptions of the other HDI08 configuration registers.

Table 2-9 Host Interface

| Signal Name | Туре                           | State during Reset | Signal Description                                                                                                                                                                                            |
|-------------|--------------------------------|--------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| H0–H7       | Input/<br>output               | GPIO disconnected  | <b>Host Data</b> —When the HDI08 is programmed to interface a nonmultiplexed host bus and the HI function is selected, these signals are lines 0–7 of the bidirectional, tri-state data bus.                  |
| HAD0–HAD7   | Input/<br>output               |                    | <b>Host Address</b> —When HDI08 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, output, or disconnected |                    | <b>Port B 0–7</b> —When the HDI08 is configured as GPIO, these signals are individually programmable as input, output, or internally disconnected.                                                            |
|             | disconnected                   |                    | The default state after reset for these signals is GPIO disconnected.                                                                                                                                         |
|             |                                |                    | This input is 5 V tolerant.                                                                                                                                                                                   |

Table 2-9 Host Interface (Continued)

| Signal Name | Туре                              | State during Reset | Signal Description                                                                                                                                                                                                                                                                            |
|-------------|-----------------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HA0         | Input                             | GPIO disconnected  | Host Address Input 0—When the HDI08 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/<br>HAS | Input                             |                    | Host Address Strobe—When HDI08 is programmed to interface a multiplexed host bus and the HI function is selected, this signal is the host address strobe (HAS) Schmitt-trigger input. The polarity of the address strobe is programmable, but is configured active-low (HAS) following reset. |
|             |                                   |                    | Port B 8—When the HDI08 is configured as GPIO, this signal is individually programmed as input, output, or internally disconnected.                                                                                                                                                           |
| PB8         | Input, output, or disconnected    |                    | The default state after reset for this signal is GPIO disconnected.                                                                                                                                                                                                                           |
|             |                                   |                    | This input is 5 V tolerant.                                                                                                                                                                                                                                                                   |
| HA1         | Input                             | GPIO disconnected  | Host Address Input 1—When the HDI08 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                             |                    | Host Address 8—When HDI08 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, output, or                 |                    | Port B 9—When the HDI08 is configured as GPIO, this signal is individually programmed as input, output, or internally disconnected.                                                                                                                                                           |
|             | disconnected                      |                    | The default state after reset for this signal is GPIO disconnected.                                                                                                                                                                                                                           |
|             |                                   |                    | This input is 5 V tolerant.                                                                                                                                                                                                                                                                   |
| HA2         | Input                             | GPIO disconnected  | Host Address Input 2—When the HDI08 is programmed to interface a non-multiplexed host bus and the HI function is selected, this signal is line 2 of the host address (HA2) input bus.                                                                                                         |
| НА9         | Input                             |                    | Host Address 9—When HDI08 is programmed to interface a multiplexed host bus and the HI function is selected, this signal is line 9 of the host address (HA9) input bus.                                                                                                                       |
|             |                                   |                    | Port B 10—When the HDI08 is configured as GPIO, this signal is individually programmed as input, output, or internally disconnected.                                                                                                                                                          |
| PB10        | Input, Output, or<br>Disconnected |                    | The default state after reset for this signal is GPIO disconnected.                                                                                                                                                                                                                           |
|             |                                   |                    | This input is 5 V tolerant.                                                                                                                                                                                                                                                                   |

Table 2-9 Host Interface (Continued)

| polarity of the data strobe is programmable, but is configured as active-low (HRD) after reset.  Port B 11—When the HDI08 is configured as GPIO, this signal is individually programmed as input, output, or internally disconnected.  The default state after reset for this signal is GPIO disconnected. This input is 5 V tolerant.  HDS/ HDS  Input  GPIO disconnected  GPIO disconnected  Host Data Strobe—When HDI08 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.  Host Write Data—When HDI08 is programmed to interface a double-data-strobe host bus and the HI function is selected, this signal is the host write data strobe is programmable, but is configured as active-low (HWR) following reset.  Port B 12—When the HDI08 is configured as GPIO, this signal is individually programmed as input, output, or internally disconnected.  PB12  Input, output, or disconnected  This input is 5 V tolerant.  HCS  Input  GPIO disconnected  Host Chip Select—When HDI08 is programmed to interface a nonnultiplexed host bus and the HI function is selected, this signi is the host chip select (HCS) input. The polarity of the chip select programmable, but is configured active-low (HCS) after reset. | Signal Name | Туре            | State during Reset | Signal Description                                                                                                                                                                                         |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|-----------------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HRD/ HRD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | HRW         | Input           | GPIO disconnected  | single-data-strobe host bus and the HI function is selected, this                                                                                                                                          |
| PB11   Input, Output, or Disconnected   Disconnected   Disconnected   Disconnected   The default state after reset for this signal is GPIO disconnected.   The default state after reset for this signal is GPIO disconnected.   This input is 5 V tolerant.   Host Data Strobe—When HDI08 is programmed to interface a single-data-strobe host bus and the HI function is selected, this signal is the host data strobe is programmable, but is configured as active-low (HDS) following reset.   Host Write Data—When HDI08 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.   Port B 12—When the HDI08 is configured as GPIO, this signal is individually programmed as input, output, or internally disconnected.   PB12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |             | Input           |                    | double-data-strobe host bus and the HI function is selected, this signal is the host read data strobe (HRD) Schmitt-trigger input. The polarity of the data strobe is programmable, but is configured as   |
| The default state after reset for this signal is GPIO disconnected.  This input is 5 V tolerant.  HDS/ HDS  Input  GPIO disconnected  Host Data Strobe—When HDI08 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.  Host Write Data—When HDI08 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 a active-low (HWR) following reset.  Port B 12—When the HDI08 is configured as GPIO, this signal individually programmed as input, output, or internally disconnected.  PB12  Input, output, or disconnected  The default state after reset for this signal is GPIO disconnected. This input is 5 V tolerant.  HCS  Input  GPIO disconnected  GPIO disconnected  Host Chip Select—When HDI08 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 programmable, but is configured active-low (HCS) after reset.                                                                                                         | DD11        | Input Output or |                    |                                                                                                                                                                                                            |
| HDS                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | FBII        |                 |                    | The default state after reset for this signal is GPIO disconnected.                                                                                                                                        |
| HDS   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.    Host Write Data—When HDI08 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 a active-low (HWR) following reset.    Port B 12—When the HDI08 is configured as GPIO, this signal is individually programmed as input, output, or internally disconnected.    PB12                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |             |                 |                    | This input is 5 V tolerant.                                                                                                                                                                                |
| HWR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |             | Input           | GPIO disconnected  | 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        |
| PB12 Input, output, or disconnected  The default state after reset for this signal is GPIO disconnected.  This input is 5 V tolerant.  HCS Input GPIO disconnected  GPIO disconnected  Host Chip Select—When HDI08 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 programmable, but is configured active-low (HCS) after reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |             | Input           |                    | 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 |
| HCS Input GPIO disconnected Host Chip Select—When HDI08 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 programmable, but is configured active-low (HCS) after reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |             |                 |                    |                                                                                                                                                                                                            |
| HCS Input GPIO disconnected Host Chip Select—When HDI08 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 programmable, but is configured active-low (HCS) after reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | PB12        |                 |                    | The default state after reset for this signal is GPIO disconnected.                                                                                                                                        |
| nonmultiplexed host bus and the HI function is selected, this signal is the host chip select (HCS) input. The polarity of the chip select programmable, but is configured active-low (HCS) after reset.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |             | disconnected    |                    | This input is 5 V tolerant.                                                                                                                                                                                |
| Host Address 10—When HDIOS is programmed to interface a                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | HCS         | Input           | GPIO disconnected  | 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                                                               |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | HA10        | Input           |                    | Host Address 10—When HDI08 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.                                 |
| individually programmed as input, output, or internally disconnected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | DD12        | Input output or |                    |                                                                                                                                                                                                            |
| PB13 Input, output, or disconnected The default state after reset for this signal is GPIO disconnected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | LR12        |                 |                    | The default state after reset for this signal is GPIO disconnected.                                                                                                                                        |
| This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |             |                 |                    | This input is 5 V tolerant.                                                                                                                                                                                |

Table 2-9 Host Interface (Continued)

| Signal Name     | Туре                           | State during Reset | Signal Description                                                                                                                                                                                                                                                                                                                                                 |
|-----------------|--------------------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HOREQ/HOR<br>EQ | Output                         | GPIO disconnected  | Host Request—When HDI08 is programmed to interface a single host request host bus and the HI function is selected, this signal is the host request (HOREQ) output. The polarity of the host request is programmable, but is configured as active-low (HOREQ) following reset. The host request may be programmed as a driven or open-drain output.                 |
| HTRQ/<br>HTRQ   | Output                         |                    | Transmit Host Request—When HDI08 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. |
|                 |                                |                    | Port B 14—When the HDI08 is configured as GPIO, this signal is individually programmed as input, output, or internally disconnected.                                                                                                                                                                                                                               |
| PB14            | Input, output, or              |                    | The default state after reset for this signal is GPIO disconnected.                                                                                                                                                                                                                                                                                                |
| PD14            | disconnected                   |                    | This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                        |
| HACK/<br>HACK   | Input                          | GPIO disconnected  | Host Acknowledge—When HDI08 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                         |                    | Receive Host Request—When HDI08 is programmed to interface a double host request host bus and the HI function is selected, this signal is the receive host request (HRRQ) output. The polarity of the host request is programmable, but is configured as active-low (HRRQ) after reset. The host request may be programmed as a driven or open-drain output.       |
|                 |                                |                    | Port B 15—When the HDI08 is configured as GPIO, this signal is individually programmed as input, output, or internally disconnected.                                                                                                                                                                                                                               |
| PB15            | Input, output, or disconnected |                    | The default state after reset for this signal is GPIO disconnected.                                                                                                                                                                                                                                                                                                |
|                 | uisconnecteu                   |                    | This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                        |

#### 2.8 SERIAL HOST INTERFACE

The SHI has five I/O signals that can be configured to allow the SHI to operate in either SPI or  ${\rm I}^2{\rm C}$  mode.

**Table 2-10 Serial Host Interface Signals** 

| Signal Name | Signal Type                | State during<br>Reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|-------------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SCK         | Input or output            | Tri-stated  SPI Serial Clock—The SCK signal is an output when the SPI is configured as a master and a Schmitt-trigger input when the SPI is configured as a slave. When the SPI is configured as a master, the SCF signal is derived from the internal SHI clock generator. When the SPI is configured as a slave, the SCK signal is an input, and the clock signal from the external master synchronizes the data transfer. The SCK signal is ignored by the SPI if it is defined as a slave and the slave select (SS) signal is not asserted. In both the master and slave SPI devices, data is shifted on one edge of the SCK signal and is sampled on the opposite edge where data is stable. Edge polarity is determined by the SPI transfer protocol. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| SCL         | Input or output            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | I <sup>2</sup> C Serial Clock—SCL carries the clock for I <sup>2</sup> C bus transactions in the I <sup>2</sup> C mode. SCL is a Schmitt-trigger input when configured as a slave and an open-drain output when configured as a master. SCL should be connected to V <sub>CC</sub> through a pull-up resistor.  This signal is tri-stated during hardware, software, and individual reset.                                                                                                              |
|             |                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Thus, there is no need for an external pull-up in this state.  This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                                                                                              |
| MISO        | Input or output            | Tri-stated                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | SPI Master-In-Slave-Out—When the SPI is configured as a master, MISO is the master data input line. The MISO signal is used in conjunction with the MOSI signal for transmitting and receiving serial data. This signal is a Schmitt-trigger input when configured for the SPI Master mode, an output when configured for the SPI Slave mode, and tri-stated if configured for the SPI Slave mode when \$\overline{SS}\$ is deasserted. An external pull-up resistor is not required for SPI operation. |
| SDA         | Input or open-drain output |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | $I^2C$ Data and Acknowledge—In $I^2C$ mode, SDA is a Schmitt-trigger input when receiving and an open-drain output when transmitting. SDA should be connected to $V_{CC}$ through a pull-up resistor. SDA carries the data for $I^2C$ transactions. The data in SDA must be stable during the high period of SCL. The data in SDA is only allowed to change when SCL is low. When the bus is free, SDA is high. The SDA line is only                                                                    |
|             |                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | allowed to change during the time SCL is high in the case of start and stop events. A high-to-low transition of the SDA line while SCL is high is a unique situation, and is defined as the start event. A low-to-high transition of SDA while SCL is high is a unique situation defined as the stop event.                                                                                                                                                                                             |
|             |                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | This signal is tri-stated during hardware, software, and individual reset.  Thus, there is no need for an external pull-up in this state.                                                                                                                                                                                                                                                                                                                                                               |
|             |                            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

**Table 2-10 Serial Host Interface Signals (Continued)** 

| Signal Name | Signal Type     | State during<br>Reset | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-------------|-----------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| MOSI        | Input or output | Tri-stated            | SPI Master-Out-Slave-In—When the SPI is configured as a master, MOSI is the master data output line. The MOSI signal is used in conjunction with the MISO signal for transmitting and receiving serial data. MOSI is the slave data input line when the SPI is configured as a slave. This signal is a Schmitt-trigger input when configured for the SPI Slave mode.                                                                                                                                                                 |
| НА0         | Input           |                       | I <sup>2</sup> C Slave Address 0—This signal uses a Schmitt-trigger input when configured for the I <sup>2</sup> C mode. When configured for I <sup>2</sup> C slave mode, the HA0 signal is used to form the slave device address. HA0 is ignored when configured for the I <sup>2</sup> C master mode.                                                                                                                                                                                                                              |
|             |                 |                       | This signal is tri-stated during hardware, software, and individual reset.  Thus, there is no need for an external pull-up in this state.                                                                                                                                                                                                                                                                                                                                                                                            |
|             |                 |                       | This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| SS          | Input           | Tri-stated            | SPI Slave Select—This signal is an active low Schmitt-trigger input when configured for the SPI mode. When configured for the SPI Slave mode, this signal is used to enable the SPI slave for transfer. When configured for the SPI master mode, this signal should be kept deasserted (pulled high). If it is asserted while configured as SPI master, a bus error condition is flagged. If SS is deasserted, the SHI ignores SCK clocks and keeps the MISO output signal in the high-impedance state.                              |
| HA2         | Input           |                       | I <sup>2</sup> C Slave Address 2—This signal uses a Schmitt-trigger input when configured for the I <sup>2</sup> C mode. When configured for the I <sup>2</sup> C Slave mode, the HA2 signal is used to form the slave device address. HA2 is ignored in the I <sup>2</sup> C master mode.                                                                                                                                                                                                                                           |
|             |                 |                       | This signal is tri-stated during hardware, software, and individual reset.  Thus, there is no need for an external pull-up in this state.                                                                                                                                                                                                                                                                                                                                                                                            |
|             |                 |                       | This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| HREQ        | Input or Output | Tri-stated            | Host Request—This signal is an active low Schmitt-trigger input when configured for the master mode but an active low output when configured for the slave mode.                                                                                                                                                                                                                                                                                                                                                                     |
|             |                 |                       | When configured for the slave mode, $\overline{HREQ}$ is asserted to indicate that the SHI is ready for the next data word transfer and deasserted at the first clock pulse of the new data word transfer. When configured for the master mode, $\overline{HREQ}$ is an input. When asserted by the external slave device, it will trigger the start of the data word transfer by the master. After finishing the data word transfer, the master will await the next assertion of $\overline{HREQ}$ to proceed to the next transfer. |
|             |                 |                       | This signal is tri-stated during hardware, software, personal reset, or when the HREQ1–HREQ0 bits in the HCSR are cleared. There is no need for external pull-up in this state.                                                                                                                                                                                                                                                                                                                                                      |
|             |                 |                       | This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

#### 2.9 ENHANCED SERIAL AUDIO INTERFACE

**Table 2-11 Enhanced Serial Audio Interface Signals** 

| Signal<br>Name | Signal Type                    | State during Reset | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|--------------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HCKR           | Input or output                | GPIO disconnected  | High Frequency Clock for Receiver—When programmed as an input, this signal provides a high frequency clock source for the ESAI receiver as an alternate to the DSP core clock. When programmed as an output, this signal can serve as a high-frequency sample clock (e.g., for external digital to analog converters [DACs]) or as an additional system clock.  Port C 2—When the ESAI is configured as GPIO, this signal is individually programmable as input, output, or internally disconnected.                                                            |
| PC2            | Input, output, or disconnected |                    | The default state after reset is GPIO disconnected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                |                                |                    | This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| HCKT           | Input or output                | GPIO disconnected  | High Frequency Clock for Transmitter—When programmed as an input, this signal provides a high frequency clock source for the ESAI transmitter as an alternate to the DSP core clock. When programmed as an output, this signal can serve as a high frequency sample clock (e.g., for external DACs) or as an additional system clock.                                                                                                                                                                                                                           |
| PC5            | Input, output, or disconnected |                    | Port C 5—When the ESAI is configured as GPIO, this signal is individually programmable as input, output, or internally disconnected.                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                |                                |                    | The default state after reset is GPIO disconnected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                |                                |                    | This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| FSR            | Input or output                | GPIO disconnected  | Frame Sync for Receiver—This is the receiver frame sync input/output signal. In the asynchronous mode (SYN=0), the FSR pin operates as the frame sync input or output used by all the enabled receivers. In the synchronous mode (SYN=1), it operates as either the serial flag 1 pin (TEBE=0), or as the transmitter external buffer enable control (TEBE=1, RFSD=1).                                                                                                                                                                                          |
|                |                                |                    | When this pin is configured as serial flag pin, its direction is determined by the RFSD bit in the RCCR register. When configured as the output flag OF1, this pin will reflect the value of the OF1 bit in the SAICR register, and the data in the OF1 bit will show up at the pin synchronized to the frame sync in normal mode or the slot in network mode. When configured as the input flag IF1, the data value at the pin will be stored in the IF1 bit in the SAISR register, synchronized by the frame sync in normal mode or the slot in network mode. |
|                |                                |                    | Port C 1—When the ESAI is configured as GPIO, this signal is individually programmable as input, output, or internally disconnected.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| P.C.I          | Input, output, or              |                    | The default state after reset is GPIO disconnected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| PC1            | disconnected                   |                    | This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

Table 2-11 Enhanced Serial Audio Interface Signals (Continued)

| Signal<br>Name | Signal Type                               | State during Reset | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|-------------------------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FST            | Input or output                           | GPIO disconnected  | Frame Sync for Transmitter—This is the transmitter frame sync input/output signal. For synchronous mode, this signal is the frame sync for both transmitters and receivers. For asynchronous mode, FST is the frame sync for the transmitters only. The direction is determined by the transmitter frame sync direction (TFSD) bit in the ESAI transmit clock control register (TCCR).                                                                                                                                                                          |
| PC4            | Input, output, or disconnected            |                    | Port C 4—When the ESAI is configured as GPIO, this signal is individually programmable as input, output, or internally disconnected.                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                | u se e me e e e e e e e e e e e e e e e e |                    | The default state after reset is GPIO disconnected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                |                                           |                    | This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| SCKR           | Input or output                           | GPIO disconnected  | <b>Receiver Serial Clock</b> —SCKR provides the receiver serial bit clock for the ESAI. The SCKR operates as a clock input or output used by all the enabled receivers in the asynchronous mode (SYN=0), or as serial flag 0 pin in the synchronous mode (SYN=1).                                                                                                                                                                                                                                                                                               |
|                |                                           |                    | When this pin is configured as serial flag pin, its direction is determined by the RCKD bit in the RCCR register. When configured as the output flag OF0, this pin will reflect the value of the OF0 bit in the SAICR register, and the data in the OF0 bit will show up at the pin synchronized to the frame sync in normal mode or the slot in network mode. When configured as the input flag IF0, the data value at the pin will be stored in the IF0 bit in the SAISR register, synchronized by the frame sync in normal mode or the slot in network mode. |
|                |                                           |                    | Port C 0—When the ESAI is configured as GPIO, this signal is individually programmable as input, output, or internally disconnected.                                                                                                                                                                                                                                                                                                                                                                                                                            |
| PC0            | Input, output, or disconnected            |                    | The default state after reset is GPIO disconnected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| FCO            | disconnected                              |                    | This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| SCKT           | Input or output                           | GPIO disconnected  | Transmitter Serial Clock—This signal provides the serial bit rate clock for the ESAI. SCKT is a clock input or output used by all enabled transmitters and receivers in synchronous mode, or by all enabled transmitters in asynchronous mode.                                                                                                                                                                                                                                                                                                                  |
| PC3            | Input, output, or disconnected            |                    | Port C 3—When the ESAI is configured as GPIO, this signal is individually programmable as input, output, or internally disconnected.                                                                                                                                                                                                                                                                                                                                                                                                                            |
|                |                                           |                    | The default state after reset is GPIO disconnected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                |                                           |                    | This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

#### **Enhanced Serial Audio Interface**

**Table 2-11 Enhanced Serial Audio Interface Signals (Continued)** 

| Signal<br>Name | Signal Type                    | State during Reset | Signal Description                                                                                                                         |  |  |
|----------------|--------------------------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| SDO5           | Output                         | GPIO disconnected  | Serial Data Output 5—When programmed as a transmitter, SDO5 is used to transmit data from the TX5 serial transmit shift register.          |  |  |
| SDI0           | Input                          |                    | Serial Data Input 0—When programmed as a receiver, SDI0 is used to receive serial data into the RX0 serial receive shift register.         |  |  |
| PC6            | Input, output, or              |                    | Port C 6—When the ESAI is configured as GPIO, this signal is individually programmable as input, output, or internally disconnected.       |  |  |
| 100            | disconnected                   |                    | The default state after reset is GPIO disconnected.                                                                                        |  |  |
|                |                                |                    | This input is 5 V tolerant.                                                                                                                |  |  |
| SDO4           | Output                         | GPIO disconnected  | <b>Serial Data Output 4</b> —When programmed as a transmitter, SDO4 is used to transmit data from the TX4 serial transmit shift register.  |  |  |
| SDI1           | Input                          |                    | Serial Data Input 1—When programmed as a receiver, SDI1 is used to receive serial data into the RX1 serial receive shift register.         |  |  |
| 205            |                                |                    | Port C 7—When the ESAI is configured as GPIO, this signal is individually programmable as input, output, or internally disconnected.       |  |  |
| PC7            | Input, output, or disconnected |                    | The default state after reset is GPIO disconnected.                                                                                        |  |  |
|                |                                |                    | This input is 5 V tolerant.                                                                                                                |  |  |
| SDO3           | Output                         | GPIO disconnected  | Serial Data Output 3—When programmed as a transmitter, SDO3 is used to transmit data from the TX3 serial transmit shift register.          |  |  |
| SDI2           | Input                          |                    | <b>Serial Data Input 2</b> —When programmed as a receiver, SDI2 is used to receive serial data into the RX2 serial receive shift register. |  |  |
| PC8            | Innut output or                |                    | Port C 8—When the ESAI is configured as GPIO, this signal is individually programmable as input, output, or internally disconnected.       |  |  |
| PC8            | Input, output, or disconnected |                    | The default state after reset is GPIO disconnected.                                                                                        |  |  |
|                |                                |                    | This input is 5 V tolerant.                                                                                                                |  |  |
| SDO2           | Output                         | GPIO disconnected  | Serial Data Output 2—When programmed as a transmitter, SDO2 is used to transmit data from the TX2 serial transmit shift register.          |  |  |
| SDI3           | Input                          |                    | Serial Data Input 3—When programmed as a receiver, SDI3 is used to receive serial data into the RX3 serial receive shift register.         |  |  |
| DC0            | Invest and                     |                    | Port C 9—When the ESAI is configured as GPIO, this signal is individually programmable as input, output, or internally disconnected.       |  |  |
| PC9            | Input, output, or disconnected |                    | The default state after reset is GPIO disconnected.                                                                                        |  |  |
|                |                                |                    | This input is 5 V tolerant.                                                                                                                |  |  |

#### **Enhanced Serial Audio Interface**

Table 2-11 Enhanced Serial Audio Interface Signals (Continued)

| Signal<br>Name | Signal Type                    | State during Reset | Signal Description                                                                                                                            |  |
|----------------|--------------------------------|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--|
| SDO1           | Output                         | GPIO disconnected  | Serial Data Output 1—SDO1 is used to transmit data from the TX1 serial transmit shift register.                                               |  |
| PC10           | Input, output, or disconnected |                    | <b>Port C 10</b> —When the ESAI is configured as GPIO, this signal is individually programmable as input, output, or internally disconnected. |  |
|                |                                |                    | The default state after reset is GPIO disconnected.                                                                                           |  |
|                |                                |                    | This input is 5 V tolerant.                                                                                                                   |  |
| SDO0           | Output                         | GPIO disconnected  | Serial Data Output 0—SDO0 is used to transmit data from the TX0 serial transmit shift register.                                               |  |
| PC11           | Input, output, or disconnected |                    | Port C 11—When the ESAI is configured as GPIO, this signal is individually programmable as input, output, or internally disconnected.         |  |
|                |                                |                    | The default state after reset is GPIO disconnected.                                                                                           |  |
|                |                                |                    | This input is 5 V tolerant.                                                                                                                   |  |

## 2.10 DIGITAL AUDIO INTERFACE (DAX)

Table 2-12 Digital Audio Interface (DAX) Signals

| Signal<br>Name | Туре                                 | State During<br>Reset | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|----------------|--------------------------------------|-----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ACI PD0        | Input, output, or disconnected       | Disconnected          | Audio Clock Input—This is the DAX clock input. When programmed to use an external clock, this input supplies the DAX clock. The external clock frequency must be 256, 384, or 512 times the audio sampling frequency (256 × Fs, 384 × Fs or 512 × Fs, respectively).  Port D 0—When the DAX is configured as GPIO, this signal is individually programmable as input, output, or internally disconnected.  The default state after reset is GPIO disconnected. |
|                |                                      |                       | This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| ADO            | Output                               | Disconnected          | <b>Digital Audio Data Output</b> —This signal is an audio and non-audio output in the form of AES/EBU, CP340 and IEC958 data in a biphase mark format.                                                                                                                                                                                                                                                                                                         |
| PD1            | Input,<br>output, or<br>disconnected |                       | Port D 1—When the DAX is configured as GPIO, this signal is individually programmable as input, output, or internally disconnected.  The default state after reset is GPIO disconnected.                                                                                                                                                                                                                                                                       |
|                |                                      |                       | This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                                                                                                                    |

### **2.11 TIMER**

**Table 2-13 Timer Signal** 

| Signal Name | Туре            | State during Reset | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-------------|-----------------|--------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TIOO        | Input or Output | Input              | Timer 0 Schmitt-Trigger Input/Output—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 input/output through the timer 0 control/status register (TCSR0). If TIO0 is not being used, it is recommended to either define it as GPIO output immediately at the beginning of operation or leave it defined as GPIO input but connected it to Vcc through a pull-up resistor in order to ensure a stable logic level at the input.  This input is 5 V tolerant. |

#### 2.12 JTAG/OnCE INTERFACE

Table 2-14 JTAG/OnCE™ Interface

| Signal<br>Name | Туре             | State<br>during<br>Reset | Signal Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|------------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| TCK            | Input            | Input                    | <b>Test Clock</b> —TCK is a test clock input signal used to synchronize the JTAG test logic. It has an internal pull-up resistor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                |                  |                          | This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| TDI            | Input            | Input                    | <b>Test Data Input</b> —TDI is 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                |                  |                          | This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| TDO            | Output           | Tri-stated               | <b>Test Data Output</b> —TDO is a test data serial output signal used for test instructions and data. TDO can be tri-stated and is actively driven in the shift-IR and shift-DR controller states. TDO changes on the falling edge of TCK.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| TMS            | Input            | Input                    | <b>Test Mode Select</b> —TMS is an input signal used to sequence the test controller's state machine. TMS is sampled on the rising edge of TCK and has an internal pull-up resistor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|                |                  |                          | This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| TRST           | Input            | Input                    | Test Reset—TRST is an active-low Schmitt-trigger input signal used to asynchronously initialize the test controller. TRST has an internal pull-up resistor.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                |                  |                          | The use of TRST is not recommended for new designs. It is recommended to leave TRST disconnected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                |                  |                          | This input is 5 V tolerant.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| DE             | Input/<br>Output | Input                    | Debug Event—DE is an open-drain, bidirectional, active-low signal providing, as an input, a means of entering the debug mode of operation from an external command controller, and, as an output, a means of acknowledging that the chip has entered the debug mode. This signal, when asserted as an input, causes the DSP56300 core to finish the current instruction being executed, 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 the 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. |
|                |                  |                          | 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.                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                |                  |                          | The use of $\overline{DE}$ is not recommended for new designs. It is recommended to leave $\overline{DE}$ disconnected.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|                |                  |                          | This input is <b>not</b> 5 V tolerant.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

JTAG/OnCE Interface

# SECTION 3 MEMORY CONFIGURATION

#### 3.1 MEMORY SPACES

The DSP56362 provides the following three independent memory spaces:

- 1. Program
- 2. X data
- 3. Y data

By default, each memory space uses 18 external address lines for addressing, allowing access to 256K of external memory when using the SRAM operating mode, and 16 M when using the DRAM operating mode. Program and data word length is 24 bits, and internal memory uses 24-bit addressing.

The DSP56362 provides a 16-bit compatibility mode that effectively uses 16-bit addressing for each memory space, allowing access to 64K of memory for each. This mode puts zeros in the most significant byte of the usual (24-bit) program and data word and ignores the zeroed byte, thus effectively using 16-bit program and data words. The 16-bit Compatibility mode allows the DSP56362 to use 56000 object code without change (thus minimizing system cost for applications that use the smaller address space). See the *DSP56300 Family Manual* for more details.

#### 3.1.1 PROGRAM MEMORY SPACE

Program memory space consists of the following:

- Internal program memory, consisting of program RAM, 3K by default, and program ROM, 30K x 24-bit
- Bootstrap program ROM (192 x 24-bit)
- (Optionally) Off-chip memory expansion—as much as 1 M when using SRAM operating mode in 24-bit mode, and 16 M when using DRAM operating mode in 24-bit mode. In 16-bit mode, just 64K may be addressed.

#### **Memory Spaces**

• (Optionally) Instruction cache (1K) formed from program RAM

#### 3.1.1.1 Program RAM

The on-chip program RAM consists of 24-bit wide, high-speed, internal static RAM occupying the lowest 3K (default), 2K, 4K, or 5K locations in the program memory space (depending on the settings of the MS and CE bits). The program RAM default organization is 12 banks of 256 24-bit words (3K). The upper eight banks of Y data RAM can be configured as program RAM by setting the MS bit. When the CE is set, the upper 1K of program RAM is used as an internal instruction cache.

#### CAUTION

The contents of program RAM are unaffected by toggling the MS bit. The location of program data placed in the program RAM/instruction cache area changes after the MS bit is toggled, because the cache always occupies the topmost 1K program RAM addresses. To preserve program integrity, do not set or clear the MS bit when the CE bit is set. See Section 3.5 for the correct procedure.

#### 3.1.1.2 Program ROM

The program ROM contains customer-supplied code. For further information on supplying code for a customized DSP56362 program ROM, please contact your Motorola regional sales office.

The last 128 words (\$FF8780-\$FF87FF) of the program ROM are reserved for Motorola use. This memory area is reserved for use as expansion area for the bootstrap ROM as well as for testing purposes. Customer code should not use this area. The contents of this program ROM segment is defined by the bootstrap ROM source code in Appendix A.1.

#### 3.1.1.3 Bootstrap ROM

The bootstrap code is accessed at addresses \$FF0000 to \$FFF0BF (192 words) in program memory space. The bootstrap ROM is factory-programmed to perform the bootstrap operation following hardware reset. The bootstrap ROM can not be accessed in 16-bit address compatibility mode. See Appendix A for a complete listing of the bootstrap code.

#### 3.1.1.4 Reserved Program Memory Locations

Program memory space at locations \$FF00C0 to \$FF0FFF and \$FF8800 to \$FFFFFF is reserved and should not be accessed.

#### 3.1.2 DATA MEMORY SPACES

Data memory space is divided into X data memory and Y data memory to match the natural partitioning of DSP algorithms. The data memory partitioning allows the DSP56362 to feed two operands to the Data ALU simultaneously, enabling it to perform a multiply-accumulate operation in one clock cycle.

X and Y data memory space are similar in structure and functionality, but there are two differences between them. First, part of Y data RAM may be switched over to program RAM, while X data RAM is fixed in size. Second, the upper 128 words of each space are reserved for different uses. The upper 128 words of X data memory are reserved for internal I/O. It is suggested that the programmer reserve the upper 128 words of Y data memory for external I/O. (For more information, refer to Sections 3.1.2.1 X Data Memory Space on page 3-3 and 3.1.2.3 Y Data Memory Space on page 3-4.)

X and Y data memory space each consist of the following:

- Internal data RAM memory (X data RAM (5.5K), and Y data RAM (default size is 5.5K, but 2K of Y data RAM can be switched to program RAM)
- Internal data ROM Memory (6K in size for each of X and Y data memory)
- (Optionally) Off-chip memory expansion (up to 256K in the 24-bit address mode and 64K in the 16-bit address mode).

The X and Y data ROMs contain customer-supplied code. For further information on supplying code for a customized DSP56362 program ROM, please contact your Motorola regional sales office.

#### 3.1.2.1 X Data Memory Space

The X memory space at locations \$001600 to \$001FFF and from \$FF0000 to \$FFEFFF is reserved and should not be accessed.

#### **Memory Space Configuration**

#### 3.1.2.2 X Data RAM

The on-chip X data RAM consists of 24-bit wide, high-speed, internal static RAM occupying 5.5K locations in the X memory space. The X data RAM organization is 22 banks of 256 24-bit words.

#### 3.1.2.3 Y Data Memory Space

The Y memory space at locations \$001600 to \$001FFF (if MS = 0) or \$000E00 to \$001FFF (if MS = 1) and from \$FF0000 to \$FFEFFF is reserved and should not be accessed.

#### 3.1.2.4 Y Data RAM

The on-chip Y data RAM consists of 24-bit wide, high-speed, internal static RAM occupying 5.5K (default) or 3.5K locations in the Y memory space. The size of the Y data RAM is dependent on the setting of the MS bit (default: MS is cleared). The Y data RAM default organization is 22 banks of 256 24-bit words. Eight banks of RAM may be switched from the Y data RAM to the program RAM by setting the MS bit (leaving 3.5K of Y data RAM).

#### 3.2 MEMORY SPACE CONFIGURATION

Memory space addressing is for 24-bit words by default. The DSP56362 switches to 16-bit address compatibility mode by setting the 16-bit compatibility (SC) bit in the SR.

Table 3-1 Memory Space Configuration Bit Settings for the DSP56362

| Bit Abbreviation | Bit Name             | Bit Location | Cleared = 0 Effect<br>(Default)         | Set = 1 Effect                           |
|------------------|----------------------|--------------|-----------------------------------------|------------------------------------------|
| SC               | 16-bit Compatibility | SR 13        | 16 Mword address<br>space (24-bit word) | 64 K word address<br>space (16-bit word) |

Accessible external memory in the 24-bit mode is limited to a maximum of 1 M when using the SRAM operating mode and to 16 M when using the DRAM operating mode.

Memory maps for the different configurations are shown in **Figure 3-1** through Figure 3-8.

#### 3.3 INTERNAL MEMORY CONFIGURATION

The following subsections discuss the internal memory configuration of the DSP56362. The size and location configurations for RAM and ROM for the DSP56362 are provided in the following sections.

#### 3.3.1 RAM CONFIGURATION BITS

RAM configuration depends on three bits: the cache enable (CE) of the SR, the patch enable (PEN) of the OMR, and the memory select (MS) of the OMR. RAM configuration bit settings are shown in Table 3-2.

Table 3-2 RAM Configuration Bit Settings for the DSP56362

| Bit Abbreviation | Bit Name      | Bit Location | Cleared = 0 Effect<br>(Default)                      | Set = 1 Effect                                                          |
|------------------|---------------|--------------|------------------------------------------------------|-------------------------------------------------------------------------|
| CE               | Cache enable  | SR 19        | Cache disabled                                       | Cache enabled<br>1K                                                     |
| PEN              | Patch enable  | OMR 23       | Patch disabled                                       | If $CE = 1$ , Patch enabled <sup>1</sup> , if $CE = 0$ , Patch disabled |
| MS               | Memory switch | OMR 7        | Program RAM 3K<br>X data RAM 5.5K<br>Y data RAM 5.5K | Program RAM 5K<br>X data RAM 5.5K<br>Y data RAM 3.5K                    |

Note: The Patch can only be enabled if the cache has already been enabled, because the patch is made of part of the cache. The amount of cache memory allocated to the patch is user-definable.

#### 3.3.2 SIZE CONFIGURATIONS

The RAM and ROM size configurations for the DSP56362 are listed in Table 3-3. Memory maps for the different configurations are shown in Figure 3-1 to Figure 3-8.

**Bit Settings** Memory Sizes (24-bit words) X Data Y Data X Data Y Data Prog. Prog. Prog. Boot SCCE MS ROM ROM ROM RAM ROM RAM RAM Cache 0 3K 30K 192 5.5K 5.5K 6K 6K 0 0 1K 30K 192 5.5K 1 2K 5.5K 6K 6K 5K 30K 192 5.5K 3.5K 6K 6K 1 0 1 4K 1K 30K 192 5.5K 3.5K 6K 6K 3K 5.5K 5.5K 6K 6K 0 2K 1K 5.5K 5.5K 6K 6K 0 1 1 5K 5.5K 3.5K 6K 6K 1 4K1K 5.5K 3.5K 6K 6K

**Table 3-3 Internal Memory Size Configurations** 

#### 3.3.3 RAM LOCATIONS

The actual memory locations for program RAM, instruction cache, and Y data RAM in their own memory space are determined by the MS bit. The memory location of X data RAM is independent of the MS bit. The addresses of the different RAMs are listed in Table 3-4.

Table 3-4 RAM Memory Locations

RAM Memory Locations

| 1  | Bit Settings | S  | RAM Memory Locations |                   |               |               |  |
|----|--------------|----|----------------------|-------------------|---------------|---------------|--|
| CE | MS           | SC | Program RAM          | Instruction Cache | X Data RAM    | Y Data RAM    |  |
| 0  | 0            | 0  | \$0000-\$0BFF        | _                 | \$0000-\$15FF | \$0000-\$15FF |  |
| 1  | 0            | 0  | \$0000-\$07FF        | \$0800-\$0BFF     | \$0000-\$15FF | \$0000-\$15FF |  |
| 0  | 1            | 0  | \$0000-\$13FF        | _                 | \$0000-\$15FF | \$0000-\$0DFF |  |
| 1  | 1            | 0  | \$0000-\$0FFF        | \$1000-\$13FF     | \$0000-\$15FF | \$0000-\$0DFF |  |
| 0  | 0            | 1  | \$0000-\$0BFF        | _                 | \$0000-\$15FF | \$0000-\$15FF |  |

**Table 3-4 RAM Memory Locations** 

| Bit Settings |         |   | RAM Memory Locations          |               |               |               |  |
|--------------|---------|---|-------------------------------|---------------|---------------|---------------|--|
| CE           | E MS SC |   | Program RAM Instruction Cache |               | X Data RAM    | Y Data RAM    |  |
| 1            | 0       | 1 | \$0000-\$07FF                 | \$0800-\$0BFF | \$0000-\$15FF | \$0000-\$15FF |  |
| 0            | 1       | 1 | \$0000-\$13FF                 | _             | \$0000-\$15FF | \$0000-\$0DFF |  |
| 1            | 1       | 1 | \$0000-\$0FFF                 | \$1000-\$13FF | \$0000-\$15FF | \$0000-\$0DFF |  |

**Note:** The addresses are given as though in 16-bit addressing mode, but the two leading hexadecimal figures for 24-bit mode will always be zeros.

#### 3.3.4 ROM LOCATIONS

The actual memory locations for ROMs in their own memory space are fixed, but when the SC bit is set (i.e. the chip is in 16-bit mode), the program ROM and the bootstrap ROM are not accessible. ROM addresses are listed in Table 3-5.

**Table 3-5 On-Chip ROM Memory Locations** 

| Bit Settings |    |    | ROM Memory Locations  |                       |                       |                       |               |            |            |
|--------------|----|----|-----------------------|-----------------------|-----------------------|-----------------------|---------------|------------|------------|
| CE           | MS | sc | sc                    | sc                    | sc                    | Program ROM           | Bootstrap ROM | X Data ROM | Y Data ROM |
| 0            | 0  | 0  | \$FF1000-<br>\$FF87FF | \$FF0000-<br>\$FF00BF | \$002000–<br>\$0037FF | \$002000-<br>\$0037FF |               |            |            |
| 1            | 0  | 0  | \$FF1000-<br>\$FF87FF | \$FF0000-<br>\$FF00BF | \$002000–<br>\$0037FF | \$002000–<br>\$0037FF |               |            |            |
| 0            | 1  | 0  | \$FF1000-<br>\$FF87FF | \$FF0000-<br>\$FF00BF | \$002000–<br>\$0037FF | \$002000–<br>\$0037FF |               |            |            |
| 1            | 1  | 0  | \$FF1000-<br>\$FF87FF | \$FF0000-<br>\$FF00BF | \$002000–<br>\$0037FF | \$002000–<br>\$0037FF |               |            |            |
| 0            | 0  | 1  | _                     | _                     | \$2000–\$37FF         | \$2000–\$37FF         |               |            |            |
| 1            | 0  | 1  | _                     | _                     | \$2000–\$37FF         | \$2000–\$37FF         |               |            |            |
| 0            | 1  | 1  | _                     | _                     | \$2000-\$37FF         | \$2000-\$37FF         |               |            |            |
| 1            | 1  | 1  | _                     | _                     | \$2000–\$37FF         | \$2000-\$37FF         |               |            |            |

#### 3.4 DYNAMIC MEMORY CONFIGURATION SWITCHING

The internal memory configuration is altered by remapping RAM modules from Y data memory into program memory space and vice-versa. The contents of the switched RAM modules are preserved.

The memory can be dynamically switched from one configuration to another by changing the MS bit in OMR. The address ranges that are directly affected by the switch operation are specified in Table 3-4. The memory switch can be accomplished provided that the affected address ranges are not being accessed during the instruction cycle in which the switch operation takes place. For trouble-free dynamic switching, no accesses (including instruction fetches) to or from the affected address ranges in program and data memories are allowed during the switch cycle.

**Note:** The switch cycle actually occurs three instruction cycles after the instruction that modifies the MS bit.

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. In this case a switch can be accomplished by just changing the MS bit in OMR 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 bit. Special care should be taken in relation to the interrupt vector routines since an interrupt could cause the DSP to fetch instructions out of sequence and might violate the switch condition.

Special attention should be given when running 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 bit change while the DSP is in debug mode. As a result, subsequent instructions might be fetched according to the new memory configuration (after the switch), and thus might execute improperly.

Note: The MS bit may not be changed when CE is set. The instruction cache occupies the top 1K of what would otherwise be program RAM and to switch memory into or out of program RAM when the cache is enabled will cause conflicts. To change the MS bit when CE is set:

- 1. Clear CE.
- 2. Change MS.
- 3. Set CE.

#### 3.5 PATCH MODE

Patch mode allows for changes or additions to be made to the ROM code. In patch mode, one or more sectors of the cache memory is selected for the patch, and corrected or supplementary code is read into the patch, then the patch is locked so that it cannot be overwritten, and the code in it is executed instead of the ROM code.

Using patch mode presupposes that the cache is enable. The number of cache sectors used for a patch is user-selected. Each cache section is 128 words, and there are eight sections in the cache. The cache sectors not used as patch function as usual. Since the amount of memory used by the patch mode, as well as which sectors are used, is defined by the user, patch memory is not shown in the memory maps (Figure 3-1 and Figure 3-8).

#### 3.5.1 INITIALIZING PATCH MODE

To initialize patch mode, execute these steps from external memory or by download via host interface:

- 1. Enable the cache (set CE).
- 2. Enable patch mode (set PEN).
- 3. Initialize TAGs to different values by unlocking eight different external sectors.
- 4. Lock the patch sectors.
- 5. Move new code to the locked sectors, to the addresses that should be replaced.
- 6. Start the program ROM program to be patched.

#### 3.5.2 PATCH INITIALIZATION EXAMPLE

```
page
                   132,55,0,0,0
              nolist
              INCLUDE "ioequ.asm"
              INCLUDE "intequ.asm"
              list
                     $100
START
              equ
                                          ; main program starting
address
PATCH OFSET
                     128
                                          ; patch offset
              equ
```

#### **Patch Mode**

```
M_PAE
                                23
                                                                 ; Patch Enable
                     equ
M_PROMS
                                $ff87ec
                                                      ; ROM area Start
                     equ
M_PROME
                                $ff87ff
                                                      ; ROM area End
                     equ
                                P:START
                     org
                                #M_PROMS,r0
                     move
                     bset
                                #M_CE,sr
                                                                 ; CacheEnable = 1
                                                                 ; PatchEnable = 1
                     bset
                                #M_PAE,omr
                                #$800000,r1
                                                                 ; any external address
                     move
                                #128,n1
                                                                 ; 128 for 1K ICACHE,
                     move
sector size
                                #(M_PROMS+PATCH_OFSET),r2
                     move
                                8
                     dup
                     punlock
                                 (r1)+n1
                                                                 ; initialize TAGs to
different
                                                                 ; values
                     endm
                                                                 ; lock patch's sector
                     plock
                                 (r2)
                                                                  ; (start/mid/end)
                     move
                                #PATCH_DATA_START,r1
;
; replace ROM code by PATCH
                                #(PATCH_DATA_END-PATCH_DATA_START+1),PATCH_LOOP
                     do
                     movem
                                p:(r1)+,x0
                                x0,p:(r2)+
                     movem
                                                                 ; Do-loop restriction
                     nop
PATCH_LOOP
                                 #M_PROMS
                                                                 ; start ROM code
                      jsr
execution
ENDTEST
                      jmp
                                ENDTEST
                     nop
                     nop
                     nop
                     nop
; patch data
PATCH_DATA_START
                                #5,m0
                     move
                                #6,m1
                     move
                     move
                                #7,m2
```

| PATCH_DATA_END                         |
|----------------------------------------|
| ;************************************* |

## 3.6 MEMORY MAPS

|          | PROGRAM              |                      | X DATA                      |                          | Y DATA                      |
|----------|----------------------|----------------------|-----------------------------|--------------------------|-----------------------------|
| \$FFFFF  | INTERNAL<br>RESERVED | \$FFFFFF<br>\$FFFF80 | INTERNAL I/O<br>(128 words) | \$FFFFFF<br>\$FFFF80     | EXTERNAL I/O<br>(128 words) |
| \$FF8800 | 30K INTERNAL         | \$FFF000             | EXTERNAL                    | \$FFF000                 | EXTERNAL                    |
| \$FF1000 | ROM                  |                      | INTERNAL<br>RESERVED        |                          | INTERNAL<br>RESERVED        |
| \$FF00C0 | INTERNAL<br>RESERVED | \$FF0000             |                             | \$FF0000                 |                             |
| \$FF0000 | BOOT ROM             |                      | EXTERNAL                    |                          | EXTERNAL                    |
|          |                      | \$003800             | 6K INTERNAL                 | \$003800 .               | 6K INTERNAL                 |
|          | EVTERNAL             | <b>\$000000</b>      | ROM                         | <b>\$00000</b>           | ROM                         |
|          | EXTERNAL             | \$002000<br>\$001600 | INT. RESERVED               | \$002000 -<br>\$001600 . | INT. RESERVED               |
| \$000C00 | 3K INTERNAL          |                      | 5.5K INTERNAL               |                          | 5.5K INTERNAL               |
| \$000000 | RAM                  | \$000000             | RAM                         | \$000000                 | RAM                         |

Figure 3-1 Memory Maps CE=0, MS=0, SC=0

### **Memory Maps**

|                      | PROGRAM              |                          | X DATA               |                      | Y DATA                      |
|----------------------|----------------------|--------------------------|----------------------|----------------------|-----------------------------|
| \$FFFFFF<br>\$FF8800 | INTERNAL<br>RESERVED | \$FFFFFF<br>\$FFFF80     | (128 words)          | \$FFFFFF<br>\$FFFF80 | EXTERNAL I/O<br>(128 words) |
| 4                    | 30K INTERNAL         | \$FFF000                 | EXTERNAL             | \$FFF000             | EXTERNAL                    |
| \$FF1000             | ROM                  |                          | INTERNAL<br>RESERVED |                      | INTERNAL<br>RESERVED        |
| \$FF00C0             | INTERNAL<br>RESERVED | \$FF0000                 |                      | \$FF0000             |                             |
| \$FF0000             | BOOT ROM             |                          | EXTERNAL             |                      | EXTERNAL                    |
|                      |                      | \$003800                 |                      | \$003800             |                             |
|                      |                      |                          | 6K INTERNAL          |                      | 6K INTERNAL                 |
|                      |                      |                          | ROM                  |                      | ROM                         |
| \$001400             | EXTERNAL             | \$002000 -<br>\$001600 . | INT. RESERVED        | \$002000             | INT. RESERVED               |
| ψ001400              |                      | ψ001000 .                |                      | \$000E00 .           |                             |
| \$000000             | 5K INTERNAL<br>RAM   | \$000000                 | 5.5K INTERNAL<br>RAM | \$000000             | 3.5K INTERNAL<br>RAM        |

Figure 3-2 Memory Maps CE=0, MS=1, SC=0

|                      | PROGRAM              |                      | X DATA                      |                          | Y DATA                      |
|----------------------|----------------------|----------------------|-----------------------------|--------------------------|-----------------------------|
| \$FFFFFF             | INTERNAL<br>RESERVED | \$FFFFFF<br>\$FFFF80 | INTERNAL I/O<br>(128 words) | \$FFFFFF<br>\$FFFF80     | EXTERNAL I/O<br>(128 words) |
| \$FF8800 <u></u>     | 30K INTERNAL         | \$FFF000             | EXTERNAL                    | \$FFF000                 | EXTERNAL                    |
| \$FF1000             | ROM                  |                      | INTERNAL<br>RESERVED        |                          | INTERNAL<br>RESERVED        |
| \$FF00C0             | INTERNAL<br>RESERVED | \$FF0000             |                             | \$FF0000                 |                             |
| \$FF0000             | BOOT ROM             |                      | EXTERNAL                    |                          | EXTERNAL                    |
|                      |                      | \$003800             |                             | \$003800                 |                             |
|                      |                      |                      | 6K INTERNAL                 |                          | 6K INTERNAL                 |
|                      |                      |                      | ROM                         |                          | ROM                         |
|                      | EXTERNAL             | \$002000<br>\$001600 | INT. RESERVED               | \$002000 -<br>\$001600 . | INT. RESERVED               |
| \$000C00<br>\$000800 | 1K I-CACHE           |                      | 5.5K INTERNAL               |                          | 5.5K INTERNAL               |
| \$000000             | 2K INT. RAM          | \$000000             | RAM                         | \$000000                 | RAM                         |
|                      |                      |                      |                             |                          |                             |

Figure 3-3 Memory Maps for CE=1, MS=0, SC=0



Figure 3-4 Memory Maps for CE=1, MS=1, SC=0



Figure 3-5 Memory Maps for CE=0, MS=0, SC=1

#### **Memory Maps**



Figure 3-6 Memory Maps for CE=0, MS=1, SC=1



Figure 3-7 Memory Maps for CE=1, MS=0, SC=1



Figure 3-8 Memory Maps for CE=1, MS=1, SC=1

#### 3.7 EXTERNAL MEMORY SUPPORT

The DSP56362 supports SRAM and DRAM memory types, as indicated in the *DSP56300* 24-Bit Digital Signal Processor Family Manual, Motorola publication DSP56300FM/AD. It does not support the SSRAM memory type. Also, care should be taken when accessing external memory to ensure that the necessary address lines are available. For example, when using glueless SRAM interfacing, it is possible to address directly 2<sup>20</sup> memory locations (1 M) when using the 18 address lines and the four programmable address attribute lines.

#### 3.8 INTERNAL I/O MEMORY MAP

The DSP56362 on-chip peripheral modules have their register files programmed to the addresses in the internal X-I/O memory range (the top 128 locations of the X data memory space) as shown in Appendix D.

Internal I/O Memory Map

## SECTION 4 CORE CONFIGURATION

#### 4.1 INTRODUCTION

This chapter contains DSP56300 core configuration information details specific to the DSP56362. These include the following:

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

For more information on specific registers or modules in the DSP56300 core, refer to the DSP56300 Family Manual (DSP56300FM/AD).

## 4.2 OPERATING MODE REGISTER (OMR)

See DSP56300 24-Bit Digital Signal Processor Family Manual, Motorola publication DSP56300FM/AD for a description of the OMR. The OMR is shown in Figure 4-1.

SCS **EOM** COM 22 16 14 10 9 8 7 6 5 2 23 21 20 19 18 17 15 13 12 11 4 3 1 0 EUN XYS APD BRT MS SD PEN SEN WRP EOV ATE ABE TAS BE CDP1:0 EBD MD MC MB MA PEN - Patch Enable ATE - Address Tracing Enable MS - Memory Switch Mode APD - Address Priority Disable SD - Stop Delay -reserved - reserved -reserved ABE - Asyn. Bus Arbitration Enable SEN -Stack Extension Enable **BRT** - Bus Release Timing **EBD** - External Bus Disable **WRP** -Extended Stack Wrap Flag TAS - TA Synchronize Select MD- Operating Mode D -Extended Stack Overflow Flag EOV BE - Burst Mode Enable - Operating Mode C MC **EUN** CDP1 MB -Extended Stack Underflow - Core-DMA Priority 1 - Operating Mode B Flag XYS - Operating Mode A -Stack Extension Space Select CDP0 - Core-DMA Priority 0 MA Reserved bit. Read as zero, should be written with zero for future compatibility

Figure 4-1 Operating Mode Register (OMR)

## 4.2.1 ASYNCHRONOUS BUS ARBITRATION ENABLE (ABE) - BIT 13

The asynchronous bus arbitration mode is activated by setting the ABE bit in the OMR register. Hardware reset clears the ABE bit.

When asynchronous bus arbitration is active, the  $\overline{BB}$  and  $\overline{BG}$  inputs are not constrained by setup and hold time requirements relative to CLKOUT. Instead it is required that there is no overlap period between the deassertation of the  $\overline{BG}$  input to the DSP that is releasing the bus and the assertion of the  $\overline{BG}$  input to the DSP that will receive the bus.

For DSP clock frequencies of 100MHz and above, the ABE bit must be set in order to ensure correct operation of the  $\overline{BG}$  and  $\overline{BB}$  signals.

#### 4.3 OPERATING MODES

The DSP56362 begins operations by leaving Reset and going into one of eleven operating modes. As the DSP56362 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 determines what bootstrap program option the chip uses to start up.

The MA–MD bits of the OMR can also be set directly by software. Jumping directly to the bootstrap program entry point (\$FF0000) after setting the OMR bits causes the DSP56362 to execute the specified bootstrap program option (except modes 0 and 8).

**Table 4-1** shows the DSP56362 bootstrap operation modes, the corresponding settings of the external operational mode signal lines (the mode bits MA–MD in the OMR), and the reset vector address to which the DSP56362 jumps once it leaves the Reset state.

Table 4-1 DSP56362 Operating Modes

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description                                                                                  |
|------|------|------|------|------|-----------------|----------------------------------------------------------------------------------------------|
| 0    | 0    | 0    | 0    | 0    | \$C00000        | Expanded mode (OnCE disabled)                                                                |
| 1    | 0    | 0    | 0    | 1    | \$FF0000        | Bootstrap from byte-wide memory                                                              |
| 2    | 0    | 0    | 1    | 0    | \$FF0000        | Jump to PROM starting address                                                                |
| 3    | 0    | 0    | 1    | 1    | \$FF0000        | Reserved                                                                                     |
| 4    | 0    | 1    | 0    | 0    | \$FF0000        | Reserved                                                                                     |
| 5    | 0    | 1    | 0    | 1    | \$FF0000        | Bootstrap from SHI (slave SPI mode)                                                          |
| 6    | 0    | 1    | 1    | 0    | \$FF0000        | Bootstrap from SHI (slave I <sup>2</sup> C mode, clock freeze enabled, 100ns filter enabled) |
| 7    | 0    | 1    | 1    | 1    | \$FF0000        | Bootstrap from SHI (slave I <sup>2</sup> C mode)                                             |
| 8    | 1    | 0    | 0    | 0    | \$008000        | Expanded mode (OnCE disabled)                                                                |
| 9    | 1    | 0    | 0    | 1    | \$FF0000        | Reserved for Burn-in testing                                                                 |
| A    | 1    | 0    | 1    | 0    | \$FF0000        | Reserved                                                                                     |
| В    | 1    | 0    | 1    | 1    | \$FF0000        | Reserved                                                                                     |

#### **Bootstrap Program**

Table 4-1 DSP56362 Operating Modes

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description                                  |
|------|------|------|------|------|-----------------|----------------------------------------------|
| С    | 1    | 1    | 0    | 0    | \$FF0000        | HDI08 Bootstrap in ISA<br>Mode               |
| D    | 1    | 1    | 0    | 1    | \$FF0000        | HDI08 Bootstrap in HC11 non-multiplexed mode |
| Е    | 1    | 1    | 1    | 0    | \$FF0000        | HDI08 Bootstrap in 8051 multiplexed bus mode |
| F    | 1    | 1    | 1    | 1    | \$FF0000        | HDI08 Bootstrap in 68302<br>bus mode         |

# 4.4 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 SHI, or the host port. The bootstrap program described here, and listed in Appendix A is a default, which may be modified or replaced by the user.

On exiting the Reset state, the DSP56362 does the following:

- 1. Samples the MODA, MODB, MODC and MODD signal lines
- 2. Loads their values into bits MA, MB, MC, and MD in the OMR

The contents of the MA, MB, MC, and MD bits determine which bootstrap mode the DSP56362 enters:

- 1. If MA, MB, MC, and MD are all cleared (bootstrap mode 0), the program bypasses the bootstrap ROM and the DSP56362 starts loading instructions from external program memory location \$C00000.
- 2. If MA, MB, and MC are cleared and MD is set (bootstrap mode 8), the program bypasses the bootstrap ROM and the DSP56362 starts loading in instruction values from external program memory location \$008000.
- 3. Otherwise (bootstrap modes 1, 2, 5, 7, C, D, E, F), the DSP56362 jumps to the bootstrap program entry point at \$FF0000.

If the bootstrap program is loading via the Host interface (HDI08), setting the HF0 bit in the HSR causes the DSP56362 to stop loading and begin execution of the loaded program at the specified start address.

See Table 4-1 for a tabular description of the mode bit settings for the operating modes.

The bootstrap program options (except modes 0 and 8) can be invoked at any time by setting the appropriate MA, MB, MC, and MD bits in the OMR and jumping to the bootstrap program entry point, \$FF0000. The mode selection bits in the OMR can be set directly by software.

In bootstrap modes 1, 5, 7, C, D, E, and F, the bootstrap program expects the following data sequence when downloading the user program through an external port:

- 1. Three bytes defining the number of (24-bit) program words to be loaded
- 2. Three bytes defining the (24-bit) start address to which the user program loads in the DSP56362 program memory
- 3. The user program (three bytes for each 24-bit program word). The program words will be stored in contiguous PRAM memory locations starting at the specified starting address.

For bootstrap mode 1, the three bytes for each data sequence must be loaded with the least significant byte first.

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

# 4.4.1 MODE 0: EXPANDED MODE

**Table 4-2 Expanded Mode** 

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description   |
|------|------|------|------|------|-----------------|---------------|
| 0    | 0    | 0    | 0    | 0    | \$C00000        | Expanded mode |

The bootstrap ROM is bypassed and the DSP56362 starts fetching instructions beginning at address \$C00000. Memory accesses are performed using SRAM memory access type with 31 wait states and no address attributes selected. Address \$C00000 is reflected as address \$00000 on Port A pins A0–A17.

The DSP starts fetching instructions beginning at address \$C00000. Memory accesses are performed using SRAM memory access type with 31 wait states and no address attributes

#### **Bootstrap Program**

selected. Address \$C00000 is reflected as address \$00000 on Port A pins A0-A17. Note that the OnCE interface is disabled during HW reset, and will remain disabled until explicitly enabled by writing to the OnCE GDB Register (OGDB) at the internal I/O address X:\$FFFFFC.

# 4.4.2 MODE 1: BOOTSTRAP FROM BYTE-WIDE EXTERNAL MEMORY

**Table 4-3 Bootstrap From External Memory** 

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description                     |
|------|------|------|------|------|-----------------|---------------------------------|
| 1    | 0    | 0    | 0    | 1    | \$FF0000        | Bootstrap from byte-wide memory |

The bootstrap program loads instructions through Port A from external byte-wide memory, connected to the least significant byte of the data bus (bits 7-0), and starting at address P:\$D00000. The 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 will be stored in contiguous PRAM memory locations starting at the specified starting address. After reading the program words, program execution starts from the same address where loading started. The SRAM memory access type is selected by the values in Address Attribute Register 1 (AAR1), with 31 wait states for each memory access. Address \$D00000 is reflected as address \$00000 on Port A pins A0-A17.

# 4.4.3 MODE 2: BOOTSTRAP JUMP TO PROM STARTING ADDRESS

Table 4-4 Jump To PROM Starting Address

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description                   |
|------|------|------|------|------|-----------------|-------------------------------|
| 2    | 0    | 0    | 1    | 0    | \$FF0000        | Jump to PROM starting address |

The DSP starts fetching instructions from the starting address of the on-chip Program ROM.

# 4.4.4 MODE 3: RESERVED

Table 4-5 Mode 3 (Reserved)

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description |
|------|------|------|------|------|-----------------|-------------|
| 3    | 0    | 0    | 1    | 1    | _               | Reserved    |

This mode is reserved for future use.

#### 4.4.5 MODE 4: RESERVED

Table 4-6 Mode 4 (Reserved)

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description |
|------|------|------|------|------|-----------------|-------------|
| 4    | 0    | 1    | 0    | 0    | _               | Reserved    |

This mode is reserved for future use.

# 4.4.6 MODE 5: BOOTSTRAP FROM SHI (SLAVE SPI MODE)

Table 4-7 Bootstrap From SHI (Slave SPI)

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description                            |
|------|------|------|------|------|-----------------|----------------------------------------|
| 5    | 0    | 1    | 0    | 1    | _               | Bootstrap from SHI<br>(slave SPI mode) |

In this mode, the internal PRAM is loaded from the Serial Host Interface (SHI). The SHI operates in the SPI slave mode, with 24-bit word width. The 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 will be stored in contiguous PRAM memory locations starting at the specified starting address. After reading the program words, program execution starts from the same address where loading started.

# 4.4.7 MODE 6: BOOTSTRAP FROM SHI (SLAVE I<sup>2</sup>C MODE)

Table 4-8 Mode 6 Bootstrap From SHI (Slave I<sup>2</sup>C)

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description                                                                                   |
|------|------|------|------|------|-----------------|-----------------------------------------------------------------------------------------------|
| 6    | 0    | 1    | 1    | 0    | \$FF0000        | Bootstrap from SHI (slave I <sup>2</sup> C mode, clock freeze enabled, 100 ns filter enabled) |

Same as mode 5, except the SHI interface operates in the I<sup>2</sup>C slave mode, with clock freeze enabled (HCKFR=1) and with the 100ns spike filter enabled.

# 4.4.8 MODE 7: BOOTSTRAP FROM SHI (SLAVE I<sup>2</sup>C MODE)

Table 4-9 Mode 7 Bootstrap From SHI (Slave I<sup>2</sup>C)

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description                                      |
|------|------|------|------|------|-----------------|--------------------------------------------------|
| 7    | 0    | 1    | 1    | 1    | \$FF0000        | Bootstrap from SHI (slave I <sup>2</sup> C mode) |

Same as mode 5, except the SHI interface operates in the I<sup>2</sup>C slave mode, without clock freeze and no filter.

#### 4.4.9 MODE 8: EXPANDED MODE

Table 4-10 Mode 8 (Expanded Mode)

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description                   |
|------|------|------|------|------|-----------------|-------------------------------|
| 8    | 1    | 0    | 0    | 0    | \$008000        | Expanded mode (OnCE disabled) |

The DSP starts fetching instructions beginning at address \$008000. Memory accesses are performed using SRAM memory access type with 31 wait states and no address attributes selected. Note that the OnCE interface is disabled during HW reset, and will remain disabled until explicitly enabled by writing to the OnCE GDB Register (OGDB) at the internal I/O address X:\$FFFFFC.

# **4.4.10 MODE 9: RESERVED**

Table 4-11 Mode 9 (Reserved)

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description |
|------|------|------|------|------|-----------------|-------------|
| 9    | 1    | 0    | 0    | 1    | _               | Reserved    |

This mode is reserved. It is used in burn-in testing.

# 4.4.11 MODE A: RESERVED

Table 4-12 Mode A (Reserved)

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description |
|------|------|------|------|------|-----------------|-------------|
| A    | 1    | 0    | 1    | 0    | _               | Reserved    |

This mode is reserved for future use.

# 4.4.12 MODE B: RESERVED

Table 4-13 Mode B (Reserved)

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description |
|------|------|------|------|------|-----------------|-------------|
| В    | 1    | 0    | 1    | 1    | _               | Reserved    |

This mode is reserved for future use.

# 4.4.13 MODE C: BOOTSTRAP THROUGH HDI08 IN ISA MODE

Table 4-14 Mode C Bootstrap Through HDI08 (ISA Mode)

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description                 |
|------|------|------|------|------|-----------------|-----------------------------|
| С    | 1    | 1    | 0    | 0    | \$FF0000        | HDI08 Bootstrap in ISA Mode |

Instructions are loaded through the HDI08, which is configured to interface with an ISA bus. 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 will be stored in contiguous PRAM memory locations starting at the specified starting address. After reading the program words, program execution starts from the same address where loading started. The Host Interface bootstrap load program may be stopped by setting the Host Flag 0 (HF0). This will start execution of the loaded program from the specified starting address.

# 4.4.14 MODE D: BOOTSTRAP THROUGH HDI08 IN HC11 NON-MULTIPLEXED MODE

**Table 4-15 Bootstrap Through HDI08 (Non-multiplexed Mode)** 

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description                                     |
|------|------|------|------|------|-----------------|-------------------------------------------------|
| D    | 1    | 1    | 0    | 1    | \$FF0000        | HDI08 Bootstrap in HC11<br>non-multiplexed mode |

As in Mode C, but HDI08 is set for interfacing to Motorola HC11 microcontroller in non-multiplexed mode.

# 4.4.15 MODE E: BOOTSTRAP THROUGH HDI08 IN 8051 MULTIPLEXED BUS MODE

Table 4-16 Bootstrap Through HDI08 (8051 Multiplexed Bus Mode)

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description                             |
|------|------|------|------|------|-----------------|-----------------------------------------|
| Е    | 1    | 1    | 1    | 0    | \$FF0000        | HDI08 Bootstrap in 8051 multiplexed bus |

The bootstrap program sets the host interface to interface with the Intel 8051 multiplexed bus.

If the host processor sets host flag 0 (HF0) in the HDI08 interface control register (HCR) while writing the initialization program, the bootstrap program stops loading instructions, jumps to the starting address specified, and executes the loaded program.

# 4.4.16 MODE F: BOOTSTRAP THROUGH HDI08 IN 68302/68360 BUS MODE

Table 4-17 Bootstrap Through HDI08 (68302/68360 Bus Mode)

| Mode | MODD | MODC | MODB | MODA | Reset<br>Vector | Description                  |
|------|------|------|------|------|-----------------|------------------------------|
| F    | 1    | 1    | 1    | 1    | \$FF0000        | HDI08 Bootstrap in 68302 bus |

The bootstrap program sets the host interface to interface with the Motorola 68302 or 68360 bus.

If the host processor sets host flag 0 (HF0) in the HCR while writing the initialization program, the bootstrap program stops loading instructions, jumps to the starting address specified, and executes the loaded program.

# 4.5 INTERRUPT PRIORITY REGISTERS

There are two interrupt priority registers in the DSP56362: IPR-C is dedicated to DSP56300 core interrupt sources, and IPR-P is dedicated to DSP56362 peripheral interrupt sources. The interrupt priority registers are shown in Figure 4-2 and Figure 4-3. The interrupt priority level

# **Interrupt Priority Registers**

bits are defined in Table 4-18. The interrupt vectors are shown in **Section D.3**, and the interrupt priorities are shown in **Section D.4**.

| IPL bits |      | Interrupts | Interrupt<br>Priority |  |
|----------|------|------------|-----------------------|--|
| xxL1     | xxL0 | Enabled    | Level                 |  |
| 0        | 0    | No         | _                     |  |
| 0        | 1    | Yes        | 0                     |  |
| 1        | 0    | Yes        | 1                     |  |
| 1        | 1    | Yes        | 2                     |  |

**Table 4-18 Interrupt Priority Level Bits** 



Figure 4-2 Interrupt Priority Register C



Figure 4-3 Interrupt Priority Register P

# 4.6 DMA REQUEST SOURCES

The DMA request source bits (DRS[4:0] bits in the DMA control/status registers) encode the source of DMA requests used to trigger the DMA transfers. The DMA request sources may be the internal peripherals or external devices requesting service through the IRQA, IRQB, IRQC and IRQD pins. The DMA request sources are shown in Table 4-19.

**Table 4-19 DMA Request Sources** 

| DMA Request Source Bits<br>DRS [4:0] | Requesting Device                |
|--------------------------------------|----------------------------------|
| 00000                                | External (TRQA pin)              |
| 00001                                | External (TRQB pin)              |
| 00010                                | External (TRQC pin)              |
| 00011                                | External (TRQD pin)              |
| 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 |

#### **PLL Initialization**

Table 4-19 DMA Request Sources (Continued)

| DMA Request Source Bits<br>DRS [4:0] | Requesting Device                |
|--------------------------------------|----------------------------------|
| 01001                                | Transfer done from DMA channel 5 |
| 01010                                | DAX transmit data                |
| 01011                                | ESAI receive data (RDF=1)        |
| 01100                                | ESAI transmit data (TDE=1)       |
| 01101                                | SHI HTX empty                    |
| 01110                                | SHI FIFO not empty               |
| 01111                                | SHI FIFO full                    |
| 10000                                | Host receive data                |
| 10001                                | Host transmit data               |
| 10010                                | TIMER0 (TCF=1)                   |
| 10011                                | TIMER1 (TCF=1)                   |
| 10100                                | TIMER2 (TCF=1)                   |
| 10101–11111                          | RESERVED                         |

# 4.7 PLL INITIALIZATION

PLL initialization is outlined in the subsections below.

# 4.7.1 PLL MULTIPLICATION FACTOR (MF0-MF11)

The DSP56362 PLL multiplication factor is set to six during hardware reset, that is the value of the multiplication factor bits (MF[11:0]) in the PLL control register (PCTL) is \$005.

# 4.7.2 PLL PRE-DIVIDER FACTOR (PD0-PD3)

The DSP56362 PLL pre-divider factor is 1 during hardware reset, that is the value of the pre-divider factor bits (PD[3:0]) in the PCTL is \$0.

# 4.7.3 CRYSTAL RANGE BIT (XTLR)

The XTLR bit controls the on-chip crystal oscillator transconductance. The on-chip crystal oscillator is not used on the DSP56362 since no XTAL pin is available. The XTLR bit is cleared during hardware reset in the DSP56362.

# 4.7.4 XTAL DISABLE BIT (XTLD)

The XTLD is set (XTAL disabled) during hardware reset in the DSP56362.

# 4.8 DEVICE IDENTIFICATION (IDR) REGISTER

The device register (IDR) is a 24-bit, read-only factory programmed register used to identify the different DSP56300 core-based family members. This register specifies the derivative number and revision number. This information may be used in testing or by software. Figure 4-4 shows the ID register configuration.

Figure 4-4 Identification Register Configuration

| 23       | 16 15           | 12 11             | 0 |
|----------|-----------------|-------------------|---|
| Reserved | Revision Number | Derivative Number |   |
| \$00     | \$1             | \$362             |   |

# 4.9 JTAG IDENTIFICATION (ID) REGISTER

The JTAG identification (ID) register is a 32-bit, read-only JTAG, factory programmed register used to distinguish the component on a board according to the IEEE 1149.1 standard. Figure 4-5 shows the JTAG ID register configuration.

Figure 4-5 JTAG Identification Register Configuration

| 31                  | 28 27            | 22 21                | 12 11                 | 1 0 |
|---------------------|------------------|----------------------|-----------------------|-----|
| Version Information | Customer Part Nu | simber Sequence Numb | Manufacturer Identity | y 1 |
| 0000                | 000110           | 0001100010           | 0000001110            | 1   |

JTAG Boundary Scan Register (BSR)

# 4.10 JTAG BOUNDARY SCAN REGISTER (BSR)

The BSR in the DSP56362 JTAG implementation contains bits for all device signal and clock pins and associated control signals. All bidirectional pins have a single register bit in the BSR for pin data, and are controlled by an associated control bit in the BSR. The BSR bit definitions are described in Table 4-20.

Table 4-20 DSP56362 BSR Bit Definition

| Bit<br># | Pin Name | Pin Type     | BSR Cell<br>Type |
|----------|----------|--------------|------------------|
| 0        | ĪRQĀ     | Input        | Data             |
| 1        | ĪRQB     | Input        | Data             |
| 2        | ĪRQC     | Input        | Data             |
| 3        | ĪRQD     | Input        | Data             |
| 4        | D23      | Input/Output | Data             |
| 5        | D22      | Input/Output | Data             |
| 6        | D21      | Input/Output | Data             |
| 7        | D20      | Input/Output | Data             |
| 8        | D19      | Input/Output | Data             |
| 9        | D18      | Input/Output | Data             |
| 10       | D17      | Input/Output | Data             |
| 11       | D16      | Input/Output | Data             |
| 12       | D15      | Input/Output | Data             |
| 13       | D[23:13] | _            | Control          |
| 14       | D14      | Input/Output | Data             |
| 15       | D13      | Input/Output | Data             |
| 16       | D12      | Input/Output | Data             |
| 17       | D11      | Input/Output | Data             |
| 18       | D10      | Input/Output | Data             |
| 19       | D9       | Input/Output | Data             |
| 20       | D8       | Input/Output | Data             |
| 21       | D7       | Input/Output | Data             |
| 22       | D6       | Input/Output | Data             |
| 23       | D5       | Input/Output | Data             |
| 24       | D4       | Input/Output | Data             |

| Bit<br># | Pin Name | Pin Type     | BSR Cell<br>Type |  |  |
|----------|----------|--------------|------------------|--|--|
| 73       | RES      | Input        | Data             |  |  |
| 74       | HAD0     | _            | Control          |  |  |
| 75       | HAD0     | Input/Output | Data             |  |  |
| 76       | HAD1     | _            | Control          |  |  |
| 77       | HAD1     | Input/Output | Data             |  |  |
| 78       | HAD2     | _            | Control          |  |  |
| 79       | HAD2     | Input/Output | Data             |  |  |
| 80       | HAD3     | _            | Control          |  |  |
| 81       | HAD3     | Input/Output | Data             |  |  |
| 82       | HAD4     | _            | Control          |  |  |
| 83       | HAD4     | Input/Output | Data             |  |  |
| 84       | HAD5     | _            | Control          |  |  |
| 85       | HAD5     | Input/Output | Data             |  |  |
| 86       | HAD6     | _            | Control          |  |  |
| 87       | HAD6     | Input/Output | Data             |  |  |
| 88       | HAD7     | _            | Control          |  |  |
| 89       | HAD7     | Input/Output | Data             |  |  |
| 90       | HAS/A0   | _            | Control          |  |  |
| 91       | HAS/A0   | Input/Output | Data             |  |  |
| 92       | HA8/A1   | _            | Control          |  |  |
| 93       | HA8/A1   | Input/Output | Data             |  |  |
| 94       | HA9/A2   | _            | Control          |  |  |
| 95       | HA9/A2   | Input/Output | Data             |  |  |
| 96       | HCS/A10  | _            | Control          |  |  |
| 97       | HCS/A10  | Input/Output | Data             |  |  |

# JTAG Boundary Scan Register (BSR)

Table 4-20 DSP56362 BSR Bit Definition (Continued)

| Bit<br># | Pin Name                 | Pin Type     | BSR Cell<br>Type |  |  |  |  |
|----------|--------------------------|--------------|------------------|--|--|--|--|
| 25       | D3                       | Input/Output | Data             |  |  |  |  |
| 26       | D[12:0]                  | _            | Control          |  |  |  |  |
| 27       | D2                       | Input/Output | Data             |  |  |  |  |
| 28       | D1                       | Input/Output | Data             |  |  |  |  |
| 29       | D0                       | Input/Output | Data             |  |  |  |  |
| 30       | A17                      | Output3      | Data             |  |  |  |  |
| 31       | A16                      | Output3      | Data             |  |  |  |  |
| 32       | A15                      | Output3      | Data             |  |  |  |  |
| 33       | A[17:9]                  | _            | Control          |  |  |  |  |
| 34       | A14                      | Output3      | Data             |  |  |  |  |
| 35       | A13                      | Output3      | Data             |  |  |  |  |
| 36       | A12                      | Output3      | Data             |  |  |  |  |
| 37       | A11                      | Output3      | Data             |  |  |  |  |
| 38       | A10                      | Output3      | Data             |  |  |  |  |
| 39       | A9                       | Output3      | Data             |  |  |  |  |
| 40       | A8                       | Output3      | Data             |  |  |  |  |
| 41       | A7                       | Output3      | Data             |  |  |  |  |
| 42       | A6                       | Output3      | Data             |  |  |  |  |
| 43       | A[8:0]                   | _            | Control          |  |  |  |  |
| 44       | A5                       | Output3      | Data             |  |  |  |  |
| 45       | A4                       | Output3      | Data             |  |  |  |  |
| 46       | A3                       | Output3      | Data             |  |  |  |  |
| 47       | A2                       | Output3      | Data             |  |  |  |  |
| 48       | A1                       | Output3      | Data             |  |  |  |  |
| 49       | A0                       | Output3      | Data             |  |  |  |  |
| 50       | $\overline{\mathrm{BG}}$ | Input        | Data             |  |  |  |  |
| 51       | AA0                      | _            | Control          |  |  |  |  |
| 52       | AA0                      | Output3      | Data             |  |  |  |  |
| 53       | AA1                      | _            | Control          |  |  |  |  |
| 54       | AA1                      | Output3      | Data             |  |  |  |  |
| 55       | $\overline{\text{RD}}$   | Output3 Data |                  |  |  |  |  |

| Bit<br># | Pin Name   | Pin Type     | BSR Cell<br>Type |  |  |
|----------|------------|--------------|------------------|--|--|
| 98       | TIO0       | _            | Control          |  |  |
| 99       | TIO0       | Input/Output | Data             |  |  |
| 100      | ACI        | _            | Control          |  |  |
| 101      | ACI        | Input/Output | Data             |  |  |
| 102      | ADO        | _            | Control          |  |  |
| 103      | ADO        | Input/Output | Data             |  |  |
| 104      | HOREQ/HTRQ | _            | Control          |  |  |
| 105      | HOREQ/HTRQ | Input/Output | Data             |  |  |
| 106      | HACK/RRQ   | _            | Control          |  |  |
| 107      | HACK/RRQ   | Input/Output | Data             |  |  |
| 108      | HRW/RD     | _            | Control          |  |  |
| 109      | HRW/RD     | Input/Output | Data             |  |  |
| 110      | HDS/WR     | _            | Control          |  |  |
| 111      | HDS/WR     | Input/Output | Data             |  |  |
| 112      | HCKR       | _            | Control          |  |  |
| 113      | HCKR       | Input/Output | Data             |  |  |
| 114      | НСКТ       | _            | Control          |  |  |
| 115      | HCKT       | Input/Output | Data             |  |  |
| 116      | SCKR       | _            | Control          |  |  |
| 117      | SCKR       | Input/Output | Data             |  |  |
| 118      | SCKT       | _            | Control          |  |  |
| 119      | SCKT       | Input/Output | Data             |  |  |
| 120      | FSR        | _            | Control          |  |  |
| 121      | FSR        | Input/Output | Data             |  |  |
| 122      | FST        | _            | Control          |  |  |
| 123      | FST        | Input/Output | Data             |  |  |
| 124      | SDO5/SDI0  | _            | Control          |  |  |
| 125      | SDO5/SDI0  | Input/Output | Data             |  |  |
| 126      | SDO4/SDI1  | _            | Control          |  |  |
| 127      | SDO4/SDI1  | Input/Output | Data             |  |  |
| 128      | SDO3/SDI2  | _            | Control          |  |  |

# JTAG Boundary Scan Register (BSR)

Table 4-20 DSP56362 BSR Bit Definition (Continued)

| Bit<br># | Pin Name                                    | Pin Type     | BSR Cell<br>Type |  |  |
|----------|---------------------------------------------|--------------|------------------|--|--|
| 56       | WR                                          | Output3      | Data             |  |  |
| 57       | BB                                          | _            | Control          |  |  |
| 58       | BB                                          | Input/Output | Data             |  |  |
| 59       | BR                                          | Output2      | Data             |  |  |
| 60       | TA                                          | Input        | Data             |  |  |
| 61       | PINIT                                       | Input        | Data             |  |  |
| 62       | CLKOUT                                      | Output2      | Data             |  |  |
| 63       | $\overline{\text{RD}},\overline{\text{WR}}$ | _            | Control          |  |  |
| 64       | EXTAL                                       | Input        | Data             |  |  |
| 65       | DE                                          | _            | Control          |  |  |
| 66       | <del>DE</del>                               | Input/Output | Data             |  |  |
| 67       | CAS                                         | _            | Control          |  |  |
| 68       | CAS                                         | Output3      | Data             |  |  |
| 69       | AA2                                         | _            | Control          |  |  |
| 70       | AA2                                         | Output3      | Data             |  |  |
| 71       | AA3                                         | _            | Control          |  |  |
| 72       | AA3                                         | Output3      | Data             |  |  |

| Bit<br># | Pin Name  | Pin Type     | BSR Cell<br>Type |  |  |
|----------|-----------|--------------|------------------|--|--|
| 129      | SDO3/SDI2 | Input/Output | Data             |  |  |
| 130      | SDO2/SDI3 | _            | Control          |  |  |
| 131      | SDO2/SDI3 | Input/Output | Data             |  |  |
| 132      | SDO1      | _            | Control          |  |  |
| 133      | SDO1      | Input/Output | Data             |  |  |
| 134      | SDO0      | _            | Control          |  |  |
| 135      | SDO0      | Input/Output | Data             |  |  |
| 136      | HREQ      | _            | Control          |  |  |
| 137      | HREQ      | Input/Output | Data             |  |  |
| 138      | SS        | Input        | Data             |  |  |
| 139      | SCK/SCL   | _            | Control          |  |  |
| 140      | SCK/SCL   | Input/Output | Data             |  |  |
| 141      | MISO/SDA  | _            | Control          |  |  |
| 142      | MISO/SDA  | Input/Output | Data             |  |  |
| 143      | MOSI/HA0  | _            | Control          |  |  |
| 144      | MOSI/HA0  | Input/Output | Data             |  |  |

# SECTION 5 GENERAL PURPOSE INPUT/OUTPUT

## 5.1 INTRODUCTION

The DSP56362 provides up to 31 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 techniques for register programming for all GPIO functionality is very similar between these interfaces. This section describes how signals may be used as GPIO.

# 5.2 PROGRAMMING MODEL

The signals description section of this manual describes the special uses of these signals in detail. There are five groups of these signals which can be controlled separately or as groups:

- Port B: up to 16 GPIO signals (shared with the HDI08 signals)
- Port C: 12 GPIO signals (shared with the ESAI signals)
- Port D: two GPIO signals (shared with the DAX signals)
- Timer: one GPIO signal (shared with the timer/event counter signal)

# 5.2.1 PORT B SIGNALS AND REGISTERS

When HDI08 is disabled, all 16 HDI08 signals can be used as GPIO. When HDI08 is enabled, five (HA8, HA9, HCS, HOREQ, and HACK) of the 16 port B signals, if not used as a HDI08 signal, can be configured as GPIO signals. The GPIO functionality of port B is controlled by three registers: host port control register (HPCR), host port GPIO data register (HDR), and host port GPIO direction register (HDDR). These registers are described in Section 6 - Host Interface (HDI08) of this document.

# 5.2.2 PORT C SIGNALS AND REGISTERS

Each of the 12 port C signals not used as an ESAI signal can be configured individually as a GPIO signal. The GPIO functionality of port C is controlled by three registers: port C control register (PCRC), port C direction register (PRRC), and port C data register (PDRC). These registers are described in Section 8 - Enhanced Serial AUDIO Interface (ESAI).

# 5.2.3 PORT D SIGNALS AND REGISTERS

Each of the two Port D signals not used as a DAX signal can be configured individually as a GPIO signal. The GPIO functionality of Port D is controlled by three registers: Port D control register (PCRD), Port D direction register (PRRD) and Port D data register (PDRD). These registers are described in Section 10 - Digital Audio Transmitter.

## 5.2.4 TIMER/EVENT COUNTER SIGNALS

The timer/event counter signal (TIO), when not used as a timer signal can be configured as a GPIO signal. The signal is controlled by the appropriate timer control status register (TCSR). The register is described in Section 9 - Timer/ Event Counter.

# SECTION 6 HOST INTERFACE (HDI08)

#### 6.1 INTRODUCTION

The host interface (HDI08) is a byte-wide, full-duplex, double-buffered, parallel port that can be connected directly to the data bus of a host processor. The HDI08 supports a variety of buses and provides glueless connection with a number of industry standard microcomputers, microprocessors, DSPs and DMA hardware.

The host bus can operate asynchronously to the DSP core clock, therefore the HDI08 registers are divided into 2 banks. The host register bank is accessible to the external host and the DSP register bank is accessible to the DSP core.

The HDI08 supports three classes of interfaces:

- Host processor/Microcontroller (MCU) connection interface
- DMA controller interface
- General purpose I/O (GPIO) port

#### 6.2 HDI08 FEATURES

#### 6.2.1 INTERFACE - DSP SIDE

- Mapping:
  - Registers are directly mapped into eight internal X data memory locations
- Data Word:
  - 24-bit (native) data words are supported, as are 8-bit and 16-bit words
- Transfer Modes:
  - DSP to Host
  - Host to DSP

#### **HDI08 Features**

- Host Command
- Handshaking Protocols:
  - Software polled
  - Interrupt driven
  - Core DMA accesses
- Instructions:
  - Memory-mapped registers allow the standard MOVE instruction to be used to transfer data between the DSP and the external host.
  - Special MOVEP instruction provides for I/O service capability using fast interrupts.
  - Bit addressing instructions (e.g. BCHG, BCLR, BSET, BTST, JCLR, JSCLR, JSET, JSSET) simplify I/O service routines.

#### 6.2.2 INTERFACE - HOST SIDE

- Sixteen signals are provided to support non-multiplexed or multiplexed buses:
  - H0-H7/HAD0-HAD7
     Host data bus (H7-H0) 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
  - HOREQ/HTRQ
     Host request (HOREQ) or Host transmit request (HTRQ)

HACK/HRRQ
 Host acknowledge (HACK) or Host receive request (HRRQ)

# Mapping:

- HDI08 registers are mapped into eight consecutive byte locations in the external host bus address space.
- The HDI08 acts as a memory or IO-mapped peripheral for microprocessors, microcontrollers, etc.
- Data Word:
  - 8-bit
- 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).
  - Cycle-stealing DMA with initialization
- Dedicated Interrupts:
  - Separate interrupt lines for each interrupt source
  - Special host commands force DSP core interrupts under host processor control, which are useful for the following:
    - Real-Time Production Diagnostics
    - Debugging Window for Program Development
    - Host Control Protocols
- Interface Capabilities:
  - Glueless interface (no external logic required) to the following:
    - Motorola HC11
    - Hitachi H8
    - 8051 family

# **HDI08 Host Port Signals**

- Thomson P6 family
- external DMA controllers
- Minimal glue-logic (pullups, pulldowns) required to interface to the following:
  - ISA bus
  - Motorola 68K family
  - Intel X86 family.

#### 6.3 HDI08 HOST PORT SIGNALS

The host port signals are described in **Section 2**. If the Host Interface functionality is not required, the 16 pins may be defined as general purpose I/O pins PB0-PB15. When the HDI08 is in use, only five host port signals (HA8, HA9, HCS, HOREQ and HACK) may be individually programmed as GPIO pins if they are not needed for their HDI08 function. Summary of the HDI08 signals.

Table 6-1 HDI08 Signal Summary

| HDI08 Port Pin | Multiplexed address/data bus<br>Mode | Non Multiplexed bus Mode | GPIO Mode |
|----------------|--------------------------------------|--------------------------|-----------|
| HAD0-HAD7      | HAD0-HAD7                            | Н0-Н7                    | PB0-PB7   |
| HAS/HA0        | HAS/ <del>HAS</del>                  | HA0                      | PB8       |
| HA8/HA1        | HA8                                  | HA1                      | PB9       |
| HA9/HA2        | HA9                                  | HA2                      | PB10      |
| HCS/HA10       | HA10                                 | HCS/ <del>HCS</del>      | PB13      |

**Table 6-2 Strobe Signals Support signals** 

| HDI08 Port Pin | Single strobe bus   | Dual strobe bus     | GPIO Mode |
|----------------|---------------------|---------------------|-----------|
| HRW/HRD        | HRW                 | HRD/HRD             | PB11      |
| HDS/HWR        | HDS/ <del>HDS</del> | HWR/ <del>HWR</del> | PB12      |

# Table 6-3 Host request support signals

| HDI08 Port Pin | Vector required         | No vector required    | GPIO Mode |
|----------------|-------------------------|-----------------------|-----------|
| HOREQ/HTRQ     | HOREQ/ <del>HOREQ</del> | HTRQ/ <del>HTRQ</del> | PB14      |
| HACK/HRRQ      | HACK/ <del>HACK</del>   | HRRQ/ <del>HRRQ</del> | PB15      |

# 6.4 HDI08 BLOCK DIAGRAM

Figure 6-1 shows the HDI08 registers. The top row of registers (HCR, HSR, HDDR, HDR, HBAR, HPCR, HOTX, HORX) can be accessed the DSP core. The bottom row of registers (ISR, ICR, CVR, IVR, RXH:RXM:RXL and TXH:TXM:TXL) can be accessed by the host processor.



Figure 6-1 HDI08 Block Diagram

#### 6.5 HDI08 – DSP-SIDE PROGRAMMER'S MODEL

The DSP core threats the HDI08 as a memory-mapped peripheral occupying eight 24-bit words in X data memory space. The DSP may use the HDI08 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 DSP core to communicate with the HDI08 registers using standard instructions and addressing modes. In addition, the MOVEP instruction allows direct data transfers between the DSP memory and the HDI08 registers or vice-versa. The HOTX and HORX registers may be serviced by the on-chip DMA controller for data transfers.

The eight host processor registers consists of two data registers and six control registers. All registers can be accessed by the DSP core but not by the external processor.

Data registers are 24-bit registers used for high-speed data transfer to and from the DSP. They are as follows:

- Host Data Receive Register (HORX)
- Host Data Transmit Register (HOTX)

The control registers are 16-bit registers used to control the HDI08 functions. The eight MSBs in the control registers are read by the DSP as zero. The control registers are as follows:

- Host control register (HCR)
- Host status register (HSR)
- Host base address register (HBAR)
- Host port control register (HPCR)
- Host GPIO data direction register (HDDR)
- Host GPIO data register (HDR)

Hardware and software reset disable the HDI08. After reset, the HDI08 signals are configured as GPIO with all pins disconnected.

# 6.5.1 HOST RECEIVE DATA REGISTER (HORX)

The 24-bit read-only HORX register is used for host-to-DSP data transfers. The HORX register 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 TXDE (host side) and host receive data

full HRDF (DSP side) bits are cleared. This transfer operation sets both the TXDE and HRDF flags. The HORX register contains valid data when the HRDF bit is set. Reading HORX clears HRDF. The DSP may program the HRIE bit to cause a host receive data interrupt when HRDF is set. Also, a DMA channel may be programmed to read the HORX when HRDF is set.

# 6.5.2 HOST TRANSMIT DATA REGISTER (HOTX)

The 24-bit write-only HOTX register is used for DSP- to-host data transfers. Writing to the HOTX register clears the host transfer data empty flag HTDE (DSP side). The contents of the HOTX register are transferred as 24-bit data to the receive byte registers (RXH:RXM:RXL) when both the HTDE flag (DSP side) and receive data full RXDF flag (host side) are cleared. This transfer operation sets the RXDF and HTDE flags. The DSP may set the HTIE bit to cause a host transmit data interrupt when HTDE is set. Also, a DMA Channel may be programmed to write to HOTX when HTDE is set. To prevent the previous data from being overwritten, data should not be written to the HOTX until the HTDE flag is set.

Note:

When writing data to a peripheral device, there is a two-cycle pipeline delay until any status bits affected by the operation are updated. If the programmer reads any of those status bits within the next two cycles, the bit will not reflect its current status. See the *DSP56300 24-Bit Digital Signal Processor Family Manual*, *Motorola publication DSP56300FM/AD* for further details.

# 6.5.3 HOST CONTROL REGISTER (HCR)

The HCR is 16-bit read/write control register used by the DSP core to control the HDI08 operating mode. The initialization values for the HCR bits are described in Section 6.5.9. The HCR bits are described in the following paragraphs.

Figure 6-2 Host Control Register (HCR) (X:\$FFFC2)

15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0

HDM2 HMD1 HDM0 HF3 HF2 HCIE HTIE HRIE

- Reserved bit. Read as 0. Should be written with 0 for future compatibility.

#### 6.5.3.1 HCR Host Receive Interrupt Enable (HRIE) Bit 0

The HRIE bit is used to enable the host receive data interrupt request. When the host receive data full (HRDF) status bit in the host status register (HSR) is set, a host receive data interrupt request occurs if HRIE is set. If HRIE is cleared, HRDF interrupts are disabled.

## 6.5.3.2 HCR Host Transmit Interrupt Enable (HTIE) Bit 1

The HTIE bit is used to enable the host transmit data empty interrupt request. When the host transmit data empty (HTDE) status bit in the HSR is set, a host transmit data interrupt request occurs if HTIE is set. If HTIE is cleared, HTDE interrupts are disabled.

# 6.5.3.3 HCR Host Command Interrupt Enable (HCIE) Bit 2

The HCIE bit is used to enable the host command interrupt request. When the host command pending (HCP) status bit in the HSR is set, a host command interrupt request occurs if HCIE is set. If HCIE is cleared, HCP interrupts are disabled. The interrupt address is determined by the host command vector register (CVR).

Note:

Host interrupt request priorities: If more than one interrupt request source is asserted and enabled (e.g. HRDF=1, HCP=1, HRIE=1 and HCIE=1), the HDI08 generates interrupt requests according to the following table:

Priority Interrupt Source

Highest Host Command (HCP=1)

Transmit Data (HTDE=1)

Lowest Receive Data (HRDF=1)

Table 6-4 HDI08 IRQ

# 6.5.3.4 HCR Host Flags 2,3 (HF2,HF3) Bits 3-4

HF2 and HF3 bits are used as a general-purpose flags for DSP to host communication. HF2 and HF3 may be set or cleared by the DSP core. HF2 and HF3 are reflected in the interface status register (ISR) on the host side such that if they are modified by the DSP software, the host processor can read the modified values by reading the ISR.

These two flags are not designated for any specific purpose but are general-purpose flags. They can be used individually or as encoded pairs in a simple DSP to host communication protocol, implemented in both the DSP and the host processor software.

# 6.5.3.5 HCR Host DMA Mode Control Bits (HDM0, HDM1, HDM2) Bits 5-7

The HDM[2:0] bits are used to enable the HDI08 DMA mode operation. The HDI08 DMA mode supports external DMA controller devices connected to the HDI08 on the Host side. This mode should not be confused with the operation of the on-chip DMA controller.

With HDM[2:0] cleared, the HDI08 does not support DMA mode operation and the TREQ and RREQ control bits are used for host processor interrupt control via the external HOREQ output signal (or HRREQ and HTREQ output signals if HDREQ in the ICR is set). Also, in the non-DMA mode, the HACK input signal is used for the MC68000 Family vectored

interrupt acknowledge input. If HDM[2:0] are not all cleared, the HDI08 operates as described in Table 6-5.

**HDM** Mode 0 2 1 Description **ICR** 0 0 DMA operation disabled INIT HLEND HF1 HF0 **HDRO** TREO RREO 1 0 DMA Operation Enabled. Host may set HM1 or HM0 in INIT HM1 HM0HF1 HF0 TREQ **RREQ** the ICR to enable DMA transfers DMA Mode Data Output Transfers Enabled. (24-Bit words) DMA Mode Data Output Transfers Enabled. (16-Bit words) 0 1 DMA Mode Data Output Transfers Enabled. INIT HDM1 HDM0 HF1 HF0 TREQ **RREQ** (8-Bit words) DMA Mode Data Input Transfers Enabled. (24-Bit words) DMA Mode Data Input Transfers Enabled. (16-Bit words) 1 1 DMA Mode Data Input Transfers Enabled. (8-Bit words)

Table 6-5 HDM[2:0] Functionality

If HDM1 or HDM0 are set, the DMA mode is enabled, and the HOREQ signal is used to request DMA transfers (the value of the HM1, HM0, HLEND and HDREQ bits in the ICR have no affect). When the DMA mode is enabled, the HDM2 bit selects the direction of DMA transfers:

- setting HDM2 sets the direction of DMA transfer to be DSP to host and enables the HOREQ signal to request data transfer.
- clearing HDM2 sets the direction of DMA transfer to be host to DSP and enables the HOREQ signal to request data transfer.

The HACK input signal is used as a DMA transfer acknowledge input. If the DMA direction is from DSP to host, the contents of the selected register are driven onto the host data bus

#### HDI08 - DSP-Side Programmer's Model

when HACK is asserted. If the DMA direction is from host to DSP, the selected register is written from the host data bus when HACK is asserted.

The size of the DMA word to be transferred is determined by the DMA control bits, HDM[1:0]. Only the data registers TXH, TXM, TXL and RXH, RXM, RXL can be accessed in DMA mode. The HDI08 data register selected during a DMA transfer is determined by a 2-bit address counter, which is preloaded with the value in HDM[1:0]. The address counter substitutes for the address bits of the HDI08 during a DMA transfer. The address counter can be initialized with the INIT bit feature. After each DMA transfer on the host data bus, the address counter is incremented to the next register. When the address counter reaches the highest register (RXL or TXL), the address counter is not incremented but is loaded with the value in HDM[1:0]. This allows 8-, 16- or 24-bit data to be transferred in a circular fashion and eliminates the need for the DMA controller to supply the HA2, HA1, and HA0 signals. For 16- or 24-bit data transfers, the DSP CPU interrupt rate is reduced by a factor of 2 or 3, respectively, from the host request rate – i.e., for every two or three host processor data transfers of one byte each, there is only one 24-bit DSP CPU interrupt.

If HDM1 or HDM0 are set, the HM[1:0] bits in the ICR register reflect the value of HDM[1:0].

The HDM[2:0] bits should be changed only while HEN is cleared in the HPCR.

#### 6.5.3.6 HCR Reserved Bits 8-15

These bits are reserved. They read as zero and should be written with zero for future compatibility.

# 6.5.4 HOST STATUS REGISTER (HSR)

The HSR is a 16-bit read-only status register used by the DSP to read the status and flags of the HDI08. It cannot be directly accessed by the host processor. The initialization values for the HSR bits are described in Section 6.5.9. The HSR bits are described in the following paragraphs.

# Figure 6-3 Host Status Register (HSR) (X:FFFFC3)

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

- Reserved bit. Read as 0. Should be written with 0 for future compatibility.

# 6.5.4.1 HSR Host Receive Data Full (HRDF) Bit 0

The HRDF bit indicates that the host receive data register (HORX) contains data from the host processor. HRDF is set when data is transferred from the TXH:TXM:TXL registers to the HORX register. HRDF is cleared when HORX is read by the DSP core. If HRDF is set the

HDI08 generates a receive data full DMA request, if enabled by a DSP core DMA Channel. If HRDF is set when HRIE is set, a host receive data interrupt request is generated. HRDF can also be cleared by the host processor using the initialize function.

# 6.5.4.2 HSR Host Transmit Data Empty (HTDE) Bit 1

The HTDE bit indicates that the host transmit data register (HOTX) is empty and can be written by the DSP core. HTDE is set when the HOTX register is transferred to the RXH:RXM:RXL registers. HTDE is cleared when HOTX is written by the DSP core. If HTDE is set the HDI08 generates a transmit data empty DMA request, if enabled by a DSP core DMA Channel. If HTDE is set when HTIE is set, a host transmit data interrupt request is generated. HTDE can also be set by the host processor using the initialize function.

# 6.5.4.3 HSR Host Command Pending (HCP) Bit 2

The HCP bit indicates that the host has set the HC bit and that a host command interrupt is pending. The HCP bit reflects the status of the HC bit in the command vector register (CVR). HC and HCP are cleared by the HDI08 hardware when the interrupt request is serviced by the DSP core. The host can clear HC, which also clears HCP.

## 6.5.4.4 HSR Host Flags 0,1 (HF0,HF1) Bits 3-4

HF0 and HF1 bits are used as a general-purpose flags for host to DSP communication. HF0 and HF1 may be set or cleared by the host. HF0 and HF1 reflect the status of host flags HF0 and HF1 in the ICR register on the host side.

These two flags are not designated for any specific purpose but are general-purpose flags. They can be used individually or as encoded pairs in a simple host to DSP communication protocol, implemented in both the DSP and the host Processor software.

#### 6.5.4.5 HSR Reserved Bits 5-6, 8-15

These bits are reserved. They read as zero and should be written with zero for future compatibility.

# 6.5.4.6 HSR DMA Status (DMA) Bit 7

The DMA status bit is set when the DMA mode of operation is enabled, and is cleared when the DMA mode is disabled. The DMA mode is enabled under the following conditions:

- HCR bits HDM[2:0] = 100 and the host processor has enabled the DMA mode by setting either or both the ICR bits HM1 and HM0
- Either or both of the HCR bits HDM1 and HDM0 have been set

When the DMA bit is zero, the channel not in use can be used for polled or interrupt operation by the DSP.

# 6.5.5 HOST BASE ADDRESS REGISTER (HBAR)

The HBAR is used in multiplexed bus modes. This register selects the base address where the host side registers are mapped into the bus address space. The address from the host bus is compared with the base address as programmed in the base address register. If the addresses match, an internal chip select is generated. The use of this register by the chip select logic is shown in Figure 6-5.

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

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

# 6.5.5.1 HBAR Base Address (BA[10:3]) Bits 0-7

These bits define the base address where the host side registers are mapped into the bus address space.

#### 6.5.5.2 HBAR Reserved Bits 8-15

These bits are reserved. They read as zero and should be written with zero for future compatibility.



Figure 6-5 Self Chip Select logic

# 6.5.6 HOST PORT CONTROL REGISTER (HPCR)

The HPCR is a 16-bit read/write control register used by the DSP to control the HDI08 operating mode. The initialization values for the HPCR bits are described in Section 6.5.9. The HPCR bits are described in the following paragraphs.

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

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

Note:

To assure proper operation of the HDI08, the HPCR bits HAP, HRP, HCSP, HDDS, HMUX, HASP, HDSP, HROD, HAEN and HREN should be changed only if HEN is cleared. Also, 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 or simultaneously with setting HEN.

# 6.5.6.1 HPCR Host GPIO Port Enable (HGEN) Bit 0

If the HGEN bit is set, pins configured as GPIO are enabled. If this bit is cleared, pins configured as GPIO are disconnected: outputs are high impedance, inputs are electrically disconnected. Pins configured as HDI08 are not affected by the state of HGEN.

# 6.5.6.2 HPCR Host Address Line 8 Enable (HA8EN) Bit 1

If the HA8EN bit is set and the HDI08 is used in multiplexed bus mode, then HA8/HA1 is used as host address line 8 (HA8). If this bit is cleared and the HDI08 is used in multiplexed bus mode, then HA8/HA1 is configured as GPIO pin according to the value of HDDR and HDR registers. HA8EN is ignored when the HDI08 is not in the multiplexed bus mode (HMUX=0).

## 6.5.6.3 HPCR Host Address Line 9 Enable (HA9EN) Bit 2

If the HA9EN bit is set and the HDI08 is used in multiplexed bus mode, then HA9/HA2 is used as host address line 9 (HA9). If this bit is cleared and the HDI08 is used in multiplexed bus mode, then HA9/HA2 is configured as GPIO pin according to the value of HDDR and HDR registers. HA9EN is ignored when the HDI08 is not in the multiplexed bus mode (HMUX=0).

## 6.5.6.4 HPCR Host Chip Select Enable (HCSEN) Bit 3

If the HCSEN bit is set, then HCS/HA10 is used as host chip select (HCS) in the non-multiplexed bus mode (HMUX=0), and as host address line 10 (HA10) in the multiplexed bus mode (HMUX=1). If this bit is cleared, then HCS/HA10 is configured as GPIO pin according to the value of HDDR and HDR registers.

## HDI08 - DSP-Side Programmer's Model

## 6.5.6.5 HPCR Host Request Enable (HREN) Bit 4

The HREN bit controls the host request signals. If HREN is set and the HDI08 is in the single host request mode (HDRQ=0 in the ICR), HOREQ/HTRQ is configured as the host request (HOREQ) output.

If HREN is set in the double host request mode (HDRQ=1 in the ICR), HOREQ/HTRQ is configured as the host transmit request (HTRQ) output and HACK/HRRQ as the host receive request (HRRQ) output.

If HREN is cleared, HOREQ/HTRQ and HACK/HRRQ are configured as GPIO pins according to the value of HDDR and HDR registers.

# 6.5.6.6 HPCR Host Acknowledge Enable (HAEN) Bit 5

The HAEN bit controls the HACK signal. In the single host request mode (HDRQ=0 in the ICR), if HAEN and HREN are both set, HACK/HRRQ is configured as the host acknowledge (HACK) input. If HAEN or HREN is cleared, HACK/HRRQ is configured as a GPIO pin according to the value of HDDR and HDR registers. In the double host request mode (HDRQ=1 in the ICR), HAEN is ignored.

#### 6.5.6.7 HPCR Host Enable (HEN) Bit 6

If the HEN bit is set, the HDI08 operation is enabled as Host Interface. If cleared, the HDI08 is not active, and all the HDI08 pins are configured as GPIO pins according to the value of HDDR and HDR registers.

#### 6.5.6.8 HPCR Reserved Bit 7

This bit is reserved. It reads as zero and should be written with zero for future compatibility.

# 6.5.6.9 HPCR Host Request Open Drain (HROD) Bit 8

The HROD bit controls the output drive of the host request signals. In the single host request mode (HDRQ=0 in ICR), if HROD is cleared and host requests are enabled (HREN=1 and HEN=1 in HPCR), the HOREQ signal is always driven. If HROD is set and host requests are enabled, the HOREQ signal is an open drain output.

In the double host request mode (HDRQ=1 in the ICR), if HROD is cleared and host requests are enabled (HREN=1 and HEN=1 in the HPCR), the HTRQ and HRRQ signals are always driven. If HROD is set and host requests are enabled, the HTRQ and HRRQ signals are open drain outputs.

#### 6.5.6.10 HPCR Host Data Strobe Polarity (HDSP) Bit 9

If the HDSP bit is cleared, the data strobe signals are configured as active low inputs, and data is transferred when the data strobe is low. If HDSP is set, the data strobe signals are configured as active high inputs, and data is transferred when the data strobe is high. The data strobe signals are either HDS by itself or HRD and HWR together.

## 6.5.6.11 HPCR Host Address Strobe Polarity (HASP) Bit 10

If the HASP bit is cleared, the address strobe (HAS) signal is an active low input, and the address on the host address/data bus is sampled when the  $\overline{\text{HAS}}$  signal is low. If HASP is set, HAS is an active high address strobe input, and the address on the host address/data bus 8 is sampled when the HAS signal is high.

# 6.5.6.12 HPCR Host Multiplexed bus (HMUX) Bit 11

If the HMUX bit is set, the HDI08 latches the lower portion of a multiplexed address/data bus. In this mode the internal address line values of the host registers are taken from the internal latch. If HMUX is cleared, it indicates that the HDI08 is connected to a non-multiplexed type of bus, and the address lines are taken from the HDI08 input signals.

# 6.5.6.13 HPCR Host Dual Data Strobe (HDDS) Bit 12

If the HDDS bit is cleared, the HDI08 operates in the single strobe bus mode. In this mode, the bus has a single data strobe signal for both reads and writes. If HDDS is set, the HDI08 operates in the dual strobe bus mode. In this mode, the bus has two separate data strobes, one for data reads, the other for data writes. See Figure 6-7 and Figure 6-8 for more information on the two types of buses.



Figure 6-7 Single strobe bus



Figure 6-8 Dual strobes bus

## HDI08 - DSP-Side Programmer's Model

## 6.5.6.14 HPCR Host Chip Select Polarity (HCSP) Bit 13

If the HCSP bit is cleared, the chip select  $(\overline{HCS})$  signal is configured as an active low input and the HDI08 is selected when the  $\overline{HCS}$  signal is low. If HCSP is set, HCS is configured as an active high input and the HDI08 is selected when the HCS signal is high. This bit is ignored in the multiplexed mode.

# 6.5.6.15 HPCR Host Request Polarity (HRP) Bit 14

The HRP bit controls the polarity of the host request signals. In the single host request mode (HDRQ=0 in the ICR), if HRP is cleared and host requests are enabled (HREN=1 and HEN=1 in the HPCR), the HOREQ signal is an active low output. If HRP is set and host requests are enabled, the HOREQ signal is an active high output.

In the double host request mode (HDRQ=1 in the ICR), if HRP is cleared and host requests are enabled (HREN=1 and HEN=1 in the HPCR), the HTRQ and HRRQ signals are active low outputs. If HRP is set and host requests are enabled, the HTRQ and HRRQ signals are active high outputs.

# 6.5.6.16 HPCR Host Acknowledge Polarity (HAP) Bit 15

If the HAP bit is cleared, the host acknowledge ( $\overline{HACK}$ ) signal is configured as an active low input, and the HDI08 drives the contents of the HIVR register onto the host bus when the  $\overline{HACK}$  signal is low. If HAP is set, HACK is configured as an active high input, and the HDI08 outputs the contents of the HIVR register when the HACK signal is high.

# 6.5.7 DATA DIRECTION REGISTER (HDDR)

The HDDR controls the direction of the data flow for each of the HDI08 pins configured as GPIO. Even when the HDI08 is used as the host interface, some of its unused signals may be configured as GPIO pins. For information on the HDI08 GPIO configuration options, see Section 6.6.8. If bit DRxx is set, the corresponding HDI08 pin is configured as an output signal. If bit DRxx is cleared, the corresponding HDI08 pin is configured as an input signal. See Table 6-6.

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

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

# 6.5.8 HOST DATA REGISTER (HDR)

The HDR register holds the data value of the corresponding bits of the HDI08 pins which are configured as GPIO pins. The functionality of the Dxx bit depends on the corresponding HDDR bit (DRxx). See Table 6-6.

Figure 6-10 Host Data Register (HDR) (X:\$FFFFC9)

|     |     |     | 12  |     |     |    |    |    |    |    |    |    |    |    |    |
|-----|-----|-----|-----|-----|-----|----|----|----|----|----|----|----|----|----|----|
| D15 | D14 | D13 | D12 | D11 | D10 | D9 | D8 | D7 | D6 | D5 | D4 | D3 | D2 | D1 | D0 |

Table 6-6 HDR and HDDR Functionality

| HDDR | н                                                                                                                                                  | DR                                                   |  |  |  |  |  |
|------|----------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|--|--|--|--|--|
|      | Dxx                                                                                                                                                |                                                      |  |  |  |  |  |
| DRxx | GPIO pin <sup>a</sup>                                                                                                                              | non-GPIO pin <sup>a</sup>                            |  |  |  |  |  |
| 0    | Read only bit. The value read is the binary value of the pin. The corresponding pin is configured as an input.                                     | Read only bit. Does not contain significant data.    |  |  |  |  |  |
| 1    | Read/write bit. The value written is the value read. The corresponding pin is configured as an output, and is driven with the data written to Dxx. | Read/write bit. The value written is the value read. |  |  |  |  |  |

a.Defined by the selected configuration

# 6.5.9 DSP-SIDE REGISTERS AFTER RESET

Table 6-7 shows the results of the four reset types on the bits in each of the HDI08 registers accessible by the DSP core. The hardware reset (HW) is caused by the  $\overline{RESET}$  signal. The software reset (SW) is caused by executing the RESET instruction. The individual reset (IR)

#### **HDI08 – DSP-Side Programmer's Model**

is caused by clearing the HEN bit (HPCR bit 6). The stop reset (ST) is caused by executing the STOP instruction.

Table 6-7 DSP-Side Registers after Reset

| <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           | _           | _           |  |  |  |
| HPCR             | All bits         | 0           | 0           | _           | _           |  |  |  |
| HSR              | HF[1:0]          | 0           | 0           | _           | _           |  |  |  |
|                  | НСР              | 0           | 0           | 0           | 0           |  |  |  |
|                  | HTDE             | 1           | 1           | 1           | 1           |  |  |  |
|                  | HRDF             | 0           | 0           | 0           | 0           |  |  |  |
|                  | DMA              | 0           | 0           | _           | _           |  |  |  |
| HBAR             | BA[10:3]         | \$80        | \$80        | _           | _           |  |  |  |
| HDDR             | DR[15:0]         | 0           | 0           | _           | _           |  |  |  |
| HDR              | D[15:0]          | _           | _           | _           | _           |  |  |  |
| HORX             | HORX[23:0]       | empty       | empty       | empty       | empty       |  |  |  |
| НОТХ             | HOTX[23:0]       | empty       | empty       | empty       | empty       |  |  |  |

# 6.5.10 HOST INTERFACE DSP CORE INTERRUPTS

The HDI08 may request interrupt service from either the DSP core or the host processor. The DSP core interrupts are internal and do not require the use of an external interrupt pin. When the appropriate interrupt enable bit in the HCR is set, an interrupt condition caused by the host processor sets the appropriate bit in the HSR, generating an interrupt request to the DSP core. The DSP core acknowledges interrupts caused by the host processor by jumping to the appropriate interrupt service routine. The three possible interrupts are as follows:

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

Although there is a set of vectors reserved for host command use, the host command can access any interrupt vector in the interrupt vector table. The DSP interrupt service routine

must read or write the appropriate HDI08 register (clearing HRDF or HTDE, for example) to clear the interrupt. In the case of host command interrupts, the interrupt acknowledge from the DSP core program controller clears the pending interrupt condition. Figure 6-11 illustrates the HSR-HCR operation.



Figure 6-11 HSR-HCR Operation

## 6.6 HDI08 – EXTERNAL HOST PROGRAMMER'S MODEL

The HDI08 has been designed to provide a simple, high speed interface to a host processor. To the host bus, the HDI08 appears to be eight byte-wide registers. Separate transmit and receive data registers are double-buffered to allow the DSP core and host processor to transfer data efficiently at high speed. The host may access the HDI08 asynchronously by using polling techniques or interrupt-based techniques.

The HDI08 appears to the host processor as a memory-mapped peripheral occupying 8 bytes in the host processor address space (See Table 6-8). The eight HDI08 include the following:

- A control register (ICR)
- A status register (ISR)
- Three data registers (RXH/TXH, RXM/TXM and RXL/TXL)

#### **HDI08 – External Host Programmer's Model**

• Two vector registers (IVR and CVR)

These registers can be accessed only by the host processor.

Host processors may use standard host processor instructions (e.g., byte move) and addressing modes to communicate with the HDI08 registers. The HDI08 registers are aligned so that 8-bit host processors can use 8/16/24-bit load and store instructions for data transfers. The HOREQ/HTRQ and HACK/HRRQ handshake flags are provided for polled or interrupt-driven data transfers with the host processor. Because the DSP 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 DSP as a fast device, and data can be transferred between the host processor and the DSP at the fastest host processor data rate.

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 DSP core. The host may select any of 128 DSP interrupt routines to be executed by writing a vector address register in the HDI08. This flexibility allows the host programmer to execute up to 128 pre-programmed functions inside the DSP. For example, host interrupts can allow the host processor to read or write DSP registers (X, Y, or program memory locations), force interrupt handlers (e.g.  $\overline{IRQA}$ ,  $\overline{IRQB}$ , etc. interrupt routines), and perform control and debugging operations if interrupt routines are implemented in the DSP to perform these tasks.

Host **Big Endian** Little Endian Function HLEND=0 HLEND=1 Address 0 **ICR ICR** Interface Control 1 CVR **CVR** Command Vector 2 ISR ISR Interface Status 3 **IVR IVR** Interrupt Vector 4 00000000 00000000 Unused 5 RXH/TXH RXL/TXL Receive/Transmit RXM/TXM RXM/TXM 6 **Bytes** 7 RXL/TXL RXH/TXH Host Data Bus Host Data Bus H0 - H7 Note: The RXH/TXH register is always mapped to the most significant byte of the DSP word.

Table 6-8 HDI08 Host Side Register Map

# 6.6.1 INTERFACE CONTROL REGISTER (ICR)

The ICR is an 8-bit read/write control register used by the host processor to control the HDI08 interrupts and flags. The ICR cannot be accessed by the DSP core. The ICR is a read/write register, which allows the use of bit manipulation instructions on control register bits. The control bits are described in the following paragraphs.

Bits 2, 5 and 6 of the ICR are affected by the condition of HDM[2:0] (HCR bits 5-7), as shown in Figure 6-12.

7 5 4 3 2 0 1 TREQ HLEND HF1 HF0 RREQ For HDM[2:0]=000 INIT HDRQ For HDM[2:0]=100 INIT HM1 HM0 HF1 HF0 TREQ RREQ For HDM1=1 and/or INIT HDM1 HDM0 HF1 HF0 TREO **RREO** HDM0=1HDM[1:0] - These read-only bits reflect the value of the HDM[1:0] bits in the HCR. - Reserved bit. Read as 0. Should be written with 0 for future compatibility.

Figure 6-12 Interface Control Register (ICR)

## 6.6.1.1 ICR Receive Request Enable (RREQ) Bit 0

In interrupt mode (HDM[2:0]=000 or HM[1:0]=00), RREQ is used to enable host receive data requests via the host request (HOREQ or HRRQ) signal when the receive data register full (RXDF) status bit in the ISR is set. If RREQ is cleared, RXDF requests are disabled. If RREQ is set, the host request signal (HOREQ or HRRQ) is asserted if RXDF is set.

In the DMA modes where HDM[2:0]=100 and (HM1≠0 or HM0≠0), RREQ must be set and TREQ must be cleared to direct DMA transfers from DSP to host. In the other DMA modes, RREQ is ignored.

Table 6-9 summarizes the effect of RREQ and TREQ on the HOREQ, HTRQ and HRRQ signals.

#### 6.6.1.2 ICR Transmit Request Enable (TREQ) Bit 1

In interrupt mode (HDM[2:0]=000 or HM[1:0]=00), TREQ is used to enable host transmit data requests via the host request (HOREQ or HTRQ) signal when the transmit data register empty (TXDE) status bit in the ISR is set. If TREQ is cleared, TXDE requests are disabled. If TREQ is set, the host request signal (HOREQ or HTRQ) is asserted if TXDE is set.

# **HDI08 – External Host Programmer's Model**

In the DMA modes where HDM[2:0]=100 and (HM1≠0 or HM0≠0), TREQ must be set and RREQ must be cleared to direct DMA transfers from host to DSP. In the other DMA modes, TREQ is ignored.

Table 6-9 summarizes the effect of RREQ and TREQ on the HOREQ, HTRQ and HRRQ signals.

Table 6-9 TREQ RREQ Interrupt Mode (HDM[2:0]=000 or HM[1:0]=00)

| TREO | RREO | HDRQ=0                              | HDRQ=1                   |                          |  |
|------|------|-------------------------------------|--------------------------|--------------------------|--|
| TREQ | KKEQ | HOREQ signal                        | HTRQ signal              | HRRQ signal              |  |
| 0    | 0    | No Interrupts (Polling)             | No Interrupts (Polling)  | No Interrupts (Polling)  |  |
| 0    | 1    | RXDF Request (Interrupt)            | No Interrupts (Polling)  | RXDF Request (Interrupt) |  |
| 1    | 0    | TXDE Request (Interrupt)            | TXDE Request (Interrupt) | No Interrupts (Polling)  |  |
| 1    | 1    | RXDF and TXDE Requests (Interrupts) | TXDE Request (Interrupt) | RXDF Request (Interrupt) |  |

Table 6-10 TREQ RREQ DMA Mode (HM1≠0 or HM0≠0)

| TREQ | RREQ | HDRQ=0                   | HDRQ=1                   |                          |  |
|------|------|--------------------------|--------------------------|--------------------------|--|
|      |      | HOREQ signal             | HTRQ signal              | HRRQ signal              |  |
| 0    | 0    | No DMA request           | No DMA request           | No DMA request           |  |
| 0    | 1    | DSP to Host Request (RX) | No DMA request           | DSP to Host Request (RX) |  |
| 1    | 0    | Host to DSP Request (TX) | Host to DSP Request (TX) | No DMA request           |  |
| 1    | 1    | Reserved                 | Reserved                 | Reserved                 |  |

# 6.6.1.3 ICR Double Host Request (HDRQ) Bit 2

The HDRQ bit determines the functions of the HOREQ/HTRQ and HACK/HRRQ signals as shown in Table 6-11.

Table 6-11 HDRQ

| HDRQ | HOREQ/HTRQ pin | HACK/HRRQ pin |
|------|----------------|---------------|
| 0    | HOREQ signal   | HACK signal   |
| 1    | HTRQ signal    | HRRQ signal   |

## 6.6.1.4 ICR Host Flag 0 (HF0) Bit 3

The HF0 bit is used as a general purpose flag for host-to-DSP communication. HF0 may be set or cleared by the host processor and cannot be changed by the DSP core. HF0 is reflected in the HSR on the DSP side of the HDI08.

## 6.6.1.5 ICR Host Flag 1 (HF1) Bit 4

The HF1 bit is used as a general purpose flag for host-to-DSP communication. HF1 may be set or cleared by the host processor and cannot be changed by the DSP core. HF1 is reflected in the HSR on the DSP side of the HDI08.

## 6.6.1.6 ICR Host Little Endian (HLEND) Bit 5

If the HLEND bit is cleared, the HDI08 can be accessed by the host in big endian byte order. If set, the HDI08 can be accessed by the host in little endian byte order. If the HLEND bit is cleared, the RXH/TXH register is located at address \$5, the RXM/TXM register is located at address \$6, and the RXL/TXL register is located at address \$7. If the HLEND bit is set, the RXH/TXH register is located at address \$7, the RXM/TXM register is located at address \$6, and the RXL/TXL is located at address \$5. See Table 6-8 for an illustration of the effect of HLEND.

The HLEND function is available only if HDM[2:0]=000 in the host control register (HCR). When HLEND is available, the ICR bit 6 has no function and should be regarded as reserved.

## 6.6.1.7 ICR Host Mode Control (HM1 and HM0 bits) Bits 5-6

Bits 6 and 5 function as read/write HM[1:0] bits only when the HCR bits HDM[2:0]=100 (See Table 6-5). The HM0 and HM1 bits select the transfer mode of the HDI08, as shown in Table 6-12.

| HM1 | HM0 | Mode                     |  |
|-----|-----|--------------------------|--|
| 0   | 0   | Interrupt Mode (DMA Off) |  |
| 0   | 1   | DMA Mode (24 Bit)        |  |
| 1   | 0   | DMA Mode (16 Bit)        |  |
| 1   | 1   | DMA Mode (8 Bit)         |  |

**Table 6-12 Host Mode Bit Definition** 

When both HM1 and HM0 are cleared, the DMA mode is disabled and the interrupt mode is enabled. In interrupt mode, the TREQ and RREQ control bits are used for host processor interrupt control via the external HOREQ output signal, and the HACK input signal is used for the MC68000 Family vectored interrupt acknowledge input.

When HM1 and/or HM0 are set, they enable the DMA mode and determine the size of the DMA word to be transferred. In the DMA mode, the HOREQ signal is used to request DMA transfers, the TREQ and RREQ bits select the direction of DMA transfers (see Table 6-10), and the HACK input signal is used as a DMA transfer acknowledge input. If the DMA direction is from DSP to host, the contents of the selected register are enabled onto the host data bus when HACK is asserted. If the DMA direction is from host to DSP, the selected register is written from the host data bus when HACK is asserted.

## **HDI08 – External Host Programmer's Model**

The size of the DMA word to be transferred is determined by the DMA control bits, HM0 and HM1. The HDI08 host side data register selected during a DMA transfer is determined by a 2-bit address counter, which is preloaded with the value in HM1 and HM0. The address counter substitutes for the HA1 and HA0 host address signals of the HDI08 during a DMA transfer. The host address signal HA2 is forced to one during each DMA transfer. The address counter can be initialized with the INIT bit feature. After each DMA transfer on the host data bus, the address counter is incremented to the next data register. When the address counter reaches the highest register (RXL or TXL), the address counter is not incremented but is loaded with the value in HM1 and HM0. This allows 8-, 16- or 24-bit data to be transferred in a circular fashion and eliminates the need for the DMA controller to supply the HA2, HA1, and HA0 address signals. For 16- or 24-bit data transfers, the DSP CPU interrupt rate is reduced by a factor of 2 or 3, respectively, from the host request rate – i.e., for every two or three host processor data transfers of one byte each, there is only one 24-bit DSP CPU interrupt.

If either HDM1 or HDM0 in the HCR register are set, bits 6 and 5 become read-only bits that reflect the value of HDM[1:0].

## 6.6.1.8 ICR Initialize Bit (INIT) Bit 7

The INIT bit is used by the host processor to force initialization of the HDI08 hardware. During initialization, the HDI08 transmit and receive control bits are configured.

Using the INIT bit to initialize the HDI08 hardware may or may not be necessary, depending on the software design of the interface.

The type of initialization done when the INIT bit is set depends on the state of TREQ and RREQ in the HDI08. The INIT command, which is local to the HDI08, is designed to conveniently configure the HDI08 into the desired data transfer mode. The effect of the INIT command is described in Table 6-13. When the host sets the INIT bit, the HDI08 hardware executes the INIT command. The interface hardware clears the INIT bit after the command has been executed.

| TREQ | RREQ | After INIT Execution                   | Transfer Direction Initialized |
|------|------|----------------------------------------|--------------------------------|
| 0    | 0    | INIT=0                                 | None                           |
| 0    | 1    | INIT=0; RXDF=0; HTDE=1                 | DSP to Host                    |
| 1    | 0    | INIT=0; TXDE=1; HRDF=0                 | Host to DSP                    |
| 1    | 1    | INIT=0; RXDF=0; HTDE=1; TXDE=1; HRDF=0 | Host to/from DSP               |

Table 6-13 INIT Command Effect

## 6.6.2 COMMAND VECTOR REGISTER (CVR)

The CVR is used by the host processor to cause the DSP core to execute an interrupt. The host command feature is independent of any of the data transfer mechanisms in the HDI08. It can be used to invoke execution of any of the 128 possible interrupt routines in the DSP core.

Figure 6-13 Command Vector Register (CVR)

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

## 6.6.2.1 CVR Host Vector (HV[6:0]) Bits 0–6

The seven HV bits select the host command interrupt address to be used by the host command interrupt logic. When the host command interrupt is recognized by the DSP interrupt control logic, the address of the interrupt routine taken is 2 \* HV. The host can write HC and HV in the same write cycle.

The host processor can select the starting address of any of the 128 possible interrupt routines in the DSP by writing the interrupt routine address divided by 2 into the HV bits. The host processor can thus force execution of any of the existing interrupt handlers (IRQA, IRQB, etc.) and can use any of the reserved or otherwise unused addresses provided they have been pre-programmed in the DSP. HV[6:0] is set to \$32 (vector location \$0064) by hardware, software, individual and stop resets.

## 6.6.2.2 CVR Host Command Bit (HC) Bit 7

The HC bit is used by the host processor to handshake the execution of host command interrupts. Normally, the host processor sets HC to request the host command interrupt from the DSP core. When the host command interrupt is acknowledged by the DSP core, the HC bit is cleared by the HDI08 hardware. The host processor can read the state of HC to determine when the host command has been accepted. After setting HC, the host must not write to the CVR again until HC is cleared by the HDI08 hardware. Setting HC causes the host command pending (HCP) in the HSR to be set. The host can write to the HC and HV bits in the same write cycle.

# 6.6.3 INTERFACE STATUS REGISTER (ISR)

The ISR is an 8-bit read-only status register used by the host processor to interrogate the status and flags of the HDI08. The host processor can write to this address without affecting the internal state of the HDI08, which is useful if the user desires to access all of the HDI08

#### **HDI08 – External Host Programmer's Model**

registers by stepping through the HDI08 addresses. The ISR cannot be accessed by the DSP core. The ISR bits are described in the following paragraphs.

Figure 6-14 Interface Status Register (ISR)

| 7                                                                             | 6 | 5 | 4   | 3   | 2    | 1    | 0    |
|-------------------------------------------------------------------------------|---|---|-----|-----|------|------|------|
| HREQ                                                                          |   |   | HF3 | HF2 | TRDY | TXDE | RXDF |
|                                                                               |   |   |     |     |      |      |      |
| - Reserved bit. Read as 0. Should be written with 0 for future compatibility. |   |   |     |     |      |      |      |

## 6.6.3.1 ISR Receive Data Register Full (RXDF) Bit 0

The RXDF bit indicates that the receive byte registers (RXH:RXM:RXL) contain data from the DSP core and may be read by the host processor. RXDF is set when the contents of HOTX is transferred to the receive byte registers. RXDF is cleared when the receive data (RXL or RXH according to HLEND bit) register is read by the host processor. RXDF can be cleared by the host processor using the initialize function. RXDF may be used to assert the external HOREQ signal if the RREQ bit is set. Regardless of whether the RXDF interrupt is enabled, RXDF indicates whether the RX registers are full and data can be latched out (so that polling techniques may be used by the host processor).

## 6.6.3.2 ISR Transmit Data Register Empty (TXDE) Bit 1

The TXDE bit indicates that the transmit byte registers (TXH:TXM:TXL) are empty and can be written by the host processor. TXDE is set when the contents of the transmit byte registers are transferred to the HORX register. TXDE is cleared when the transmit (TXL or TXH according to HLEND bit) register is written by the host processor. TXDE can be set by the host processor using the initialize feature. TXDE may be used to assert the external HOREQ signal if the TREQ bit is set. Regardless of whether the TXDE interrupt is enabled, TXDE indicates whether the TX registers are full and data can be latched in (so that polling techniques may be used by the host processor).

## 6.6.3.3 ISR Transmitter Ready (TRDY) Bit 2

The TRDY status bit indicates that TXH:TXM:TXL and the HORX registers are empty.

If TRDY is set, the data that the host processor writes to TXH:TXM:TXL is immediately transferred to the DSP side of the HDI08. This feature has many applications. For example, if the host processor issues a host command which causes the DSP core to read the HORX, the host processor can be guaranteed that the data it just transferred to the HDI08 is what is being received by the DSP core.

## 6.6.3.4 ISR Host Flag 2 (HF2) Bit 3

The HF2 bit in the ISR indicates the state of host flag 2 in the HCR on the DSP side. HF2 can be changed only by the DSP (see Section 6.5.3.4).

## 6.6.3.5 ISR Host Flag 3 (HF3) Bit 4

The HF3 bit in the ISR indicates the state of host flag 3 in the HCR on the DSP side. HF3 can be changed only by the DSP (see Section 6.5.3.4).

#### 6.6.3.6 ISR Reserved Bits 5-6

These bits are reserved. They read as zero and should be written with zero for future compatibility.

## 6.6.3.7 ISR Host Request (HREQ) Bit 7

The HREQ bit indicates the status of the external host request output signal (HOREQ) if HDRQ is cleared. If HDRQ is set, it indicates the status of the external transmit and receive request output signals (HTRQ and HRRQ).

Table 6-14 Host Request Status (HREQ)

Status [HDRO=0] Status [HDRO=

| HREQ | Status [HDRQ=0]                                            | Status [HDRQ=1]                                                      |
|------|------------------------------------------------------------|----------------------------------------------------------------------|
| 0    | HOREQ deasserted; no host processor interrupt is requested | HTRQ and HRRQ deasserted; no host processor interrupts are requested |
| 1    | HOREQ asserted; a host processor interrupt is requested    | HTRQ and/or HRRQ asserted; host processor interrupts are requested   |

The HREQ bit may be set from either or both of two conditions – either the receive byte registers are full or the transmit byte registers are empty. These conditions are indicated by the ISR RXDF and TXDE status bits, respectively. If the interrupt source has been enabled by the associated request enable bit in the ICR, HREQ is set if one or more of the two enabled interrupt sources is set.

# 6.6.4 INTERRUPT VECTOR REGISTER (IVR)

The IVR is an 8-bit read/write register which 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 IVR are placed on the host data bus (H0–H7) when both the HOREQ and HACK signals are asserted. The contents of this register are initialized to \$0F by hardware or software reset, which corresponds to the uninitialized interrupt vector in the MC68000 Family.

Figure 6-15 Interrupt Vector Register (IVR)

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

## 6.6.5 RECEIVE BYTE REGISTERS (RXH:RXM:RXL)

The receive byte registers are viewed by the host processor as three 8-bit read-only registers. These registers are 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 HOTX register and are selected by the external host address inputs (HA2, HA1 and HA0) during a host processor read operation.

The memory locations of the receive byte registers are determined by the HLEND bit in the ICR. If the HLEND bit is set, the RXH is located at address \$7, RXM at \$6 and RXL at \$5. If the HLEND bit is cleared, the RXH is located at address \$5, RXM at \$6 and RXL at \$7.

When data is transferred from the HOTX register to the receive byte registers, the receive data register full (RXDF) bit is set. The host processor may program the RREQ bit to assert the external HOREQ/HRRQ signal when RXDF is set. This indicates that the HDI08 has a full word (either 8, 16 or 24 bits) for the host processor. When the host reads the receive byte register at host address \$7, the RXDF bit is cleared.

# 6.6.6 TRANSMIT BYTE REGISTERS (TXH:TXM:TXL)

The transmit byte registers are viewed as three 8-bit write-only registers by the host processor. 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 HORX register and are selected by the external host address inputs (HA2, HA1 and HA0) during a host processor write operation.

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

Data may be written into the transmit byte registers when the transmit data register empty (TXDE) bit is set. The host processor may program the TREQ bit to assert the external HOREQ/HTRQ signal when 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 TXDE bit. The contents of the transmit byte registers are transferred as 24-bit data to the HORX register when both TXDE and the HRDF bit are cleared. This transfer operation sets TXDE and HRDF.

## 6.6.7 HOST SIDE REGISTERS AFTER RESET

Table 6-15 shows the result of the four kinds of reset on bits in each of the HDI08 registers seen by the host processor. The hardware reset (HW) is caused by asserting the RESET signal. The software reset (SW) is caused by executing the RESET instruction. The individual reset (IR) is caused by clearing the HEN bit in the HPCR register. The stop reset (ST) is caused by executing the STOP instruction.

| D                | D                    | Reset Type    |                 |                                    |                                  |  |
|------------------|----------------------|---------------|-----------------|------------------------------------|----------------------------------|--|
| Register<br>Name | Register<br>Data     | HW<br>Reset   | SW<br>Reset     | IR<br>Reset                        | ST<br>Reset                      |  |
| ICR              | All Bits             | 0             | 0               | _                                  | _                                |  |
| CVR              | НС                   | 0             | 0               | 0                                  | 0                                |  |
|                  | HV[6:0]              | \$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[7:0]              | \$0F          | \$0F            | _                                  | _                                |  |
| RX               | RXH:RXM:RXL          | empty         | empty           | empty                              | empty                            |  |
| TX               | TXH:TXM:TXL          | empty         | empty           | empty                              | empty                            |  |
|                  | Note: A long dash (- | —) denotes th | at the register | value is not affected by the speci | fied reset.                      |  |

Table 6-15 Host Side Registers After Reset

# 6.6.8 GENERAL PURPOSE INPUT/OUTPUT (GPIO)

When configured as general-purpose I/O, the HDI08 is viewed by the DSP core as memory-mapped registers (see Section 6.5, "HDI08 – DSP-Side Programmer's Model") that control up to 16 I/O pins. The software and hardware resets clear all DSP-side control registers and configure the HDI08 as GPIO with all 16 signals disconnected. External circuitry connected to the HDI08 may need external pull-up/pull-down resistors until the signals are configured for operation. The registers cleared are the HPCR, HDDR and HDR. Selection between GPIO and HDI08 is made by clearing HPCR bits 6 through 1 for GPIO or setting these bits for HDI08 functionality. If the HDI08 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 (see Section 6.5.7 and Section 6.5.8).

## 6.7 SERVICING THE HOST INTERFACE

The HDI08 can be serviced by using one of the following protocols:

- Polling,
- Interrupts

## 6.7.1 HDI08 HOST PROCESSOR DATA TRANSFER

To the host processor, the HDI08 appears as a contiguous block of static RAM. To transfer data between itself and the HDI08, the host processor performs the following steps:

- 1. Asserts the HDI08 address to select the register to be read or written.
- 2. Selects the direction of the data transfer. If it is writing, the host processor drives the data on the bus.
- 3. Strobes the data transfer.

## 6.7.2 POLLING

In the polling mode of operation, the HOREQ/HTRQ signal is not connected to the host processor and HACK must be deasserted to ensure IVR data is not being driven on H0-H7 when other registers are being polled.

The host processor first performs a data read transfer to read the ISR register. This allows the host processor to assess the status of the HDI08:

- 1. If RXDF=1, the receive byte registers are full and therefore a data read can be performed by the host processor.
- 2. If TXDE=1, the transmit byte registers are empty. A data write can be performed by the host processor.
- 3. If TRDY=1, the transmit byte registers and the receive data register on the DSP side are empty. Data written by the host processor is transferred directly to the DSP side.
- 4. If (HF2 HF3) ≠ 0, depending on how the host flags have been defined, may indicate an application-specific state within the DSP core has been reached. Intervention by the host processor may be required.

5. If HREQ=1, the HOREQ/HTRQ/HRRQ signal has been asserted, and the DSP is requesting the attention of the host processor. One of the previous four conditions exists.

After the appropriate data transfer has been made, the corresponding status bit is updated to reflect the transfer.

If the host processor has issued a command to the DSP by writing the CVR and setting the HC bit, it can read the HC bit in the CVR to determine when the command has been accepted by the interrupt controller in the DSP core. When the command has been accepted for execution, the HC bit is cleared by the interrupt controller in the DSP core.



Figure 6-16 HDI08 Host Request Structure

## 6.7.3 SERVICING INTERRUPTS

If either the HOREQ/HTRQ or the HRRQ signal or both are connected to the host processor interrupt inputs, the HDI08 can request service from the host processor by asserting one of these signals. The HOREQ/HTRQ and/or the HRRQ signal is asserted when TXDE=1 and/or RXDF=1 and the corresponding enable bit (TREQ or RREQ, respectively) is set. This is depicted in Figure 6-16.

HOREQ/HTRQ and HRRQ are normally connected to the host processor maskable interrupt inputs. The host processor acknowledges host interrupts by executing an interrupt service routine. The host processor can test RXDF and TXDE to determine the interrupt source. The host processor interrupt service routine must read or write the appropriate HDI08 data register to clear the interrupt. HOREQ/HTRQ and/or HRRQ is deasserted under the following conditions:

## **Servicing The Host Interface**

- The enabled request is cleared or masked
- The DSP is reset.

If the host processor is a member of the MC68000 family, there is no need for the additional step when the host processor reads the ISR to determine how to respond to an interrupt generated by the DSP. Instead, the DSP automatically sources the contents of the IVR on the data bus when the host processor acknowledges the interrupt by asserting HACK. The contents of the IVR are placed on the host data bus while HOREQ and HACK are simultaneously asserted. The IVR data tells the MC680XX host processor which interrupt routine to execute to service the DSP.

# SECTION 7 SERIAL HOST INTERFACE

## 7.1 INTRODUCTION

The Serial Host Interface (SHI) is a serial I/O interface that provides a path for communication and program/coefficient data transfers between the DSP and an external host processor. The SHI can also communicate with other serial peripheral devices. The SHI supports two well-known and widely used synchronous serial buses: the Motorola Serial Peripheral Interface (SPI) bus and the Philips Inter-Integrated-Circuit Control (I<sup>2</sup>C) bus. The SHI supports either bus protocol as either a slave or a single-master device. To minimize DSP overhead, the SHI supports 8-bit, 16-bit and 24-bit data transfers. The SHI has a 1 or 10-word receive FIFO that permits receiving up to 30 bytes before generating a receive interrupt, reducing the overhead for data reception.

When configured in the SPI mode, the SHI can perform the following functions:

- Identify its slave selection (in slave mode)
- Simultaneously transmit (shift out) and receive (shift in) serial data
- Directly operate with 8-, 16- and 24-bit words
- Generate vectored interrupts separately for receive and transmit events and update status bits
- Generate a separate vectored interrupt for a receive exception
- Generate a separate vectored interrupt for a bus-error exception
- Generate the serial clock signal (in master mode)
- Trigger DMA interrupts to service the transmit and receive events

When configured in the I<sup>2</sup>C mode, the SHI can perform the following functions:

- Detect/generate start and stop events
- Identify its slave (ID) address (in slave mode)
- Identify the transfer direction (receive/transmit)
- Transfer data byte-wise according to the SCL clock line

#### Serial Host Interface Internal Architecture

- Generate ACK signal following a byte receive
- Inspect ACK signal following a byte transmit
- Directly operate with 8-, 16- and 24-bit words
- Generate vectored interrupts separately for receive and transmit events and update status bits
- Generate a separate vectored interrupt for a receive exception
- Generate a separate vectored interrupt for a bus error exception
- Generate the clock signal (in master mode)
- Trigger DMA interrupts to service the transmit and receive events

## 7.2 SERIAL HOST INTERFACE INTERNAL ARCHITECTURE

The DSP views the SHI as a memory-mapped peripheral in the X data memory space. The DSP uses the SHI as a normal memory-mapped peripheral using standard polling or interrupt programming techniques and DMA transfers. Memory mapping allows DSP communication with the SHI registers to be accomplished using standard instructions and addressing modes. In addition, the MOVEP instruction allows interface-to-memory and memory-to-interface data transfers without going through an intermediate register. The DMA controller may be used to service the receive or transmit data path. The single master configuration allows the DSP to directly connect to dumb peripheral devices. For that purpose, a programmable baud-rate generator is included to generate the clock signal for serial transfers. The host side invokes the SHI for communication and data transfer with the DSP through a shift register that may be accessed serially using either the I<sup>2</sup>C or the SPI bus protocols. Figure 7-1 shows the SHI block diagram.



Figure 7-1 Serial Host Interface Block Diagram

## 7.3 SHI CLOCK GENERATOR

The SHI clock generator generates the SHI serial clock if the interface operates in the master mode. The clock generator is disabled if the interface operates in the slave mode, except in  $I^2C$  mode when the HCKFR bit is set in the HCKR register. When the SHI operates in the slave mode, the clock is external and is input to the SHI (HMST = 0). Figure 7-2 illustrates the internal clock path connections. It is the user's responsibility to select the proper clock rate within the range as defined in the  $I^2C$  and SPI bus specifications.



Figure 7-2 SHI Clock Generator

# 7.4 SERIAL HOST INTERFACE PROGRAMMING MODEL

The Serial Host Interface programming model has two parts:

- **Host side**—see Figure 7-3 below and Section 7.4.1
- **DSP side**—see Figure 7-4 and Section 7.4.2 through Section 7.4.6 for detailed information.



Figure 7-3 SHI Programming Model—Host Side



Figure 7-4 SHI Programming Model—DSP Side

The SHI interrupt vector table is shown in Table 7-1 and the exception priorities generated by the SHI are shown in Table 7-2.

Table 7-1 SHI Interrupt Vectors

| Program Address | Interrupt Source            |
|-----------------|-----------------------------|
| VBA:\$0040      | SHI Transmit Data           |
| VBA:\$0042      | SHI Transmit Underrun Error |
| VBA:\$0044      | SHI Receive FIFO Not Empty  |
| VBA:\$0048      | SHI Receive FIFO Full       |
| VBA:\$004A      | SHI Receive Overrun Error   |
| VBA:\$004C      | SHI Bus Error               |

**Table 7-2 SHI Internal Interrupt Priorities** 

| Priority | Interrupt                   |  |  |
|----------|-----------------------------|--|--|
| Highest  | SHI Bus Error               |  |  |
|          | SHI Receive Overrun Error   |  |  |
|          | SHI Transmit Underrun Error |  |  |
|          | SHI Receive FIFO Full       |  |  |
|          | SHI Transmit Data           |  |  |
| Lowest   | SHI Receive FIFO Not Empty  |  |  |

# 7.4.1 SHI INPUT/OUTPUT SHIFT REGISTER (IOSR)—HOST SIDE

The variable length Input/Output Shift Register (IOSR) can be viewed as a serial-to-parallel and parallel-to-serial buffer in the SHI. The IOSR is involved with every data transfer in both directions (read and write). In compliance with the I<sup>2</sup>C and SPI bus protocols, data is shifted in and out MSB first. In 8-bit data transfer modes, the most significant byte of the IOSR is used as the shift register. In 16-bit data transfer modes, the two most significant bytes become the shift register. In 24-bit transfer modes, the shift register uses all three bytes of the IOSR (see Figure 7-5).

**Note:** The IOSR cannot be accessed directly either by the host processor or by the DSP. It is fully controlled by the SHI controller logic.



Figure 7-5 SHI I/O Shift Register (IOSR)

# 7.4.2 SHI HOST TRANSMIT DATA REGISTER (HTX)—DSP SIDE

The host transmit data register (HTX) is used for DSP-to-Host data transfers. The HTX register is 24 bits wide. Writing to the HTX register by DSP core instructions or by DMA transfers clears the HTDE flag. The DSP may program the HTIE bit to cause a host transmit data interrupt when HTDE is set (see **7.4.6.10 HCSR Transmit-Interrupt Enable** (HTIE)—Bit 11 on page 7-15). Data should not be written to the HTX until HTDE is set in order to prevent overwriting the previous data. HTX is reset to the empty state when in stop mode and during hardware reset, software reset, and individual reset.

In the 8-bit data transfer mode the most significant byte of the HTX is transmitted; in the 16-bit mode the two most significant bytes, and in the 24-bit mode all the contents of HTX is transferred.

# 7.4.3 SHI HOST RECEIVE DATA FIFO (HRX)—DSP SIDE

The 24-bit host receive data FIFO (HRX) is a 10-word deep, First-In-First-Out (FIFO) register used for Host-to-DSP data transfers. The serial data is received via the shift register and then loaded into the HRX. In the 8-bit data transfer mode, the most significant byte of the shift register is transferred to the HRX (the other bits are cleared); in the 16-bit mode the two most significant bytes are transferred (the least significant byte is cleared), and in the 24-bit mode, all 24 bits are transferred to the HRX. The HRX may be read by the DSP while the FIFO is

being loaded from the shift register. Reading all data from HRX clears the HRNE flag. The HRX may be read by DSP core instructions or by DMA transfers. The HRX FIFO is reset to the empty state when the chip is in stop mode, and during hardware reset, software reset, and individual reset.

# 7.4.4 SHI SLAVE ADDRESS REGISTER (HSAR)—DSP SIDE

The 24-bit slave address register (HSAR) is used when the SHI operates in the  $I^2C$  slave mode and is ignored in the other operational modes. HSAR holds five bits of the 7-bit slave device address. The SHI also acknowledges the general call address specified by the  $I^2C$  protocol (eight zeroes comprising a 7-bit address and a  $R/\overline{W}$  bit), but treats any following data bytes as regular data. That is, the SHI does not differentiate between its dedicated address and the general call address. HSAR cannot be accessed by the host processor.

## 7.4.4.1 HSAR Reserved Bits—Bits 19, 17–0

These bits are reserved. They read as zero and should be written with zero for future compatibility.

# 7.4.4.2 HSAR I<sup>2</sup>C Slave Address (HA[6:3], HA1)—Bits 23–20,18

Part of the I<sup>2</sup>C slave device address is stored in the read/write HA[6:3], HA1 bits of HSAR. The full 7-bit slave device address is formed by combining the HA[6:3], HA1 bits with the HA0 and HA2 pins to obtain the HA[6:0] slave device address. The full 7-bit slave device address is compared to the received address byte whenever an I<sup>2</sup>C master device initiates an I<sup>2</sup>C bus transfer. During hardware reset or software reset, HA[6:3] = 1011 and HA1 is cleared; this results in a default slave device address of 1011[HA2]0[HA0].

# 7.4.5 SHI CLOCK CONTROL REGISTER (HCKR)—DSP SIDE

The HCKR is a 24-bit read/write register that controls SHI clock generator operation. The HCKR bits should be modified only while the SHI is in the individual reset state (HEN = 0 in the HCSR).

For proper SHI clock setup, please consult the datasheet. The programmer should not use the combination HRS = 1 and HDM[7:0] = 00000000, since it may cause synchronization problems and improper operation (it is an illegal combination).

The HCKR bits are cleared during hardware reset or software reset, except for CPHA, which is set. The HCKR is not affected by the stop state.

The HCKR bits are described in the following paragraphs.

## 7.4.5.1 Clock Phase and Polarity (CPHA and CPOL)—Bits 1–0

The Clock Phase (CPHA) bit controls the relationship between the data on the master-in-slave-out (MISO) and master-out-slave-in (MOSI) pins and the clock produced or received at the SCK pin. The CPOL bit determines the clock polarity (1 = active-high, 0 = active-low).

The clock phase and polarity should be identical for both the master and slave SPI devices. CPHA and CPOL are functional only when the SHI operates in the SPI mode, and are ignored in the I<sup>2</sup>C mode. The CPHA bit is set and the CPOL bit is cleared during hardware reset and software reset.

The programmer may select any of four combinations of serial clock (SCK) phase and polarity when operating in the SPI mode (See Figure 7-6).



Figure 7-6 SPI Data-To-Clock Timing Diagram

If CPOL is cleared, it produces a steady-state low value at the SCK pin of the master device whenever data is not being transferred. If the CPOL bit is set, it produces a high value at the SCK pin of the master device whenever data is not being transferred.

CPHA is used with the CPOL bit to select the desired clock-to-data relationship. The CPHA bit, in general, selects the clock edge that captures data and allows it to change states. It has its greatest impact on the first bit transmitted (MSB) in that it does or does not allow a clock transition before the data capture edge.

When the SHI is in slave mode and CPHA = 0, the  $\overline{SS}$  line must be deasserted and asserted by the external master between each successive word transfer.  $\overline{SS}$  must remain asserted between successive bytes within a word. The DSP core should write the next data word to HTX when HTDE = 1, clearing HTDE. However, the data is transferred to the shift register for transmission only when  $\overline{SS}$  is deasserted. HTDE is set when the data is transferred from HTX to the shift register.

When the SHI is in slave mode and CPHA = 1, the  $\overline{SS}$  line may remain asserted between successive word transfers. The  $\overline{SS}$  must remain asserted between successive bytes within a word. The DSP core should write the next data word to HTX when HTDE = 1, clearing HTDE. The HTX data is transferred to the shift register for transmission as soon as the shift register is empty. HTDE is set when the data is transferred from HTX to the shift register.

When the SHI is in master mode and CPHA = 0, the DSP core should write the next data word to HTX when HTDE = 1, clearing HTDE. The data is transferred immediately to the shift register for transmission. HTDE is set only at the end of the data word transmission.

**Note:** The master is responsible for deasserting and asserting the slave device  $\overline{SS}$  line between word transmissions.

When the SHI is in master mode and CPHA = 1, the DSP core should write the next data word to HTX when HTDE = 1, clearing HTDE. The HTX data is transferred to the shift register for transmission as soon as the shift register is empty. HTDE is set when the data is transferred from HTX to the shift register.

## 7.4.5.2 HCKR Prescaler Rate Select (HRS)—Bit 2

The HRS bit controls a prescaler in series with the clock generator divider. This bit is used to extend the range of the divider when slower clock rates are desired. When HRS is set, the prescaler is bypassed. When HRS is cleared, the fixed divide-by-eight prescaler is operational. HRS is ignored when the SHI operates in the slave mode, except for I<sup>2</sup>C when HCKFR is set. The HRS bit is cleared during hardware reset and software reset.

**Note:** Use the equations in the SHI datasheet to determine the value of HRS for the specific serial clock frequency required.

## 7.4.5.3 HCKR Divider Modulus Select (HDM[7:0])—Bits 10–3

The HDM[7:0] bits specify the divide ratio of the clock generator divider. A divide ratio between 1 and 256 (HDM[7:0] = \$00 to \$FF) may be selected. When the SHI operates in the slave mode, the HDM[7:0] bits are ignored (except for  $I^2C$  when HCKFR is set). The HDM[7:0] bits are cleared during hardware reset and software reset.

**Note:** Use the equations in the SHI datasheet to determine the value of HDM[7:0] for the specific serial clock frequency required.

## 7.4.5.4 HCKR Reserved Bits—Bits 23–14, 11

These bits in HCKR are reserved. They are read as zero and should be written with zero for future compatibility.

## 7.4.5.5 HCKR Filter Mode (HFM[1:0]) — Bits 13–12

The read/write control bits HFM[1:0] specify the operational mode of the noise reduction filters, as described in Table 7-3. The filters are designed to eliminate undesired spikes that might occur on the clock and data-in lines and allow the SHI to operate in noisy environments when required. One filter is located in the input path of the SCK/SCL line and the other is located in the input path of the data line (i.e., the SDA line when in I<sup>2</sup>C mode, the MISO line when in SPI master mode, and the MOSI line when in SPI slave mode).

| HFM1 | HFM0 | Description            |
|------|------|------------------------|
| 0    | 0    | Bypassed (Disabled)    |
| 0    | 1    | Reserved               |
| 1    | 0    | Narrow Spike Tolerance |
| 1    | 1    | Wide Spike Tolerance   |

Table 7-3 SHI Noise Reduction Filter Mode

When HFM[1:0] = 00, the filter is bypassed (spikes are **not** filtered out). This mode is useful when higher bit-rate transfers are required and the SHI operates in a noise-free environment.

When HFM[1:0] = 10, the narrow-spike-tolerance filter mode is selected. In this mode the filters eliminate spikes with durations of up to 50ns. This mode is suitable for use in mildly noisy environments and imposes some limitations on the maximum achievable bit-rate transfer.

When HFM[1:0] = 11, the wide-spike-tolerance filter mode is selected. In this mode the filters eliminate spikes up to 100 ns. This mode is recommended for use in noisy environments; the bit-rate transfer is strictly limited. The wide-spike- tolerance filter mode is highly recommended for use in  $I^2C$  bus systems as it fully conforms to the  $I^2C$  bus specification and improves noise immunity.

**Note:** HFM[1:0] are cleared during hardware reset and software reset.

After changing the filter bits in the HCKR to a non-bypass mode (HFM[1:0] not equal to '00'), the programmer should wait at least ten times the tolerable spike width before enabling the SHI (setting the HEN bit in the HCSR). Similarly, after changing the HI<sup>2</sup>C bit in the HCSR or the CPOL bit in the HCKR, while the filter mode bits are in a non-bypass mode (HFM[1:0] not equal to '00'), the programmer should wait at least ten times the tolerable spike width before enabling the SHI (setting HEN in the HCSR).

# 7.4.6 SHI CONTROL/STATUS REGISTER (HCSR)—DSP SIDE

The HCSR is a 24-bit register that controls the SHI operation and reflects its status. The control bits are read/write. The status bits are read-only. The bits are described in the following paragraphs. When in the stop state or during individual reset, the HCSR status bits are reset to their hardware-reset state, while the control bits are not affected.

## 7.4.6.1 HCSR Host Enable (HEN)—Bit 0

The read/write control bit HEN, when set, enables the SHI. When HEN is cleared, the SHI is disabled (that is, it is in the individual reset state, see below). The HCKR and the HCSR control bits are not affected when HEN is cleared. When operating in master mode, HEN should be cleared only when the SHI is idle (HBUSY = 0). HEN is cleared during hardware reset and software reset.

## 7.4.6.1.1 SHI Individual Reset

While the SHI is in the individual reset state, SHI input pins are inhibited, output and bidirectional pins are disabled (high impedance), the HCSR status bits and the transmit/receive paths are reset to the same state produced by hardware reset or software reset. The individual reset state is entered following a one-instruction-cycle delay after clearing HEN.

# 7.4.6.2 HCSR I<sup>2</sup>C/SPI Selection (HI<sup>2</sup>C)—Bit 1

The read/write control bit HI<sup>2</sup>C selects whether the SHI operates in the I<sup>2</sup>C or SPI modes. When HI<sup>2</sup>C is cleared, the SHI operates in the SPI mode. When HI<sup>2</sup>C is set, the SHI operates in the I<sup>2</sup>C mode. HI<sup>2</sup>C affects the functionality of the SHI pins as described in Section 2, Signal/Connection Descriptions. It is recommended that an SHI individual reset be generated (HEN cleared) before changing HI<sup>2</sup>C. HI<sup>2</sup>C is cleared during hardware reset and software reset.

# 7.4.6.3 HCSR Serial Host Interface Mode (HM[1:0])—Bits 3–2

The read/write control bits HM[1:0] select the size of the data words to be transferred, as shown in Table 7-4. HM[1:0] should be modified only when the SHI is idle (HBUSY = 0). HM[1:0] are cleared during hardware reset and software reset.

| HM1 | нмо | Description |
|-----|-----|-------------|
| 0   | 0   | 8-bit data  |
| 0   | 1   | 16-bit data |
| 1   | 0   | 24-bit data |
| 1   | 1   | Reserved    |

Table 7-4 SHI Data Size

# 7.4.6.4 HCSR I<sup>2</sup>C Clock Freeze (HCKFR)—Bit 4

The read/write control bit HCKFR determines the behavior of the SHI when the SHI is unable to service the master request, when operating in the  $I^2C$  slave mode. The HCKFR bit is used only in the  $I^2C$  slave mode; it is ignored otherwise.

If HCKFR is set, the SHI holds the clock line to GND if it is not ready to send data to the master during a read transfer or if the input FIFO is full when the master attempts to execute a write transfer. In this way, the master may detect that the slave is not ready for the requested transfer, without causing an error condition in the slave. When HCKFR is set for transmit sessions, the SHI clock generator must be programmed as if to generate the same serial clock as produced by the external master, otherwise erroneous operation may result. The programmed frequency should be in the range of 1 to 0.75 times the external clock frequency.

If HCKFR is cleared, any attempt from the master to execute a transfer when the slave is not ready results in an overrun or underrun error condition.

It is recommended that an SHI individual reset be generated (HEN cleared) before changing HCKFR. HCKFR is cleared during hardware reset and software reset.

## 7.4.6.5 HCSR FIFO-Enable Control (HFIFO)—Bit 5

The read/write control bit HFIFO selects the receive FIFO size. When HFIFO is cleared, the FIFO has one level. When HFIFO is set, the FIFO has 10 levels. It is recommended that an SHI individual reset be generated (HEN cleared) before changing HFIFO. HFIFO is cleared during hardware reset and software reset.

## 7.4.6.6 HCSR Master Mode (HMST)—Bit 6

The read/write control bit HMST determines the SHI operating mode. If HMST is set, the interface operates in the master mode. If HMST is cleared, the interface operates in the slave mode. The SHI supports a single-master configuration in both I<sup>2</sup>C and SPI modes.

When configured as an SPI master, the SHI drives the SCK line and controls the direction of the data lines MOSI and MISO. The  $\overline{SS}$  line must be held deasserted in the SPI master mode; if the  $\overline{SS}$  line is asserted when the SHI is in SPI master mode, a bus error is generated (the HCSR HBER bit is set—see Section 7.4.6.18).

When configured as an I<sup>2</sup>C master, the SHI controls the I<sup>2</sup>C bus by generating start events, clock pulses, and stop events for transmission and reception of serial data.

It is recommended that an SHI individual reset be generated (HEN cleared) before changing HMST. HMST is cleared during hardware reset and software reset.

## 7.4.6.7 HCSR Host-Request Enable (HRQE[1:0])—Bits 8–7

The read/write control bits HRQE[1:0] are used to control the  $\overline{HREQ}$  pin. When HRQE[1:0] are cleared, the  $\overline{HREQ}$  pin is disabled and held in the high impedance state. If either of HRQE[1:0] are set and the SHI is in a master mode, the  $\overline{HREQ}$  pin becomes an input controlling SCK: deasserting  $\overline{HREQ}$  suspends SCK. If either of HRQE[1:0] are set and the SHI is in a slave mode,  $\overline{HREQ}$  becomes an output and its operation is defined in Table 7-5. HRQE[1:0] should be changed only when the SHI is idle (HBUSY = 0). HRQE[1:0] are cleared during hardware reset and software reset.

| HRQE1 | HRQE0 | HREQ Pin Operation                                                                                                           |
|-------|-------|------------------------------------------------------------------------------------------------------------------------------|
| 0     | 0     | High impedance                                                                                                               |
| 0     | 1     | Asserted if IOSR is ready to receive a new word                                                                              |
| 1     | 0     | Asserted if IOSR is ready to transmit a new word                                                                             |
| 1     | 1     | I <sup>2</sup> C: Asserted if IOSR is ready to transmit or receive<br>SPI: Asserted if IOSR is ready to transmit and receive |

Table 7-5 HREQ Function In SHI Slave Modes

## 7.4.6.8 HCSR Idle (HIDLE)—Bit 9

The read/write control/status bit HIDLE is used only in the I<sup>2</sup>C master mode; it is ignored otherwise. It is only possible to set the HIDLE bit during writes to the HCSR. HIDLE is cleared by writing to HTX. To ensure correct transmission of the slave device address byte, HIDLE should be set only when HTX is empty (HTDE = 1). After HIDLE is set, a write to HTX clears HIDLE and causes the generation of a stop event, a start event, and then the transmission of the eight MSBs of the data as the slave device address byte. While HIDLE is cleared, data written to HTX is transmitted as is. If the SHI completes transmitting a word and there is no new data in HTX, the clock is suspended after sampling ACK. If HIDLE is set when the SHI completes transmitting a word with no new data in HTX, a stop event is generated.

HIDLE determines the acknowledge that the receiver sends after correct reception of a byte. If HIDLE is cleared, the reception is acknowledged by sending a 0 bit on the SDA line at the ACK clock tick. If HIDLE is set, the reception is not acknowledged (a 1 bit is sent). It is used to signal an end-of-data to a slave transmitter by not generating an ACK on the last byte. As a result, the slave transmitter must release the SDA line to allow the master to generate the stop event. If the SHI completes receiving a word and the HRX FIFO is full, the clock is suspended before transmitting an ACK. While HIDLE is cleared the bus is busy, that is, the start event was sent but no stop event was generated. Setting HIDLE causes a stop event after receiving the current word.

HIDLE is set while the SHI is not in the I<sup>2</sup>C master mode, while the chip is in the stop state, and during hardware reset, software reset and individual reset.

**Note:** Programmers should take care to ensure that all DMA channel service to HTX is disabled before setting HIDLE.

## 7.4.6.9 HCSR Bus-Error Interrupt Enable (HBIE)—Bit 10

The read/write control bit HBIE is used to enable the SHI bus-error interrupt. If HBIE is cleared, bus-error interrupts are disabled, and the HBER status bit must be polled to determine if an SHI bus error occurred. If both HBIE and HBER are set, the SHI requests an SHI bus-error interrupt service from the interrupt controller. HBIE is cleared by hardware reset and software reset.

Note:

Clearing HBIE masks a pending bus-error interrupt only after a one instruction cycle delay. If HBIE is cleared in a long interrupt service routine, it is recommended that at least one other instruction separate the instruction that clears HBIE and the RTI instruction at the end of the interrupt service routine.

## 7.4.6.10 HCSR Transmit-Interrupt Enable (HTIE)—Bit 11

The read/write control bit HTIE is used to enable the SHI transmit data interrupts. If HTIE is cleared, transmit interrupts are disabled, and the HTDE status bit must be polled to determine if HTX is empty. If both HTIE and HTDE are set and HTUE is cleared, the SHI requests an SHI transmit-data interrupt service from the interrupt controller. If both HTIE and HTUE are set, the SHI requests an SHI transmit-underrun-error interrupt service from the interrupt controller. HTIE is cleared by hardware reset and software reset.

Note:

Clearing HTIE masks a pending transmit interrupt only after a one instruction cycle delay. If HTIE is cleared in a long interrupt service routine, it is recommended that at least one other instruction separate the instruction that clears HTIE and the RTI instruction at the end of the interrupt service routine.

## 7.4.6.11 HCSR Receive Interrupt Enable (HRIE[1:0])—Bits 13–12

The read/write control bits HRIE[1:0] are used to enable the SHI receive-data interrupts. If HRIE[1:0] are cleared, receive interrupts are disabled, and the HRNE and HRFF (bits 17 and 19, see below) status bits must be polled to determine if there is data in the receive FIFO. If

HRIE[1:0] are not cleared, receive interrupts are generated according to Table 7-6. HRIE[1:0] are cleared by hardware and software reset.

Table 7-6 HCSR Receive Interrupt Enable Bits

| HRIE[1:0] | Interrupt                                       | Condition                         |
|-----------|-------------------------------------------------|-----------------------------------|
| 00        | Disabled                                        | Not applicable                    |
| 01        | Receive FIFO not empty<br>Receive Overrun Error | HRNE = 1 and HROE = 0<br>HROE = 1 |
| 10        | Reserved                                        | Not applicable                    |
| 11        | Receive FIFO full<br>Receive Overrun Error      | HRFF = 1 and HROE = 0<br>HROE = 1 |

Note:

Clearing HRIE[1:0] masks a pending receive interrupt only after a one instruction cycle delay. If HRIE[1:0] are cleared in a long interrupt service routine, it is recommended that at least one other instruction separate the instruction that clears HRIE[1:0] and the RTI instruction at the end of the interrupt service routine.

## 7.4.6.12 HCSR Host Transmit Underrun Error (HTUE)—Bit 14

The read-only status bit HTUE indicates whether a transmit-underrun error occurred. Transmit-underrun errors can occur only when operating in the SPI slave mode or the I<sup>2</sup>C slave mode when HCKFR is cleared. In a master mode, transmission takes place on demand and no underrun can occur. HTUE is set when both the shift register and the HTX register are empty and the external master begins reading the next word:

- When operating in the I<sup>2</sup>C mode, HTUE is set in the falling edge of the ACK bit. In this case, the SHI retransmits the previously transmitted word.
- When operating in the SPI mode, HTUE is set at the first clock edge if CPHA = 1; it is set at the assertion of  $\overline{SS}$  if CPHA = 0.

If a transmit interrupt occurs with HTUE set, the transmit-underrun interrupt vector is generated. If a transmit interrupt occurs with HTUE cleared, the regular transmit-data interrupt vector is generated. HTUE is cleared by reading the HCSR and then writing to the HTX register. HTUE is cleared by hardware reset, software reset, SHI individual reset, and during the stop state.

# 7.4.6.13 HCSR Host Transmit Data Empty (HTDE)—Bit 15

The read-only status bit HTDE indicates whether the HTX register is empty and can be written by the DSP. HTDE is set when the data word is transferred from HTX to the shift register, except in SPI master mode when CPHA = 0 (see HCKR). When in the SPI master mode with CPHA = 0, HTDE is set after the end of the data word transmission. HTDE is

cleared when the DSP writes the HTX either with write instructions or DMA transfers. HTDE is set by hardware reset, software reset, SHI individual reset, and during the stop state.

## 7.4.6.14 HCSR Reserved Bits—Bits 23, 18 and 16

These bits are reserved. They read as zero and should be written with zero for future compatibility.

## 7.4.6.15 Host Receive FIFO Not Empty (HRNE)—Bit 17

The read-only status bit HRNE indicates that the Host Receive FIFO (HRX) contains at least one data word. HRNE is set when the FIFO is not empty. HRNE is cleared when HRX is read by the DSP (read instructions or DMA transfers), reducing the number of words in the FIFO to zero. HRNE is cleared during hardware reset, software reset, SHI individual reset, and during the stop state.

## 7.4.6.16 Host Receive FIFO Full (HRFF)—Bit 19

The read-only status bit HRFF indicates, when set, that the Host Receive FIFO (HRX) is full. HRFF is cleared when HRX is read by the DSP (read instructions or DMA transfers) and at least one place is available in the FIFO. HRFF is cleared by hardware reset, software reset, SHI individual reset, and during the stop state.

## 7.4.6.17 Host Receive Overrun Error (HROE)—Bit 20

The read-only status bit HROE indicates, when set, that a data-receive overrun error has occurred. Receive-overrun errors cannot occur when operating in the I<sup>2</sup>C master mode, because the clock is suspended if the receive FIFO is full; nor can they occur in the I<sup>2</sup>C slave mode when HCKFR is set.

HROE is set when the shift register (IOSR) is filled and ready to transfer the data word to the HRX FIFO and the FIFO is already full (HRFF is set). When a receive-overrun error occurs, the shift register is not transferred to the FIFO. If a receive interrupt occurs with HROE set, the receive-overrun interrupt vector is generated. If a receive interrupt occurs with HROE cleared, the regular receive-data interrupt vector is generated.

HROE is cleared by reading the HCSR with HROE set, followed by reading HRX. HROE is cleared by hardware reset, software reset, SHI individual reset, and during the stop state.

## 7.4.6.18 Host Bus Error (HBER)—Bit 21

The read-only status bit HBER indicates, when set, that an SHI bus error occurred when operating as a master (HMST set). In  $I^2C$  mode, HBER is set if the transmitter does not receive an acknowledge after a byte is transferred; then a stop event is generated and transmission is suspended. In SPI mode, HBER is set if  $\overline{SS}$  is asserted; then transmission is suspended at the end of transmission of the current word. HBER is cleared only by hardware reset, software reset, SHI individual reset, and during the stop state.

#### **Characteristics Of The SPI Bus**

## 7.4.6.19 HCSR Host Busy (HBUSY)—Bit 22

The read-only status bit HBUSY indicates that the  $I^2C$  bus is busy (when in the  $I^2C$  mode) or that the SHI itself is busy (when in the SPI mode). When operating in the  $I^2C$  mode, HBUSY is set after the SHI detects a start event and remains set until a stop event is detected. When operating in the slave SPI mode, HBUSY is set while  $\overline{SS}$  is asserted. When operating in the master SPI mode, HBUSY is set if the HTX register is not empty or if the IOSR is not empty. HBUSY is cleared otherwise. HBUSY is cleared by hardware reset, software reset, SHI individual reset, and during the stop state.

## 7.5 CHARACTERISTICS OF THE SPI BUS

The SPI bus consists of two serial data lines (MISO and MOSI), a clock line (SCK), and a Slave Select line ( $\overline{SS}$ ). During an SPI transfer, a byte is shifted out one data pin while a different byte is simultaneously shifted in through a second data pin. It can be viewed as two 8-bit shift registers connected together in a circular manner, with one shift register on the master side and the other on the slave side. Thus the data bytes in the master device and slave device are exchanged. The MISO and MOSI data pins are used for transmitting and receiving serial data. When the SPI is configured as a master, MISO is the master data input line, and MOSI is the master data output line. When the SPI is configured as a slave device, MISO is the slave data output line, and MOSI is the slave data input line.

Clock control logic allows a selection of clock polarity and a choice of two fundamentally different clocking protocols to accommodate most available synchronous serial peripheral devices. When the SPI is configured as a master, the control bits in the HCKR select the appropriate clock rate, as well as the desired clock polarity and phase format (see Figure 7-6).

The  $\overline{SS}$  line allows selection of an individual slave SPI device; slave devices that are not selected do not interfere with SPI bus activity (i.e., they keep their MISO output pin in the high-impedance state). When the SHI is configured as an SPI master device, the  $\overline{SS}$  line should be held high. If the  $\overline{SS}$  line is driven low when the SHI is in SPI master mode, a bus error is generated (the HCSR HBER bit is set).

# 7.6 CHARACTERISTICS OF THE I<sup>2</sup>C BUS

The  $I^2C$  serial bus consists of two bidirectional lines, one for data signals (SDA) and one for clock signals (SCL). Both the SDA and SCL lines must be connected to a positive supply voltage via a pull-up resistor.

**Note:** In the I<sup>2</sup>C bus specifications, the standard mode (100 kHz clock rate) and a fast mode (400 kHz clock rate) are defined. The SHI can operate in either mode.

## 7.6.1 OVERVIEW

The I<sup>2</sup>C bus protocol must conform to the following rules:

- Data transfer may be initiated only when the bus is not busy.
- During data transfer, the data line must remain stable whenever the clock line is high. Changes in the data line when the clock line is high are interpreted as control signals (see Figure 7-7).



Figure 7-7 I<sup>2</sup>C Bit Transfer

Accordingly, the I<sup>2</sup>C bus protocol defines the following events:

- **Bus not busy**—Both data and clock lines remain high.
- **Start data transfer**—The start event is defined as a change in the state of the data line, from high to low, while the clock is high (see Figure 7-8).
- **Stop data transfer**—The stop event is defined as a change in the state of the data line, from low to high, while the clock is high (see Figure 7-8).
- **Data valid**—The state of the data line represents valid data when, after a start event, the data line is stable for the duration of the high period of the clock signal. The data on the line may be changed during the low period of the clock signal. There is one clock pulse per bit of data.

#### Characteristics Of The I<sup>2</sup>C Bus



Figure 7-8 I<sup>2</sup>C Start and Stop Events

Each 8-bit word is followed by one acknowledge bit. This acknowledge bit is a high level put on the bus by the transmitter when the master device generates an extra acknowledge-related clock pulse. A slave receiver that is addressed must generate an acknowledge after each byte is received. Also, a master receiver must generate an acknowledge after the reception of each byte that has been clocked out of the slave transmitter. The acknowledging device must pull down the SDA line during the acknowledge clock pulse so that the SDA line is stable low during the high period of the acknowledge-related clock pulse (see Figure 7-9).



Figure 7-9 Acknowledgment on the I<sup>2</sup>C Bus

A device generating a signal is called a transmitter, and a device receiving a signal is called a receiver. A device controlling a signal is called a master and devices controlled by the master are called slaves. A master receiver must signal an end-of-data to the slave transmitter by not generating an acknowledge on the last byte clocked out of the slave device. In this case the transmitter must leave the data line high to enable the master to generate the stop event. Handshaking may also be accomplished by using the clock synchronizing mechanism. Slave devices can hold the SCL line low, after receiving and acknowledging a byte, to force the master into a wait state until the slave device is ready for the next byte transfer. The SHI

supports this feature when operating as a master device and waits until the slave device releases the SCL line before proceeding with the data transfer.

## 7.6.2 I<sup>2</sup>C DATA TRANSFER FORMATS

I<sup>2</sup>C bus data transfers follow the following process: after the start event, a slave device address is sent. The address consists of seven address bits and an eighth bit as a data direction bit (R/W). In the data direction bit, zero indicates a transmission (write), and one indicates a request for data (read). A data transfer is always terminated by a stop event generated by the master device. However, if the master device still wishes to communicate on the bus, it can generate another start event, and address another slave device without first generating a stop event (the SHI does not support this feature when operating as an I<sup>2</sup>C master device). This method is also used to provide indivisible data transfers. Various combinations of read/write formats are illustrated in Figure 7-10 and Figure 7-11.



Figure 7-10 I<sup>2</sup>C Bus Protocol For Host Write Cycle



Figure 7-11 I<sup>2</sup>C Bus Protocol For Host Read Cycle

## **SHI Programming Considerations**

Note:

The first data byte in a write-bus cycle can be used as a user-predefined control byte (e.g., to determine the location to which the forthcoming data bytes should be transferred).

## 7.7 SHI PROGRAMMING CONSIDERATIONS

The SHI implements both SPI and I<sup>2</sup>C bus protocols and can be programmed to operate as a slave device or a single-master device. Once the operating mode is selected, the SHI may communicate with an external device by receiving and/or transmitting data. Before changing the SHI operational mode, an SHI individual reset should be generated by clearing the HEN bit. The following paragraphs describe programming considerations for each operational mode.

## 7.7.1 SPI SLAVE MODE

The SPI slave mode is entered by enabling the SHI (HEN=1), selecting the SPI mode (HI<sup>2</sup>C=0), and selecting the slave mode of operation (HMST=0). The programmer should verify that the CPHA and CPOL bits (in the HCKR) correspond to the external host clock phase and polarity. Other HCKR bits are ignored. When configured in the SPI slave mode, the SHI external pins operate as follows:

- SCK/SCL is the SCK serial clock input.
- MISO/SDA is the MISO serial data output.
- MOSI/HA0 is the MOSI serial data input.
- $\overline{SS}/HA2$  is the  $\overline{SS}$  slave select input.
- HREQ is the Host Request output.

In the SPI slave mode, a receive, transmit, or full-duplex data transfer may be performed. Actually, the interface performs data receive and transmit simultaneously. The status bits of both receive and transmit paths are active; however, the programmer may disable undesired interrupts and ignore irrelevant status bits. It is recommended that an SHI individual reset (HEN cleared) be generated before beginning data reception in order to reset the HRX FIFO to its initial (empty) state (e.g., when switching from transmit to receive data).

If a write to HTX occurs, its contents are transferred to IOSR between data word transfers. The IOSR data is shifted out (via MISO) and received data is shifted in (via MOSI). The DSP may write HTX with either DSP instructions or DMA transfers if the HTDE status bit is set. If no writes to HTX occur, the contents of HTX are not transferred to IOSR, so the data shifted

#### SHI Programming Considerations

out when receiving is the data present in the IOSR at the time. The HRX FIFO contains valid receive data, which the DSP can read with either DSP instructions or DMA transfers (if the HRNE status bit is set).

The  $\overline{HREQ}$  output pin, if enabled for receive (HRQE[1:0] = 01), is asserted when the IOSR is ready for receive and the HRX FIFO is not full; this operation guarantees that the next received data word is stored in the FIFO. The  $\overline{HREQ}$  output pin, if enabled for transmit (HRQE[1:0] = 10), is asserted when the IOSR is loaded from HTX with a new data word to transfer. If  $\overline{HREQ}$  is enabled for both transmit and receive (HRQE[1:0] = 11), it is asserted when the receive and transmit conditions are both true.  $\overline{HREQ}$  is deasserted at the first clock pulse of the next data word transfer. The  $\overline{HREQ}$  line may be used to interrupt the external master device. Connecting the  $\overline{HREQ}$  line between two SHI-equipped DSPs, one operating as an SPI master device and the other as an SPI slave device, enables full hardware handshaking if operating with CPHA = 1.

The  $\overline{SS}$  line should be kept asserted during a data word transfer. If the  $\overline{SS}$  line is deasserted before the end of the data word transfer, the transfer is aborted and the received data word is lost.

#### 7.7.2 SPI MASTER MODE

The SPI master mode is initiated by enabling the SHI (HEN = 1), selecting the SPI mode ( $HI^2C=0$ ), and selecting the master mode of operation (HMST = 1). Before enabling the SHI as an SPI master device, the programmer should program the proper clock rate, phase and polarity in HCKR. When configured in the SPI master mode, the SHI external pins operate as follows:

- SCK/SCL is the SCK serial clock output.
- MISO/SDA is the MISO serial data input.
- MOSI/HA0 is the MOSI serial data output.
- $\overline{SS}/HA2$  is the  $\overline{SS}$  input. It should be kept deasserted (high) for proper operation.
- HREQ is the Host Request input.

The external slave device can be selected either by using external logic or by activating a GPIO pin connected to its  $\overline{SS}$  pin. However, the  $\overline{SS}$  input pin of the SPI master device should be held deasserted (high) for proper operation. If the SPI master device  $\overline{SS}$  pin is asserted, the host bus error status bit (HBER) is set. If the HBIE bit is also set, the SHI issues a request to the DSP interrupt controller to service the SHI bus error interrupt.

#### **SHI Programming Considerations**

In the SPI master mode the DSP must write to HTX to receive, transmit or perform a full-duplex data transfer. Actually, the interface performs simultaneous data receive and transmit. The status bits of both receive and transmit paths are active; however, the programmer may disable undesired interrupts and ignore irrelevant status bits. In a data transfer, the HTX is transferred to IOSR, clock pulses are generated, the IOSR data is shifted out (via MOSI) and received data is shifted in (via MISO). The DSP programmer may write HTX (if the HTDE status bit is set) with either DSP instructions or DMA transfers to initiate the transfer of the next word. The HRX FIFO contains valid receive data, which the DSP can read with either DSP instructions or DMA transfers, if the HRNE status bit is set.

It is recommended that an SHI individual reset (HEN cleared) be generated before beginning data reception in order to reset the receive FIFO to its initial (empty) state (e.g., when switching from transmit to receive data).

The  $\overline{HREQ}$  input pin is ignored by the SPI master device if the HRQE[1:0] bits are cleared, and considered if any of them is set. When asserted by the slave device,  $\overline{HREQ}$  indicates that the external slave device is ready for the next data transfer. As a result, the SPI master sends clock pulses for the full data word transfer.  $\overline{HREQ}$  is deasserted by the external slave device at the first clock pulse of the new data transfer. When deasserted,  $\overline{HREQ}$  prevents the clock generation of the next data word transfer until it is asserted again. Connecting the  $\overline{HREQ}$  line between two SHI-equipped DSPs, one operating as an SPI master device and the other as an SPI slave device, enables full hardware handshaking if CPHA = 1. For CPHA = 0,  $\overline{HREQ}$  should be disabled by clearing HRQE[1:0].

# 7.7.3 I<sup>2</sup>C SLAVE MODE

The I<sup>2</sup>C slave mode is entered by enabling the SHI (HEN=1), selecting the I<sup>2</sup>C mode (HI<sup>2</sup>C=1), and selecting the slave mode of operation (HMST=0). In this operational mode the contents of HCKR are ignored. When configured in the I<sup>2</sup>C slave mode, the SHI external pins operate as follows:

- SCK/SCL is the SCL serial clock input.
- MISO/SDA is the SDA open drain serial data line.
- MOSI/HA0 is the HA0 slave device address input.
- SS/HA2 is the HA2 slave device address input.
- HREQ is the Host Request output.

When the SHI is enabled and configured in the I<sup>2</sup>C slave mode, the SHI controller inspects the SDA and SCL lines to detect a start event. Upon detection of the start event, the SHI receives the slave device address byte and enables the slave device address recognition unit. If the

slave device address byte was not identified as its personal address, the SHI controller fails to acknowledge this byte by not driving low the SDA line at the ninth clock pulse (ACK = 1). However, it continues to poll the SDA and SCL lines to detect a new start event. If the personal slave device address was correctly identified, the slave device address byte is acknowledged (ACK = 0 is sent) and a receive/transmit session is initiated according to the eighth bit of the received slave device address byte (i.e., the  $R/\overline{W}$  bit).

# 7.7.3.1 Receive Data in I<sup>2</sup>C Slave Mode

A receive session is initiated when the personal slave device address has been correctly identified and the  $R/\overline{W}$  bit of the received slave device address byte has been cleared. Following a receive initiation, data in the SDA line is shifted into IOSR MSB first. Following each received byte, an acknowledge (ACK = 0) is sent at the ninth clock pulse via the SDA line. Data is acknowledged bytewise, as required by the  $I^2C$  bus protocol, and is transferred to the HRX FIFO when the complete word (according to HM[1:0]) is filled into IOSR. It is the responsibility of the programmer to select the correct number of bytes in an  $I^2C$  frame so that they fit in a complete number of words. For this purpose, the slave device address byte does not count as part of the data; therefore, it is treated separately.

In a receive session, only the receive path is enabled and HTX to IOSR transfers are inhibited. The HRX FIFO contains valid data, which may be read by the DSP with either DSP instructions or DMA transfers (if the HRNE status bit is set).

If HCKFR is cleared, when the HRX FIFO is full and IOSR is filled, an overrun error occurs and the HROE status bit is set. In this case, the last received byte is not acknowledged (ACK=1 is sent) and the word in the IOSR is not transferred to the HRX FIFO. This may inform the external I<sup>2</sup>C master device of the occurrence of an overrun error on the slave side. Consequently the I<sup>2</sup>C master device may terminate this session by generating a stop event.

If HCKFR is set, when the HRX FIFO is full the SHI holds the clock line to GND not letting the master device write to IOSR, which eliminates the possibility of reaching the overrun condition.

The  $\overline{HREQ}$  output pin, if enabled for receive (HRQE[1:0] = 01), is asserted when the IOSR is ready to receive and the HRX FIFO is not full; this operation guarantees that the next received data word is stored in the FIFO.  $\overline{HREQ}$  is deasserted at the first clock pulse of the next received word. The  $\overline{HREQ}$  line may be used to interrupt the external I<sup>2</sup>C master device. Connecting the  $\overline{HREQ}$  line between two SHI-equipped DSPs, one operating as an I<sup>2</sup>C master device and the other as an I<sup>2</sup>C slave device, enables full hardware handshaking.

# 7.7.3.2 Transmit Data In I<sup>2</sup>C Slave Mode

A transmit session is initiated when the personal slave device address has been correctly identified and the  $R/\overline{W}$  bit of the received slave device address byte has been set. Following a transmit initiation, the IOSR is loaded from HTX (assuming the latter was not empty) and its

## **SHI Programming Considerations**

contents are shifted out, MSB first, on the SDA line. Following each transmitted byte, the SHI controller samples the SDA line at the ninth clock pulse, and inspects the ACK status. If the transmitted byte was acknowledged (ACK = 0), the SHI controller continues and transmits the next byte. However, if it was not acknowledged (ACK = 1), the transmit session is stopped and the SDA line is released. Consequently, the external master device may generate a stop event in order to terminate the session.

HTX contents are transferred to IOSR when the complete word (according to HM[1:0]) has been shifted out. It is, therefore, the responsibility of the programmer to select the correct number of bytes in an I<sup>2</sup>C frame so that they fit in a complete number of words. For this purpose, the slave device address byte does not count as part of the data; therefore, it is treated separately.

In a transmit session, only the transmit path is enabled and the IOSR-to-HRX FIFO transfers are inhibited. When the HTX transfers its valid data word to IOSR, the HTDE status bit is set and the DSP may write a new data word to HTX with either DSP instructions or DMA transfers.

If HCKFR is cleared and both IOSR and HTX are empty when the master device attempts a transmit session, an underrun condition occurs, setting the HTUE status bit, and the previous word is retransmitted.

If HCKFR is set and both IOSR and HTX are empty when the master device attempts a transmit session, the SHI holds the clock line to GND to avoid an underrun condition.

The  $\overline{HREQ}$  output pin, if enabled for transmit (HRQE[1:0] = 10), is asserted when HTX is transferred to IOSR for transmission. When asserted,  $\overline{HREQ}$  indicates that the slave device is ready to transmit the next data word.  $\overline{HREQ}$  is deasserted at the first clock pulse of the next transmitted data word. The  $\overline{HREQ}$  line may be used to interrupt the external I<sup>2</sup>C master device. Connecting the  $\overline{HREQ}$  line between two SHI-equipped DSPs, one operating as an I<sup>2</sup>C master device and the other as an I<sup>2</sup>C slave device, enables full hardware handshaking.

# 7.7.4 I<sup>2</sup>C MASTER MODE

The I<sup>2</sup>C master mode is entered by enabling the SHI (HEN=1), selecting the I<sup>2</sup>C mode (HI<sup>2</sup>C=1) and selecting the master mode of operation (HMST=1). Before enabling the SHI as an I<sup>2</sup>C master, the programmer should program the appropriate clock rate in HCKR.

When configured in the I<sup>2</sup>C master mode, the SHI external pins operate as follows:

• SCK/SCL is the SCL open drain serial clock output.

- MISO/SDA is the SDA open drain serial data line.
- MOSI/HA0 is the HA0 slave device address input.
- $\overline{SS}/HA2$  is the HA2 slave device address input.
- HREQ is the Host Request input.

In the I<sup>2</sup>C master mode, a data transfer session is always initiated by the DSP by writing to the HTX register when HIDLE is set. This condition ensures that the data byte written to HTX is interpreted as being a slave address byte. This data byte must specify the slave device address to be selected and the requested data transfer direction.

Note: The slave address byte should be located in the high portion of the data word, whereas the middle and low portions are ignored. Only one byte (the slave address byte) is shifted out, independent of the word length defined by the HM[1:0] bits.

In order for the DSP to initiate a data transfer the following actions are to be performed:

- The DSP tests the HIDLE status bit.
- If the HIDLE status bit is set, the DSP writes the slave device address and the  $R/\overline{W}$  bit to the most significant byte of HTX.
- The SHI generates a start event.
- The SHI transmits one byte only, internally samples the  $R/\overline{W}$  direction bit (last bit), and accordingly initiates a receive or transmit session.
- The SHI inspects the SDA level at the ninth clock pulse to determine the ACK value. If acknowledged (ACK = 0), it starts its receive or transmit session according to the sampled R/W value. If not acknowledged (ACK = 1), the HBER status bit in HCSR is set, which causes an SHI Bus Error interrupt request if HBIE is set, and a stop event is generated.

The  $\overline{HREQ}$  input pin is ignored by the  $I^2C$  master device if HRQE[1:0] are cleared, and considered if either of them is set. When asserted,  $\overline{HREQ}$  indicates that the external slave device is ready for the next data transfer. As a result, the  $I^2C$  master device sends clock pulses for the full data word transfer.  $\overline{HREQ}$  is deasserted by the external slave device at the first clock pulse of the next data transfer. When deasserted,  $\overline{HREQ}$  prevents the clock generation of the next data word transfer until it is asserted again. Connecting the  $\overline{HREQ}$  line between two SHI-equipped DSPs, one operating as an  $I^2C$  master device and the other as an  $I^2C$  slave device, enables full hardware handshaking.

# 7.7.4.1 Receive Data in I<sup>2</sup>C Master Mode

A receive session is initiated if the  $R/\overline{W}$  direction bit of the transmitted slave device address byte is set. Following a receive initiation, data in the SDA line is shifted into IOSR MSB first. Following each received byte, an acknowledge (ACK = 0) is sent at the ninth clock pulse via

#### **SHI Programming Considerations**

the SDA line if the HIDLE control bit is cleared. Data is acknowledged bytewise, as required by the I<sup>2</sup>C bus protocol, and is transferred to the HRX FIFO when the complete word (according to HM[1:0]) is filled into IOSR. It is the responsibility of the programmer to select the correct number of bytes in an I<sup>2</sup>C frame so that they fit in a complete number of words. For this purpose, the slave device address byte does not count as part of the data; therefore, it is treated separately.

If the I<sup>2</sup>C slave transmitter is acknowledged, it should transmit the next data byte. In order to terminate the receive session, the programmer should set the HIDLE bit at the last required data word. As a result, the last byte of the next received data word is not acknowledged, the slave transmitter releases the SDA line, and the SHI generates the stop event and terminates the session.

In a receive session, only the receive path is enabled and the HTX-to-IOSR transfers are inhibited. If the HRNE status bit is set, the HRX FIFO contains valid data, which may be read by the DSP with either DSP instructions or DMA transfers. When the HRX FIFO is full, the SHI suspends the serial clock just before acknowledge. In this case, the clock is reactivated when the FIFO is read (the SHI gives an ACK = 0 and proceeds receiving).

# 7.7.4.2 Transmit Data In I<sup>2</sup>C Master Mode

A transmit session is initiated if the  $R/\overline{W}$  direction bit of the transmitted slave device address byte is cleared. Following a transmit initiation, the IOSR is loaded from HTX (assuming HTX is not empty) and its contents are shifted out, MSB-first, on the SDA line. Following each transmitted byte, the SHI controller samples the SDA line at the ninth clock pulse, and inspects the ACK status. If the transmitted byte was acknowledged (ACK=0), the SHI controller continues transmitting the next byte. However, if it was not acknowledged (ACK=1), the HBER status bit is set to inform the DSP side that a bus error (or overrun, or any other exception in the slave device) has occurred. Consequently, the  $I^2C$  master device generates a stop event and terminates the session.

HTX contents are transferred to the IOSR when the complete word (according to HM[1:0]) has been shifted out. It is, therefore, the responsibility of the programmer to select the right number of bytes in an I<sup>2</sup>C frame so that they fit in a complete number of words. Remember that for this purpose, the slave device address byte does not count as part of the data.

In a transmit session, only the transmit path is enabled and the IOSR-to-HRX FIFO transfers are inhibited. When the HTX transfers its valid data word to the IOSR, the HTDE status bit is set and the DSP may write a new data word to HTX with either DSP instructions or DMA transfers. If both IOSR and HTX are empty, the SHI suspends the serial clock until new data is written into HTX (when the SHI proceeds with the transmit session) or HIDLE is set (the SHI reactivates the clock to generate the stop event and terminate the transmit session).

# 7.7.5 SHI OPERATION DURING DSP STOP

The SHI operation cannot continue when the DSP is in the stop state, because no DSP clocks are active. While the DSP is in the stop state, the SHI remains in the individual reset state.

While in the individual reset state the following is true:

- If the SHI was operating in the I<sup>2</sup>C mode, the SHI signals are disabled (high impedance state).
- If the SHI was operating in the SPI mode, the SHI signals are not affected.
- The HCSR status bits and the transmit/receive paths are reset to the same state produced by hardware reset or software reset.
- The HCSR and HCKR control bits are not affected.

**Note:** It is recommended that the SHI be disabled before entering the stop state.

**SHI Programming Considerations** 

# SECTION 8

# ENHANCED SERIAL AUDIO INTERFACE (ESAI)

#### 8.1 INTRODUCTION

The Enhanced Serial Audio Interface (ESAI) 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 which implement the Motorola SPI serial protocol. The ESAI consists of independent transmitter and receiver sections, each section with its own clock generator. It is a superset of the 56300 Family ESSI peripheral and of the 56000 Family SAI peripheral.

The ESAI block diagram is shown in Figure 8-1. The ESAI is named synchronous because all serial transfers are synchronized to a clock. Additional synchronization signals are used to delineate the word frames. The normal mode of operation is used to transfer data at a periodic rate, one word per period. The network mode is similar in that it is also intended for periodic transfers; however, it supports up to 32 words (time slots) per period. This mode can be used to build time division multiplexed (TDM) networks. In contrast, the on-demand mode is intended for non-periodic transfers of data and to transfer data serially at high speed when the data becomes available. This mode offers a subset of the SPI protocol.

#### Introduction



Figure 8-1 ESAI Block Diagram

# 8.2 ESAI DATA AND CONTROL PINS

Three to twelve pins are required for operation, depending on the operating mode selected and the number of transmitters and receivers enabled. The SDO0 and SDO1 pins are used by transmitters 0 and 1 only. The SDO2/SDI3, SDO3/SDI2, SDO4/SDI1, and SDO5/SDI0 pins are shared by transmitters 2 to 5 with receivers 0 to 3. The actual mode of operation is selected under software control. All transmitters operate fully synchronized under control of the same transmitter clock signals. All receivers operate fully synchronized under control of the same receiver clock signals.

# 8.2.1 SERIAL TRANSMIT 0 DATA PIN (SDO0)

SDO0 is used for transmitting data from the TX0 serial transmit shift register. SDO0 is an output when data is being transmitted from the TX0 shift register. In the on-demand mode with an internally generated bit clock, the SDO0 pin becomes high impedance for a full clock period after the last data bit has been transmitted, assuming another data word does not follow immediately. If a data word follows immediately, there is no high-impedance interval.

SDO0 may be programmed as a general-purpose I/O pin (PC11) when the ESAI SDO0 function is not being used.

# 8.2.2 SERIAL TRANSMIT 1 DATA PIN (SDO1)

SDO1 is used for transmitting data from the TX1 serial transmit shift register. SDO1 is an output when data is being transmitted from the TX1 shift register. In the on-demand mode with an internally generated bit clock, the SDO1 pin becomes high impedance for a full clock period after the last data bit has been transmitted, assuming another data word does not follow immediately. If a data word follows immediately, there is no high-impedance interval.

SDO1 may be programmed as a general-purpose I/O pin (PC10) when the ESAI SDO1 function is not being used.

# 8.2.3 SERIAL TRANSMIT 2/RECEIVE 3 DATA PIN (SDO2/SDI3)

SDO2/SDI3 is used as the SDO2 for transmitting data from the TX2 serial transmit shift register when programmed as a transmitter pin, or as the SDI3 signal for receiving serial data to the RX3 serial receive shift register when programmed as a receiver pin. SDO2/SDI3 is an

#### **ESAI Data and Control Pins**

input when data is being received by the RX3 shift register. SDO2/SDI3 is an output when data is being transmitted from the TX2 shift register. In the on-demand mode with an internally generated bit clock, the SDO2/SDI3 pin becomes high impedance for a full clock period after the last data bit has been transmitted, assuming another data word does not follow immediately. If a data word follows immediately, there is no high-impedance interval.

SDO2/SDI3 may be programmed as a general-purpose I/O pin (PC9) when the ESAI SDO2 and SDI3 functions are not being used.

# 8.2.4 SERIAL TRANSMIT 3/RECEIVE 2 DATA PIN (SDO3/SDI2)

SDO3/SDI2 is used as the SDO3 signal for transmitting data from the TX3 serial transmit shift register when programmed as a transmitter pin, or as the SDI2 signal for receiving serial data to the RX2 serial receive shift register when programmed as a receiver pin. SDO3/SDI2 is an input when data is being received by the RX2 shift register. SDO3/SDI2 is an output when data is being transmitted from the TX3 shift register. In the on-demand mode with an internally generated bit clock, the SDO3/SDI2 pin becomes high impedance for a full clock period after the last data bit has been transmitted, assuming another data word does not follow immediately. If a data word follows immediately, there is no high-impedance interval.

SDO3/SDI2 may be programmed as a general-purpose I/O pin (PC8) when the ESAI SDO3 and SDI2 functions are not being used.

# 8.2.5 SERIAL TRANSMIT 4/RECEIVE 1 DATA PIN (SDO4/SDI1)

SDO4/SDI1 is used as the SDO4 signal for transmitting data from the TX4 serial transmit shift register when programmed as transmitter pin, or as the SDI1 signal for receiving serial data to the RX1 serial receive shift register when programmed as a receiver pin. SDO4/SDI1 is an input when data is being received by the RX1 shift register. SDO4/SDI1 is an output when data is being transmitted from the TX4 shift register. In the on-demand mode with an internally generated bit clock, the SDO4/SDI1 pin becomes high impedance for a full clock period after the last data bit has been transmitted, assuming another data word does not follow immediately. If a data word follows immediately, there is no high-impedance interval.

SDO4/SDI1 may be programmed as a general-purpose I/O pin (PC7) when the ESAI SDO4 and SDI1 functions are not being used.

# 8.2.6 SERIAL TRANSMIT 5/RECEIVE 0 DATA PIN (SDO5/SDI0)

SDO5/SDI0 is used as the SDO5 signal for transmitting data from the TX5 serial transmit shift register when programmed as transmitter pin, or as the SDI0 signal for receiving serial data to the RX0 serial shift register when programmed as a receiver pin. SDO5/SDI0 is an input when data is being received by the RX0 shift register. SDO5/SDI0 is an output when data is being transmitted from the TX5 shift register. In the on-demand mode with an internally generated bit clock, the SDO5/SDI0 pin becomes high impedance for a full clock period after the last data bit has been transmitted, assuming another data word does not follow immediately. If a data word follows immediately, there is no high-impedance interval.

SDO5/SDI0 may be programmed as a general-purpose I/O pin (PC6) when the ESAI SDO5 and SDI0 functions are not being used

# 8.2.7 RECEIVER SERIAL CLOCK (SCKR)

SCKR is a bidirectional pin providing the receivers serial bit clock for the ESAI interface. The direction of this pin is determined by the RCKD bit in the RCCR register. The SCKR operates as a clock input or output used by all the enabled receivers in the asynchronous mode (SYN=0), or as serial flag 0 pin in the synchronous mode (SYN=1).

When this pin is configured as serial flag pin, its direction is determined by the RCKD bit in the RCCR register. When configured as the output flag OF0, this pin reflects the value of the OF0 bit in the SAICR register, and the data in the OF0 bit shows up at the pin synchronized to the frame sync being used by the transmitter and receiver sections. When this pin is configured as the input flag IF0, the data value at the pin is stored in the IF0 bit in the SAISR register, synchronized by the frame sync in normal mode or the slot in network mode.

SCKR may be programmed as a general-purpose I/O pin (PC0) when the ESAI SCKR function is not being used.

Note:

Although the external ESAI serial clock can be independent of and asynchronous to the DSP system clock, the DSP clock frequency must be at least three times the external ESAI serial clock frequency and each ESAI serial clock phase must exceed the minimum of 1.5 DSP clock periods.

#### **ESAI** Data and Control Pins

For more information on pin mode and definition, see Table 8-10 and on receiver clock signals see Table 8-1.

Table 8-1 Receiver Clock Sources (asynchronous mode only)

| RHCKD | RFSD | RCKD | Receiver<br>Bit Clock<br>Source | OUTPUTS |     |      |
|-------|------|------|---------------------------------|---------|-----|------|
| 0     | 0    | 0    | SCKR                            |         |     |      |
| 0     | 0    | 1    | HCKR                            |         |     | SCKR |
| 0     | 1    | 0    | SCKR                            |         | FSR |      |
| 0     | 1    | 1    | HCKR                            |         | FSR | SCKR |
| 1     | 0    | 0    | SCKR                            | HCKR    |     |      |
| 1     | 0    | 1    | INT                             | HCKR    |     | SCKR |
| 1     | 1    | 0    | SCKR                            | HCKR    | FSR |      |
| 1     | 1    | 1    | INT                             | HCKR    | FSR | SCKR |

# 8.2.8 TRANSMITTER SERIAL CLOCK (SCKT)

SCKT is a bidirectional pin providing the transmitters serial bit clock for the ESAI interface. The direction of this pin is determined by the TCKD bit in the TCCR register. The SCKT is a clock input or output used by all the enabled transmitters in the asynchronous mode (SYN=0)

or by all the enabled transmitters and receivers in the synchronous mode (SYN=1) (see Table 8-2).

| THCKD | TFSD | TCKD | Transmitter<br>Bit Clock Source | OUTPUTS |     |      |
|-------|------|------|---------------------------------|---------|-----|------|
| 0     | 0    | 0    | SCKT                            |         |     |      |
| 0     | 0    | 1    | НСКТ                            |         |     | SCKT |
| 0     | 1    | 0    | SCKT                            |         | FST |      |
| 0     | 1    | 1    | НСКТ                            |         | FST | SCKT |
| 1     | 0    | 0    | SCKT                            | HCKT    |     |      |
| 1     | 0    | 1    | INT                             | HCKT    |     | SCKT |
| 1     | 1    | 0    | SCKT                            | НСКТ    | FST |      |
| 1     | 1    | 1    | INT                             | HCKT    | FST | SCKT |

**Table 8-2 Transmitter Clock Sources** 

SCKT may be programmed as a general-purpose I/O pin (PC3) when the ESAI SCKT function is not being used.

Note:

Although the external ESAI serial clock can be independent of and asynchronous to the DSP system clock, the DSP clock frequency must be at least three times the external ESAI serial clock frequency and each ESAI serial clock phase must exceed the minimum of 1.5 DSP clock periods.

# 8.2.9 FRAME SYNC FOR RECEIVER (FSR)

FSR is a bidirectional pin providing the receivers frame sync signal for the ESAI interface. The direction of this pin is determined by the RFSD bit in RCR register. In the asynchronous mode (SYN=0), the FSR pin operates as the frame sync input or output used by all the enabled receivers. In the synchronous mode (SYN=1), it operates as either the serial flag 1 pin (TEBE=0), or as the transmitter external buffer enable control (TEBE=1, RFSD=1). For further information on pin mode and definition, see Table 8-11 and on receiver clock signals see Table 8-1.

When this pin is configured as serial flag pin, its direction is determined by the RFSD bit in the RCCR register. When configured as the output flag OF1, this pin reflects the value of the OF1 bit in the SAICR register, and the data in the OF1 bit shows up at the pin synchronized to the frame sync being used by the transmitter and receiver sections. When configured as the

#### **ESAI Data and Control Pins**

input flag IF1, the data value at the pin is stored in the IF1 bit in the SAISR register, synchronized by the frame sync in normal mode or the slot in network mode.

FSR may be programmed as a general-purpose I/O pin (PC1) when the ESAI FSR function is not being used.

# 8.2.10 FRAME SYNC FOR TRANSMITTER (FST)

FST is a bidirectional pin providing the frame sync for both the transmitters and receivers in the synchronous mode (SYN=1) and for the transmitters only in asynchronous mode (SYN=0) (see Table 8-2). The direction of this pin is determined by the TFSD bit in the TCR register. When configured as an output, this pin is the internally generated frame sync signal. When configured as an input, this pin receives an external frame sync signal for the transmitters (and the receivers in synchronous mode).

FST may be programmed as a general-purpose I/O pin (PC4) when the ESAI FST function is not being used.

# 8.2.11 HIGH FREQUENCY CLOCK FOR TRANSMITTER (HCKT)

HCKT is a bidirectional pin providing the transmitters high frequency clock for the ESAI interface. The direction of this pin is determined by the THCKD bit in the TCCR register. In the asynchronous mode (SYN=0), the HCKT pin operates as the high frequency clock input or output used by all enabled transmitters. In the synchronous mode (SYN=1), it operates as the high frequency clock input or output used by all enabled transmitters and receivers. When programmed as input this pin is used as an alternative high frequency clock source to the ESAI transmitter rather than the DSP main clock. When programmed as output it can serve as a high frequency sample clock (to external DACs for example) or as an additional system clock. See Table 8-2.

HCKT may be programmed as a general-purpose I/O pin (PC5) when the ESAI HCKT function is not being used.

# 8.2.12 HIGH FREQUENCY CLOCK FOR RECEIVER (HCKR)

HCKR is a bidirectional pin providing the receivers high frequency clock for the ESAI interface. The direction of this pin is determined by the RHCKD bit in the RCCR register. In the asynchronous mode (SYN=0), the HCKR pin operates as the high frequency clock input

or output used by all the enabled receivers. In the synchronous mode (SYN=1), it operates as the serial flag 2 pin. For further information on pin mode and definition, see Table 8-12 and on receiver clock signals see Table 8-1.

When this pin is configured as serial flag pin, its direction is determined by the RHCKD bit in the RCCR register. When configured as the output flag OF2, this pin reflects the value of the OF2 bit in the SAICR register, and the data in the OF2 bit shows up at the pin synchronized to the frame sync being used by the transmitter and receiver sections. When configured as the input flag IF2, the data value at the pin is stored in the IF2 bit in the SAISR register, synchronized by the frame sync in normal mode or the slot in network mode.

HCKR may be programmed as a general-purpose I/O pin (PC2) when the ESAI HCKR function is not being used.

#### 8.3 ESAI PROGRAMMING MODEL

The ESAI can be viewed as five control registers, one status register, six transmit data registers, four receive data registers, two transmit slot mask registers, two receive slot mask registers and a special-purpose time slot register. The following paragraphs give detailed descriptions and operations of each bit in the ESAI registers.

The ESAI pins can also function as GPIO pins (Port C), described in Section 8.5, "GPIO - Pins and Registers".

# 8.3.1 ESAI TRANSMITTER CLOCK CONTROL REGISTER (TCCR)

The read/write Transmitter Clock Control Register (TCCR) controls the ESAI transmitter clock generator bit and frame sync rates, the bit clock and high frequency clock sources and the directions of the HCKT, FST and SCKT signals. (See Table 8-3). In the synchronous

mode (SYN=1), the bit clock defined for the transmitter determines the receiver bit clock as well. TCCR also controls the number of words per frame for the serial data.

Table 8-3 TCCR Register



Hardware and software reset clear all the bits of the TCCR register.

The TCCR control bits are described in the following paragraphs.

# 8.3.1.1 TCCR Transmit Prescale Modulus Select (TPM7–TPM0) - Bits 0–7

The TPM7–TPM0 bits specify the divide ratio of the prescale divider in the ESAI transmitter clock generator. A divide ratio from 1 to 256 (TPM[7:0]=\$00 to \$FF) may be selected. The bit clock output is available at the transmit serial bit clock (SCKT) pin 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. The ESAI transmit clock generator functional diagram is shown in Figure 8-2.



Figure 8-2 ESAI Clock Generator Functional Block Diagram

# 8.3.1.2 TCCR Transmit Prescaler Range (TPSR) - Bit 8

The TPSR bit controls a fixed divide-by-eight prescaler in series with the variable prescaler. This bit is used to extend the range of the prescaler for those cases where a slower bit clock is desired. When TPSR is set, the fixed prescaler is bypassed. When TPSR is cleared, the fixed divide-by-eight prescaler is operational (see Figure 8-2). The maximum internally generated bit clock frequency is Fosc/4; the minimum internally generated bit clock frequency is Fosc/(2 x 8 x 256)=Fosc/4096.

**Note:** Do not use the combination TPSR=1 and TPM7-TPM0=\$00, which causes

synchronization problems when using the internal DSP clock as source (TCKD=1

or THCKD=1).

# 8.3.1.3 TCCR Tx Frame Rate Divider Control (TDC4–TDC0) - Bits 9–13

The TDC4–TDC0 bits control the divide ratio for the programmable frame rate dividers used to generate the transmitter frame clocks.

In network mode, this ratio may be interpreted as the number of words per frame minus one. The divide ratio may range from 2 to 32 (TDC[4:0]=00001 to 11111) for network mode. A divide ratio of one (TDC[4:0]=00000) in network mode is a special case (on-demand mode).

In normal mode, this ratio determines the word transfer rate. The divide ratio may range from 1 to 32 (TDC[4:0]=00000 to 11111) for normal mode. In normal mode, a divide ratio of 1 (TDC[4:0]=00000) provides continuous periodic data word transfers. A bit-length frame sync (TFSL=1) must be used in this case.

The ESAI frame sync generator functional diagram is shown in Figure 8-3.



Figure 8-3 ESAI Frame Sync Generator Functional Block Diagram

# 8.3.1.4 TCCR Tx High Frequency Clock Divider (TFP3-TFP0) - Bits 14–17

The TFP3–TFP0 bits control the divide ratio of the transmitter high frequency clock to the transmitter serial bit clock when the source of the high frequency clock and the bit clock is the internal DSP clock. When the HCKT input is being driven from an external high frequency clock, the TFP3-TFP0 bits specify an additional division ratio in the clock divider chain. See Table 8-4 for the specification of the divide ratio. The ESAI high frequency clock generator functional diagram is shown in Figure 8-2.

| TFP3-TFP0 | Divide Ratio |
|-----------|--------------|
| \$0       | 1            |
| \$1       | 2            |
| \$2       | 3            |
| \$3       | 4            |
|           |              |
| \$F       | 16           |

Table 8-4 Transmitter High Frequency Clock Divider

# 8.3.1.5 TCCR Transmit Clock Polarity (TCKP) - Bit 18

The Transmitter Clock Polarity (TCKP) bit controls on which bit clock edge data and frame sync are clocked out and latched in. If TCKP is cleared the data and the frame sync are clocked out on the rising edge of the transmit bit clock and latched in on the falling edge of the transmit bit clock. If TCKP is set the falling edge of the transmit clock is used to clock the data out and frame sync and the rising edge of the transmit clock is used to latch the data and frame sync in.

# 8.3.1.6 TCCR Transmit Frame Sync Polarity (TFSP) - Bit 19

The Transmitter Frame Sync Polarity (TFSP) bit determines the polarity of the transmit frame sync signal. When TFSP is cleared, the frame sync signal polarity is positive (i.e the frame start is indicated by a high level on the frame sync pin). When TFSP is set, the frame sync signal polarity is negative (i.e the frame start is indicated by a low level on the frame sync pin).

# 8.3.1.7 TCCR Transmit High Frequency Clock Polarity (THCKP) - Bit 20

The Transmitter High Frequency Clock Polarity (THCKP) bit controls on which bit clock edge data and frame sync are clocked out and latched in. If THCKP is cleared the data and the frame sync are clocked out on the rising edge of the transmit bit clock and latched in on the falling edge of the transmit bit clock. If THCKP is set the falling edge of the transmit clock is used to clock the data out and frame sync and the rising edge of the transmit clock is used to latch the data and frame sync in.

# 8.3.1.8 TCCR Transmit Clock Source Direction (TCKD) - Bit 21

The Transmitter Clock Source Direction (TCKD) bit selects the source of the clock signal used to clock the transmit shift registers in the asynchronous mode (SYN=0) and the transmit shift registers and the receive shift registers in the synchronous mode (SYN=1). When TCKD is set, the internal clock source becomes the bit clock for the transmit shift registers and word length divider and is the output on the SCKT pin. When TCKD is cleared, the clock source is external; the internal clock generator is disconnected from the SCKT pin, and an external clock source may drive this pin. See Table 8-2.

# 8.3.1.9 TCCR Transmit Frame Sync Signal Direction (TFSD) - Bit 22 TESD controls the direction of the EST pin. When TESD is cleared. EST is an input: when

TFSD controls the direction of the FST pin. When TFSD is cleared, FST is an input; when TFSD is set, FST is an output. See Table 8-2.

**8.3.1.10** TCCR Transmit High Frequency Clock Direction (THCKD) - Bit 23 THCKD controls the direction of the HCKT pin. When THCKD is cleared, HCKT is an input; when THCKD is set, HCKT is an output. See Table 8-2.

# 8.3.2 ESAI TRANSMIT CONTROL REGISTER (TCR)

The read/write Transmit Control Register (TCR) controls the ESAI transmitter section. Interrupt enable bits for the transmitter section are provided in this control register. Operating modes are also selected in this register. See Table 8-5.

Table 8-5 TCR Register

10 7 6 3 11 2 1 0 X:\$FFFFB5 TSWS1 TSWS0 TMOD1 TMOD0 TWA TSHFD TE5 TE4 TE3 TE2 TE1 TE0 23 2.1 20 19 18 17 16 15 14 13 12 TLIE TEDIE TPR PADC TFSR TFSL TSWS4 TSWS3 TSWS2 TEIE Reserved bit - read as zero; should be written with zero for future compatibility.

<del>-----</del>

The TCR bits are described in the following paragraphs.

#### 8.3.2.1 TCR ESAI Transmit 0 Enable (TE0) - Bit 0

Hardware and software reset clear all the bits in the TCR register.

TE0 enables the transfer of data from TX0 to the transmit shift register #0. When TE0 is set and a frame sync is detected, the transmit #0 portion of the ESAI is enabled for that frame. When TE0 is cleared, the transmitter #0 is disabled after completing transmission of data currently in the ESAI transmit shift register. The SDO0 output is tri-stated, and any data present in TX0 is not transmitted (i.e., data can be written to TX0 with TE0 cleared; but data is not transferred to the transmit shift register #0).

The normal mode transmit enable sequence is to write data to one or more transmit data registers before setting TEx. The normal transmit disable sequence is to clear TEx, TIE and TEIE after TDE equals one.

In the network mode, the operation of clearing TE0 and setting it again disables the transmitter #0 after completing transmission of the current data word until the beginning of the next frame. During that time period, the SDO0 pin remains in the high-impedance state. The on-demand mode transmit enable sequence can be the same as the normal mode, or TE0 can be left enabled.

# 8.3.2.2 TCR ESAI Transmit 1 Enable (TE1) - Bit 1

TE1 enables the transfer of data from TX1 to the transmit shift register #1. When TE1 is set and a frame sync is detected, the transmit #1 portion of the ESAI is enabled for that frame. When TE1 is cleared, the transmitter #1 is disabled after completing transmission of data currently in the ESAI transmit shift register. The SDO1 output is tri-stated, and any data present in TX1 is not transmitted (i.e., data can be written to TX1 with TE1 cleared; but data is not transferred to the transmit shift register #1).

The normal mode transmit enable sequence is to write data to one or more transmit data registers before setting TEx. The normal transmit disable sequence is to clear TEx, TIE and TEIE after TDE equals one.

In the network mode, the operation of clearing TE1 and setting it again disables the transmitter #1 after completing transmission of the current data word until the beginning of the next frame. During that time period, the SDO1 pin remains in the high-impedance state. The on-demand mode transmit enable sequence can be the same as the normal mode, or TE1 can be left enabled.

# 8.3.2.3 TCR ESAI Transmit 2 Enable (TE2) - Bit 2

TE2 enables the transfer of data from TX2 to the transmit shift register #2. When TE2 is set and a frame sync is detected, the transmit #2 portion of the ESAI is enabled for that frame. When TE2 is cleared, the transmitter #2 is disabled after completing transmission of data currently in the ESAI transmit shift register. Data can be written to TX2 when TE2 is cleared but the data is not transferred to the transmit shift register #2.

The SDO2/SDI3 pin is the data input pin for RX3 if TE2 is cleared and RE3 in the RCR register is set. If both RE3 and TE2 are cleared the transmitter and receiver are disabled, and the pin is tri-stated. Both RE3 and TE2 should not be set at the same time.

The normal mode transmit enable sequence is to write data to one or more transmit data registers before setting TEx. The normal transmit disable sequence is to clear TEx, TIE and TEIE after TDE equals one.

In the network mode, the operation of clearing TE2 and setting it again disables the transmitter #2 after completing transmission of the current data word until the beginning of the next frame. During that time period, the SDO2/SDI3 pin remains in the high-impedance

state. The on-demand mode transmit enable sequence can be the same as the normal mode, or TE2 can be left enabled.

### 8.3.2.4 TCR ESAI Transmit 3 Enable (TE3) - Bit 3

TE3 enables the transfer of data from TX3 to the transmit shift register #3. When TE3 is set and a frame sync is detected, the transmit #3 portion of the ESAI is enabled for that frame. When TE3 is cleared, the transmitter #3 is disabled after completing transmission of data currently in the ESAI transmit shift register. Data can be written to TX3 when TE3 is cleared but the data is not transferred to the transmit shift register #3.

The SDO3/SDI2 pin is the data input pin for RX2 if TE3 is cleared and RE2 in the RCR register is set. If both RE2 and TE3 are cleared the transmitter and receiver are disabled, and the pin is tri-stated. Both RE2 and TE3 should not be set at the same time.

The normal mode transmit enable sequence is to write data to one or more transmit data registers before setting TEx. The normal transmit disable sequence is to clear TEx, TIE and TEIE after TDE equals one.

In the network mode, the operation of clearing TE3 and setting it again disables the transmitter #3 after completing transmission of the current data word until the beginning of the next frame. During that time period, the SDO3/SDI2 pin remains in the high-impedance state. The on-demand mode transmit enable sequence can be the same as the normal mode, or TE3 can be left enabled.

#### 8.3.2.5 TCR ESAI Transmit 4 Enable (TE4) - Bit 4

TE4 enables the transfer of data from TX4 to the transmit shift register #4. When TE4 is set and a frame sync is detected, the transmit #4 portion of the ESAI is enabled for that frame. When TE4 is cleared, the transmitter #4 is disabled after completing transmission of data currently in the ESAI transmit shift register. Data can be written to TX4 when TE4 is cleared but the data is not transferred to the transmit shift register #4.

The SDO4/SDI1 pin is the data input pin for RX1 if TE4 is cleared and RE1 in the RCR register is set. If both RE1 and TE4 are cleared the transmitter and receiver are disabled, and the pin is tri-stated. Both RE1 and TE4 should not be set at the same time.

The normal mode transmit enable sequence is to write data to one or more transmit data registers before setting TEx. The normal transmit disable sequence is to clear TEx, TIE and TEIE after TDE equals one.

In the network mode, the operation of clearing TE4 and setting it again disables the transmitter #4 after completing transmission of the current data word until the beginning of the next frame. During that time period, the SDO4/SDI1 pin remains in the high-impedance

state. The on-demand mode transmit enable sequence can be the same as the normal mode, or TE4 can be left enabled.

### 8.3.2.6 TCR ESAI Transmit 5 Enable (TE5) - Bit 5

TE5 enables the transfer of data from TX5 to the transmit shift register #5. When TE5 is set and a frame sync is detected, the transmit #5 portion of the ESAI is enabled for that frame. When TE5 is cleared, the transmitter #5 is disabled after completing transmission of data currently in the ESAI transmit shift register. Data can be written to TX5 when TE5 is cleared but the data is not transferred to the transmit shift register #5.

The SDO5/SDI0 pin is the data input pin for RX0 if TE5 is cleared and RE0 in the RCR register is set. If both RE0 and TE5 are cleared the transmitter and receiver are disabled, and the pin is tri-stated. Both RE0 and TE5 should not be set at the same time.

The normal mode transmit enable sequence is to write data to one or more transmit data registers before setting TEx. The normal transmit disable sequence is to clear TEx, TIE and TEIE after TDE equals one.

In the network mode, the operation of clearing TE5 and setting it again disables the transmitter #5 after completing transmission of the current data word until the beginning of the next frame. During that time period, the SDO5/SDI0 pin remains in the high-impedance state. The on-demand mode transmit enable sequence can be the same as the normal mode, or TE5 can be left enabled.

#### 8.3.2.7 TCR Transmit Shift Direction (TSHFD) - Bit 6

The TSHFD bit causes the transmit shift registers to shift data out MSB first when TSHFD equals zero or LSB first when TSHFD equals one (see Figure 8-7 and Figure 8-8).

# 8.3.2.8 TCR Transmit Word Alignment Control (TWA) - Bit 7

The Transmitter Word Alignment Control (TWA) bit defines the alignment of the data word in relation to the slot. This is relevant for the cases where the word length is shorter than the slot length. If TWA is cleared, the data word is left-aligned in the slot frame during transmission. If TWA is set, the data word is right-aligned in the slot frame during transmission.

Since the data word is shorter than the slot length, the data word is extended until achieving the slot length, according to the following rule:

1. If the data word is left-aligned (TWA=0), and zero padding is disabled (PADC=0), then the last data bit is repeated after the data word has been transmitted. If zero padding is enabled (PADC=1), zeroes are transmitted after the data word has been transmitted.

2. If the data word is right-aligned (TWA=1), and zero padding is disabled (PADC=0), then the first data bit is repeated before the transmission of the data word. If zero padding is enabled (PADC=1), zeroes are transmitted before the transmission of the data word.

### 8.3.2.9 TCR Transmit Network Mode Control (TMOD1-TMOD0) - Bits 8-9

The TMOD1 and TMOD0 bits are used to define the network mode of ESAI transmitters according to Table 8-6. In the normal mode, the frame rate divider determines the word transfer rate – one word is transferred per frame sync during the frame sync time slot, as shown in Figure 8-4. In network mode, it is possible to transfer a word for every time slot, as shown in Figure 8-4. For more details, see Section 8.4, "Operating Modes".

In order to comply with AC-97 specifications, TSWS4-TSWS0 should be set to 00011 (20-bit slot, 20-bit word length), TFSL and TFSR should be cleared, and TDC4-TDC0 should be set to \$0C (13 words in frame). If TMOD[1:0]=\$11 and the above recommendations are followed, the first slot and word will be 16 bits long, and the next 12 slots and words will be 20 bits long, as required by the AC97 protocol.

TDC4-TDC0 TMOD1 TMOD0 **Transmitter Network Mode** 0 \$0-\$1F 0 Normal Mode 0 \$0 On-Demand Mode 1 \$1-\$1F Network Mode 0 X 1 Reserved 1 \$0C 1 AC97

Table 8-6 Transmit Network Mode Selection



Figure 8-4 Normal and Network Operation

# 8.3.2.10 TCR Tx Slot and Word Length Select (TSWS4-TSWS0) - Bits 10-14

The TSWS4-TSWS0 bits are used to select the length of the slot and the length of the data words being transferred via the ESAI. The word length must be equal to or shorter than the slot length. The possible combinations are shown in Table 8-7. See also the ESAI data path programming model in Figure 8-7 and Figure 8-8.

Table 8-7 ESAI Transmit Slot and Word Length Selection

| TSWS4 | TSWS3 | TSWS2 | TSWS1 | TSWS0 | SLOT LENGTH | WORD LENGTH |
|-------|-------|-------|-------|-------|-------------|-------------|
| 0     | 0     | 0     | 0     | 0     | 8           | 8           |
| 0     | 0     | 1     | 0     | 0     | 12          | 8           |
| 0     | 0     | 0     | 0     | 1     |             | 12          |
| 0     | 1     | 0     | 0     | 0     | 16          | 8           |
| 0     | 0     | 1     | 0     | 1     |             | 12          |
| 0     | 0     | 0     | 1     | 0     |             | 16          |
| 0     | 1     | 1     | 0     | 0     | 20          | 8           |
| 0     | 1     | 0     | 0     | 1     |             | 12          |
| 0     | 0     | 1     | 1     | 0     |             | 16          |
| 0     | 0     | 0     | 1     | 1     |             | 20          |
| 1     | 0     | 0     | 0     | 0     | 24          | 8           |
| 0     | 1     | 1     | 0     | 1     |             | 12          |
| 0     | 1     | 0     | 1     | 0     |             | 16          |
| 0     | 0     | 1     | 1     | 1     |             | 20          |
| 1     | 1     | 1     | 1     | 0     |             | 24          |
| 1     | 1     | 0     | 0     | 0     | 32          | 8           |
| 1     | 0     | 1     | 0     | 1     |             | 12          |
| 1     | 0     | 0     | 1     | 0     |             | 16          |
| 0     | 1     | 1     | 1     | 1     |             | 20          |
| 1     | 1     | 1     | 1     | 1     |             | 24          |

Table 8-7 ESAI Transmit Slot and Word Length Selection (Continued)

| TSWS4 | TSWS3 | TSWS2 | TSWS1 | TSWS0 | SLOT LENGTH | WORD LENGTH |
|-------|-------|-------|-------|-------|-------------|-------------|
| 0     | 1     | 0     | 1     | 1     | Rese        | erved       |
| 0     | 1     | 1     | 1     | 0     |             |             |
| 1     | 0     | 0     | 0     | 1     |             |             |
| 1     | 0     | 0     | 1     | 1     |             |             |
| 1     | 0     | 1     | 0     | 0     |             |             |
| 1     | 0     | 1     | 1     | 0     |             |             |
| 1     | 0     | 1     | 1     | 1     |             |             |
| 1     | 1     | 0     | 0     | 1     |             |             |
| 1     | 1     | 0     | 1     | 0     |             |             |
| 1     | 1     | 0     | 1     | 1     |             |             |
| 1     | 1     | 1     | 0     | 0     |             |             |
| 1     | 1     | 1     | 0     | 1     |             |             |

# 8.3.2.11 TCR Transmit Frame Sync Length (TFSL) - Bit 15

The TFSL bit selects the length of frame sync to be generated or recognized. If TFSL is cleared, a word-length frame sync is selected. If TFSL is set, a 1-bit clock period frame sync is selected. See Figure 8-5 for examples of frame length selection.



Figure 8-5 Frame Length Selection

### 8.3.2.12 TCR Transmit Frame Sync Relative Timing (TFSR) - Bit 16

TFSR determines the relative timing of the transmit frame sync signal as referred to the serial data lines, for a word length frame sync only (TFSL=0). When TFSR is cleared the word length frame sync occurs together with the first bit of the data word of the first slot. When TFSR is set the word length frame sync starts one serial clock cycle earlier (i.e together with the last bit of the previous data word).

# 8.3.2.13 TCR Transmit Zero Padding Control (PADC) - Bit 17

When PADC is cleared, zero padding is disabled. When PADC is set, zero padding is enabled. PADC, in conjunction with the TWA control bit, determines the way that padding is done for operating modes where the word length is less than the slot length. See the TWA bit description in Section 8.3.2.8, "TCR Transmit Word Alignment Control (TWA) - Bit 7" for more details.

Since the data word is shorter than the slot length, the data word is extended until achieving the slot length, according to the following rule:

- 1. If the data word is left-aligned (TWA=0), and zero padding is disabled (PADC=0), then the last data bit is repeated after the data word has been transmitted. If zero padding is enabled (PADC=1), zeroes are transmitted after the data word has been transmitted.
- 2. If the data word is right-aligned (TWA=1), and zero padding is disabled (PADC=0), then the first data bit is repeated before the transmission of the data word. If zero padding is enabled (PADC=1), zeroes are transmitted before the transmission of the data word.

#### 8.3.2.14 TCR Reserved Bit - Bit 18

This bit is reserved. It reads as zero, and it should be written with zero for future compatibility.

# 8.3.2.15 TCR Transmit Section Personal Reset (TPR) - Bit 19

The TPR control bit is used to put the transmitter section of the ESAI in the personal reset state. The receiver section is not affected. When TPR is cleared, the transmitter section may operate normally. When TPR is set, the transmitter section enters the personal reset state immediately. When in the personal reset state, the status bits are reset to the same state as after hardware reset. The control bits are not affected by the personal reset state. The transmitter data pins are tri-stated while in the personal reset state; if a stable logic level is desired, the transmitter data pins should be defined as GPIO outputs, or external pull-up or pull-down resistors should be used. The transmitter clock outputs drive zeroes while in the personal reset state. Note that to leave the personal reset state by clearing TPR, the procedure described in Section 8.6, "ESAI Initialization Examples" should be followed.

#### 8.3.2.16 TCR Transmit Exception Interrupt Enable (TEIE) - Bit 20

When TEIE is set, the DSP is interrupted when both TDE and TUE in the SAISR status register are set. When TEIE is cleared, this interrupt is disabled. Reading the SAISR status register followed by writing to all the data registers of the enabled transmitters clears TUE, thus clearing the pending interrupt.

# 8.3.2.17 TCR Transmit Even Slot Data Interrupt Enable (TEDIE) - Bit 21

The TEDIE control bit is used to enable the transmit even slot data interrupts. If TEDIE is set, the transmit even slot data interrupts are enabled. If TEDIE is cleared, the transmit even slot data interrupts are disabled. A transmit even slot data interrupt request is generated if TEDIE is set and the TEDE status flag in the SAISR status register is set. Even time slots are all even-numbered time slots (0, 2, 4, etc.) when operating in network mode. The zero time slot in the frame is marked by the frame sync signal and is considered to be even. Writing data to all the data registers of the enabled transmitters or to TSR clears the TEDE flag, thus servicing the interrupt.

Transmit interrupts with exception have higher priority than transmit even slot data interrupts, therefore if exception occurs (TUE is set) and TEIE is set, the ESAI requests an ESAI transmit data with exception interrupt from the interrupt controller.

# 8.3.2.18 TCR Transmit Interrupt Enable (TIE) - Bit 22

The DSP is interrupted when TIE and the TDE flag in the SAISR status register are set. When TIE is cleared, this interrupt is disabled. Writing data to all the data registers of the enabled transmitters or to TSR clears TDE, thus clearing the interrupt.

Transmit interrupts with exception have higher priority than normal transmit data interrupts, therefore if exception occurs (TUE is set) and TEIE is set, the ESAI requests an ESAI transmit data with exception interrupt from the interrupt controller.

#### 8.3.2.19 TCR Transmit Last Slot Interrupt Enable (TLIE) - Bit 23

TLIE enables an interrupt at the beginning of last slot of a frame in network mode. When TLIE is set the DSP is interrupted at the start of the last slot in a frame in network mode regardless of the transmit mask register setting. When TLIE is cleared the transmit last slot interrupt is disabled. TLIE is disabled when TDC[4:0]=\$00000 (on-demand mode). The use of the transmit last slot interrupt is described in Section 8.4.3, "ESAI Interrupt Requests".

# 8.3.3 ESAI RECEIVE CLOCK CONTROL REGISTER (RCCR)

The read/write Receive Clock Control Register (RCCR) controls the ESAI receiver clock generator bit and frame sync rates, word length, and number of words per frame for the serial data. The RCCR control bits are described in the following paragraphs (see Table 8-8).

Table 8-8 RCCR Register 11 10 8 5 0 3 2 X:\$FFFFB8 RDC2 RDC1 RDC0 RPSR RPM7 RPM6 RPM5 RPM4 RPM3 RPM2 RPM1 RPM0 23 22 2.1 20 19 18 17 16 15 14 13 12 RFSD RCKD RHCKP RFSP **RCKP** RFP3 RFP2 RFP1 RFP0 RDC4 RDC3

Hardware and software reset clear all the bits of the RCCR register.

# 8.3.3.1 RCCR Receiver Prescale Modulus Select (RPM7–RPM0) - Bits 7–0

The RPM7–RPM0 bits specify the divide ratio of the prescale divider in the ESAI receiver clock generator. A divide ratio from 1 to 256 (RPM[7:0]=\$00 to \$FF) may be selected. The bit clock output is available at the receiver serial bit clock (SCKR) pin of the DSP. The bit clock output is also available internally for use as the bit clock to shift the receive shift registers. The ESAI receive clock generator functional diagram is shown in Figure 8-2.

#### 8.3.3.2 RCCR Receiver Prescaler Range (RPSR) - Bit 8

The RPSR controls a fixed divide-by-eight prescaler in series with the variable prescaler. This bit is used to extend the range of the prescaler for those cases where a slower bit clock is desired. When RPSR is set, the fixed prescaler is bypassed. When RPSR is cleared, the fixed divide-by-eight prescaler is operational (see Figure 8-2). The maximum internally generated bit clock frequency is Fosc/4, the minimum internally generated bit clock frequency is Fosc/(2 x 8 x 256)=Fosc/4096.

**Note:** Do not use the combination RPSR=1 and RPM7-RPM0=\$00, which causes synchronization problems when using the internal DSP clock as source (RHCKD=1 or RCKD=1).

# 8.3.3.3 RCCR Rx Frame Rate Divider Control (RDC4–RDC0) - Bits 9–13

The RDC4–RDC0 bits control the divide ratio for the programmable frame rate dividers used to generate the receiver frame clocks.

In network mode, this ratio may be interpreted as the number of words per frame minus one. The divide ratio may range from 2 to 32 (RDC[4:0]=00001 to 11111) for network mode. A divide ratio of one (RDC[4:0]=00000) in network mode is a special case (on-demand mode).

In normal mode, this ratio determines the word transfer rate. The divide ratio may range from 1 to 32 (RDC[4:0]=00000 to 11111) for normal mode. In normal mode, a divide ratio of one (RDC[4:0]=00000) provides continuous periodic data word transfers. A bit-length frame sync (RFSL=1) must be used in this case.

The ESAI frame sync generator functional diagram is shown in Figure 8-3.

# 8.3.3.4 RCCR Rx High Frequency Clock Divider (RFP3-RFP0) - Bits 14-17

The RFP3–RFP0 bits control the divide ratio of the receiver high frequency clock to the receiver serial bit clock when the source of the receiver high frequency clock and the bit clock is the internal DSP clock. When the HCKR input is being driven from an external high frequency clock, the RFP3-RFP0 bits specify an additional division ration in the clock divider chain. See Table 8-9 for the specification of the divide ratio. The ESAI high frequency generator functional diagram is shown in Figure 8-2.

| RFP3-RFP0 | Divide Ratio |
|-----------|--------------|
| \$0       | 1            |
| \$1       | 2            |
| \$2       | 3            |
| \$3       | 4            |
|           |              |
| \$F       | 16           |

Table 8-9 Receiver High Frequency Clock Divider

# 8.3.3.5 RCCR Receiver Clock Polarity (RCKP) - Bit 18

The Receiver Clock Polarity (RCKP) bit controls on which bit clock edge data and frame sync are clocked out and latched in. If RCKP is cleared the data and the frame sync are clocked out on the rising edge of the receive bit clock and the frame sync is latched in on the falling edge of the receive bit clock. If RCKP is set the falling edge of the receive clock is used to clock the data and frame sync out and the rising edge of the receive clock is used to latch the frame sync in.

# 8.3.3.6 RCCR Receiver Frame Sync Polarity (RFSP) - Bit 19

The Receiver Frame Sync Polarity (RFSP) determines the polarity of the receive frame sync signal. When RFSP is cleared the frame sync signal polarity is positive (i.e the frame start is indicated by a high level on the frame sync pin). When RFSP is set the frame sync signal polarity is negative (i.e the frame start is indicated by a low level on the frame sync pin).

### 8.3.3.7 RCCR Receiver High Frequency Clock Polarity (RHCKP) - Bit 20

The Receiver High Frequency Clock Polarity (RHCKP) bit controls on which bit clock edge data and frame sync are clocked out and latched in. If RHCKP is cleared the data and the frame sync are clocked out on the rising edge of the receive bit clock and the frame sync is latched in on the falling edge of the receive bit clock. If RHCKP is set the falling edge of the receive clock is used to clock the data and frame sync out and the rising edge of the receive clock is used to latch the frame sync in.

# 8.3.3.8 RCCR Receiver Clock Source Direction (RCKD) - Bit 21

The Receiver Clock Source Direction (RCKD) bit selects the source of the clock signal used to clock the receive shift register in the asynchronous mode (SYN=0) and the IF0/OF0 flag direction in the synchronous mode (SYN=1).

In the asynchronous mode when RCKD is set, the internal clock source becomes the bit clock for the receive shift registers and word length divider, and is the output on the SCKR pin. In the asynchronous mode when RCKD is cleared, the clock source is external; the internal clock generator is disconnected from the SCKR pin, and an external clock source may drive this pin.

In the synchronous mode when RCKD is set, the SCKR pin becomes the OF0 output flag. If RCKD is cleared, then the SCKR pin becomes the IF0 input flag. See Table 8-1 and Table 8-10.

| Contr | SCKR PIN |             |  |
|-------|----------|-------------|--|
| SYN   | SYN RCKD |             |  |
| 0     | 0        | SCKR input  |  |
| 0     | 1        | SCKR output |  |
| 1     | 0        | IF0         |  |
| 1     | 1        | OF0         |  |

Table 8-10 SCKR Pin Definition Table

# 8.3.3.9 RCCR Receiver Frame Sync Signal Direction (RFSD) - Bit 22

The Receiver Frame Sync Signal Direction (RFSD) bit selects the source of the receiver frame sync signal when in the asynchronous mode (SYN=0), and the IF1/OF1/Transmitter Buffer Enable flag direction in the synchronous mode (SYN=1).

In the asynchronous mode when RFSD is set, the internal clock generator becomes the source of the receiver frame sync, and is the output on the FSR pin. In the asynchronous mode when RFSD is cleared, the receiver frame sync source is external; the internal clock generator is disconnected from the FSR pin, and an external clock source may drive this pin.

In the synchronous mode when RFSD is set, the FSR pin becomes the OF1 output flag or the Transmitter Buffer Enable, according to the TEBE control bit. If RFSD is cleared, then the FSR pin becomes the IF1 input flag. See Table 8-1 and Table 8-11.

**Control Bits** FSR Pin SYN TEBE RFSD FSR input 0 Χ 0 0 X 1 FSR output 1 0 0 IF1 0 OF1 1 1 1 1 0 reserved 1 1 Transmitter

**Table 8-11 FSR Pin Definition Table** 

#### 8.3.3.10 RCCR Receiver High Frequency Clock Direction (RHCKD) - Bit 23

Buffer Enable

The Receiver High Frequency Clock Direction (RHCKD) bit selects the source of the receiver high frequency clock when in the asynchronous mode (SYN=0), and the IF2/OF2 flag direction in the synchronous mode (SYN=1).

In the asynchronous mode when RHCKD is set, the internal clock generator becomes the source of the receiver high frequency clock, and is the output on the HCKR pin. In the asynchronous mode when RHCKD is cleared, the receiver high frequency clock source is external; the internal clock generator is disconnected from the HCKR pin, and an external clock source may drive this pin.

When RHCKD is cleared, HCKR is an input; when RHCKD is set, HCKR is an output.

In the synchronous mode when RHCKD is set, the HCKR pin becomes the OF2 output flag. If RHCKD is cleared, then the HCKR pin becomes the IF2 input flag. See Table 8-1 and Table 8-12.

Table 8-12 HCKR Pin Definition Table

| Contr | Control Bits |             |  |  |  |  |
|-------|--------------|-------------|--|--|--|--|
| SYN   | RHCKD        | HCKR PIN    |  |  |  |  |
| 0     | 0            | HCKR input  |  |  |  |  |
| 0     | 1            | HCKR output |  |  |  |  |
| 1     | 0            | IF2         |  |  |  |  |
| 1     | 1            | OF2         |  |  |  |  |

## 8.3.4 ESAI RECEIVE CONTROL REGISTER (RCR)

The read/write Receive Control Register (RCR) controls the ESAI receiver section. Interrupt enable bits for the receivers are provided in this control register. The receivers are enabled in this register (0,1,2 or 3 receivers can be enabled) if the input data pin is not used by a transmitter. Operating modes are also selected in this register.

Table 8-13 RCR Register

11 10 6 5 3 2 1 0 X:\$FFFFB7 RSWS1 RSWS0 RMOD1 RMOD0 RWA RSHFD RE3 RE2 RE1 RE0 23 22 20 19 18 17 15 14 12 13 RLIE RIE REDIE REIE RFSR RFSL RSWS4 RSWS3 RSWS2 RPR Reserved bit - read as zero; should be written with zero for future compatibility.

Hardware and software reset clear all the bits in the RCR register.

The ESAI RCR bits are described in the following paragraphs.

#### 8.3.4.1 RCR ESAI Receiver 0 Enable (RE0) - Bit 0

When RE0 is set and TE5 is cleared, the ESAI receiver 0 is enabled and samples data at the SDO5/SDI0 pin. TX5 and RX0 should not be enabled at the same time (RE0=1 and TE5=1). When RE0 is cleared, receiver 0 is disabled by inhibiting data transfer into RX0. If this bit is cleared while receiving a data word, the remainder of the word is shifted in and transferred to the RX0 data register.

If RE0 is set while some of the other receivers are already in operation, the first data word received in RX0 will be invalid and must be discarded.

#### 8.3.4.2 RCR ESAI Receiver 1 Enable (RE1) - Bit 1

When RE1 is set and TE4 is cleared, the ESAI receiver 1 is enabled and samples data at the SDO4/SDI1 pin. TX4 and RX1 should not be enabled at the same time (RE1=1 and TE4=1). When RE1 is cleared, receiver 1 is disabled by inhibiting data transfer into RX1. If this bit is cleared while receiving a data word, the remainder of the word is shifted in and transferred to the RX1 data register.

If RE1 is set while some of the other receivers are already in operation, the first data word received in RX1 will be invalid and must be discarded.

#### 8.3.4.3 RCR ESAI Receiver 2 Enable (RE2) - Bit 2

When RE2 is set and TE3 is cleared, the ESAI receiver 2 is enabled and samples data at the SDO3/SDI2 pin. TX3 and RX2 should not be enabled at the same time (RE2=1 and TE3=1). When RE2 is cleared, receiver 2 is disabled by inhibiting data transfer into RX2. If this bit is cleared while receiving a data word, the remainder of the word is shifted in and transferred to the RX2 data register.

If RE2 is set while some of the other receivers are already in operation, the first data word received in RX2 will be invalid and must be discarded.

#### 8.3.4.4 RCR ESAI Receiver 3 Enable (RE3) - Bit 3

When RE3 is set and TE2 is cleared, the ESAI receiver 3 is enabled and samples data at the SDO2/SDI3 pin. TX2 and RX3 should not be enabled at the same time (RE3=1 and TE2=1). When RE3 is cleared, receiver 3 is disabled by inhibiting data transfer into RX3. If this bit is cleared while receiving a data word, the remainder of the word is shifted in and transferred to the RX3 data register.

If RE3 is set while some of the other receivers are already in operation, the first data word received in RX3 will be invalid and must be discarded.

#### 8.3.4.5 RCR Reserved Bits - Bits 4-5, 17-18

These bits are reserved. They read as zero, and they should be written with zero for future compatibility.

#### 8.3.4.6 RCR Receiver Shift Direction (RSHFD) - Bit 6

The RSHFD bit causes the receiver shift registers to shift data in MSB first when RSHFD is cleared or LSB first when RSHFD is set (see Figure 8-7 and Figure 8-8).

#### 8.3.4.7 RCR Receiver Word Alignment Control (RWA) - Bit 7

The Receiver Word Alignment Control (RWA) bit defines the alignment of the data word in relation to the slot. This is relevant for the cases where the word length is shorter than the slot length. If RWA is cleared, the data word is assumed to be left-aligned in the slot frame. If RWA is set, the data word is assumed to be right-aligned in the slot frame.

If the data word is shorter than the slot length, the data bits which are not in the data word field are ignored.

For data word lengths of less than 24 bits, the data word is right-extended with zeroes before being stored in the receive data registers.

#### 8.3.4.8 RCR Receiver Network Mode Control (RMOD1-RMOD0) - Bits 8-9

The RMOD1 and RMOD0 bits are used to define the network mode of the ESAI receivers according to Table 8-14. In the normal mode, the frame rate divider determines the word

transfer rate – one word is transferred per frame sync during the frame sync time slot, as shown in Figure 8-4. In network mode, it is possible to transfer a word for every time slot, as shown in Figure 8-4. For more details, see Section 8.4, "Operating Modes".

In order to comply with AC-97 specifications, RSWS4-RSWS0 should be set to 00011 (20-bit slot, 20-bit word), RFSL and RFSR should be cleared, and RDC4-RDC0 should be set to \$0C (13 words in frame).

| RMOD1 | RMOD0 | RDC4-RDC0 | Receiver Network Mode |
|-------|-------|-----------|-----------------------|
| 0     | 0     | \$0-\$1F  | Normal Mode           |
| 0     | 1     | \$0       | On-Demand Mode        |
| 0     | 1     | \$1-\$1F  | Network Mode          |
| 1     | 0     | X         | Reserved              |
| 1     | 1     | \$0C      | AC97                  |

Table 8-14 ESAI Receive Network Mode Selection

#### 8.3.4.9 RCR Receiver Slot and Word Select (RSWS4-RSWS0) - Bits 10-14

The RSWS4-RSWS0 bits are used to select the length of the slot and the length of the data words being received via the ESAI. The word length must be equal to or shorter than the slot length. The possible combinations are shown in Table 8-15. See also the ESAI data path programming model in Figure 8-7 and Figure 8-8.

| ı     | able 8-13 | ESAII | Receive 3 | Siot and | word Length S | election    |
|-------|-----------|-------|-----------|----------|---------------|-------------|
| RSWS4 | RSWS3     | RSWS2 | RSWS1     | RSWS0    | SLOT LENGTH   | WORD LENGTH |
| 0     | 0         | 0     | 0         | 0        | 8             | 8           |
| 0     | 0         | 1     | 0         | 0        | 12            | 8           |
| 0     | 0         | 0     | 0         | 1        |               | 12          |
| 0     | 1         | 0     | 0         | 0        | 16            | 8           |
| 0     | 0         | 1     | 0         | 1        |               | 12          |
| 0     | 0         | 0     | 1         | 0        |               | 16          |
| 0     | 1         | 1     | 0         | 0        | 20            | 8           |
| 0     | 1         | 0     | 0         | 1        |               | 12          |
| 0     | 0         | 1     | 1         | 0        |               | 16          |
| 0     | 0         | 0     | 1         | 1        |               | 20          |
| 1     | 0         | 0     | 0         | 0        | 24            | 8           |
| 0     | 1         | 1     | 0         | 1        |               | 12          |
| 0     | 1         | 0     | 1         | 0        |               | 16          |
| 0     | 0         | 1     | 1         | 1        |               | 20          |

Table 8-15 ESAI Receive Slot and Word Length Selection

| RSWS4 | RSWS3 | RSWS2 | RSWS1 | RSWS0 | SLOT LENGTH | WORD LENGTH |  |  |
|-------|-------|-------|-------|-------|-------------|-------------|--|--|
| 1     | 1     | 0     | 0     | 0     | 32          | 8           |  |  |
| 1     | 0     | 1     | 0     | 1     |             | 12          |  |  |
| 1     | 0     | 0     | 1     | 0     |             | 16          |  |  |
| 0     | 1     | 1     | 1     | 1     |             | 20          |  |  |
| 1     | 1     | 1     | 1     | 1     |             | 24          |  |  |
| 0     | 1     | 0     | 1     | 1     | Rese        | erved       |  |  |
| 0     | 1     | 1     | 1     | 0     |             |             |  |  |
| 1     | 0     | 0     | 0     | 1     |             |             |  |  |
| 1     | 0     | 0     | 1     | 1     |             |             |  |  |
| 1     | 0     | 1     | 0     | 0     |             |             |  |  |
| 1     | 0     | 1     | 1     | 0     |             |             |  |  |
| 1     | 0     | 1     | 1     | 1     |             |             |  |  |
| 1     | 1     | 0     | 0     | 1     |             |             |  |  |
| 1     | 1     | 0     | 1     | 0     |             |             |  |  |
| 1     | 1     | 0     | 1     | 1     |             |             |  |  |
| 1     | 1     | 1     | 0     | 0     |             |             |  |  |
| 1     | 1     | 1     | 0     | 1     |             |             |  |  |

Table 8-15 ESAI Receive Slot and Word Length Selection (Continued)

#### 8.3.4.10 RCR Receiver Frame Sync Length (RFSL) - Bit 15

The RFSL bit selects the length of the receive frame sync to be generated or recognized. If RFSL is cleared, a word-length frame sync is selected. If RFSL is set, a 1-bit clock period frame sync is selected. See Figure 8-5 for examples of frame length selection.

## 8.3.4.11 RCR Receiver Frame Sync Relative Timing (RFSR) - Bit 16

RFSR determines the relative timing of the receive frame sync signal as referred to the serial data lines, for a word length frame sync only. When RFSR is cleared the word length frame sync occurs together with the first bit of the data word of the first slot. When RFSR is set the word length frame sync starts one serial clock cycle earlier (i.e. together with the last bit of the previous data word).

#### 8.3.4.12 RCR Receiver Section Personal Reset (RPR) - Bit 19

The RPR control bit is used to put the receiver section of the ESAI in the personal reset state. The transmitter section is not affected. When RPR is cleared, the receiver section may operate normally. When RPR is set, the receiver section enters the personal reset state immediately. When in the personal reset state, the status bits are reset to the same state as after hardware reset. The control bits are not affected by the personal reset state. The receiver data pins are disconnected while in the personal reset state. Note that to leave the personal reset state by

clearing RPR, the procedure described in Section 8.6, "ESAI Initialization Examples" should be followed.

#### 8.3.4.13 RCR Receive Exception Interrupt Enable (REIE) - Bit 20

When REIE is set, the DSP is interrupted when both RDF and ROE in the SAISR status register are set. When REIE is cleared, this interrupt is disabled. Reading the SAISR status register followed by reading the enabled receivers data registers clears ROE, thus clearing the pending interrupt.

## 8.3.4.14 RCR Receive Even Slot Data Interrupt Enable (REDIE) - Bit 21

The REDIE control bit is used to enable the receive even slot data interrupts. If REDIE is set, the receive even slot data interrupts are enabled. If REDIE is cleared, the receive even slot data interrupts are disabled. A receive even slot data interrupt request is generated if REDIE is set and the REDF status flag in the SAISR status register is set. Even time slots are all even-numbered time slots (0, 2, 4, etc.) when operating in network mode. The zero time slot is marked by the frame sync signal and is considered to be even. Reading all the data registers of the enabled receivers clears the REDF flag, thus servicing the interrupt.

Receive interrupts with exception have higher priority than receive even slot data interrupts, therefore if exception occurs (ROE is set) and REIE is set, the ESAI requests an ESAI receive data with exception interrupt from the interrupt controller.

#### 8.3.4.15 RCR Receive Interrupt Enable (RIE) - Bit 22

The DSP is interrupted when RIE and the RDF flag in the SAISR status register are set. When RIE is cleared, this interrupt is disabled. Reading the receive data registers of the enabled receivers clears RDF, thus clearing the interrupt.

Receive interrupts with exception have higher priority than normal receive data interrupts, therefore if exception occurs (ROE is set) and REIE is set, the ESAI requests an ESAI receive data with exception interrupt from the interrupt controller.

#### 8.3.4.16 RCR Receive Last Slot Interrupt Enable (RLIE) - Bit 23

RLIE enables an interrupt after the last slot of a frame ended in network mode only. When RLIE is set the DSP is interrupted after the last slot in a frame ended regardless of the receive mask register setting. When RLIE is cleared the receive last slot interrupt is disabled. Hardware and software reset clear RLIE. RLIE is disabled when RDC[4:0]=00000 (on-demand mode). The use of the receive last slot interrupt is described in Section 8.4.3, "ESAI Interrupt Requests".

## 8.3.5 ESAI COMMON CONTROL REGISTER (SAICR)

The read/write Common Control Register (SAICR) contains control bits for functions that affect both the receive and transmit sections of the ESAI. See Table 8-16.

Table 8-16 SAICR Register 11 10 8 7 6 3 2 0 ALC OF2 OF1 X:\$FFFB4 **TEBE** SYN OF0 23 22 21 19 18 17 15 14 13 12 20 16 Reserved bit - read as zero; should be written with zero for future compatibility.

Hardware and software reset clear all the bits in the SAICR register.

### 8.3.5.1 SAICR Serial Output Flag 0 (OF0) - Bit 0

The Serial Output Flag 0 (OF0) is a data bit used to hold data to be send to the OF0 pin. When the ESAI is in the synchronous clock mode (SYN=1), the SCKR pin is configured as the ESAI flag 0. If the receiver serial clock direction bit (RCKD) is set, the SCKR pin is the output flag OF0, and data present in the OF0 bit is written to the OF0 pin at the beginning of the frame in normal mode or at the beginning of the next time slot in network mode.

## 8.3.5.2 SAICR Serial Output Flag 1 (OF1) - Bit 1

The Serial Output Flag 1 (OF1) is a data bit used to hold data to be send to the OF1 pin. When the ESAI is in the synchronous clock mode (SYN=1), the FSR pin is configured as the ESAI flag 1. If the receiver frame sync direction bit (RFSD) is set and the TEBE bit is cleared, the FSR pin is the output flag OF1, and data present in the OF1 bit is written to the OF1 pin at the beginning of the frame in normal mode or at the beginning of the next time slot in network mode.

#### 8.3.5.3 SAICR Serial Output Flag 2 (OF2) - Bit 2

The Serial Output Flag 2 (OF2) is a data bit used to hold data to be send to the OF2 pin. When the ESAI is in the synchronous clock mode (SYN=1), the HCKR pin is configured as the ESAI flag 2. If the receiver high frequency clock direction bit (RHCKD) is set, the HCKR pin is the output flag OF2, and data present in the OF2 bit is written to the OF2 pin at the beginning of the frame in normal mode or at the beginning of the next time slot in network mode.

#### 8.3.5.4 SAICR Reserved Bits - Bits 3-5, 9-23

These bits are reserved. They read as zero, and they should be written with zero for future compatibility.

#### 8.3.5.5 SAICR Synchronous Mode Selection (SYN) - Bit 6

The Synchronous Mode Selection (SYN) bit controls whether the receiver and transmitter sections of the ESAI operate synchronously or asynchronously with respect to each other (see Figure 8-6). When SYN is cleared, the asynchronous mode is chosen and independent clock and frame sync signals are used for the transmit and receive sections. When SYN is set, the synchronous mode is chosen and the transmit and receive sections use common clock and frame sync signals.

When in the synchronous mode (SYN=1), the transmit and receive sections use the transmitter section clock generator as the source of the clock and frame sync for both sections. Also, the receiver clock pins SCKR, FSR and HCKR now operate as I/O flags. See Table 8-10, Table 8-11 and Table 8-12 for the effects of SYN on the receiver clock pins.

#### 8.3.5.6 SAICR Transmit External Buffer Enable (TEBE) - Bit 7

The Transmitter External Buffer Enable (TEBE) bit controls the function of the FSR pin when in the synchronous mode. If the ESAI is configured for operation in the synchronous mode (SYN=1), and TEBE is set while FSR pin is configured as an output (RFSD=1), the FSR pin functions as the transmitter external buffer enable control, to enable the use of an external buffers on the transmitter outputs. If TEBE is cleared then the FSR pin functions as the serial I/O flag 1. See Table 8-11 for a summary of the effects of TEBE on the FSR pin.

#### 8.3.5.7 SAICR Alignment Control (ALC) - Bit 8

The ESAI is designed for 24-bit fractional data, thus shorter data words are left aligned to the MSB (bit 23). Some applications use 16-bit fractional data. In those cases, shorter data words may be left aligned to bit 15. The Alignment Control (ALC) bit supports these applications.

If ALC is set, transmitted and received words are left aligned to bit 15 in the transmit and receive shift registers. If ALC is cleared, transmitted and received word are left aligned to bit 23 in the transmit and receive shift registers.

**Note:** While ALC is set, 20-bit and 24-bit words may not be used, and word length control should specify 8-, 12- or 16-bit words, otherwise results are unpredictable.



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



NOTE: Transmitter and receiver have the same clocks and frame syncs.

Figure 8-6 SAICR SYN Bit Operation

## 8.3.6 ESAI STATUS REGISTER (SAISR)

The Status Register (SAISR) is a read-only status register used by the DSP to read the status and serial input flags of the ESAI. See Table 8-17. The status bits are described in the following paragraphs.

Table 8-17 SAISR Register 10 11 2 0 X:\$FFFFB3 RODF REDF RDF ROE RFS IF2 IF1 IF0 23 22 2.1 20 19 18 17 16 15 14 13 12 TODE TEDE TDE TUE **TFS** Reserved bit - read as zero; should be written with zero for future compatibility.

#### 8.3.6.1 SAISR Serial Input Flag 0 (IF0) - Bit 0

The IF0 bit is enabled only when the SCKR pin is defined as ESAI in the Port Control Register, SYN=1 and RCKD=0, indicating that SCKR is an input flag and the synchronous mode is selected. Data present on the SCKR pin is latched during reception of the first received data bit after frame sync is detected. The IF0 bit is updated with this data when the receiver shift registers are transferred into the receiver data registers. IF0 reads as a zero when it is not enabled. Hardware, software, ESAI individual, and STOP reset clear IF0.

## 8.3.6.2 SAISR Serial Input Flag 1 (IF1) - Bit 1

The IF1 bit is enabled only when the FSR pin is defined as ESAI in the Port Control Register, SYN =1, RFSD=0 and TEBE=0, indicating that FSR is an input flag and the synchronous mode is selected. Data present on the FSR pin is latched during reception of the first received data bit after frame sync is detected. The IF1 bit is updated with this data when the receiver shift registers are transferred into the receiver data registers. IF1 reads as a zero when it is not enabled. Hardware, software, ESAI individual, and STOP reset clear IF1.

## 8.3.6.3 SAISR Serial Input Flag 2 (IF2) - Bit 2

The IF2 bit is enabled only when the HCKR pin is defined as ESAI in the Port Control Register, SYN=1 and RHCKD=0, indicating that HCKR is an input flag and the synchronous mode is selected. Data present on the HCKR pin is latched during reception of the first received data bit after frame sync is detected. The IF2 bit is updated with this data when the receive shift registers are transferred into the receiver data registers. IF2 reads as a zero when it is not enabled. Hardware, software, ESAI individual, and STOP reset clear IF2.

#### 8.3.6.4 SAISR Reserved Bits - Bits 3-5, 11-12, 18-23

These bits are reserved for future use. They read as zero.

#### 8.3.6.5 SAISR Receive Frame Sync Flag (RFS) - Bit 6

When set, RFS indicates that a receive frame sync occurred during reception of the words in the receiver data registers. This indicates that the data words are from the first slot in the frame. When RFS is clear and a word is received, it indicates (only in the network mode) that the frame sync did not occur during reception of that word. RFS is cleared by hardware, software, ESAI individual, or STOP reset. RFS is valid only if at least one of the receivers is enabled (REx=1).

**Note:** In normal mode, RFS always reads as a one when reading data because there is only one time slot per frame – the "frame sync" time slot.

#### 8.3.6.6 SAISR Receiver Overrun Error Flag (ROE) - Bit 7

The ROE flag is set when the serial receive shift register of an enabled receiver is full and ready to transfer to its receiver data register (RXx) and the register is already full (RDF=1). If REIE is set, an ESAI receive data with exception (overrun error) interrupt request is issued when ROE is set. Hardware, software, ESAI individual, and STOP reset clear ROE. ROE is also cleared by reading the SAISR with ROE set, followed by reading all the enabled receive data registers.

## 8.3.6.7 SAISR Receive Data Register Full (RDF) - Bit 8

RDF is set when the contents of the receive shift register of an enabled receiver is transferred to the respective receive data register. RDF is cleared when the DSP reads the receive data register of all enabled receivers or cleared by hardware, software, ESAI individual, or STOP reset. If RIE is set, an ESAI receive data interrupt request is issued when RDF is set.

#### 8.3.6.8 SAISR Receive Even-Data Register Full (REDF) - Bit 9

When set, REDF indicates that the received data in the receive data registers of the enabled receivers have arrived during an even time slot when operating in the network mode. Even time slots are all even-numbered slots (0, 2, 4, 6, etc.). Time slots are numbered from zero to N-1, where N is the number of time slots in the frame. The zero time slot is considered even. REDF is set when the contents of the receive shift registers are transferred to the receive data registers. REDF is cleared when the DSP reads all the enabled receive data registers or cleared by hardware, software, ESAI individual, or STOP resets. If REDIE is set, an ESAI receive even slot data interrupt request is issued when REDF is set.

#### 8.3.6.9 SAISR Receive Odd-Data Register Full (RODF) - Bit 10

When set, RODF indicates that the received data in the receive data registers of the enabled receivers have arrived during an odd time slot when operating in the network mode. Odd time slots are all odd-numbered slots (1, 3, 5, etc.). Time slots are numbered from zero to N-1, where N is the number of time slots in the frame. RODF is set when the contents of the receive

shift registers are transferred to the receive data registers. RODF is cleared when the DSP reads all the enabled receive data registers or cleared by hardware, software, ESAI individual, or STOP resets.

#### 8.3.6.10 SAISR Transmit Frame Sync Flag (TFS) - Bit 13

When set, TFS indicates that a transmit frame sync occurred in the current time slot. TFS is set at the start of the first time slot in the frame and cleared during all other time slots. Data written to a transmit data register during the time slot when TFS is set is transmitted (in network mode), if the transmitter is enabled, during the second time slot in the frame. TFS is useful in network mode to identify the start of a frame. TFS is cleared by hardware, software, ESAI individual, or STOP reset. TFS is valid only if at least one transmitter is enabled (i.e. one or more of TE0, TE1, TE2, TE3, TE4 and TE5 are set).

**Note:** In normal mode, TFS always reads as a one when transmitting data because there is only one time slot per frame – the "frame sync" time slot.

#### 8.3.6.11 SAISR Transmit Underrun Error Flag (TUE) - Bit 14

TUE is set when at least one of the enabled serial transmit shift registers is empty (no new data to be transmitted) and a transmit time slot occurs. When a transmit underrun error occurs, the previous data (which is still present in the TX registers that were not written) is retransmitted. If TEIE is set, an ESAI transmit data with exception (underrun error) interrupt request is issued when TUE is set. Hardware, software, ESAI individual, and STOP reset clear TUE. TUE is also cleared by reading the SAISR with TUE set, followed by writing to all the enabled transmit data registers or to TSR.

#### 8.3.6.12 SAISR Transmit Data Register Empty (TDE) - Bit 15

TDE is set when the contents of the transmit data register of all the enabled transmitters are transferred to the transmit shift registers; it is also set for a TSR disabled time slot period in network mode (as if data were being transmitted after the TSR was written). When set, TDE indicates that data should be written to all the TX registers of the enabled transmitters or to the time slot register (TSR). TDE is cleared when the DSP writes to all the transmit data registers of the enabled transmitters, or when the DSP writes to the TSR to disable transmission of the next time slot. If TIE is set, an ESAI transmit data interrupt request is issued when TDE is set. Hardware, software, ESAI individual, and STOP reset clear TDE.

#### 8.3.6.13 SAISR Transmit Even-Data Register Empty (TEDE) - Bit 16

When set, TEDE indicates that the enabled transmitter data registers became empty at the beginning of an even time slot. Even time slots are all even-numbered slots (0, 2, 4, 6, etc.). Time slots are numbered from zero to N-1, where N is the number of time slots in the frame. The zero time slot is considered even. This flag is set when the contents of the transmit data register of all the enabled transmitters are transferred to the transmit shift registers; it is also set for a TSR disabled time slot period in network mode (as if data were being transmitted after the TSR was written). When set, TEDE indicates that data should be written to all the TX

registers of the enabled transmitters or to the time slot register (TSR). TEDE is cleared when the DSP writes to all the transmit data registers of the enabled transmitters, or when the DSP writes to the TSR to disable transmission of the next time slot. If TIE is set, an ESAI transmit data interrupt request is issued when TEDE is set. Hardware, software, ESAI individual, and STOP reset clear TEDE.

#### 8.3.6.14 SAISR Transmit Odd-Data Register Empty (TODE) - Bit 17

When set, TODE indicates that the enabled transmitter data registers became empty at the beginning of an odd time slot. Odd time slots are all odd-numbered slots (1, 3, 5, etc.). Time slots are numbered from zero to N-1, where N is the number of time slots in the frame. This flag is set when the contents of the transmit data register of all the enabled transmitters are transferred to the transmit shift registers; it is also set for a TSR disabled time slot period in network mode (as if data were being transmitted after the TSR was written). When set, TODE indicates that data should be written to all the TX registers of the enabled transmitters or to the time slot register (TSR). TODE is cleared when the DSP writes to all the transmit data registers of the enabled transmitters, or when the DSP writes to the TSR to disable transmission of the next time slot. If TIE is set, an ESAI transmit data interrupt request is issued when TODE is set. Hardware, software, ESAI individual, and STOP reset clear TODE.



Figure 8-7 ESAI Data Path Programming Model ([R/T]SHFD=0)



Figure 8-8 ESAI Data Path Programming Model ([R/T]SHFD=1)

#### 8.3.7 ESAI RECEIVE SHIFT REGISTERS

The receive shift registers (see Figure 8-7 and Figure 8-8) receive the incoming data from the serial receive data pins. Data is shifted in by the selected (internal/external) bit clock when the associated frame sync I/O is asserted. Data is assumed to be received MSB first if RSHFD=0 and LSB first if RSHFD=1. Data is transferred to the ESAI receive data registers after 8, 12, 16, 20, 24, or 32 serial clock cycles were counted, depending on the slot length control bits in the RCR register.

## 8.3.8 ESAI RECEIVE DATA REGISTERS (RX3, RX2, RX1, RX0)

RX3, RX2, RX1 and RX0 are 24-bit read-only registers that accept data from the receive shift registers when they become full (see Figure 8-7 and Figure 8-8). The data occupies the most significant portion of the receive data registers, according to the ALC control bit setting. The unused bits (least significant portion, and 8 most significant bits when ALC=1) read as zeros. The DSP is interrupted whenever RXx becomes full if the associated interrupt is enabled.

#### 8.3.9 ESAI TRANSMIT SHIFT REGISTERS

The transmit shift registers contain the data being transmitted (see Figure 8-7 and Figure 8-8). Data is shifted out to the serial transmit data pins by the selected (internal/external) bit clock when the associated frame sync I/O is asserted. The number of bits shifted out before the shift registers are considered empty and may be written to again can be 8, 12, 16, 20, 24 or 32 bits (determined by the slot length control bits in the TCR register). Data is shifted out of these registers MSB first if TSHFD=0 and LSB first if TSHFD=1.

# 8.3.10 ESAI TRANSMIT DATA REGISTERS (TX5, TX4, TX3, TX2,TX1,TX0)

TX5, TX4, TX3, TX2, TX1 and TX0 are 24-bit write-only registers. Data to be transmitted is written into these registers and is automatically transferred to the transmit shift registers (see Figure 8-7 and Figure 8-8). The data written (8, 12, 16, 20 or 24 bits) should occupy the most significant portion of the TXx according to the ALC control bit setting. The unused bits (least significant portion, and the 8 most significant bits when ALC=1) of the TXx are don't care bits. The DSP is interrupted whenever the TXx becomes empty if the transmit data register empty interrupt has been enabled.

## 8.3.11 ESAI TIME SLOT REGISTER (TSR)

The write-only Time Slot Register (TSR) is effectively a null data register that is used when the data is not to be transmitted in the available transmit time slot. The transmit data pins of all the enabled transmitters are in the high-impedance state for the respective time slot where TSR has been written. The Transmitter External Buffer Enable pin (FSR pin when SYN=1, TEBE=1, RFSD=1) disables the external buffers during the slot when the TSR register has been written.

## 8.3.12 TRANSMIT SLOT MASK REGISTERS (TSMA, TSMB)

The Transmit Slot Mask Registers (TSMA and TSMB) are two read/write registers used by the transmitters in network mode to determine for each slot whether to transmit a data word and generate a transmitter empty condition (TDE=1), or to tri-state the transmitter data pins. TSMA and TSMB should each be considered as containing half a 32-bit register TSM. See Table 8-18 and Table 8-19. Bit number N in TSM (TS\*\*) is the enable/disable control bit for transmission in slot number N.

Table 8-18 TSMA Register 7 5 11 10 8 3 2 1 0 X:\$FFFFB9 TS11 TS10 TS9 TS8 TS7 TS5 TS4 TS3 TS2 TS1 TS0 TS6 23 22 21 20 19 18 17 16 15 14 13 12 TS15 TS14 TS13 TS12 Reserved bit - read as zero; should be written with zero for future compatibility. Table 8-19 TSMB Register 11 10 8 5 3 2 1 0 X:\$FFFBA TS25 TS21 TS20 TS19 TS18 TS17 TS16 **TS27** TS26 TS24 **TS23** TS22 23 22 21 20 19 18 17 16 15 14 13 12 TS31 TS30 TS29 **TS28** Reserved bit - read as zero; should be written with zero for future compatibility.

When bit number N in TSM is cleared, all the transmit data pins of the enabled transmitters are tri-stated during transmit time slot number N. The data is still transferred from the transmit data registers to the transmit shift registers but neither the TDE nor the TUE flags are set. This means that during a disabled slot, no transmitter empty interrupt is generated. The DSP is interrupted only for enabled slots. Data that is written to the transmit data registers when servicing this request is transmitted in the next enabled transmit time slot.

When bit number N in TSM register is set, the transmit sequence is as usual: data is transferred from the TX registers to the shift registers, transmitted during slot number N, and the TDE flag is set.

Using the slot mask in TSM does not conflict with using TSR. Even if a slot is enabled in TSM, the user may chose to write to TSR instead of writing to the transmit data registers TXx. This causes all the transmit data pins of the enabled transmitters to be tri-stated during the next slot.

Data written to the TSM affects the next frame transmission. The frame being transmitted is not affected by this data and would comply to the last TSM setting. Data read from TSM returns the last written data.

After hardware or software reset, the TSM register is preset to \$FFFFFFF, which means that all 32 possible slots are enabled for data transmission.

**Note:** When operating in normal mode, bit 0 of the mask register must be set, otherwise no output is generated.

## 8.3.13 RECEIVE SLOT MASK REGISTERS (RSMA, RSMB)

The Receive Slot Mask Registers (RSMA and RSMB) are two read/write registers used by the receiver in network mode to determine for each slot whether to receive a data word and generate a receiver full condition (RDF=1), or to ignore the received data. RSMA and RSMB should be considered as each containing half of a 32-bit register RSM. See Table 8-20 and

Table 8-21. Bit number N in RSM (RS\*\*) is an enable/disable control bit for receiving data in slot number N.



When bit number N in the RSM register is cleared, the data from the enabled receivers input pins are shifted into their receive shift registers during slot number N. The data is not transferred from the receive shift registers to the receive data registers, and neither the RDF nor the ROE flags are set. This means that during a disabled slot, no receiver full interrupt is generated. The DSP is interrupted only for enabled slots.

When bit number N in the RSM is set, the receive sequence is as usual: data which is shifted into the enabled receivers shift registers is transferred to the receive data registers and the RDF flag is set.

Data written to the RSM affects the next received frame. The frame being received is not affected by this data and would comply to the last RSM setting. Data read from RSM returns the last written data.

#### **Operating Modes**

After hardware or software reset, the RSM register is preset to \$FFFFFFF, which means that all 32 possible slots are enabled for data reception.

**Note:** When operating in normal mode, bit 0 of the mask register must be set to one,

otherwise no input is received.

#### 8.4 OPERATING MODES

ESAI operating mode are selected by the ESAI control registers (TCCR, TCR, RCCR, RCR and SAICR). The main operating mode are described in the following paragraphs.

#### 8.4.1 ESAI AFTER RESET

Hardware or software reset clears the port control register bits and the port direction control register bits, which configure all ESAI I/O pins as disconnected. The ESAI is in the individual reset state while all ESAI pins are programmed as GPIO or disconnected, and is active only if at least one of the ESAI I/O pins is programmed as an ESAI pin.

#### 8.4.2 ESAI INITIALIZATION

The correct way to initialize the ESAI is as follows:

- 1. Hardware, software, ESAI individual, or STOP reset.
- 2. Program ESAI control and time slot registers.
- 3. Write data to all the enabled transmitters.
- 4. Configure at least one pin as ESAI pin.

During program execution, all ESAI pins may be defined as GPIO or disconnected, causing the ESAI to stop serial activity and enter the individual reset state. All status bits of the interface are set to their reset state; however, the control bits are not affected. This procedure allows the DSP programmer to reset the ESAI separately from the other internal peripherals. During individual reset, internal DMA accesses to the data registers of the ESAI are not valid and data read is undefined.

The DSP programmer must use an individual ESAI reset when changing the ESAI control registers (except for TEIE, REIE, TLIE, RLIE, TIE, RIE, TE0-TE5, RE0-RE3) to ensure proper operation of the interface.

Note:

If the ESAI receiver section is already operating with some of the receivers, enabling additional receivers on the fly (i.e. without first putting the ESAI receiver in the personal reset state) by setting their REx control bits will result in erroneous data being received as the first data word for the newly enabled receivers.

#### 8.4.3 ESAI INTERRUPT REQUESTS

The ESAI can generate eight different interrupt requests (ordered from the highest to the lowest priority):

#### 1. ESAI Receive Data with Exception Status.

Occurs when the receive exception interrupt is enabled (REIE=1 in the RCR register), at least one of the enabled receive data registers is full (RDF=1), and a receiver overrun error has occurred (ROE=1 in the SAISR register). ROE is cleared by first reading the SAISR and then reading all the enabled receive data registers.

#### 2. ESAI Receive Even Data

Occurs when the receive even slot data interrupt is enabled (REDIE=1), at least one of the enabled receive data registers is full (RDF=1), the data is from an even slot (REDF=1), and no exception has occurred (ROE=0 or REIE=0).

Reading all enabled receiver data registers clears RDF and REDF.

#### 3. ESAI Receive Data

Occurs when the receive interrupt is enabled (RIE=1), at least one of the enabled receive data registers is full (RDF=1), no exception has occurred (ROE=0 or REIE=0), and no even slot interrupt has occurred (REDF=0 or REDIE=0). Reading all enabled receiver data registers clears RDF.

#### 4. ESAI Receive Last Slot Interrupt

Occurs, if enabled (RLIE=1), after the last slot of the frame ended (in network mode only) regardless of the receive mask register setting. The receive last slot interrupt may be used for resetting the receive mask slot register, reconfiguring the DMA channels and reassigning data memory pointers. Using the receive last slot interrupt guarantees that the previous frame was serviced with the previous setting and the new frame is serviced with the new setting without synchronization problems. Note that the maximum receive last slot interrupt service time should not exceed N-1 ESAI bits service time (where N is the number of bits in a slot).

#### 5. ESAI Transmit Data with Exception Status

Occurs when the transmit exception interrupt is enabled (TEIE=1), at least one transmit data register of the enabled transmitters is empty (TDE=1), and a transmitter underrun error has occurred (TUE=1). TUE is cleared by first reading the SAISR and then writing to all the enabled transmit data registers, or to the TSR register.

#### **Operating Modes**

#### 6. ESAI Transmit Last Slot Interrupt

Occurs, if enabled (TLIE=1), at the start of the last slot of the frame in network mode regardless of the transmit mask register setting. The transmit last slot interrupt may be used for resetting the transmit mask slot register, reconfiguring the DMA channels and reassigning data memory pointers. Using the transmit last slot interrupt guarantees that the previous frame was serviced with the previous setting and the new frame is serviced with the new setting without synchronization problems. Note that the maximum transmit last slot interrupt service time should not exceed N-1 ESAI bits service time (where N is the number of bits in a slot).

#### 7. ESAI Transmit Even Data

Occurs when the transmit even slot data interrupt is enabled (TEDIE=1), at least one of the enabled transmit data registers is empty (TDE=1), the slot is an even slot (TEDE=1), and no exception has occurred (TUE=0 or TEIE=0). Writing to all the TX registers of the enabled transmitters or to TSR clears this interrupt request.

#### 8. ESAI Transmit Data

Occurs when the transmit interrupt is enabled (TIE=1), at least one of the enabled transmit data registers is empty (TDE=1), no exception has occurred (TUE=0 or TEIE=0), and no even slot interrupt has occurred (TEDE=0 or TEDIE=0). Writing to all the TX registers of the enabled transmitters, or to the TSR clears this interrupt request.

# 8.4.4 OPERATING MODES – NORMAL, NETWORK, AND ON-DEMAND

The ESAI has three basic operating modes and many data/operation formats.

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

Selecting between the normal mode and network mode is accomplished by clearing or setting the TMOD0-TMOD1 bits in the TCR register for the transmitter section, and in the RMOD0-RMOD1 bits in the RCR register for the receiver section.

For normal mode, the ESAI functions with one data word of I/O per frame (per enabled transmitter or receiver). The normal mode is typically used to transfer data to/from a single device.

For the network mode, 2 to 32 time slots per frame may be selected. During each frame, 0 to 32 data words of I/O may be received/transmitted. In either case, the transfers are periodic. The frame sync signal indicates the first time slot in the frame. Network mode is typically

used in time division multiplexed (TDM) networks of codecs, DSPs with multiple words per frame, or multi-channel devices.

Selecting the network mode and setting the frame rate divider to zero (DC=00000) selects the on-demand mode. This special case does not generate a periodic frame sync. A frame sync pulse is generated only when data is available to transmit. The on-demand mode requires that the transmit frame sync be internal (output) and the receive frame sync be external (input). Therefore, for simplex operation, the synchronous mode could be used; however, for full-duplex operation, the asynchronous mode must be used. Data transmission that is data driven is enabled by writing data into each TX. Although the ESAI 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 as usual using TDE and RDF; however, transmit underruns are impossible for on-demand transmission and are disabled.

#### 8.4.4.2 Synchronous/Asynchronous Operating Modes

The transmit and receive sections of the ESAI may be synchronous or asynchronous – i.e., the transmitter and receiver sections may use common clock and synchronization signals (synchronous operating mode), or they may have their own separate clock and sync signals (asynchronous operating mode). The SYN bit in the SAICR register selects synchronous or asynchronous operation. Since the ESAI is designed to operate either synchronously or asynchronously, separate receive and transmit interrupts are provided.

When SYN is cleared, the ESAI transmitter and receiver clocks and frame sync sources are independent. If SYN is set, the ESAI transmitter and receiver clocks and frame sync come from the transmitter section (either external or internal sources).

Data clock and frame sync signals can be generated internally by the DSP or may be obtained from external sources. If internally generated, the ESAI clock generator is used to derive high frequency clock, bit clock and frame sync signals from the DSP internal system clock.

#### 8.4.4.3 Frame Sync Selection

The frame sync can be either a bit-long or word-long signal. The transmitter frame format is defined by the TFSL bit in the TCR register. The receiver frame format is defined by the RFSL bit in the RCR register.

- 1. In the word-long frame sync format, the frame sync signal is asserted during the entire word data transfer period. This frame sync length is compatible with Motorola codecs, SPI serial peripherals, serial A/D and D/A converters, shift registers, and telecommunication PCM serial I/O.
- 2. In the bit-long frame sync format, the frame sync signal is asserted for one bit clock immediately before the data transfer period. This frame sync length is compatible with Intel and National components, codecs, and telecommunication PCM serial I/O.

#### **Operating Modes**

The relative timing of the word length frame sync as referred to the data word is specified by the TFSR bit in the TCR register for the transmitter section, and by the RFSR bit in the RCR register for the receive section. The word length frame sync may be generated (or expected) with the first bit of the data word, or with the last bit of the previous word. TFSR and RFSR are ignored when a bit length frame sync is selected.

Polarity of the frame sync signal may be defined as positive (asserted high) or negative (asserted low). The TFSP bit in the TCCR register specifies the polarity of the frame sync for the transmitter section. The RFSP bit in the RCCR register specifies the polarity of the frame sync for the receiver section.

The ESAI receiver looks for a receive frame sync leading edge (trailing edge if RFSP is set) only when the previous frame is completed. If the frame sync goes high 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 RFSR 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 – i.e., a new frame sync does not have to immediately follow the previous frame. Gaps of arbitrary periods can occur between frames. Enabled transmitters are tri-stated during these gaps.

When operating in the synchronous mode (SYN=1), all clocks including the frame sync are generated by the transmitter section.

#### 8.4.4.4 Shift Direction Selection

Some data formats, such as those used by codecs, specify MSB first while other data formats, such as the AES-EBU digital audio interface, specify LSB first. The MSB/LSB first selection is made by programming RSHFD bit in the RCR register for the receiver section, and by programming the TSHFD bit in the TCR register for the transmitter section.

#### 8.4.5 SERIAL I/O FLAGS

Three ESAI pins (FSR, SCKR and HCKR) are available as serial I/O flags when the ESAI is operating in the synchronous mode (SYN=1). Their operation is controlled by RCKD, RFSD, TEBE bits in the RCR, RCCR and SAICR registers. The output data bits (OF2, OF1 and OF0) and the input data bits (IF2, IF1 and IF0) are double buffered to/from the HCKR, FSR and SCKR pins. Double buffering the flags keeps them in sync with the TX and RX data lines.

Each flag can be separately programmed. Flag 0 (SCKR pin) direction is selected by RCKD, RCKD=1 for output and RCKD=0 for input. Flag 1 (FSR pin) is enabled when the pin is not configured as external transmitter buffer enable (TEBE=0) and its direction is selected by RFSD, RFSD=1 for output and RFSD=0 for input. Flag 2 (HCKR pin) direction is selected by RHCKD, RHCKD=1 for output and RHCKD=0 for input.

When programmed as input flags, the SCKR, FSR and HCKR logic values, respectively, are latched at the same time as the first bit of the receive data word is sampled. Because the input was latched, the signal on the input flag pin (SCKR, FSR or HCKR) can change without affecting the input flag until the first bit of the next receive data word. When the received data words are transferred to the receive data registers, the input flag latched values are then transferred to the IF0, IF1 and IF2 bits in the SAISR register, where they may be read by software.

When programmed as output flags, the SCKR, FSR and HCKR logic values are driven by the contents of the OF0, OF1 and OF2 bits in the SAICR register respectively, and are driven when the transmit data registers are transferred to the transmit shift registers. The value on SCKR, FSR and HCKR is stable from the time the first bit of the transmit data word is transmitted until the first bit of the next transmit data word is transmitted. Software may change the OF0-OF2 values thus controlling the SCKR, FSR and HCKR pin values for each transmitted word. The normal sequence for setting output flags when transmitting data is as follows: wait for TDE (transmitter empty) to be set, first write the flags, and then write the transmit data to the transmit registers. OF0, OF1 and OF2 are double buffered so that the flag states appear on the pins when the transmit data is transferred to the transmit shift register (i.e., the flags are synchronous with the data).

#### 8.5 GPIO - PINS AND REGISTERS

The GPIO functionality of the ESAI port is controlled by three registers: Port C control register (PCRC), Port C direction register (PRRC) and Port C data register (PDRC).

## 8.5.1 PORT C CONTROL REGISTER (PCRC)

The read/write 24-bit Port C Control Register (PCRC) in conjunction with the Port C Direction Register (PRRC) controls the functionality of the ESAI GPIO pins. Each of the PC(11:0) bits controls the functionality of the corresponding port pin. See Table 8-22 for the port pin configurations. Hardware and software reset clear all PCRC bits.

## 8.5.2 PORT C DIRECTION REGISTER (PRRC)

The read/write 24-bit Port C Direction Register (PRRC) in conjunction with the Port C Control Register (PCRC) controls the functionality of the ESAI GPIO pins. Table 8-22 describes the port pin configurations. Hardware and software reset clear all PRRC bits.

Table 8-22 PCRC and PRRC Bits Functionality

| PDC[i] | PC[i] | Port Pin[i] Function |
|--------|-------|----------------------|
| 0      | 0     | disconnected         |
| 0      | 1     | GPIO input           |
| 1      | 0     | GPIO output          |
| 1      | 1     | ESAI                 |

Table 8-23 PCRC Register

11 10 2 1 0 X:\$FFFBF PC11 PC10 PC9 PC8 PC7 PC6 PC5 PC4 PC3 PC2 PC1 PC0 23 22 19 12 21 20 18 17 16 15 14 13 Reserved bit - read as zero; should be written with zero for future compatibility.

Table 8-24 PRRC Register

|           | 11    | 10    | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-----------|-------|-------|------|------|------|------|------|------|------|------|------|------|
| X:\$FFFBE | PDC11 | PDC10 | PDC9 | PDC8 | PDC7 | PDC6 | PDC5 | PDC4 | PDC3 | PDC2 | PDC1 | PDC0 |
|           |       |       |      |      |      |      |      |      |      |      |      |      |
|           | 23    | 22    | 21   | 20   | 19   | 18   | 17   | 16   | 15   | 14   | 13   | 12   |
|           |       |       |      |      |      |      |      |      |      |      |      |      |
|           |       |       |      |      |      |      |      |      |      |      |      |      |

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

## 8.5.3 PORT C DATA REGISTER (PDRC)

The read/write 24-bit Port C Data Register (see Table 8-25) is used to read or write data to/from ESAI GPIO pins. Bits PD(11:0) are used to read or write data from/to the corresponding port pins if they are configured as GPIO. If a port pin [i] is configured as a GPIO input, then the corresponding PD[i] bit reflects the value present on this pin. If a port pin [i] is configured as a GPIO output, then the value written into the corresponding PD[i] bit is reflected on this pin. If a port pin [i] is configured as disconnected, the corresponding PD[i] bit is not reset and contains undefined data.

|           |      |      | Т    | able 8      | 3-25 I     | PDRC       | Regis      | ster      |            |          |        |     |
|-----------|------|------|------|-------------|------------|------------|------------|-----------|------------|----------|--------|-----|
|           | 11   | 10   | 9    | 8           | 7          | 6          | 5          | 4         | 3          | 2        | 1      | 0   |
| X:\$FFFBD | PD11 | PD10 | PD9  | PD8         | PD7        | PD6        | PD5        | PD4       | PD3        | PD2      | PD1    | PD0 |
|           |      |      |      |             |            |            |            |           |            |          |        |     |
|           | 23   | 22   | 21   | 20          | 19         | 18         | 17         | 16        | 15         | 14       | 13     | 12  |
|           |      |      |      |             |            |            |            |           |            |          |        |     |
|           |      |      |      |             |            |            |            |           |            |          |        |     |
|           |      |      | Rese | erved bit - | read as ze | ro; should | be written | with zero | for future | compatib | ility. |     |

#### 8.6 ESAI INITIALIZATION EXAMPLES

## 8.6.1 Initializing the ESAI Using Individual Reset

- The ESAI should be in its individual reset state (PCRC = \$000 and PRRC = \$000). In the individual reset state, both the transmitter and receiver sections of the ESAI are simultaneously reset. The TPR bit in the TCR register may be used to reset just the transmitter section. The RPR bit in the RCR register may be used to reset just the receiver section.
- Configure the control registers (TCCR, TCR, RCCR, RCR) according to the operating mode, but do not enable transmitters (TE5–TE0 = \$0) or receivers (RE3–RE0 = \$0). It is possible to set the interrupt enable bits which are in use during the operation (no interrupt occurs).
- Enable the ESAI by setting the PCRC register and PRRC register bits according to pins which are in use during operation.
- Write the first data to be transmitted to the transmitters which are in use during operation.
  - This step is needed even if DMA is used to service the transmitters.
- Enable the transmitters and receivers.
- From now on ESAI can be serviced either by polling, interrupts, or DMA.

#### Operation proceeds as follows:

- For internally generated clock and frame sync, these signals are active immediately after ESAI is enabled (step 3 above).
- Data is received only when one of the receive enable (REx) bits is set and after the occurrence of frame sync signal (either internally or externally generated).
- Data is transmitted only when the transmitter enable (TEx) bit is set and after the occurrence of frame sync signal (either internally or externally generated). The transmitter outputs remain tri-stated after TEx bit is set until the frame sync occurs.

## 8.6.2 Initializing Just the ESAI Transmitter Section

- It is assumed that the ESAI is operational; that is, at least one pin is defined as an ESAI pin.
- The transmitter section should be in its personal reset state (TPR = 1).

- Configure the control registers TCCR and TCR according to the operating mode, making sure to clear the transmitter enable bits (TE0 TE5). TPR must remain set.
- Take the transmitter section out of the personal reset state by clearing TPR.
- Write first data to the transmitters which will be used during operation. This step is needed even if DMA is used to service the transmitters.
- Enable the transmitters by setting their TE bits.
- Data is transmitted only when the transmitter enable (TEx) bit is set and after the occurrence of frame sync signal (either internally or externally generated). The transmitter outputs remain tri-stated after TEx bit is set until the frame sync occurs.
- From now on the transmitters are operating and can be serviced either by polling, interrupts, or DMA.

## 8.6.3 Initializing Just the ESAI Receiver Section

- It is assumed that the ESAI is operational; that is, at least one pin is defined as an ESAI pin.
- The receiver section should be in its personal reset state (RPR = 1).
- Configure the control registers RCCR and RCR according to the operating mode, making sure to clear the receiver enable bits (RE0 RE3). RPR must remain set.
- Take the receiver section out of the personal reset state by clearing RPR.
- Enable the receivers by setting their RE bits.
- From now on the receivers are operating and can be serviced either by polling, interrupts, or DMA.

**ESAI Initialization Examples** 

## SECTION 9

## TIMER/ EVENT COUNTER

#### 9.1 INTRODUCTION

This section describes the internal timer/event counter in the DSP56362. Each of the three timers (timer 0, 1 and 2) can use internal clocking to interrupt the DSP56362 or trigger DMA transfers after a specified number of events (clocks). In addition, timer 0 provides external access via the bidirectional signal TIO0.

When the TIO0 pin is configured as an input, timer 0 can count or capture events, or measure the width or period of an external signal. When TIO0 is configured as an output, timer 0 can function as a timer, a watchdog timer, or a pulse width modulator. TIO0 can also function as a GPIO signal.

#### 9.2 TIMER/EVENT COUNTER ARCHITECTURE

The timer module is composed of a common 21-bit prescaler and three independent general purpose 24-bit timer/event counters, each having its own register set.

#### 9.2.1 TIMER/EVENT COUNTER BLOCK DIAGRAM

Figure 9-1 shows a block diagram of the timer/event counter. This module includes a 24-bit timer prescaler load register (TPLR), a 24-bit timer prescaler count register (TPCR), a 21-bit prescaler clock counter, and three timers. Each of the three timers may use the prescaler clock as its clock source.

#### **Timer/Event Counter Architecture**



Figure 9-1 Timer/Event Counter Block Diagram

## 9.2.2 INDIVIDUAL TIMER BLOCK DIAGRAM

Figure 9-2 shows the structure of an individual timer module. The three timers are identical in structure, but only timer 0 is externally accessible.

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

The timer mode is controlled by the TC[3:0] bits of the timer control/status register (TCSR). Timer modes are described in Section 9.4.



Figure 9-2 Timer Block Diagram

#### 9.3 TIMER/EVENT COUNTER PROGRAMMING MODEL

The DSP56362 views each timer as a memory-mapped peripheral with four registers occupying four 24-bit words in the X data memory space. Either standard polled or interrupt programming techniques can be used to service the timers. The timer programming model is shown in Figure 9-3.

#### **Timer/Event Counter Programming Model**



Figure 9-3 Timer Module Programmer's Model

#### 9.3.1 PRESCALER COUNTER

The prescaler counter is a 21-bit counter that is decremented on the rising edge of the prescaler input clock. The counter is enabled when at least one of the three timers is enabled (i.e., one or more of the timer enable (TE) bits are set) and is using the prescaler output as its source (i.e., one or more of the PCE bits are set).

## 9.3.2 TIMER PRESCALER LOAD REGISTER (TPLR)

The TPLR is a 24-bit read/write register that controls the prescaler divide factor (i.e., the number that the prescaler counter will load and begin counting from) and the source for the prescaler input clock. See Figure 9-4.

| 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, read as 0, should be written with 0 for future compatibility |     |      |      |      |      |      |      |      |      |      |

Figure 9-4 Timer Prescaler Load Register (TPLR)

#### 9.3.2.1 TPLR Prescaler Preload Value PL[20:0] Bits 20–0

These 21 bits contain the prescaler preload value. This value is loaded into the prescaler counter when the counter value reaches zero or the counter switches state from disabled to enabled.

If PL[20:0] = N, then the prescaler counts N + 1 source clock cycles before generating a prescaler clock pulse. Therefore, the prescaler divide factor = (preload value) + 1.

The PL[20:0] bits are cleared by the hardware  $\overline{RESET}$  signal or the software RESET instruction.

#### 9.3.2.2 TPLR Prescaler Source PS[1:0] Bits 22-21

The two prescaler source (PS) bits control the source of the prescaler clock. **Table 9-1** summarizes PS bit functionality. The prescaler's use of the TIO0 signal is not affected by the TCSR settings of timer 0.

If the prescaler source clock is external, the prescaler counter is incremented by signal transitions on the TIO0 signal. The external clock is internally synchronized to the internal clock. The external clock frequency must be lower than the DSP56362 internal operating frequency divided by 4 (CLK/4).

#### **Timer/Event Counter Programming Model**

The PS[1:0] bits are cleared by the hardware  $\overline{RESET}$  signal or the software RESET instruction.

Note:

To ensure proper operation, change the PS[1:0] bits only when the prescaler counter is disabled. Disable the prescaler counter by clearing the TE bit in the TCSR of each of three timers.

**Table 9-1 Prescaler Source Selection** 

| PS1 | PS0 | PRESCALER CLOCK SOURCE |
|-----|-----|------------------------|
| 0   | 0   | Internal CLK/2         |
| 0   | 1   | TIO0                   |
| 1   | 0   | Reserved               |
| 1   | 1   | Reserved               |

#### 9.3.2.3 TPLR Reserved Bit 23

This reserved bit is read as zero and should be written with zero for future compatibility.

## 9.3.3 TIMER PRESCALER COUNT REGISTER (TPCR)

The TPCR is a 24-bit read-only register that reflects the current value in the prescaler counter. See Figure 9-5.



reserved, read as 0, should be written with 0 for future compatibility

Figure 9-5 Timer Prescaler Count Register (TPCR)

## 9.3.3.1 TPCR Prescaler Counter Value PC[20:0] Bits 20–0

These 21 bits contain the current value of the prescaler counter.

#### 9.3.3.2 TPCR Reserved Bits 23–21

These reserved bits are read as zero and should be written with zero for future compatibility.

## 9.3.4 TIMER CONTROL/STATUS REGISTER (TCSR)

The TCSR is a 24-bit read/write register controlling the timer and reflecting its status.

#### 9.3.4.1 TCSR Timer Enable (TE) Bit 0

The timer enable (TE) bit is used to enable or disable the timer. Setting TE enables the timer and clears the timer counter. The counter starts counting according to the mode selected by the timer control (TC[3:0]) bit values.

Clearing the TE bit disables the timer. The TE bit is cleared by the hardware  $\overline{RESET}$  signal or the software RESET instruction.

Note:

When timer 0 is disabled and TIO0 is not in GPIO mode, the pin is tri-stated. To prevent undesired spikes on TIO0 when Timer 0 is switched from tri-state to an active state, TIO0 should be tied to the power supply with a pullup or pulldown resistor.

#### 9.3.4.2 TCSR Timer Overflow Interrupt Enable (TOIE) Bit 1

The TOIE bit is used to enable the timer overflow interrupts. Setting TOIE enables overflow interrupt generation. The timer counter can hold a maximum value of \$FFFFFF. When the counter value is at the maximum value and a new event causes the counter to be incremented to \$000000, the timer generates an overflow interrupt.

Clearing the TOIE bit disables overflow interrupt generation. The TOIE bit is cleared by the hardware RESET signal or the software RESET instruction.

#### 9.3.4.3 TCSR Timer Compare Interrupt Enable (TCIE) Bit 2

The Timer Compare Interrupt Enable (TCIE) bit is used to enable or disable the timer compare interrupts. Setting TCIE enables the compare interrupts. In the timer, PWM, or watchdog modes, a compare interrupt is generated after the counter value matches the value of the TCPR. The counter will start counting up from the number loaded from the TLR and if the TCPR value is N, an interrupt occurs after (N-M+1) events, where M is the value of TLR.

Clearing the TCIE bit disables the compare interrupts. The TCIE bit is cleared by the hardware RESET signal or the software RESET instruction.

#### 9.3.4.4 TCSR Timer Control (TC[3:0]) Bits 4–7

The four TC bits control the source of the timer clock, the behavior of the TIO0 signal, and the timer mode of operation. Table 9-2 summarizes the TC bit functionality. A detailed description of the timer operating modes is given in Section 9.4.

The TC bits are cleared by the hardware  $\overline{RESET}$  signal or the software RESET instruction.

#### **Notes:**

- 1. If the clock is external, the counter is incremented by the transitions on the TIO0 signal. The external clock is internally synchronized to the internal clock, and its frequency should be lower than the internal operating frequency divided by 4 (CLK/4).
- **2.** To ensure proper operation, the TC[3:0] bits should be changed only when the timer is disabled (when the TE bit in the TCSR has been cleared).

Table 9-2 Timer Control Bits for Timer 0

|     | Bit Se | ettings |     |                | Mode Characteristic      | es     |          |  |
|-----|--------|---------|-----|----------------|--------------------------|--------|----------|--|
| TC3 | TC2    | TC1     | TC0 | Mode<br>Number | Mode Function            | TIO0   | Clock    |  |
| 0   | 0      | 0       | 0   | 0              | Timer and GPIO           | GPIO*  | 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 measurement  | Input  | Internal |  |
| 0   | 1      | 0       | 1   | 5              | Input period 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 pulse           | Output | Internal |  |
| 1   | 0      | 1       | 0   | 10             | Watchdog 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                 | _      | _        |  |
| N   |        |         |     |                |                          |        |          |  |

Note: The GPIO function is enabled only if all of the TC[3:0] bits are zero.

Table 9-3 Timer Control Bits for Timers 1 and 2

| TC3 | TC2 | TC1 | TC0 | Clock    | Mode     |
|-----|-----|-----|-----|----------|----------|
| 0   | 0   | 0   | 0   | Internal | Timer    |
| 0   | 0   | 0   | 1   | _        | Reserved |
| 0   | 0   | 1   | X   | _        | Reserved |
| 0   | 1   | X   | X   | _        | Reserved |
| 1   | X   | X   | X   | _        | Reserved |

## 9.3.4.5 TCSR Inverter (INV) Bit 8

The INV bit affects the polarity of the incoming signal on the TIO0 input signal and the polarity of the output pulse generated on the TIO0 output signal. The effects of the INV bit are summarized in Table 9-4.

This bit is not in use for timers 1 and 2. It should be left cleared.

Table 9-4 Inverter (INV) Bit Operation

| Mode  | TIO0 Program                                                                              | nmed as Input                                                                              | TIO0 Programmed as Output                          |                                                     |  |  |
|-------|-------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------|----------------------------------------------------|-----------------------------------------------------|--|--|
| Wiode | INV = 0                                                                                   | INV = 1                                                                                    | INV = 0                                            | INV = 1                                             |  |  |
| 0     | GPIO signal on the TIO0 signal read directly                                              | GPIO signal on the TIO0 signal inverted                                                    | Bit written to GPIO put on<br>TIO0 signal directly | Bit written to GPIO inverted and put on TIO0 signal |  |  |
| 1     | Counter is incremented on<br>the <b>rising</b> edge of the signal<br>from the TIO0 signal | Counter is incremented on<br>the <b>falling</b> edge of the<br>signal from the TIO0 signal | _                                                  | _                                                   |  |  |
| 2     | Counter is incremented on<br>the <b>rising</b> edge of the signal<br>from the TIO0 signal | Counter is incremented on<br>the <b>falling</b> edge of the<br>signal from the TIO0 signal | TCRx output put on TIO0 signal directly            | TCRx output inverted and put on TIO0 signal         |  |  |
| 3     | Counter is incremented on the <b>rising</b> edge of the signal from the TIO0 signal       | Counter is incremented on<br>the <b>falling</b> edge of the<br>signal from the TIO0 signal | _                                                  | _                                                   |  |  |
| 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 between<br>the <b>rising</b> edges of the<br>input signal.             | Period is measured between<br>the <b>falling</b> edges of the<br>input signal.             | _                                                  | _                                                   |  |  |

| Mode | TIO0 Program                                                            | nmed as Input                                                                   | TIO0 Programmed as Output                                 |                                                           |  |  |
|------|-------------------------------------------------------------------------|---------------------------------------------------------------------------------|-----------------------------------------------------------|-----------------------------------------------------------|--|--|
|      | INV = 0                                                                 | INV = 1                                                                         | INV = 0                                                   | INV = 1                                                   |  |  |
| 6    | Event is captured on the rising edge of the signal from the TIO0 signal | Event is captured on the <b>falling</b> edge of the signal from the TIO0 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 |  |  |

Pulse generated by the

timer has positive polarity

Pulse generated by the timer

has negative polarity

Table 9-4 Inverter (INV) Bit Operation

The INV bit is cleared by the hardware  $\overline{RESET}$  signal or the software RESET instruction.

**Note:** The INV bit affects both the timer and GPIO modes of operation. To ensure correct operation, this bit should be changed only when one or both of the following conditions is true:

- The timer has been disabled by clearing the TE bit in the TCSR.
- The timer is in GPIO mode.

The INV bit does not affect the polarity of the prescaler source when TIO0 is used as input to the prescaler.

## 9.3.4.6 TCSR Timer Reload Mode (TRM) Bit 9

The TRM bit controls the counter preload operation.

In timer (0–3) and watchdog (9–10) modes, the counter is preloaded with the TLR value after the TE bit is set and the first internal or external clock signal is received. If the TRM bit is set, the counter is reloaded each time after it reaches the value contained by the TCR. In PWM mode (7), the counter is reloaded each time counter overflow occurs. In measurement (4–5) modes, if the TRM and the TE bits are set, the counter is preloaded with the TLR value on each appropriate edge of the input signal.

If the TRM bit is cleared, the counter operates as a free-running counter and is incremented on each incoming event. The TRM bit is cleared by the hardware  $\overline{RESET}$  signal or the software RESET instruction.

## 9.3.4.7 TCSR Direction (DIR) Bit 11

The DIR bit determines the behavior of the TIO0 signal when it is used as a GPIO pin. When the DIR bit is set, the TIO0 signal is an output; when the DIR bit is cleared, the TIO0 signal is

an input. The TIO0 signal can be used as a GPIO only when the TC[3:0] bits are all cleared. If any of the TC[3:0] bits are set, then the GPIO mode is disabled and the DIR bit has no effect.

The DIR bit is cleared by the hardware  $\overline{RESET}$  signal or the software RESET instruction.

This bit is not in use for timers 1 and 2. It should be left cleared.

## 9.3.4.8 TCSR Data Input (DI) Bit 12

The DI bit reflects the value of the TIO0 signal. If the INV bit is set, the value of the TIO0 signal is inverted before it is written to the DI bit. If the INV bit is cleared, the value of the TIO0 signal is written directly to the DI bit.

DI is cleared by the hardware RESET signal or the software RESET instruction.

## 9.3.4.9 TCSR Data Output (DO) Bit 13

The DO bit is the source of the TIO0 value when it is a data output signal. The TIO0 signal is data output when the GPIO mode is enabled and DIR is set. A value written to the DO bit is written to the TIO0 signal. If the INV bit is set, the value of the DO bit is inverted when written to the TIO0 signal. When the INV bit is cleared, the value of the DO bit is written directly to the TIO0 signal. When GPIO mode is disabled, writing the DO bit has no effect.

The DO bit is cleared by the hardware  $\overline{RESET}$  signal or the software RESET instruction.

This bit is not in use for timers 1 and 2. It should be left cleared.

## 9.3.4.10 TCSR Prescaler Clock Enable (PCE) Bit 15

The PCE bit is used to select the prescaler clock as the timer source clock. When the PCE bit is cleared, the timer uses either an internal (CLK/2) signal or an external signal (TIO0) as its source clock. When the PCE bit is set, the prescaler output is used as the timer source clock for the counter regardless of the timer operating mode. To ensure proper operation, the PCE bit should be changed only when the timer is disabled (when the TE bit is cleared). Which source clock is used for the prescaler is determined by the PS[1:0] bits of the TPLR. Timers 1 and 2 can be clocked by the prescaler clock derived from TIO0.

## 9.3.4.11 TCSR Timer Overflow Flag (TOF) Bit 20

The TOF bit is set to indicate that counter overflow has occurred. This bit is cleared by writing a 1 to the TOF bit. Writing a 0 to the TOF bit has no effect. The bit is also cleared when the timer overflow interrupt is serviced.

The TOF bit is cleared by the hardware RESET signal, the software RESET instruction, the STOP instruction, or by clearing the TE bit to disable the timer.

#### 9.3.4.12 TCSR Timer Compare Flag (TCF) Bit 21

The TCF bit is set to indicate that the event count is complete. In the timer, PWM, and watchdog modes, the TCF bit is set when (N - M + 1) events have been counted (N is the value in the compare register and M is the TLR value). In the measurement modes, the TCF bit is set when the measurement has been completed.

The TCF bit is cleared by writing a one into the TCF bit. Writing a zero into the TCF bit has no effect. The bit is also cleared when the timer compare interrupt is serviced.

The TCF bit is cleared by the hardware  $\overline{RESET}$  signal, the software RESET instruction, the STOP instruction, or by clearing the TE bit to disable the timer.

Note:

The TOF and TCF bits are cleared by writing a one to the specific bit. In order to assure that only the desired bit is cleared, do not use the BSET command. The proper way to clear these bits is to write (using a MOVEP instruction) a one to the flag to be cleared and a zero to the other flag.

#### 9.3.4.13 TCSR Reserved Bits (Bits 3, 10, 14, 16-19, 22, 23)

These reserved bits are read as zero and should be written with zero for future compatibility.

# 9.3.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 TE bit in the TCSR is set and a first event occurs. The programmer must initialize the TLR to ensure correct operation in the appropriate timer operating modes.

- In timer modes, if the timer reload mode (TRM) bit in the TCSR is set, the counter is reloaded each time after it has reached the value contained by the timer compare register (TCR) and the new event occurs.
- In measurement modes, if the TRM bit in the TCSR is set and the TE bit in the TCSR is set, the counter is reloaded with the value in the TLR on each appropriate edge of the input signal.
- In PWM modes, if the TRM bit in the TCSR is set, the counter is reloaded each time after it has overflowed and the new event occurs.
- In watchdog modes, if the TRM bit in the TCSR is set, the counter is reloaded each time after it has reached the value contained by the TCR and the new event occurs. In this mode, the counter is also reloaded whenever the TLR is written with a new value while the TE bit in the TCSR is set.
- In all modes, if the TRM bit in the TCSR is cleared (TRM = 0), the counter operates as a free-running counter.

# 9.3.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 the TE bit in the TCSR is set. When the values match, the timer compare flag (TCF) bit is set and an interrupt is generated if interrupts are enabled (if the timer compare interrupt enable (TCIE) bit in the TCSR is set). The programmer must initialize the TCPR to ensure correct operation in the appropriate timer operating modes. The TCPR is ignored in measurement modes.

# 9.3.7 TIMER COUNT REGISTER (TCR)

The TCR is a 24-bit read-only register. In timer and watchdog modes, the counter's contents can be read at any time by reading 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 modes, the TIO0 signal is used for the input signal.

## 9.4 TIMER MODES OF OPERATION

Each timer has various operational modes that meet a variety of system requirements. These modes are 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
- 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

#### **Timer Modes of Operation**

- Toggle, mode 10: Output toggle, internal clock

These modes are described in detail below. Timer modes are selected by setting the TC[3:0] bits in the TCSR. Table 9-2 and Table 9-3 show how the different timer modes are selected by setting the bits in the TCSR. Table 9-2 also shows the TIO0 signal direction and the clock source for each timer mode.

**Note:** To ensure proper operation, the TC[3:0] bits should be changed only when the timer is disabled (i.e., when the TE bit in the TCSR is cleared).

#### 9.4.1 TIMER MODES

## 9.4.1.1 Timer GPIO (Mode 0)

|     | Bit Settings |     |     | Mode Characteristics   |                         |  |  |  |  |
|-----|--------------|-----|-----|------------------------|-------------------------|--|--|--|--|
| TC3 | TC2          | TC1 | TC0 | TIO0 Clock # KIND NAME |                         |  |  |  |  |
| 0   | 0            | 0   | 0   | GPIO                   | GPIO Internal 0 Timer C |  |  |  |  |

In this mode, the timer generates an internal interrupt when a counter value is reached (if the timer compare interrupt is enabled). Note that any of the three timers can be placed in GPIO mode to generate internal interrupts, but only timer 0 provides actual external GPIO access on the TIO0 signal.

Set the TE bit to clear the counter and enable the timer. Load the value the timer is to count into the TCPR. The counter is loaded with the TLR value when the first timer clock signal is received. The timer clock can be taken from either the DSP56362 clock divided by two (CLK/2) or from the prescaler clock output. Each subsequent clock signal increments the counter.

When the counter equals the TCPR value, the TCF bit in TCSR is set, and a compare interrupt is generated if the TCIE bit is set. If the TRM bit in the TCSR is set, the counter is reloaded with the TLR value at the next timer clock and the count is resumed. If the TRM bit is cleared, the counter continues to be incremented on each timer clock signal.

This process is repeated until the timer is disabled (i.e., TE is cleared).

If the counter overflows, the TOF bit is set, and if TOIE is set, an overflow interrupt is generated.

## **9.4.1.2** Timer Pulse (Mode 1)

|     | Bit Settings |     |     |                       | Mode Characteristics |   |       |       |  |  |
|-----|--------------|-----|-----|-----------------------|----------------------|---|-------|-------|--|--|
| TC3 | TC2          | TC1 | TC0 | TIO0 Clock # KIND NAM |                      |   |       |       |  |  |
| 0   | 0            | 0   | 1   | Output                | Internal             | 1 | Timer | Pulse |  |  |

In this mode, the timer generates a compare interrupt when the timer count reaches a preset value. In addition, timer 0 provides an external pulse on its TIO0 signal.

Set the TE bit to clear the counter and enable the timer. The value to which the timer is to count is loaded into the TCPR. The counter is loaded with the TLR value when the first timer clock signal is received. The TIO0 signal is loaded with the value of the INV bit. The timer clock signal can be taken from either the DSP56362 clock divided by two (CLK/2) or from the prescaler clock output. Each subsequent clock signal increments the counter.

When the counter matches the TCPR value, the TCF bit in TCSR is set and a compare interrupt is generated if the TCIE bit is set. The polarity of the TIO0 signal is inverted for one timer clock period.

If the TRM bit is set, the counter is loaded with the TLR value on the next timer clock and the count is resumed. If the TRM bit is cleared, the counter continues to be incremented on each timer clock.

This process is repeated until the TE bit is cleared (disabling the timer).

The value of the TLR sets the delay between starting the timer and the generation of the output pulse. To generate successive output pulses with a delay of X clocks between signals, the TLR value should be set to X/2 and the TRM bit should be set.

This process is repeated until the timer is disabled (i.e., TE is cleared).

If the counter overflows, the TOF bit is set, and if TOIE is set, an overflow interrupt is generated.

#### **Timer Modes of Operation**

## 9.4.1.3 Timer Toggle (Mode 2)

|     | Bit Settings |     |     |                        | Mode Characteristics |   |       |        |  |
|-----|--------------|-----|-----|------------------------|----------------------|---|-------|--------|--|
| TC3 | TC2          | TC1 | TC0 | TIO0 Clock # KIND NAME |                      |   |       |        |  |
| 0   | 0            | 1   | 0   | Output                 | Internal             | 0 | Timer | Toggle |  |

In this mode, the timer generates a periodic interrupt; timer 0 also toggles the polarity of the TIO0 signal.

Set the TE bit in the TCR to clear the counter and enable the timer. The value the timer is to count is loaded into the TPCR. The counter is loaded with the TLR value when the first timer clock signal is received. The TIO0 signal is loaded with the value of the INV bit. The timer clock signal can be taken from either the DSP56362 clock divided by two (CLK/2) or from the prescaler clock output. Each subsequent clock signal increments the counter.

When the counter value matches the value in the TCPR, the polarity of the TIO0 output signal is inverted. The TCF bit in the TCSR is set and a compare interrupt is generated if the TCIE bit is set.

If the 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 TRM bit is cleared, the counter continues to be incremented on each timer clock.

This process is repeated until the TE bit is cleared, disabling the timer.

The TLR value in the TCPR sets the delay between starting the timer and toggling the TIO0 signal. To generate output signals with a delay of X clock cycles between toggles, the TLR value should be set to X/2 and the TRM bit should be set.

This process is repeated until the timer is disabled (i.e., TE is cleared). If the counter overflows, the TOF bit is set, and if TOIE is set, an overflow interrupt is generated.

| 9.4.1.4 | Timer Event | Counter | (Mode 3) |
|---------|-------------|---------|----------|
|---------|-------------|---------|----------|

|     | Bit Settings |     |     |                        | Mode Characteristics        |  |  |  |  |
|-----|--------------|-----|-----|------------------------|-----------------------------|--|--|--|--|
| TC3 | TC2          | TC1 | TC0 | TIO0 Clock # KIND NAME |                             |  |  |  |  |
| 0   | 0            | 1   | 1   | Input                  | Input External 3 Timer Ever |  |  |  |  |

In this mode, the timer counts internal events and issues an interrupt when a preset number of events is counted. Timer 0 can also count external events.

Set the TE bit to clear the counter and enable the timer. The number of events the timer is to count is loaded into the TPCR. The counter is loaded with the TLR value when the first timer clock signal is received. The timer clock signal is provided by the prescaler clock output. Timer 0 can be also be clocked from the TIO0 input signal. Each subsequent clock signal increments the counter. If an external clock is used, it must be internally synchronized to the internal clock and its frequency must be less than the DSP56362 internal operating frequency divided by 4.

The value of the INV bit in the TCSR 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. If the INV bit is cleared, low-to-high transitions increment the counter.

When the counter matches the value contained in the TCPR, the TCF bit in the TCSR is set and a compare interrupt is generated if the TCIE bit is set. If the 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 TRM bit is cleared, the counter continues to be incremented on each timer clock.

This process is repeated until the timer is disabled (i.e., TE is cleared). If the counter overflows, the TOF bit is set, and if TOIE is set, an overflow interrupt is generated.

The counter contents can be read at any time by reading the TCR.

## 9.4.2 SIGNAL MEASUREMENT MODES

The following signal measurement modes are provided:

- Measurement input width
- Measurement input period
- Measurement capture

#### **Timer Modes of Operation**

These functions are available only on timer 0.

## 9.4.2.1 Measurement Accuracy

The external signal is synchronized with the internal clock used to increment 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.4.2.2 Measurement Input Width (Mode 4)

|     | Bit Settings |     |     |                                 | Mode Characteristics |  |  |  |  |  |
|-----|--------------|-----|-----|---------------------------------|----------------------|--|--|--|--|--|
| TC3 | TC2          | TC1 | TC0 | Mode Name Kind TIO0 Cloc        |                      |  |  |  |  |  |
| 0   | 1            | 0   | 0   | 4 Input Width Measurement Input |                      |  |  |  |  |  |

In this mode, the timer 0 counts the number of clocks that occur between opposite edges of an input signal.

Set the TE bit to clear the counter and enable the timer. Load the timer's count value into the TLR. After the first appropriate transition (as determined by the INV bit) occurs on the TIO0 input pin, the counter is loaded with the TLR value on the first timer clock signal received either from the DSP56362 clock divided by two (CLK/2) or from the prescaler clock input. Each subsequent clock signal increments the counter.

If the INV bit is set, the timer starts on the first high-to-low (1 to 0) signal transition on the TIO0 signal. If the INV bit is cleared, the timer starts on the first low-to-high (0 to 1) transition on the TIO0 signal.

When the first transition opposite in polarity to the INV bit setting occurs on the TIO0 signal, the counter stops. The TCF bit in the TCSR is set and a compare interrupt is generated if the TCIE bit is set. The value of the counter (which measures the width of the TIO0 pulse) is loaded into the TCR. The TCR can be read to determine the external signal pulse width.

If the TRM bit is set, the counter is loaded with the TLR value on the first timer clock received following the next valid transition occurring on the TIO0 input pin and the count is resumed. If the TRM bit is cleared, the counter continues to be incremented on each timer clock.

This process is repeated until the timer is disabled (i.e., TE is cleared).

If the counter overflows, the TOF bit is set, and if TOIE is set, an overflow interrupt is generated.

#### 9.4.2.3 Measurement Input Period (Mode 5)

|     | Bit Se | ettings |     | Mode Characteristics      |              |             |       |          |  |
|-----|--------|---------|-----|---------------------------|--------------|-------------|-------|----------|--|
| TC3 | TC2    | TC1     | TC0 | Mode Name Kind TIO0 Clock |              |             |       |          |  |
| 0   | 1      | 0       | 1   | 5                         | Input Period | Measurement | Input | Internal |  |

In this mode, the timer counts the period between the reception of signal edges of the same polarity across the TIO0 signal.

Set the TE bit to clear the counter and enable the timer. The value the timer is to count is loaded into the TLR. The value of the INV bit determines whether the period is measured between consecutive low-to-high (0 to 1) transitions of TIO0 or between consecutive high-to-low (1 to 0) transitions of TIO0. 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 TIO0 input pin, the counter is loaded with the TLR value on the first timer clock signal received from either the DSP56362 clock divided by two (CLK/2) or the prescaler clock output. Each subsequent clock signal increments the counter.

On the next signal transition of the same polarity that occurs on TIO0, the TCF bit in the TCSR is set and a compare interrupt is generated if the TCIE bit is set. The contents of the counter are loaded into the TCR. The TCR then contains the value of the time that elapsed between the two signal transitions on the TIO0 signal.

After the second signal transition, if the TRM bit is set, the 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 TRM bit is cleared, the counter continues to be incremented until it overflows.

This process is repeated until the timer is disabled (i.e., TE is cleared).

If the counter overflows, the TOF bit is set, and if TOIE is set, an overflow interrupt is generated.

#### **Timer Modes of Operation**

## 9.4.2.4 Measurement Capture (Mode 6)

|     | Bit Settings |     |     |                          | Mode Characteristics |             |       |          |  |
|-----|--------------|-----|-----|--------------------------|----------------------|-------------|-------|----------|--|
| TC3 | TC2          | TC1 | TC0 | Mode Name Kind TIO0 Cloc |                      |             |       |          |  |
| 0   | 1            | 1   | 0   | 6                        | Capture              | Measurement | Input | Internal |  |

In this mode, the timer counts the number of clocks that elapse between starting the timer and receiving an external signal.

Set the TE bit to clear the counter and enable the timer. The value the timer is to count is loaded into the TLR. When the first timer clock signal is received, the counter is loaded with the TLR value. The timer clock signal can be taken from either the DSP56362 clock divided by two (CLK/2) or from the prescaler clock output. Each subsequent clock signal increments the counter.

At the first appropriate transition of the external clock detected on the TIO0 signal, the TCF bit in the TCSR is set and, if the 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 TE bit and the detection of the first clock edge signal on the TIO0 signal.

If the INV bit is set, a high-to-low transition signals the end of the timing period. If INV is cleared, a low-to-high transition signals the end of the timing period.

If the counter overflows, the TOF bit is set, and if TOIE is set, an overflow interrupt is generated.

# 9.4.3 PULSE WIDTH MODULATION (PWM, MODE 7)

| Bit Settings |     |     |     | <b>Mode Characteristics</b> |                        |     |        |          |
|--------------|-----|-----|-----|-----------------------------|------------------------|-----|--------|----------|
| TC3          | TC2 | TC1 | TC0 | Mode Name Kind TIO0         |                        |     |        | Clock    |
| 0            | 1   | 1   | 1   | 7                           | Pulse Width Modulation | PWM | Output | Internal |

In this mode, the timer generates periodic pulses of a preset width. This function is available only on timer 0.

Set the TE bit to clear the counter and enable the timer. The value the timer is to count is loaded into the TPCR. When first timer clock is received from either the DSP56362 internal clock divided by two (CLK/2) or the prescaler clock output, the counter is loaded with the TLR value. Each subsequent timer clock increments the counter.

When the counter equals the value in the TCPR, the TIO0 output pin is toggled and the TCF bit in the TCSR is set. The contents of the counter are placed into the TCR. If the TCIE bit is set, a compare interrupt is generated. The counter continues to be incremented on each timer clock.

If counter overflow has occurred, the TIO0 output pin is toggled, the TOF bit in TCSR is set, and an overflow interrupt is generated if the TOIE bit is set. If the TRM bit is set, the counter is loaded with the TLR value on the next timer clock and the count is resumed. If the TRM bit is cleared, the counter continues to be incremented on each timer clock.

This process is repeated until the timer is disabled by clearing the TE bit.

TIO0 signal polarity is determined by the value of the INV bit. When the counter is started by setting the TE bit, the TIO0 signal assumes the value of the INV bit. On each subsequent toggling of the TIO0 signal, the polarity of the TIO0 signal is reversed. For example, if the INV bit is set, the TIO0 signal generates the following signal: 1010. If the INV bit is cleared, the TIO0 signal generates the following signal: 0101.

The counter contents can be read at any time by reading the TCR.

The value of the TLR determines the output period (FFFFFF - TLR + 1). The timer counter increments the initial TLR value and toggles the TIO0 signal when the counter value exceeds FFFFFFF.

The duty cycle of the TIO0 signal is determined by the value in the TCPR. When the value in the TLR is incremented to a value equal to the value in the TCPR, the TIO0 signal is toggled.

#### **Timer Modes of Operation**

The duty cycle is equal to (FFFFFF - TCPR) divided by (FFFFFF - TLR + 1). For a 50% duty cycle, the value of TCPR is equal to (FFFFFFF + TLR + 1) / 2.

**Note:** The value in TCPR must be greater than the value in TLR.

#### 9.4.4 WATCHDOG MODES

## 9.4.4.1 Watchdog Pulse (Mode 9)

| Bit Settings |     |     |     | Mode Characteristics    |       |          |        |          |
|--------------|-----|-----|-----|-------------------------|-------|----------|--------|----------|
| TC3          | TC2 | TC1 | TC0 | Mode Name Kind TIO0 Clo |       |          |        |          |
| 1            | 0   | 0   | 1   | 9                       | Pulse | Watchdog | Output | Internal |

In this mode, the timer generates an interrupt at a preset rate. Timer 0 also generates pulse on TIO0. The signal period is equal to the period of one timer clock.

Set the TE bit to clear the counter and enable the timer. The value the timer is to count is loaded into the TCPR. The counter is loaded with the TLR value on the first timer clock received from either the DSP56362 internal clock divided by two (CLK/2) or the prescaler clock output. Each subsequent timer clock increments the counter.

When the counter matches the value of the TCPR, the TCF bit in the TCSR is set and a compare interrupt is generated if the TCIE bit is also set.

If the TRM bit is set, the counter is loaded with the TLR value on the next timer clock and the count is resumed. If the TRM bit is cleared, the counter continues to be incremented on each subsequent timer clock.

This process is repeated until the timer is disabled (i.e., TE is cleared).

If the counter overflows, the TOF bit is set, and if TOIE is set, an overflow interrupt is generated. Timer 0 also generates an output pulse on the TIO0 signal with a pulse width equal to the timer clock period. The pulse polarity is determined by the value of the INV bit. If the INV bit is set, the pulse polarity is high (logical 1). If the INV bit is cleared, the pulse polarity is low (logical 0).

The counter contents can be read at any time by reading the TCR.

The counter is reloaded whenever the TLR is written with a new value while the TE bit is set.

Note:

In this mode, internal logic preserves the TIO0 value and direction for an additional 2.5 internal clock cycles after the DSP56362 hardware  $\overline{\text{RESET}}$  signal is asserted. This ensures that a valid  $\overline{\text{RESET}}$  signal is generated when the TIO0 signal is used to reset the DSP56362.

#### 9.4.4.2 Watchdog Toggle (Mode 10)

|     | Bit Settings |     |     |                        | М      | ode Characteristics |        |          |
|-----|--------------|-----|-----|------------------------|--------|---------------------|--------|----------|
| TC3 | TC2          | TC1 | TC0 | Mode NAME Kind TIO0 Cl |        |                     |        |          |
| 1   | 0            | 1   | 0   | 10                     | Toggle | Watchdog            | Output | Internal |

In this mode, the timer generates an interrupt at a preset rate. Timer 0 also toggles the output on TIO0.

Set the TE bit to clear the counter and enable the timer. The value the timer is to count is loaded into the TPCR. The counter is loaded with the TLR value on the first timer clock received from either the DSP56362 internal clock divided by two (CLK/2) or the prescaler clock output. Each subsequent timer clock increments the counter. The TIO0 signal is set to the value of the INV bit.

When the counter equals the value in the TCPR, the TCF bit in the TCSR is set, and a compare interrupt is generated if the TCIE bit is also set. If the TRM bit is set, the counter is loaded with the TLR value on the next timer clock and the count is resumed. If the TRM bit is cleared, the counter continues to be incremented on each subsequent timer clock

When counter overflow has occurred, the polarity of the TIO0 output pin is inverted, the TOF bit in the TCSR is set, and an overflow interrupt is generated if the TOIE bit is also set. The TIO0 polarity is determined by the INV bit.

The counter is reloaded whenever the TLR is written with a new value while the TE bit is set. This process is repeated until the timer is disabled by clearing the TE bit. The counter contents can be read at any time by reading the TCR register.

Note:

In this mode, internal logic preserves the TIO0 value and direction for an additional 2.5 internal clock cycles after the DSP56362 hardware RESET signal is asserted. This ensures that a valid RESET signal is generated when the TIO0 signal is used to reset the DSP56362.

**Timer Modes of Operation** 

#### 9.4.5 RESERVED MODES

Modes 8, 11, 12, 13, 14, and 15 are reserved.

## 9.4.6 SPECIAL CASES

The following special cases apply during wait and stop state.

## 9.4.6.1 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 DSP56362 leaves the wait state and services the interrupt.

## 9.4.6.2 Timer Behavior during Stop

During the execution of the STOP instruction, the timer clocks are disabled, timer activity is stopped, and the TIO0 signal is disconnected. Any external changes that happen to the TIO0 signal is ignored when the DSP56362 is the stop state. To ensure correct operation, the timers should be disabled before the DSP56362 is placed into the stop state.

## 9.4.7 DMA TRIGGER

Each timer can also be used to trigger DMA transfers. For this to occur, a DMA channel must be programmed to be triggered by a timer event. The timer issues a DMA trigger on every event in all modes of operation. The DMA channel does not have the capability to save multiple DMA triggers generated by the timer. To ensure that all DMA triggers are serviced, the user must provide for the preceding DMA trigger to be serviced before the next trigger is received by the DMA channel.

# SECTION 10 DIGITAL AUDIO TRANSMITTER

#### 10.1 INTRODUCTION

The Digital Audio Transmitter (DAX) is a serial audio interface module that outputs digital audio data in the AES/EBU, CP-340 and IEC958 formats. Some of the key features of the DAX are listed below.

- Operates on a frame basis—The DAX can handle one frame (consisting of two subframes) of audio and non-audio data at a time.
- **Double-buffered audio and non-audio data**—The DAX data path is double-buffered so the next frame data can be stored in the DAX without affecting the frame currently being transmitted.
- **Direct Memory Access**—Audio data and non-audio data can be written to the DAX using DMA.
- **Programmable clock source**—Users can select the DAX clock source, and this selection configures the DAX to operate in slave or master mode.
- Supports both master mode and slave mode in a digital audio network—If the user selects a divided DSP core clock, the DAX will operate in the master mode. If the user selects an external clock source, the DAX will operate in the slave mode.
- **GPIO**—Each of the two DAX pins can be configured as either GPIO or as specific DAX pin. Each pin is independent of the other. However, at least one of the two pins must be selected as a DAX pin to release the DAX from reset.

The accessible DAX registers are all mapped in the X I/O memory space. This allows programmers to access the DAX using standard instructions and addressing modes. Interrupts generated by the DAX can be handled with a fast interrupt for cases in which the non-audio data does not change from frame to frame. When the DAX interrupts are disabled, they can still be served by DMA or by a "polling" technique. A block diagram of the DAX is shown in Figure 10-1.



**Note:** The shaded registers in Figure 10-1 are directly accessible by DSP instructions.

Figure 10-1 Digital Audio Transmitter (DAX) Block Diagram

#### 10.2 DAX SIGNALS

The DAX has two signal lines:

- **DAX Digital Audio Output** (**ADO/PD1**)—The ADO pin sends audio and non-audio data in the AES/EBU, CP340, and IEC958 formats in a biphase mark format. The ADO pin may also be used as a GPIO pin PD1 if the DAX is not operational.
- **DAX Clock Input (ACI/PD0)**—When the DAX clock is configured to be supplied externally, the external clock is applied to the ACI pin. The frequency of the external clock must be 256 times, 384 times, or 512 times the audio sampling frequency (256 × Fs, 384 × Fs, or 512 × Fs). The ACI pin may also be used as a GPIO pin PD0 when the DAX is disabled or when operating from the internal DSP clock.

#### 10.3 DAX FUNCTIONAL OVERVIEW

The DAX consists of the following:

- Audio data register (XADR)
- Two audio data buffers (XADBUFA and XADBUFB)
- Non-audio data register (XNADR)
- Non-audio data buffer (XNADBUF)
- Audio and non-audio data shift register (XADSR)
- Control register (XCTR)
- Status register (XSTR)
- Parity generator (PRTYG)
- Preamble generator
- Biphase encoder
- Clock multiplexer
- Control state machine

XADR, XADBUFA, XADBUFB and XADSR creates a FIFO-like data path. Channel A is written to XADR and moves to XADBUFA. Then channel B is written to XADR, and when XADBUFB empties XADR moves into it. XADBUFA moves to the shift register XADSR when XADSR has shifted out its last bit. After channel A audio and non-audio data has been shifted out, XADBUFB moves into XADSR, and channel B audio and non audio shift begins.

The frame non-audio data (stored in XNADR) is transferred to the XADSR (for channel A) and to the XNADBUF registers (for channel B) at the beginning of a frame transmission. This is called an "upload." The DAX audio data register empty (XADE) flag is set when XADR and XADBUFA are empty, and, if the audio data register empty interrupt is enabled (XDIE=1), an interrupt request is sent to the DSP core. The interrupt handling routine then sends the non-audio data bits to XNADR and the next frame of audio data to XADR (two subframes).

At the beginning of a frame transmission, one of the 8-bit channel A preambles (Z-preamble for the first subframe in a block, or X-preamble otherwise) is generated in the preamble generator, and then shifted out to the ADO pin in the first eight time slots. The preamble is generated in biphase mark format. The twenty-four audio and three non-audio data bits in the XADSR are shifted out to the biphase encoder, which shifts them out through the ADO pin in the biphase mark format in the next 54 time slots. The parity generator calculates an even parity over the 27 bits of audio and non-audio data, and then outputs the result through the

#### **DAX Programming Model**

biphase encoder to the ADO pin at the last two time slots. This is the end of the first (channel A) subframe transmission.

The second subframe transmission (channel B) starts with the preamble generator generating the channel B preamble (Y-preamble). At the same time, channel B audio and non-audio data is transferred to the XADSR shift-register from the XADBUFB and XNADBUF registers. The generated Y-preamble is output immediately after the channel A parity and is followed by the audio and non-audio data in the XADSR, which is in turn followed by the calculated parity for channel B. This completes a frame transmission. When the channel B parity is sent, the audio data for the next frame, stored in XADBUFA and the non-audio data bits from the XNADR, are uploaded to XADSR.

#### 10.4 DAX PROGRAMMING MODEL

The programmer-accessible DAX registers are shown in Figure 10-2. The registers are described in the following subsections. The Interrupt Vector table for the DAX is shown in Table 10-1. The internal interrupt priority is shown in Table 10-2.

Table 10-1 DAX Interrupt Vectors

| Condition   | Address  | Description                   |
|-------------|----------|-------------------------------|
| XAUR        | VBA:\$28 | DAX transmit underrun error   |
| XADE & XBLK | VBA:\$2A | DAX block transferred         |
| XADE        | VBA:\$2E | DAX audio data register empty |

**Table 10-2 DAX Interrupt Priority** 

| Priority | Interrupt                     |
|----------|-------------------------------|
| highest  | DAX transmit underrun error   |
|          | DAX block transferred         |
| lowest   | DAX audio data register empty |

#### 10.5 DAX INTERNAL ARCHITECTURE

Hardware components shown in Figure 10-1 are described in the following sections. The DAX programming model is illustrated in Figure 10-2.



Figure 10-2 DAX Programming Model

# 10.5.1 DAX AUDIO DATA REGISTER (XADR)

XADR is a 24-bit write-only register. One frame of audio data, which is to be transmitted in the next frame slot, is transferred to this register. Successive write accesses to this register will store channel A and channel B alternately in XADBUFA and in XADBUFB respectively. When XADR and XADBUFA are empty, XADE bit in the XSTR is set, and, if the audio data register empty interrupt is enabled (XDIE=1), an interrupt request is sent to the DSP core. When channel B is transferred to XADR, the XADE bit in the XSTR is cleared. XADR can also be accessed by DMA. When XADR and XADBUFA are empty, the DAX sends a DMA request to the core. The DMA first transfers non-audio data bits to XNADR (optional), then transfers channel A and channel B to XADR. The XADR can be accessed with two different successive addresses. This feature supports sending non-audio data bits, channel A and channel B to the DAX in three successive DMA transfers.

# 10.5.2 DAX AUDIO DATA BUFFERS (XADBUFA / XADBUFB)

XADBUFA and XADBUFB are 24-bit registers that buffer XADR from XADSR, creating a FIFO-like data path. These registers hold the next two subframes of audio data to be transmitted. Channel A audio data is transferred from XADR to XADBUFA if XADBUFA is empty. Channel B audio data is transferred from XADR to XADBUFB if XADBUFB is empty. Audio data is transferred from XADBUFA and XADBUFB alternately to XADSR provided that XADSR shifted out all the audio and non-audio bits of the currently transmitted channel. This buffering mechanism provides more cycles for writing the next audio data to XADR. These registers are not directly accessible by DSP instructions.

## 10.5.3 DAX AUDIO DATA SHIFT REGISTER (XADSR)

The XADSR is a 27-bit shift register that shifts the 24-bit audio data and the 3-bit non-audio data for one subframe. The contents of XADBUFA or XADBUFB are directly transferred to the XADSR at the beginning of the subframe transmission. The channel A subframe is transferred to XADSR at the same time that the three bits of non-audio data (V-bit, U-bit and C-bit) for channel A in the DAX non-audio data register (XNADR) are transferred to the three highest-order bits of the XADSR. At the beginning of the channel B transmission, audio and non-audio data for channel B are transferred from the XADBUFB and the XNADBUF to the XADSR for shifting. The data in the XADSR is shifted toward the lowest-order bit at the fifth to thirty-first bit slot of each subframe transmission. This register is not directly accessible by DSP instructions.

# 10.5.4 DAX NON-AUDIO DATA REGISTER (XNADR)

The XNADR is a 24-bit write-only register. It holds the three bits of non-audio data for each subframe. XNADR can be accessed by core instructions or by DMA. The contents of the XNADR are shown in Figure 10-2. XNADR is not affected by any of the DAX reset states. The XNADR bits are described in the following paragraphs.

## 10.5.4.1 DAX Channel A Validity (XVA)—Bit 10

The value of the XVA bit is transmitted as the twenty-ninth bit (Bit 28) of channel A subframe in the next frame.

## 10.5.4.2 DAX Channel A User Data (XUA)—Bit 11

The value of the XUA bit is transmitted as the thirtieth bit (Bit 29) of the channel A subframe in the next frame.

#### 10.5.4.3 DAX Channel A Channel Status (XCA)—Bit 12

The value of the XCA bit is transmitted as the thirty-first bit (Bit 30) of the channel A subframe in the next frame.

## 10.5.4.4 DAX Channel B Validity (XVB)—Bit 13

The value of the XVB bit is transmitted as the twenty-ninth bit (Bit 28) of the channel B subframe in the next frame.

## 10.5.4.5 DAX Channel B User Data (XUB)—Bit 14

The value of the XUB bit is transmitted as the thirtieth bit (Bit 29) of the channel B subframe in the next frame.

## 10.5.4.6 DAX Channel B Channel Status (XCB)—Bit 15

The value of the XCB bit is transmitted as the thirty-first bit (Bit 30) of the channel B subframe in the next frame.

## 10.5.4.7 XNADR Reserved Bits—Bits 0-9, 16–23

These XNADR bits are reserved. They read as 0, and should be written with 0 to ensure compatibility with future device versions.

## 10.5.5 DAX NON-AUDIO DATA BUFFER (XNADBUF)

The XNADBUF is a 3-bit register that temporarily holds channel B non-audio data (XVB, XUB and XCB) for the current transmission while the channel A data is being transmitted. This mechanism provides programmers more instruction cycles to store the next frame's non-audio data to the XCB, XUB, XVB, XCA, XUA and XVA bits in the XNADR. The data in the XNADBUF register is transferred to the XADSR along with the contents of the XADBUF register at the beginning of channel B transmission.

**Note:** The XNADBUF register is not directly accessible by DSP instructions.

# 10.5.6 DAX CONTROL REGISTER (XCTR)

The XCTR is a 24-bit read/write register that controls the DAX operation. The contents of the XCTR are shown in Figure 10-2. XCTR is cleared by software reset and hardware reset. The XCTR bits are described in the following paragraphs.

#### **DAX Internal Architecture**

#### 10.5.6.1 Audio Data Register Empty Interrupt Enable (XDIE)—Bit 0

When the XDIE bit is set, the audio data register empty interrupt is enabled and sends an interrupt request signal to the DSP if the XADE status bit is set. When XDIE bit is cleared, this interrupt is disabled.

## 10.5.6.2 Underrun Error Interrupt Enable (XUIE)—Bit 1

When the XUIE bit is set, the underrun error interrupt is enabled and sends an interrupt request signal to the DSP if the XAUR status bit is set. When XUIE bit is cleared, this interrupt is disabled.

## 10.5.6.3 Block Transferred Interrupt Enable (XBIE)—Bit 2

When the XBIE bit is set, the block transferred interrupt is enabled and sends an interrupt request signal to the DSP if the XBLK and XADE status bits are set. When XBIE bit is cleared, this interrupt is disabled.

## 10.5.6.4 DAX Clock Input Select (XCS[1:0])—Bits 3-4

The XCS[1:0] bits select the source of the DAX clock and/or its frequency. Table 10-3 shows the configurations selected by these bits. These bits should be changed only when the DAX is disabled.

| XCS1 | XCS0 | DAX Clock Source               |
|------|------|--------------------------------|
| 0    | 0    | DSP Core Clock (f = 1024 X fs) |
| 0    | 1    | ACI Pin, f = 256 X fs          |
| 1    | 0    | ACI Pin, f = 384 X fs          |
| 1    | 1    | ACI Pin, f = 512 X fs          |

Table 10-3 Clock Source Selection

## 10.5.6.5 DAX Start Block (XSB)—Bit 5

The XSB bit forces the DAX to start a new block. When this bit is set, the next frame will start with "Z" preamble and will start a new block even though the current block was not finished. This bit is cleared when the new block starts.

#### 10.5.6.6 XCTR Reserved Bits—Bits 6-23

These XCTR bits are reserved. They read as 0 and should be written with 0 for future compatibility.

## 10.5.7 DAX STATUS REGISTER (XSTR)

The XSTR is a 24-bit read-only register that contains the DAX status flags. The contents of the XSTR are shown in Figure 10-2. XSTR is cleared by software reset, hardware reset an by the stop state. The XSTR bits are described in the following paragraphs.

#### 10.5.7.1 DAX Audio Data Register Empty (XADE)—Bit 0

The XADE status flag indicates that the DAX audio data register XADR and the audio data buffer XADBUFA are empty (and ready to receive the next frame's audio data). This bit is set at the beginning of every frame transmission (more precisely, when channel A audio data is transferred from XADBUFA to XADSR). When XADE is set and the interrupt is enabled (XDIE = 1), an audio data register empty interrupt request is sent to the DSP core. XADE is cleared by writing two channels of audio data to XADR.

## 10.5.7.2 DAX Transmit Underrun Error Flag (XAUR)—Bit 1

The XAUR status flag is set when the DAX audio data buffers XADBUFA or XADBUFB are empty and the respective audio data upload occurs. When a DAX underrun error occurs, the previous frame data will be retransmitted in both channels. When XAUR is set and the interrupt is enabled (XUIE = 1), an underrun error interrupt request is sent to the DSP core. This allows programmers to write an exception handling routine for this special case. The XAUR bit is cleared by reading the XSTR register with XAUR set, followed by writing two channels of audio data to XADR.

## 10.5.7.3 DAX Block Transfer Flag (XBLK)—Bit 2

The XBLK flag indicates that the frame being transmitted is the last frame in a block. This bit is set at the beginning of the transmission of the last frame (the 191st frame). This bit does not cause any interrupt. However, if XBIE=1 it causes a change in the interrupt vector sent to DSP core in the event of an audio data register empty interrupt, so that a different interrupt routine can be called (providing the next non-audio data structures for the next block as well as storing audio data for the next frame). Writing two channels of audio data to XADR clears this bit.

The relative timing of transmit frames and XADE and XBLK flags is shown in Figure 10-3.

#### **DAX Internal Architecture**



Figure 10-3 DAX Relative Timing

#### 10.5.7.4 XSTR Reserved Bits—Bits 3–23

These XSTR bits are reserved. They read as 0, and should be written with 0 to ensure compatibility with future device versions.

## 10.5.8 DAX PARITY GENERATOR (PRTYG)

The PRTYG generates the parity bit for the subframe being transmitted. The generated parity bit ensures that subframe bits four to thirty-one will carry an even number of ones and zeroes.

#### 10.5.9 DAX BIPHASE ENCODER

The DAX biphase encoder encodes each audio and non-audio bit into its biphase mark format and shifts this encoded data out to the ADO output pin synchronously to the biphase clock.

#### 10.5.10 DAX PREAMBLE GENERATOR

The DAX preamble generator automatically generates one of three preambles in the 8-bit preamble shift register at the beginning of each subframe transmission, and shifts it out. The generated preambles always start with "0". Bit patterns of preambles generated in the

preamble generator are shown in Table 10-4. The preamble bits are already in the biphase mark format.

| Preamble | Bit Pattern | Channel            |  |
|----------|-------------|--------------------|--|
| X        | 00011101    | A                  |  |
| Y        | 00011011    | В                  |  |
| Z        | 00010111    | A (first in block) |  |

Table 10-4 Preamble Bit Patterns

There is no programmable control for the preamble selection. The first subframe to be transmitted (immediately after the DAX is enabled) is the beginning of a block, and therefore it has a "Z" preamble. This is followed by the second subframe, which has an "Y" preamble. After that, "X" and "Y" preambles are transmitted alternately until the end of the block transfer (192 frames transmitted). See Figure 10-4 for an illustration of the preamble sequence.



Figure 10-4 Preamble sequence

## 10.5.11 DAX CLOCK MULTIPLEXER

The DAX clock multiplexer selects one of the clock sources and generates the biphase clock  $(128 \times Fs)$  and shift clock  $(64 \times Fs)$ . The clock source can be selected from the following options (see also Section 10.5.6.4, "DAX Clock Input Select (XCS[1:0])—Bits 3–4").

- The internal DSP core clock—assumes 1024 × Fs
- DAX clock input pin (ACI)—512 × Fs
- DAX clock input pin (ACI)—384 × Fs
- DAX clock input pin (ACI)—256 × Fs

## **DAX Programming Considerations**

Figure 10-5 shows how each clock is divided to generate the biphase and bit shift clocks



Figure 10-5 Clock Multiplexer Diagram

**Note:** For proper operation of the DAX, the DSP core clock frequency must be at least five times higher than the DAX bit shift clock frequency  $(64 \times Fs)$ .

## 10.5.12 DAX STATE MACHINE

The DAX state machine generates a set of sequencing signals used in the DAX.

## 10.6 DAX PROGRAMMING CONSIDERATIONS

The following sections describe programming considerations for the DAX.

## 10.6.1 INITIATING A TRANSMIT SESSION

To initiate the DAX operation, follow this procedure:

- 1. Ensure that the DAX is disabled (PC1 and PC0 bits of port control register PCR are cleared)
- 2. Write the non-audio data to the corresponding bits in the XNADR register
- 3. Write the channel A and channel B audio data in the XADR register
- 4. Write the transmit mode to the XCTR register

5. Enable DAX by setting PC1 bit (and by setting PC0 bit if in slave mode) in the port control register (PCR); transmission begins.

#### 10.6.2 AUDIO DATA REGISTER EMPTY INTERRUPT HANDLING

When the XDIE bit is set and the DAX is active, an audio data register empty interrupt (XADE = 1) is generated once at the beginning of every frame transmission. Typically, within an XADE interrupt, the non-audio data bits of the next frame are stored in XNADR and one frame of audio data to be transmitted in the next frame is stored in the FIFO by two consecutive MOVEP instructions to XADR. If the non-audio bits are not changed from frame to frame, this procedure can be handled within a fast interrupt routine. Storing the next frame's audio data in the FIFO clears the XADE bit in the XSTR.

#### 10.6.3 BLOCK TRANSFERRED INTERRUPT HANDLING

An interrupt with the XBLK vector indicates the end of a block transmission and may require some computation to provide the next non-audio data structures that are to be transmitted within the next block. Within the routine, the next audio data can be stored in the FIFO by two consecutive MOVEP instructions to XADR, and the next non-audio data can be stored in the XNADR. The XBLK interrupt occurs only if the XBIE bit in XCTR is set. If XBIE is cleared, a XADE interrupt vector will take place.

#### 10.6.4 DAX OPERATION WITH DMA

During DMA transfers, the XDIE bit of the XCTR must be cleared to avoid XADE interrupt services by the DSP core. The initialization appearing in Section 10.6.1 is relevant for DMA

# **DAX Programming Considerations**

operation. DMA transfers can be performed with or without changing non-audio bits from frame to frame. Table 10-5 describes two examples of DMA configuration.

Table 10-5 Examples of DMA configuration

| Register | Non-audio data bits change                                                                                                                                                                                                                                                      | Non-audio data bits do not change                                                                                                                                                                                                                                               |
|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DCR2     | DE=1; Enable DMA channel. DIE=1; Enable DMA interrupt. DTM[2:0]=010; Line transfer mode. D3D=0; Not 3D. DAM[5:3]=000; 2D mode. DAM[2:0]=101; post increment by 1. DDS[1:0]=00; X memory space. DRS[4:0]=01010; DAX is DMA request source. Other bits are application dependent. | DE=1; Enable DMA channel. DIE=1; Enable DMA interrupt. DTM[2:0]=010; Line transfer mode. D3D=0; Not 3D. DAM[5:3]=000; 2D mode. DAM[2:0]=101; post increment by 1. DDS[1:0]=00; X memory space. DRS[4:0]=01010; DAX is DMA request source. Other bits are application dependent. |
| DCO2     | DCOH=number of frames in block - 1<br>DCOL=\$002; 3 destination registers                                                                                                                                                                                                       | DCOH=number of frames in block - 1<br>DCOL=\$001; 2 destination registers                                                                                                                                                                                                       |
| DSR2     | first memory address of the block                                                                                                                                                                                                                                               | first memory address of the block                                                                                                                                                                                                                                               |
| DDR2     | XNADR address (base address + \$1)                                                                                                                                                                                                                                              | XADR address (base address + \$2)                                                                                                                                                                                                                                               |
| DOR0     | \$FFFFE; offset=-2                                                                                                                                                                                                                                                              | \$FFFFFF; offset=-1                                                                                                                                                                                                                                                             |

The memory organization employed for DMA transfers depends on whether or not non-audio data changes from frame to frame as shown in Figure 10-6.

| Channel B                                  | \$00000B | Channel B                                     | \$00000B |
|--------------------------------------------|----------|-----------------------------------------------|----------|
| Channel A                                  | \$00000A | Channel A                                     | \$00000A |
| Non-Audio Data                             | \$000009 | Channel B                                     | \$000009 |
| Channel B                                  | \$000008 | Channel A                                     | \$000008 |
| Channel A                                  | \$000007 | Channel B                                     | \$00007  |
| Non-Audio Data                             | \$000006 | Channel A                                     | \$000006 |
| Channel B                                  | \$000005 | Channel B                                     | \$000005 |
| Channel A                                  | \$000004 | Channel A                                     | \$000004 |
| Non-Audio Data                             | \$000003 | Channel B                                     | \$000003 |
| Channel B                                  | \$000002 | Channel A                                     | \$000002 |
| Channel A                                  | \$000001 | Channel B                                     | \$000001 |
| Non-Audio Data                             | \$000000 | Channel A                                     | \$000000 |
| Non-audio data bits ch from frame to frame | ange     | Non-audio data bits do change from frame to f |          |

Figure 10-6 Examples of data organization in memory

## 10.6.5 DAX OPERATION DURING STOP

The DAX operation cannot continue when the DSP is in the stop state since no DSP clocks are active. While the DSP is in the stop state, the DAX will remain in the individual reset state and the status flags are initialized as described for resets. No DAX control bits are affected. The DAX should be disabled before the DSP enters the stop state.

# 10.7 GPIO (PORT D) - PINS AND REGISTERS

The Port D GPIO functionality of the DAX is controlled by three registers: Port D Control Register (PCRD), Port D Direction Register (PRRD) and Port D Data Register (PDRD).

# 10.7.1 PORT D CONTROL REGISTER (PCRD)

The read/write 24-bit DAX Port D Control Register controls the functionality of the DAX GPIO pins. Each of the PC[1:0] bits controls the functionality of the corresponding port pin. When a PC[i] bit is set, the corresponding port pin is configured as a DAX pin. When a PC[i] bit is cleared, the corresponding port pin is configured as GPIO pin. If both PC1 and PC0 are cleared, the DAX is disabled. Hardware and software reset clear all PCRD bits.



Figure 10-7 Port D Control Register (PCRD)

# 10.7.2 PORT D DIRECTION REGISTER (PRRD)

The read/write 24-bit Port D Direction Register controls the direction of the DAX GPIO pins. When port pin[i] is configured as GPIO, PDC[i] controls the port pin direction. When PDC[i] is set, the GPIO port pin[i] is configured as output. When PDC[i] is cleared the GPIO port pin[i] is configured as input. Hardware and software reset clear all PRRD bits. Table 10-6 describes the port pin configurations.



Figure 10-8 Port D Direction Register (PRRD)

| PDC1 | PC1 | ADO/PD1 pin  | PDC0 | PC0 | ACI/PD0 pin  | DAX state      |
|------|-----|--------------|------|-----|--------------|----------------|
| 0    | 0   | Disconnected | 0    | 0   | Disconnected | Personal Reset |
| 0    | 0   | Disconnected | 0    | 1   | PD0 Input    | Personal Reset |
| 0    | 0   | Disconnected | 1    | 0   | PD0 Output   | Personal Reset |
| 0    | 0   | Disconnected | 1    | 1   | ACI          | Enabled        |
| 0    | 1   | PD1 Input    | 0    | 0   | Disconnected | Personal Reset |
| 0    | 1   | PD1 Input    | 0    | 1   | PD0 Input    | Personal Reset |
| 0    | 1   | PD1 Input    | 1    | 0   | PD0 Output   | Personal Reset |
| 0    | 1   | PD1 Input    | 1    | 1   | ACI          | Enabled        |
| 1    | 0   | PD1 Output   | 0    | 0   | Disconnected | Personal Reset |
| 1    | 0   | PD1 Output   | 0    | 1   | PD0 Input    | Personal Reset |
| 1    | 0   | PD1 Output   | 1    | 0   | PD0 Output   | Personal Reset |
| 1    | 0   | PD1 Output   | 1    | 1   | ACI          | Enabled        |
| 1    | 1   | ADO          | 0    | 0   | Disconnected | Enabled        |
| 1    | 1   | ADO          | 0    | 1   | PD0 Input    | Enabled        |
| 1    | 1   | ADO          | 1    | 0   | PD0 Output   | Enabled        |
| 1    | 1   | ADO          | 1    | 1   | ACI          | Enabled        |

Table 10-6 DAX Port GPIO Control Register Functionality

# 10.7.3 PORT D DATA REGISTER (PDRD)

The read/write 24-bit Port D Data Register is used to read or write data to/from the DAX GPIO pins. Bits PD[1:0] are used to read or write data from/to the corresponding port pins if they are configured as GPIO. If a port pin [i] is configured as a GPIO input, then the corresponding PD[i] bit will reflect the value present on this pin. If a port pin [i] is configured as a GPIO output, then the value written into the corresponding PD[i] bit will be reflected on the this pin. Hardware and software reset clear all PDRD bits.



Figure 10-9 Port D Data Register (PDRD)

GPIO (PORT D) - Pins and Registers

## APPENDIX A BOOTSTRAP ROM CONTENTS

## A.1 DSP56362 BOOTSTRAP PROGRAM

```
; BOOTSTRAP CODE FOR DSP56362 Rev. A silicon - (C) Copyright 1999 Motorola
; Revision 0.1 1998/DEC/29 - added command to enable OnCE.
                        - added I2C slave with clock freeze enable
                          bootstrap mode, similar to 56364.
; Revision 0.2 1999/JAN/26 - no code change. Changed "FST" to "SCKT"
                          in the comments and in the equates.
; Revision 0.3 1999/FEB/01 - Added 5 NOP instructions after OnCE enable.
; Revision 0.4 1999/MAR/29 - Enabled 100ns I2C filter in bootstrap
                          mode 0110.
; This is the Bootstrap program contained in the DSP56362 192-word Boot
; ROM. This program can load any program RAM segment from an external
; EPROM, from the Host Interface or from the SHI serial interface.
; If MD:MC:MB:MA=x000, then the Boot ROM is bypassed and the DSP56362
; will start fetching instructions beginning with address $C00000 (MD=0)
; or $008000 (MD=1) assuming that an external memory of SRAM type is
; used. The accesses will be performed using 31 wait states with no
; address attributes selected (default area).
; If MD:MC:MB:MA=0001, 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 will be condensed into 24-bit words and stored in
; contiguous PRAM memory locations starting at the specified starting
address.
; After reading the program words, program execution starts from the same
; address where loading started.
; If MD:MC:MB:MA=0010, then the bootstrap code jumps to the internal
; Program ROM, without loading the Program RAM.
; Operation mode MD:MC:MB:MA=0011 is reserved.
; If MD:MC:MB:MA=01xx, then the Program RAM is loaded from the SHI.
; Operation mode MD:MC:MB:MA=1001 is used for burn-in testing.
; Operation mode MD:MC:MB:MA=1010 is reserved
; Operation mode MD:MC:MB:MA=1011 is reserved
; If MD:MC:MB:MA=1100, then it loads the program RAM 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 will be stored in
; contiguous PRAM memory locations starting at the specified starting
address.
; After reading the program words, program execution starts from the same
; address where loading started.
; The Host Interface bootstrap load program may be stopped by
; setting the Host Flag 0 (HF0). This will start execution of the loaded
; program from the specified starting address.
; If MD:MC:MB:MA=1101, then it loads the program RAM 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 will be stored in
; contiguous PRAM memory locations starting at the specified starting
address.
; After reading the program words, program execution starts from the same
; address where loading started.
; The Host Interface bootstrap load program may be stopped by
; setting the Host Flag 0 (HF0). This will start execution of the loaded
; program from the specified starting address.
; If MD:MC:MB:MA=1110, then it loads the program RAM from the Host
; Interface programmed to operate in the 8051 multiplexed bus mode,
; in double-strob pin configuration.
; The HOST 8051 bootstrap code expects accesses that are byte wide.
; The HOST 8051 bootstrap code expects to read 3 bytes forming a 24-bit word
; specifying the number of program words, 3 bytes forming a 24-bit word
; specifying the address to start loading the program words and then 3 bytes
; forming 24-bit words for each program word to be loaded.
; The program words will be stored in contiguous PRAM memory locations
; starting at the specified starting address.
; After reading the program words, program execution starts from the same
; address where loading started.
; The Host Interface bootstrap load program may be stopped by setting the
; Host Flag 0 (HF0). This will start execution of the loaded program from
; the specified starting address.
; The base address of the HDI08 in multiplexed mode is 0x80 and is not
; modified by the bootstrap code. All the address lines are enabled
; and should be connected accordingly.
; If MD:MC:MB:MA=1111, then it loads the program RAM from the Host
; Interface programmed to operate in the MC68302 (IMP) bus mode,
; in single-strob pin configuration.
; The HOST MC68302 bootstrap code expects accesses that are byte wide.
; The HOST MC68302 bootstrap code expects to read 3 bytes forming a 24-bit
; specifying the number of program words, 3 bytes forming a 24-bit word
; specifying the address to start loading the program words and then 3 bytes
; forming 24-bit words for each program word to be loaded.
; The program words will be stored in contiguous PRAM memory locations
; starting at the specified starting address.
; After reading the program words, program execution starts from the same
; address where loading started.
; The Host Interface bootstrap load program may be stopped by setting the
; Host Flag 0 (HF0). This will start execution of the loaded program from
; the specified starting address.
```

```
132,55,0,0,0
       page
       opt
              cex, mex, mu
;;
;;
              $D00000
BOOT
       equ
                             ; this is the location in P memory
                             ; on the external memory bus
                             ; where the external byte-wide
                             ; EPROM is located
              $D00409
                             ; AAR1 selects the EPROM as CE~
AARV
       equ
                             ; mapped as P from $D00000 to
                             ; $DFFFFF, active low
                             ; Starting PROM address
PROMADDR equ
              $FF1000
       EQU
              0
MΑ
MB
       EQU
              1
       EQU
              2
MC
MD
       EQU
              3
;;
M AAR1 EQU
                             ; Address Attribute Register 1
              $FFFFF8
M OGDB
      EQU
              $FFFFFC
                             ; OnCE GDB Register
M_HPCR EQU
              $FFFFC4
                             ; Host Polarity Control Register
M HSR
       EQU
              $FFFFC3
                            ; Host Status Register
M HORX EQU
              $FFFFC6
                            ; Host Receive Register
HRDF
                            ; Host Receive Data Full
       EQU
              $0
HF0
       EQU
              $3
                             ; Host Flag 0
                            ; Host Enable
HEN
       EQU
              $6
                            ; SHI Receive FIFO
M HRX
      EQU
              $FFFF94
              $FFFF91
                            ; SHI Control/Status Register
M HCSR EQU
M_HCKR EQU
              $FFFF90
                            ; SHI Clock Control Register
                            ; SHI FIFO Not Empty flag
HRNE
       EQU
              17
HI2C
                             ; SHI I2C Enable Control Bit
       EQU
              1
HCKFR EQU
              4
                            ; SHI I2C Clock Freeze Control Bit
HFM0
       EQU
              12
                            ; SHI I2C Filter Mode Bit 0
HFM1
       EQU
              13
                             ; SHI I2C Filter Mode Bit 1
     ORG PL:$ff0000,PL:$ff0000
                               ; bootstrap code starts at $ff0000
START
       movep #$0,X:M_OGDB
                             ; enable OnCE
```

```
; 5 NOP instructions, needed for test procedure
      nop
       nop
       nop
       nop
       nop
       clr a #$0,r5
                             ; clear a and init R5 with 0
       jset #MD,omr,OMR1XXX ; If MD:MC:MB:MA=1xxx go to OMR1XXX
       jset #MC,omr,SHILD
                            ; If MD:MC:MB:MA=01xx, go load from SHI
       jclr #MB,omr,EPROMLD
                            ; If MD:MC:MB:MA=0001, go load from EPROM
       jset #MA,omr,RESERVED ; If MD:MC:MB:MA=0011, go to RESERVED
; This is the routine that jumps to the internal Program ROM.
; MD:MC:MB:MA=0010
       move #PROMADDR,r1
                            ; store starting PROM address in r1
              <FINISH
       bra
; This is the routine that loads from SHI.
; MD:MC:MB:MA=0100 - reserved for SHI
; MD:MC:MB:MA=0101 - Bootstrap from SHI (SPI slave)
; MD:MC:MB:MA=0110 - Bootstrap from SHI (I2C slave, HCKFR=1,100ns filter)
; MD:MC:MB:MA=0111 - Bootstrap from SHI (I2C slave, HCKFR=0)
SHILD
; This is the routine which loads a program through the SHI port.
; The SHI operates in the slave
; mode, with the 10-word FIFO enabled, and with the HREQ pin enabled for
; receive operation. The word size for transfer is 24 bits. The SHI
; operates in the SPI or in the I2C mode, according to the bootstrap mode.
; The program is downloaded according to the following rules:
; 1) 3 bytes - Define the program length.
; 2) 3 bytes - Define the address to which to start loading the program to.
; 3) 3n bytes (while n is the program length defined by the first 3 bytes)
; The program words will be stored in contiguous PRAM memory locations
starting
; at the specified starting address.
; After storing the program words, program execution starts from the same
; address where loading started.
                    #$A9,r1
                                    ; prepare SHI control value in r1
             move
; HEN=1, HI2C=0, HM1-HM0=10, HCKFR=0, HFIFO=1, HMST=0,
; HRQE1-HRQE0=01, HIDLE=0, HBIE=0, HTIE=0, HRIE1-HRIE0=00
             jclr
                     #MA,omr,SHI_CF ; If MD:MC:MB:MA=01x0, go to SHI
clock freeze
```

```
#MB,omr,shi_loop ; If MD:MC:MB:MA=0101, select SPI mode
            jclr
                                        ; otherwise select I2C mode.
              bset
                      #HI2C,r1
shi_loop
              movep
                      r1,x:M_HCSR
                                        ; enable SHI
                      #HRNE, x:M HCSR, *; wait for no. of words
              jclr
              movep
                      x:M_HRX,a0
              jclr
                      #HRNE,x:M_HCSR,*
                                      ; wait for starting address
                      x:M_HRX,r0
              movep
              move
                      r0,r1
              do
                      a0, LOOP2
              jclr
                      #HRNE,x:M_HCSR,*
                                        ; wait for HRX not empty
                                        ; store in Program RAM
              movep
                      x:M HRX,p:(r0)+
                                        ; req. because of restriction
              nop
LOOP2
              bra
                      <FINISH
SHI CF
              bset
                     #HI2C,r1
                                        ; select I2C mode.
                                      ; enable clock freeze in I2C mode.
              bset
                    #HCKFR,r1
              bset
                     #HFM0,x:M HCKR
                                        ; enable 100ns noise filter
                                        ; enable 100ns noise filter
              bset
                     #HFM1,x:M HCKR
                                     ; If MD:MC:MB:MA=0110, go to I2C load
            iset
                  #MB,omr,shi_loop
            bra
                   <RESERVED
                                     ; If MD:MC:MB:MA=0100, go to reserved
; This is the routine that loads from external EPROM.
; MD:MC:MB:MA=0001
EPROMLD
       move #BOOT,r2
                              ; r2 = address of external EPROM
                              ; aarl configured for SRAM types of access
       movep #AARV, X:M AAR1
                              ; read number of words and starting address
       do #6,_LOOP9
                               ; Get the 8 LSB from ext. P mem.
       movem p:(r2)+,a2
                               ; Shift 8 bit data into Al
       asr #8,a,a
LOOP9
                              ; starting address for load
       move al,r0
       move al,rl
                              ; save it in r1
                              ; a0 holds the number of words
       do a0,_LOOP10
                              ; read program words
                              ; Each instruction has 3 bytes
       do #3, LOOP11
                              ; Get the 8 LSB from ext. P mem.
       movem p:(r2)+,a2
       asr #8,a,a
                               ; Shift 8 bit data into A1
LOOP11
                              ; Go get another byte.
       movem al,p:(r0)+
                              ; Store 24-bit result in P mem.
```

```
; pipeline delay
       nop
_LOOP10
                               ; and go get another 24-bit word.
                               ; Boot from EPROM done
               <FINISH
       bra
OMR1XXX
        jclr #MC,omr,BURN_RESER ; IF MD:MC:MB:MA=101x, go to RESERVED
                                ; IF MD:MC:MB:MA=1001, go to BURN
      jclr #MB,omr,OMR1IS0
                            ; IF MD:MC:MB:MA=110x, go to look for ISA/HC11
      jclr #MA,omr, I8051HOSTLD; If MD:MC:MB:MA=1110, go load from 8051 Host
                           ; If MD:MC:MB:MA=1111, go load from MC68302 Host
; This is the routine which loads a program through the HDI08 host port
; 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 to.
; 3) 3n bytes (while n is the program length defined by the 3 first bytes)
; The program words will be stored in contiguous PRAM memory locations
starting
; at the specified starting address.
; After reading the program words, program execution starts from the same
; address where loading started.
; The host MCU may terminate the loading process by setting the HF1=0 and
HF0=1.
; When the downloading is terminated, the program will start execution of the
; loaded program from the specified starting address.
; The HDI08 boot ROM program enables the following busses to download programs
; through the HDI08 port:
                    - Dual strobes non-multiplexed bus with negative strobe
; C - ISA
                    pulses dual positive request
                   - Single strobe non-multiplexed bus with positive strobe
; D - HC11
                    pulse single negative request.
; E - i8051
                  - Dual strobes multiplexed bus with negative strobe pulses
                    dual negative request.
F - MC68302
                   - Single strobe non-multiplexed bus with negative strobe
                    pulse single negative request.
MC68302HOSTLD
               #%000000000111000,x:M HPCR
       movep
                               ; Configure the following conditions:
                               ; HAP = 0 Negative host acknowledge
                               ; HRP = 0 Negative host request
```

```
; HCSP = 0 Negatice chip select input
                                ; HDDS = 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 stobes 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 = 1 Host acknowledge is enabled
                                ; 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
               <HDI08CONT
OMR1IS0
       jset #MA,omr, HC11HOSTLD; If MD:MC:MB:MA=1101, go load from HC11 Host
                               ; If MD:MC:MB:MA=1100, go load from ISA HOST
ISAHOSTLD
              #%0101000000011000,x:M HPCR
       movep
                                ; Configure the following conditions:
                                ; HAP = 0 Negative host acknowledge
                                ; HRP = 1 Positive host request
                                ; HCSP = 0 Negatice chip select input
                                ; HDDS = 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 stobes 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
                                            meaning in non-multiplexed bus)
                                ; HA8EN = 0 (address 8 enable bit has no
```

```
meaning non-multiplexed bus)
                                ; HGEN = 0 Host GPIO pins are disabled
        bra
                <HDI08CONT
HC11HOSTLD
               #%000001000011000,x:M HPCR
        movep
                                ; Configure the following conditions:
                                ; HAP = 0 Negative host acknowledge
                                ; HRP = 0 Negative host request
                                ; HCSP = 0 Negatice chip select input
                                ; HDDS = 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 = 1 Negative data stobes 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
                                           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
               <HDI08CONT
I8051HOSTLD
              #%0001110000011110,x:M HPCR
        movep
                                ; Configure the following conditions:
                                ; HAP = 0 Negative host acknowledge
                                ; HRP = 0 Negatice host request
                                ; HCSP = 0 Negatice chip select input
                                ; HDDS = 1 Dual strobes bus (RD and WR)
                                ; HMUX = 1 Multiplexed bus
                               ; HASP = 1 Positive address strobe polarity
                                ; HDSP = 0 Negative data stobes 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
HDI08CONT
      bset
                                   ; Enable the HDI08 to operate as host
             #HEN,x:M_HPCR
                                    ; interface (set HEN=1)
       jclr
              #HRDF,x:M_HSR,*
                                    ; wait for the program length to be
                                     ; written
       movep
             x:M_HORX,a0
      jclr
             #HRDF,x:M HSR,*
                                 ; wait for the program starting address
                                     ; to be written
             x:M_HORX,r0
       movep
       move
            r0,r1
            a0,HDI08LOOP
                                 ; set a loop with the downloaded length
      do
HDI08LL
             #HRDF,x:M HSR,HDI08NW ; If new word was loaded then jump to
      jset
                                     ; read that word
                                     ; If HF0=0 then continue with the
       jclr
             #HF0,x:M HSR,HDI08LL
                                     ; downloading
       enddo
                                     ; Must terminate the do loop
       bra
              <HDI08LOOP
MN80IDH
     movep x:M HORX,p:(r0)+
                                 ; Move the new word into its destination
                                     ; location in the program RAM
                                     ; pipeline delay
       nop
HDI08LOOP
; This is the exit handler that returns execution to normal
; expanded mode and jumps to the RESET vector.
FINISH
       andi #$0,ccr
                             ; Clear CCR as if RESET to 0.
       jmp (r1)
                             ; Then go to starting Prog addr.
```

```
; MD:MC:MB:MA=1001 is used for Burn-in code
BURN_RESER
      jclr #MB,omr,BURN
                       ; IF MD:MC:MB:MA=1001, go to BURN
; The following modes are reserved, some of which are used for internal
testing
; MD:MC:MB:MA=0011 is reserved
; MD:MC:MB:MA=1010 is reserved
; MD:MC:MB:MA=1011 is reserved
RESERVED
     bra
          <*
; Code for burn-in
;; Port C GPIO Control Register
M PCRC EQU
            $FFFFBF
M PDRC EQU
            $FFFFBD
                        ;; Port C GPIO Data Register
M_PRRC EQU
            $FFFFBE
                       ;; Port C Direction Register
SCKT
     EQU
            $3
                        ;; SCKT is GPIO bit #3 in ESAI (Port C)
                  1
EQUALDATA
            equ
                        ;; 1 if xram and yram are of equal
                        ;; size and addresses, 0 otherwise.
      if
            (EQUALDATA)
start dram
            equ 0
                        ;; 5.5k X and Y RAM
length_dram
                 $1600
                       ;; same addresses
            equ
      else
                0
                       ;; 5.5k XRAM
start_xram
            equ
length xram
                 $1600
            equ
                 0
start yram
                        ;; 5.5k YRAM
            equ
length_yram
            equ
                 $1600
     endif
                  0
start pram
            equ
                        ;; 3k PRAM
length pram
                  $C00
            equ
BURN
            ;; get PATTERN pointer
           clr b #PATTERNS,r6
                                 ;; b is the error accumulator
                 #<(NUM PATTERNS-1),m6 ;; program runs forever in</pre>
            move
                                    ;; cyclic form
```

```
;; configure SCKT as gpio output.
              movep b,x:M_PDRC
                                           ;; clear GPIO data register
            bclr #SCKT,x:M_PCRC
                                      ;; Define SCKT as output GPIO pin
            bset #SCKT,x:M_PRRC
                                       ;; SCKT toggles means test pass
                                        ;; r5 = test fail flag = $000000
            lua
                  (r5) - r7
                                       ;; r7 = test pass flag = $FFFFFF
burnin_loop
                  do #9,burn1
              ;;-----
              ;; test RAM
              ;; each pass checks 1 pattern
              ;;-----
                                           ;; pattern for x memory
                     p:(r6)+,x1
              move
                     p:(r6)+,x0
                                           ;; pattern for y memory
                                           ;; pattern for p memory
              move
                     p:(r6)+,y0
              ;; write pattern to all memory locations
       if
              (EQUALDATA)
                                           ;; x/y ram symmetrical
              ;; write x and y memory
              clr a #start_dram,r0
                                           ;; start of x/y ram
                   #>length_dram,n0
                                           ;; length of x/y ram
              rep
                     n0
             \max x0,x1,a x,l:(r0)+ ;; exercise mac, write x/y ram
       else
                                           ;; x/y ram not symmetrical
              ;; write x memory
              clr a #start_xram,r0
                                           ;; start of xram
              move
                     #>length_xram,n0
                                           ;; length of xram
              mac x0,y0,a x1,x:(r0)+
                                        ;; exercise mac, write xram
              ;; write y memory
                                           ;; start of yram
              clr a #start_yram,r1
                     #>length_yram,n1
                                           ;; length of yram
              move
              rep
                     n1
              mac x1,y0,a x0,y:(r1)+
                                        ;; exercise mac, write yram
       endif
              ;; write p memory
              clr a #start_pram,r2
                                           ;; start of pram
                     #>length_pram,n2
              move
                                           ;; length of pram
                     n2
              rep
              move
                     y0,p:(r2)+
                                          ;; write pram
              ;; check memory contents
```

```
if
               (EQUALDATA)
                                              ;; x/y ram symmetrical
               ;; check dram
               clr a #start_dram,r0
                                              ;; restore pointer, clear a
                       n0,_loopd
               do
               move
                       x:(r0),a1
                                              ;; a0=a2=0
               eor
                       x1,a
               add
                       a,b
                                               ;; accumulate error in b
                                               ;; a0=a2=0
                       y:(r0)+,a1
               move
               eor
                      x0,a
               add
                       a,b
                                               ;; accumulate error in b
_loopd
       else
                                               ;; x/y ram not symmetrical
               ;; check xram
               clr a #start xram,r0
                                              ;; restore pointer, clear a
                      n0,_loopx
               do
               move
                    x:(r0)+,a1
                                              ;; a0=a2=0
               eor
                       x1,a
               add
                       a,b
                                              ;; accumulate error in b
loopx
               ;; check yram
               clr a #start_yram,r1
                                              ;; restore pointer, clear a
               do
                      n1,_loopy
                       y:(r1)+,a1
                                              ;; a0=a2=0
               move
               eor
                       x0.a
               add
                       a,b
                                              ;; accumulate error in b
_loopy
       endif
               ;; check pram
               clr a #start_pram,r2
                                          ;; restore pointer, clear a
               do
                      n2,_loopp
                      p:(r2)+,a1
                                              ;; a0=a2=0
               move
                       y0,a
               eor
                                              ;; accumulate error in b
               add
                       a,b
_loopp
               ;; toggle pin if no errors, stop execution otherwise.
               ;; if error
                   r5,r7
                                         ;; r7=$FFFFFF as long as test pass
             tne
                                              ;; condition codes preserved
                                             ;; this instr can be removed
in case of shortage
                                           ;; write pass/fail flag to OnCE
              movep r7,x:M\_OGDB
                                              ;; condition codes preserved
                                             ;; this instr can be removed
```

```
in case of shortage
               beq
                      label1
               bclr
                      #SCKT,x:M_PDRC
                                            ;; clear SCKT if error,
              enddo
                                          ;; terminate the loop normally
                                           ;; this instr can be removed
in case of shortage
              bra
                      <burn1
                                             ;; and stop execution
label1
                                             ;; if no error
                                        ;; toggle pin and keep on looping
            bchg
                   #SCKT,x:M_PDRC
burn1
                                             ;; test completion
              debug
                                            ;; enter debug mode if OnCE
port enabled
                                           ;; this instr can be removed
in case of shortage
                                          ;; enter wait otherwise (OnCE
              wait
port disabled)
BURN END
               ORG PL:,PL:
PATTERNS
              dsm
                     4
                                            ;; align for correct modulo
addressing
              ORG PL:BURN_END, PL:BURN_END
              dup PATTERNS-*
                                           ; write address in unused
Boot ROM location
              dc *
              endm
              ORG
                     PL:PATTERNS, PL:PATTERNS ;; Each value is written to
all memories
               dc
                      $555555
                      $AAAAAA
               dc
               dc
                      $333333
               dc
                      $F0F0F0
NUM_PATTERNS
                      *-PATTERNS
               equ
; This code fills the unused bootstrap rom locations with their address
              dup $FF00C0-*
              dc *
```

endm

end

```
; Reserved Area in the Program ROM: upper 128 words.
; Address range: $FF8780 - $FF87FF
ORG PL:$FF8780,PL:$FF8780
; This code fills the unused rom locations with their address
            dup $FF8800-$14-*
            dc *
            endm
; Code segment for testing of ROM Patch
; This code segment is located in the uppermost addresses of the Program ROM
            ORG PL:$FF8800-$14,PL:$FF8800-$14
            move
                   #$80000,r0
                   #$0,x0
            move
            move
                  x0,x:(r0)+
                  #$1,x0
            move
                  x0,x:(r0)+
            move
            move
                  #$2,x0
                  x0,x:(r0)+
            move
            move
                  #$3,x0
                  x0,x:(r0)+
            move
            move
                  #$4,x0
                  x0,x:(r0)+
            move
                  #$5,x0
            move
                  x0,x:(r0)+
            move
                  #$6,x0
            move
                  x0,x:(r0)+
            move
            move
                  #$7,x0
                  x0,x:(r0)+
            move
            move
                  #$8,x0
            move
                  x0,x:(r0)+
```

## APPENDIX B EQUATES

```
; EQUATES for DSP56362 interrupts
; Last update: April 24, 2000
page 132,55,0,0,0
  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_IINST EQU I_VEC+$04 ; Illegal Instruction
I_TRAP EQU I_VEC+$08 ; Trap
```

```
; 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_DMA1 EQU I_VEC+$1A ; DMA Channel 1
; DAX Interrupts
I_DAXTUE EQU I_VEC+$28 ; DAX Underrun Error
I_DAXBLK EQU I_VEC+$2A ; DAX Block Transferred
I_DAXTD EQU I_VEC+$2E ; DAX Audio Data Empty
; ESAI Interrupts
;-----
```

```
I_ESAIRD EQU I_VEC+$30  ; ESAI Receive Data
I_ESAIRED EQU I_VEC+$32 ; ESAI Receive Even Data
I_ESAIRDE EQU I_VEC+$34 ; ESAI Receive Data With Exception Status
I_ESAIRLS EQU I_VEC+$36  ; ESAI Receive Last Slot
I_ESAITD EQU I_VEC+$38 ; ESAI Transmit Data
I_ESAITED EQU I_VEC+$3A ; ESAI Transmit Even Data
I_ESAITDE EQU I_VEC+$3C ; ESAI Transmit Data With Exception Status
I_ESAITLS EQU I_VEC+$3E ; ESAI Transmit Last Slot
;-----
; SHI Interrupts
;-----;
I_SHITD EQU I_VEC+$40 ; SHI Transmit Data
I_SHITUE EQU I_VEC+$42 ; SHI Transmit Underrun Error
I_SHIRNE EQU I_VEC+$44 ; SHI Receive FIFO Not Empty
I_SHIRFF EQU I_VEC+$48 ; SHI Receive FIFO Full
I_SHIROE EQU I_VEC+$4A ; SHI Receive Overrun Error
I_SHIBER EQU I_VEC+$4C ; SHI Bus Error
;-----
; Timer Interrupts
;-----
I_TIMOC EQU I_VEC+$54 ; TIMER 0 compare
I_TIMOOF EQU I_VEC+$56 ; TIMER 0 overflow
I_TIM1C EQU I_VEC+$58 ; TIMER 1 compare
I_TIM2C EQU I_VEC+$5C ; TIMER 2 compare
I_TIM2OF EQU I_VEC+$5E ; TIMER 2 overflow
;-----
```

```
; HDI08 Interrupts
;-----
I_HI08RX EQU I_VEC+$60 ; Host Receive Data Full
I_HI08CM EQU I_VEC+$64 ; Host Command (Default)
; INTERRUPT ENDING ADDRESS
;-----
I_INTEND EQU I_VEC+$FF ; last address of interrupt vector space
;----- end of intequ.asm -----
EQUATES for DSP56362 I/O registers and ports
; Last update: April 24, 2000
page 132,55,0,0,0
 opt mex
ioequ ident 1,0
;-----
 EQUATES for I/O Port Programming
; Register Addresses
M_HDR EQU $FFFFC9 ; Host port GPIO data Register
```

```
M HDDR EQU
              $FFFFC8
                          ; Host port GPIO direction Register
M_PCRC
      EQU
              $FFFFBF
                           ; Port C Control Register
M_PRRC
                          ; Port C Direction Register
      EQU
              $FFFFBE
M_PDRC
                           ; Port C GPIO Data Register
       EQU
              $FFFFBD
M PCRD
      EQU
                           ; Port D Control register
              $FFFFD7
M_PRRD
      EQU
              $FFFFD6 ; Port D Direction Data Register
M_PDRD EQU
                           ; Port D GPIO Data Register
              $FFFFD5
M OGDB EQU
              $FFFFFC
                          ; OnCE GDB Register
;-----
;
; EQUATES for Exception Processing
     Register Addresses
M_IPRC EQU $FFFFFF ; Interrupt Priority Register Core
M_IPRP EQU $FFFFFE ; Interrupt Priority Register Peripheral
      Interrupt Priority Register Core (IPRC)
             $7
                           ; IROA Mode Mask
M_IAL EQU
M_IALO
      EQU
             0
                           ; IRQA Mode Interrupt Priority Level (low)
M_IAL1
      EQU
              1
                           ; IRQA Mode Interrupt Priority Level (high)
M_IAL2 EQU
                           ; IRQA Mode Trigger Mode
M_IBL
           $38
       EQU
                           ; IROB Mode Mask
M IBLO
      EQU
                           ; IRQB Mode Interrupt Priority Level (low)
M_IBL1
      EQU
                           ; IRQB Mode Interrupt Priority Level (high)
M_IBL2 EQU
             5
                           ; IRQB Mode Trigger Mode
                           ; IRQC Mode Mask
M_ICL EQU
           $1C0
M ICLO EQU
                           ; IRQC Mode Interrupt Priority Level (low)
```

| 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_D0L0                                          | EQU | 12       | ; DMA0 Interrupt Priority Level (low)       |  |  |
| M_D0L1                                          | EQU | 13       | ; DMAO 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 Priority Register Peripheral (IPRP) |     |          |                                             |  |  |
| M_ESL                                           | EQU | \$3      | ; ESAI Interrupt Priority Level Mask        |  |  |

```
M ESLO EQU
                            ; ESAI Interrupt Priority Level (low)
M_ESL1
      EQU
                            ; ESAI Interrupt Priority Level (high)
M_SHL
              $C
                            ; SHI Interrupt Priority Level Mask
       EQU
M_SHL0
                            ; SHI Interrupt Priority Level (low)
       EQU
              2
M SHL1
       EQU
                            ; SHI Interrupt Priority Level (high)
M\_HDL
              $30
                            ; HDI08 Interrupt Priority Level Mask
       EQU
M_HDL0
                            ; HDI08 Interrupt Priority Level (low)
       EQU
                            ; HDI08 Interrupt Priority Level (high)
M HDL1
      EQU
              5
M_DAL
      EQU
              $C0
                            ; DAX Interrupt Priority Level Mask
M_DALO EQU
                            ; DAX Interrupt Priority Level (low)
M_DAL1 EQU
             7
                            ; DAX Interrupt Priority Level (high)
M TAL EOU
             $300
                          Timer Interrupt Priority Level Mask
             8
M_TALO EQU
                            ;Timer Interrupt Priority Level (low)
M_TAL1 EQU
           9
                            ;Timer Interrupt Priority Level (high)
;-----
;
     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
                           ; DMA Offset Register 1
M_DOR1 EQU
             $FFFFF2
M DOR2 EQU
              $FFFFF1
                           ; DMA Offset Register 2
M DOR3 EQU
              $FFFFF0 ; DMA Offset Register 3
      Register Addresses Of DMA0
```

```
M DSR0
        EQU
                $FFFFEF
                                ; DMAO Source Address Register
M_DDR0
        EQU
                $FFFFEE
                                ; DMA0 Destination Address Register
M_DCO0
                $FFFFED
                                ; DMA0 Counter
        EQU
M DCR0
        EQU
                 $FFFFEC
                                ; DMA0 Control Register
       Register Addresses Of DMA1
M_DSR1
        EQU
                $FFFFEB
                                 ; DMA1 Source Address Register
M_DDR1
        EQU
                                ; DMA1 Destination Address Register
                $FFFFEA
M DCO1
                                ; DMA1 Counter
        EQU
                $FFFFE9
M_DCR1
        EQU
                $FFFFE8
                               ; DMA1 Control Register
       Register Addresses Of DMA2
M_DSR2
        EQU
                $FFFFE7
                                ; DMA2 Source Address Register
M DDR2
        EOU
                $FFFFE6
                                ; DMA2 Destination Address Register
                                ; DMA2 Counter
M_DCO2
        EQU
                $FFFFE5
M_DCR2
        EQU
                 $FFFFE4
                               ; DMA2 Control Register
       Register Addresses Of DMA3
M DSR3
        EQU
                $FFFFE3
                               ; DMA3 Source Address Register
M_DDR3
        EOU
                                ; DMA3 Destination Address Register
                $FFFFE2
M_DCO3
                                ; DMA3 Counter
        EOU
                $FFFFE1
                 $FFFFE0
                               ; DMA3 Control Register
M_DCR3
        EQU
       Register Addresses Of DMA4
M DSR4
        EQU
                                ; DMA4 Source Address Register
                $FFFFDF
M DDR4
        EQU
                $FFFFDE
                                ; DMA4 Destination Address Register
                                ; DMA4 Counter
M_DCO4
        EQU
                $FFFFDD
M_DCR4
        EQU
                $FFFFDC
                                ; DMA4 Control Register
       Register Addresses Of DMA5
M DSR5
       EQU
                $FFFFDB ; DMA5 Source Address Register
```

| M_DDR5 | EQU      | \$FFFFDA      | ; DMA5 Destination Address Register     |
|--------|----------|---------------|-----------------------------------------|
| M_DCO5 | EQU      | \$FFFFD9      | ; DMA5 Counter                          |
| M_DCR5 | EQU      | \$FFFFD8      | ; DMA5 Control Register                 |
| ;      | DMA Cont | trol 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      | \$3f0         | ; DMA Address Mode Mask (DAM5-DAM0)     |
| M_DAM0 | EQU      | 4             | ; DMA Address Mode 0                    |
| M_DAM1 | 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_DRS0 | EQU      | 11            | ;DMA Request Source bit 0               |
| M_DRS1 | EQU      | 12            | ;DMA Request Source bit 1               |
| M_DRS2 | EQU      | 13            | ;DMA Request Source bit 2               |
| M_DRS3 | EQU      | 14            | ;DMA Request Source bit 3               |
| M_DRS4 | EQU      | 15            | ;DMA Request Source bit 4               |
| M_DCON | EQU      | 16            | ; DMA Continuous Mode                   |
| M_DPR  | EQU      | \$60000       | ; DMA Channel Priority                  |

```
M DPR0
       EQU
                              ; 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
                               ; DMA Transfer Mode 1
M_DTM2
        EQU
                               ; DMA Transfer Mode 2
              21
M_DIE
        EQU
               22
                               ; DMA Interrupt Enable bit
M DE
                23
                               ; DMA Channel Enable bit
       EQU
       DMA Status Register
M_DTD
        EQU
              $3F
                               ; Channel Transfer Done Status MASK (DTD0-DTD5)
M_DTD0
        EQU
                              ; DMA Channel Transfer Done Status 0
M DTD1
        EOU
                               ; DMA Channel Transfer Done Status 1
                               ; DMA Channel Transfer Done Status 2
M_DTD2
        EQU
M_DTD3
        EQU
                               ; DMA Channel Transfer Done Status 3
M_DTD4
                               ; DMA Channel Transfer Done Status 4
        EQU
M_DTD5
        EQU
                               ; DMA Channel Transfer Done Status 5
M DACT
        EQU
                               ; DMA Active State
M_DCH
        EQU
               $E00
                              ; DMA Active Channel Mask (DCH0-DCH2)
M_DCH0
       EQU
                               ; DMA Active Channel 0
M_DCH1
       EQU
              10
                             ; DMA Active Channel 1
M_DCH2 EQU
              11
                              ; DMA Active Channel 2
     EQUATES for Phase Locked Loop (PLL)
Register Addresses Of PLL
```

| M_PCTL | EQU    | \$FFFFFD     | ; PLL Control Register                       |
|--------|--------|--------------|----------------------------------------------|
| ;      | PLL Co | ntrol Regist | cer                                          |
| M_MF   | EQU    | \$FFF        | ; Multiplication Factor Bits Mask (MF0-MF11) |
| M_MF0  | EQU    | 0            | ;Multiplication Factor bit 0                 |
| M_MF1  | EQU    | 1            | ;Multiplication Factor bit 1                 |
| M_MF2  | EQU    | 2            | ;Multiplication Factor bit 2                 |
| M_MF3  | EQU    | 3            | ;Multiplication Factor bit 3                 |
| M_MF4  | EQU    | 4            | ;Multiplication Factor bit 4                 |
| M_MF5  | EQU    | 5            | ;Multiplication Factor bit 5                 |
| M_MF6  | EQU    | 6            | ;Multiplication Factor bit 6                 |
| M_MF7  | EQU    | 7            | ;Multiplication Factor bit 7                 |
| M_MF8  | EQU    | 8            | ;Multiplication Factor bit 8                 |
| M_MF9  | EQU    | 9            | ;Multiplication Factor bit 9                 |
| M_MF10 | EQU    | 10           | ;Multiplication Factor bit 10                |
| M_MF11 | EQU    | 11           | ;Multiplication Factor bit 11                |
| M_DF   | EQU    | \$7000       | ; Division Factor Bits Mask (DF0-DF2)        |
| M_DF0  | EQU    | 12           | Division Factor bit 0                        |
| M_DF1  | EQU    | 13           | Division Factor bit 1                        |
| M_DF2  | EQU    | 14           | Division Factor bit 2                        |
| M_XTLR | EQU    | 15           | ; XTAL Range select bit                      |
| M_XTLD | EQU    | 16           | ; XTAL Disable Bit                           |
| M_PSTP | EQU    | 17           | ; STOP Processing State Bit                  |
| M_PEN  | EQU    | 18           | ; PLL Enable Bit                             |
| M_COD  | EQU    | 19           | ; PLL Clock Output Disable Bit               |
| M_PD   | EQU    | \$F00000     | ; PreDivider Factor Bits Mask (PD0-PD3)      |
| M_PD0  | EQU    | 20           | ;PreDivider Factor bit 0                     |

```
M PD1 EQU 21
                                 ;PreDivider Factor bit 1
M_PD2
       EQU
             22
                                  ;PreDivider Factor bit 2
M_PD3 EQU 23
                                  ;PreDivider Factor bit 3
     EQUATES for BIU
       Register Addresses Of BIU
M_BCR
      EQU
              $FFFFFB ; Bus Control Register
M_DCR
       EQU
            $FFFFFA ; DRAM Control Register
M AARO
       EOU
              $FFFFF9
                            ; Address Attribute Register 0
                             ; Address Attribute Register 1
M_AAR1
       EQU
              $FFFFF8
M_AAR2
       EQU
              $FFFFF7
                            ; Address Attribute Register 2
M_AAR3
               $FFFFF6
                        ; Address Attribute Register 3
       EQU
M_IDR
       EQU
               $FFFFF5
                       ; ID Register
       Bus Control Register
M_BAOW
       EQU
              $1F
                             ; Area 0 Wait Control Mask (BA0W0-BA0W4)
M_BA0W0
                              ;Area 0 Wait Control Bit 0
       EQU
                              ;Area 0 Wait Control Bit 1
M_BA0W1
       EQU
              1
                              ;Area 0 Wait Control Bit 2
M_BA0W2
       EQU
M_BAOW3
       EQU
              3
                              ;Area 0 Wait Control Bit 3
M BAOW4
       EQU
                              ;Area 0 Wait Control Bit 4
M_BA1W
        EQU
              $3E0
                              ; Area 1 Wait Control Mask (BA1W0-BA14)
M_BA1W0
                              ;Area 1 Wait Control Bit 0
       EQU
M BA1W1
                              ;Area 1 Wait Control Bit 1
       EQU
M BA1W2 EQU
                              ;Area 1 Wait Control Bit 2
```

```
M_BA1W3
          EQU
                                  ;Area 1 Wait Control Bit 3
M BA1W4
          EQU
                                  ;Area 1 Wait Control Bit 4
M BA2W
         EQU
                $1C00
                                 ; Area 2 Wait Control Mask (BA2W0-BA2W2)
M_BA2W0
          EQU
                10
                                  ;Area 2 Wait Control Bit 0
M BA2W1
                                   ;Area 2 Wait Control Bit 1
          EQU
                11
M BA2W2
          EQU
                12
                                  ;Area 2 Wait Control Bit 2
M_BA3W
         EOU
                $E000
                                 ; Area 3 Wait Control Mask (BA3W0-BA3W3)
M BA3W0
         EQU
               13
                                  ;Area 3 Wait Control Bit 0
M_BA3W1
         EQU
                14
                                  ;Area 3 Wait Control Bit 1
M_BA3W2
          EQU
                15
                                   ;Area 3 Wait Control Bit 2
M_BDFW
         EQU
                 $1F0000
                                 ; Default Area Wait Control Mask (BDFW0-BDFW4)
M BDFW0
         EQU
                                    ;Default Area Wait Control bit 0
                  16
M BDFW1
          EQU
                  17
                                    ;Default Area Wait Control bit 1
                                    ;Default Area Wait Control bit 2
M_BDFW2
         EQU
                  18
                                    ;Default Area Wait Control bit 3
M_BDFW3
         EQU
                  19
M BDFW4
                                    ;Default Area Wait Control bit 4
         EOU
                  20
M BBS
         EOU
                 21
                                 ; Bus State
M_BLH
         EQU
                 22
                                 ; Bus Lock Hold
M_BRH
         EQU
                 23
                                 ; Bus Request Hold
        DRAM Control Register
                                 ; In Page Wait States Bits Mask (BCW0-BCW1)
M BCW
         EQU
                 $3
                                 ; In Page Wait States Bit 0
M BCW0
          EQU
                0
M_BCW1
                                ; In Page Wait States Bit 1
         EQU
                 1
M BRW
         EQU
                 $C
                                 ; Out Of Page Wait States Bits Mask (BRW0-BRW1)
                                ;Out of Page Wait States bit 0
M BRW0
          EQU
M_BRW1
          EQU
                  3
                                ; Out of Page Wait States bit 1
```

```
M BPS
         EQU
                 $300
                                  ; DRAM Page Size Bits Mask (BPS0-BPS1)
M_BPS0
          EQU
                  4
                                ; DRAM Page Size Bits 0
M_BPS1
                  5
                                ; DRAM Page Size Bits 1
          EQU
M_BPLE
                                  ; Page Logic Enable
         EQU
                 11
M BME
         EQU
                                  ; Mastership Enable
                                  ; Refresh Enable
M_BRE
         EQU
                 13
                                  ; Software Triggered Refresh
M_BSTR
         EQU
                 14
M BRF
                                  ; Refresh Rate Bits Mask (BRF0-BRF7)
         EQU
                 $7F8000
M_BRF0
          EQU
                  15
                              ; Refresh Rate Bit 0
M_BRF1
                  16
                              ; Refresh Rate Bit 1
          EQU
M_BRF2
                  17
                              ; Refresh Rate Bit 2
          EQU
M BRF3
                  18
                              ; Refresh Rate Bit 3
          EOU
M_BRF4
                              ; Refresh Rate Bit 4
          EQU
                  19
M_BRF5
                  20
                              ; Refresh Rate Bit 5
          EQU
M_BRF6
                              ; Refresh Rate Bit 6
          EQU
                  21
M_BRF7
          EQU
                  22
                              ; Refresh Rate Bit 7
M BRP
         EQU
                 23
                                  ; Refresh prescaler
        Address Attribute Registers
M_BAT
                 $3
                                  ; External Access Type and Pin Definition Bits Mask
         EQU
(BAT0-BAT1)
                                  ; External Access Type and Pin Definition Bits 0
M_BAT0
          EQU
                  0
                                  ; External Access Type and Pin Definition Bits 1
M BAT1
          EQU
                  1
M_BAAP
         EQU
                                  ; Address Attribute Pin Polarity
                                  ; Program Space Enable
M_BPEN
         EQU
                 3
M BXEN
         EQU
                                  ; X Data Space Enable
M BYEN
         EQU
                                  ; Y Data Space Enable
M_BAM
                                  ; Address Muxing
         EQU
                 6
```

```
M_BPAC
         EQU
                                 ; Packing Enable
M_BNC
         EQU
                 $F00
                                 ; Number of Address Bits to Compare Mask (BNC0-BNC3)
M_BNC0
          EQU
                  8
                               ; Number of Address Bits to Compare 0
M_BNC1
          EQU
                               ; Number of Address Bits to Compare 1
M BNC2
          EQU
                                ; Number of Address Bits to Compare 2
M_BNC3
          EQU
                                ; Number of Address Bits to Compare 3
                  11
                                  ; Address to Compare Bits Mask (BAC0-BAC11)
M_BAC
         EQU
                 $FFF000
M BACO
                             ; Address to Compare Bits 0
          EQU
                  12
M_BAC1
          EQU
                  13
                             ; Address to Compare Bits 1
M_BAC2
          EQU
                           ; Address to Compare Bits 2
                  14
M_BAC3
          EQU
                  15
                             ; Address to Compare Bits 3
M BAC4
          EOU
                  16
                             ; Address to Compare Bits 4
M_BAC5
          EQU
                             ; Address to Compare Bits 5
                  17
M_BAC6
          EQU
                  18
                             ; Address to Compare Bits 6
M_BAC7
          EQU
                             ; Address to Compare Bits 7
                  19
M_BAC8
          EQU
                  20
                             ; Address to Compare Bits 8
M BAC9
          EQU
                  21
                             ; Address to Compare Bits 9
M_BAC10
                   22
                              ; Address to Compare Bits 10
           EQU
M BAC11
           EQU
                   23
                              ; Address to Compare Bits 11
        control and status bits in SR
M_C
        EQU
                                ; Carry
M V
         EOU
                                  ; Overflow
ΜZ
         EQU
                                  ; Zero
M_N
         EQU
                 3
                                  ; Negative
M_U
         EQU
                                  ; Unnormalized
M E
         EQU
                                  ; Extension
МL
         EQU
                                  ; Limit
```

| M_S    | EQU     | 7               | ;  | Scaling Bit                            |
|--------|---------|-----------------|----|----------------------------------------|
| M_I0   | EQU     | 8               | ;  | Interupt Mask Bit 0                    |
| M_I1   | EQU     | 9               | ;  | Interupt 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_CP   | EQU     | \$c00000        | ;  | mask for CORE-DMA priority bits in SR  |
| M_CP0  | EQU     | 22              | ;  | bit 0 of priority bits in SR           |
| M_CP1  | EQU     | 23              | ;  | bit 1 of priority bits in SR           |
| ;      | control | and status bits | in | OMR                                    |
| M_MA   | EQU     | 0               | ;  | Operating Mode A                       |
| M_MB   | EQU     | 1               | ;  | Operating Mode B                       |
| M_MC   | EQU     | 2               | ;  | Operating Mode C                       |
| M_MD   | EQU     | 3               | ;  | 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 Mode                    |
| M_CDP  | EQU     | \$300           | ;  | mask for CORE-DMA priority bits in OMR |
| M_CDP0 | EQU     | 8               | ;  | bit 0 of priority bits in OMR Core DMA |

```
M CDP1 EQU
                           ; bit 1 of priority bits in OMR Core DMA
                          ; Burst Enable
M_BE
      EQU
            10
M_TAS EQU
           11
                           ; TA Synchronize Select
M_BRT EQU
                           ; Bus Release Timing
           12
M ABE
      EQU
            13
                           ; Async. Bus Arbitration Enable
M_APD
      EQU
                           ; Addess Priority Disable
            14
M_ATE
      EQU
            15
                           ; Address Tracing Enable
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.
           19
M_WRP EQU
                           ; Extended WRaP flag in OMR.
M SEN EOU
             20
                           ; Stack Extension Enable bit in OMR.
             23
M_PAEN EQU
                           ; Patch Enable
;______
  EQUATES for DAX (SPDIF Tx)
     Register Addresses
M_XSTR EQU
             $FFFFD4 ; DAX Status Register (XSTR)
M_XADRB EQU
              $FFFFD3 ; DAX Audio Data Register B (XADRB)
M XADR EQU
             $FFFFD2
                           ;DAX Audio Data Register (XADR)
M_XADRA EQU
              $FFFFD2
                           ; DAX Audio Data Register A (XADRA)
M_XNADR EQU
                         ; DAX Non-Audio Data Register (XNADR)
              $FFFFD1
M XCTR EQU
              $FFFFD0 ; DAX Control Register (XCTR)
; status bits in XSTR
```

```
M_XADE EQU
                          ; DAX Audio Data Register Empty (XADE)
M XAUR
      EQU
                           ; DAX Trasmit Underrun Error Flag (XAUR)
                    ; DAX Block Transferred (XBLK)
M XBLK
      EQU
      non-audio bits in XNADR
M_XVA
     EQU
             10
                         ; DAX Channel A Validity (XVA)
M_XUA
       EQU
            11
                          ; DAX Channel A User Data (XUA)
       EQU
                           ; DAX Channel A Channel Status (XCA)
M_XCA
             12
                          ; DAX Channel B Validity (XVB)
M_XVB
      EQU 13
M_XUB
     EQU
           14
                          ; DAX Channel B User Data (XUB)
M_XCB
     EQU
            15
                   ; DAX Channel B Channel Status (XCB)
      control bits in XCTR
                         ; DAX Audio Data Register Empty Interrupt Enable (XDIE)
M_XDIE EQU
M_XUIE
                          ; DAX Underrun Error Interrupt Enable (XUIE)
      EOU
             1
M_XBIE
      EQU
                          ; DAX Block Transferred Interrupt Enable (XBIE)
M_XCS0
                   ; DAX Clock Input Select 0 (XCS0)
      EQU
M_XCS1 EQU
                   ; DAX Clock Input Select 1 (XCS1)
M XSB EOU
                          ; DAX Start Block (XSB)
   EQUATES for SHI
;______
    Register Addresses
M HRX EQU
              $FFFF94 ; SHI Receive FIFO (HRX)
            $FFFF93 ; SHI Transmit Register (HTX)
M_{TT}
       EQU
```

```
M HSAR
        EQU
                 $FFFF92
                                 ; SHI I2C Slave Address Register (HSAR)
M_HCSR
         EQU
                 $FFFF91
                                 ; SHI Control/Status Register (HCSR)
M_HCKR
                 $FFFF90
                                 ; SHI Clock Control Register (HCKR)
        EQU
        HSAR bits
м наб
         EQU
                 23
                                 ; SHI I2C Slave Address (HA6)
M_HA5
         EQU
                 22
                                 ; SHI I2C Slave Address (HA5)
                                 ; SHI I2C Slave Address (HA4)
M_HA4
         EQU
                 21
                                 ; SHI I2C Slave Address (HA3)
м наз
         EQU
                 20
M_HA1
         EQU
                 18
                                 ; SHI I2C Slave Address (HA1)
      control and status bits in HCSR
M_HBUSY EQU
                 22
                                 ; SHI Host Busy (HBUSY)
M HBER
         EOU
                 21
                                 ; SHI Bus Error (HBER)
M_HROE
         EQU
                 20
                                 ; SHI Receive Overrun Error (HROE)
M_HRFF
                 19
                                 ; SHI Receivr FIFO Full (HRFF)
         EQU
M_HRNE
         EQU
                 17
                                 ; SHI Receive FIFO Not Empty (HRNE)
M_HTDE
         EQU
                 15
                                 ; SHI Host Transmit data Empty (HTDE)
M HTUE
         EQU
                                 ; SHI Host Transmit Underrun Error (HTUE)
                 14
M_HRIE1 EQU
                                 ; SHI Receive Interrupt Enable (HRIE1)
                 13
                                 ; SHI Receive Interrupt Enable (HRIE0)
M_HRIEO EQU
                 12
M_HTIE
         EQU
                 11
                                 ; SHI Transmit Interrupt Enable (HTIE)
M_HBIE
         EQU
                                 ; SHI Bus-Error Interrupt Enable (HBIE)
                 10
M HIDLE EOU
                                 ; SHI Idle (HIDLE)
                 9
M HRQE1 EQU
                                 ; SHI Host Request Enable (HRQE1)
M_HRQE0 EQU
                                 ; SHI Host Request Enable (HRQE0)
M_HMST
         EQU
                                 ; SHI Master Mode (HMST)
                 6
M HFIFO EQU
                                 ; SHI FIFO Enable Control (HFIFO)
M HCKFR EQU
                                 ; SHI Clock Freeze (HCKFR)
```

```
EQU
                              ; SHI Serial Host Interface Mode (HM1)
M_HM1
M HMO
        EQU
                              ; SHI Serial Host Interface Mode (HMO)
M HI2C EQU
                              ; SHI I2c/SPI Selection (HI2C)
M_HEN
       EQU
                     ; SHI Host Enable (HEN)
       control bits in HCKR
M HFM1
       EQU
              13
                             ; SHI Filter Model (HFM1)
M_HFM0
        EQU
              12
                              ; SHI Filter Model (HFM0)
M_HDM7
              10
                              ; SHI Divider Modulus Select (HDM7)
        EQU
M_HDM6
        EQU
                              ; SHI Divider Modulus Select (HDM6)
M_HDM5
        EQU
                               ; SHI Divider Modulus Select (HDM5)
M_HDM4
        EQU
              7
                               ; SHI Divider Modulus Select (HDM4)
M_HDM3
        EQU
                               ; SHI Divider Modulus Select (HDM3)
M_HDM2
        EOU
                              ; SHI Divider Modulus Select (HDM2)
M_HDM1
        EQU
                              ; SHI Divider Modulus Select (HDM1)
M_HDM0
        EQU
                              ; SHI Divider Modulus Select (HDM0)
                              ; SHI Prescalar Rate Select (HRS)
M HRS
        EOU
M_CPOL
       EOU
                              ; SHI Clock Polarity (CPOL)
M_CPHA
       EQU
                              ; SHI Clock Phase (CPHA)
; EQUATES for ESAI
   Register Addresses
M_RSMB EQU $FFFFBC ; ESAI Receive Slot Mask Register B (RSMB)
```

| M_RSMA  | EQU      | \$FFFFBB   | ; | ESAI | Receive Slot Mask Register A (RSMA)    |
|---------|----------|------------|---|------|----------------------------------------|
| M_TSMB  | EQU      | \$FFFFBA   | ; | ESAI | Transmit Slot Mask Register B (TSMB)   |
| M_TSMA  | EQU      | \$FFFFB9   | ; | ESAI | Transmit Slot Mask Register A (TSMA)   |
| M_RCCR  | EQU      | \$FFFFB8   | ; | ESAI | Receive Clock Control Register (RCCR)  |
| M_RCR   | EQU      | \$FFFFB7   | ; | ESAI | Receive Control Register (RCR)         |
| M_TCCR  | EQU      | \$FFFFB6   | ; | ESAI | Transmit Clock Control Register (TCCR) |
| M_TCR   | EQU      | \$FFFFB5   | ; | ESAI | Transmit Control Register (TCR)        |
| M_SAICR | EQU      | \$FFFFB4   | ; | ESAI | Control Register (SAICR)               |
| M_SAISR | EQU      | \$FFFFB3   | ; | ESAI | Status Register (SAISR)                |
| M_RX3   | EQU      | \$FFFFAB   | ; | ESAI | Receive Data Register 3 (RX3)          |
| M_RX2   | EQU      | \$FFFFAA   | ; | ESAI | Receive Data Register 2 (RX2)          |
| M_RX1   | EQU      | \$FFFFA9   | ; | ESAI | Receive Data Register 1 (RX1)          |
| M_RX0   | EQU      | \$FFFFA8   | ; | ESAI | Receive Data Register 0 (RX0)          |
| M_TSR   | EQU      | \$FFFFA6   | ; | ESAI | Time Slot Register (TSR)               |
| M_TX5   | EQU      | \$FFFFA5   | ; | ESAI | Transmit Data Register 5 (TX5)         |
| M_TX4   | EQU      | \$FFFFA4   | ; | ESAI | Transmit Data Register 4 (TX4)         |
| M_TX3   | EQU      | \$FFFFA3   | ; | ESAI | Transmit Data Register 3 (TX3)         |
| M_TX2   | EQU      | \$FFFFA2   | ; | ESAI | Transmit Data Register 2 (TX2)         |
| M_TX1   | EQU      | \$FFFFA1   | ; | ESAI | Transmit Data Register 1 (TX1)         |
| M_TXO   | EQU      | \$FFFFA0   | ; | ESAI | Transmit Data Register 0 (TX0)         |
| ; I     | RSMB Reg | ister bits |   |      |                                        |
| M_RS31  | EQU      | 15         | ; | ESAI |                                        |
| M_RS30  | EQU      | 14         | ; | ESAI |                                        |
| M_RS29  | EQU      | 13         | ; | ESAI |                                        |
| M_RS28  | EQU      | 12         | ; | ESAI |                                        |
| M_RS27  | EQU      | 11         | ; | ESAI |                                        |
|         |          |            |   |      |                                        |

| M_RS26 | EQU  | 10       |      | ; | ESAI |
|--------|------|----------|------|---|------|
| M_RS25 | EQU  | 9        |      | ; | ESAI |
| M_RS24 | EQU  | 8        |      | ; | ESAI |
| M_RS23 | EQU  | 7        |      | ; | ESAI |
| M_RS22 | EQU  | 6        |      | ; | ESAI |
| M_RS21 | EQU  | 5        |      | ; | ESAI |
| M_RS20 | EQU  | 4        |      | ; | ESAI |
| M_RS19 | EQU  | 3        |      | ; | ESAI |
| M_RS18 | EQU  | 2        |      | ; | ESAI |
| M_RS17 | EQU  | 1        |      | ; | ESAI |
| M_RS16 | EQU  | 0        |      | ; | ESAI |
| ;      | RSMA | Register | bits |   |      |
| M_RS15 | EQU  | 15       |      | ; | ESAI |
| M_RS14 | EQU  | 14       |      | ; | ESAI |
| M_RS13 | EQU  | 13       |      | ; | ESAI |
| M_RS12 | EQU  | 12       |      | ; | ESAI |
| M_RS11 | EQU  | 11       |      | ; | ESAI |
| M_RS10 | EQU  | 10       |      | ; | ESAI |
| M_RS9  | EQU  | 9        |      | ; | ESAI |
| M_RS8  | EQU  | 8        |      | ; | ESAI |
| M_RS7  | EQU  | 7        |      | ; | ESAI |
| M_RS6  | EQU  | 6        |      | ; | ESAI |
| M_RS5  | EQU  | 5        |      | ; | ESAI |
| M_RS4  | EQU  | 4        |      | ; | ESAI |
| M_RS3  | EQU  | 3        |      | ; | ESAI |
| M_RS2  | EQU  | 2        |      | ; | ESAI |
| M_RS1  | EQU  | 1        |      | ; | ESAI |

| M_RSO  | EQU  | 0        |      | ; | ESAI |
|--------|------|----------|------|---|------|
| ;      | TSMB | Register | bits |   |      |
| M_TS31 | EQU  | 15       |      | ; | ESAI |
| M_TS30 | EQU  | 14       |      | ; | ESAI |
| M_TS29 | EQU  | 13       |      | ; | ESAI |
| M_TS28 | EQU  | 12       |      | ; | ESAI |
| M_TS27 | EQU  | 11       |      | ; | ESAI |
| M_TS26 | EQU  | 10       |      | ; | ESAI |
| M_TS25 | EQU  | 9        |      | ; | ESAI |
| M_TS24 | EQU  | 8        |      | ; | ESAI |
| M_TS23 | EQU  | 7        |      | ; | ESAI |
| M_TS22 | EQU  | 6        |      | ; | ESAI |
| M_TS21 | EQU  | 5        |      | ; | ESAI |
| M_TS20 | EQU  | 4        |      | ; | ESAI |
| M_TS19 | EQU  | 3        |      | ; | ESAI |
| M_TS18 | EQU  | 2        |      | ; | ESAI |
| M_TS17 | EQU  | 1        |      | ; | ESAI |
| M_TS16 | EQU  | 0        |      | ; | ESAI |
| ;      | TSMA | Register | bits |   |      |
| M_TS15 | EQU  | 15       |      | ; | ESAI |
| M_TS14 | EQU  | 14       |      | ; | ESAI |
| M_TS13 | EQU  | 13       |      | ; | ESAI |
| M_TS12 | EQU  | 12       |      | ; | ESAI |
| M_TS11 | EQU  | 11       |      | ; | ESAI |
| M_TS10 | EQU  | 10       |      | ; | ESAI |
| M_TS9  | EQU  | 9        |      | ; | ESAI |

| M_TS8   | EQU      | 8          | ; ESAI     |
|---------|----------|------------|------------|
| M_TS7   | EQU      | 7          | ; ESAI     |
| M_TS6   | EQU      | 6          | ; ESAI     |
| M_TS5   | EQU      | 5          | ; ESAI     |
| M_TS4   | EQU      | 4          | ; ESAI     |
| M_TS3   | EQU      | 3          | ; ESAI     |
| M_TS2   | EQU      | 2          | ; ESAI     |
| M_TS1   | EQU      | 1          | ; ESAI     |
| M_TSO   | EQU      | 0          | ; ESAI     |
| ;       | RCCR Reg | ister bits |            |
| M_RHCKD | EQU      | 23         | ; ESAI     |
| M_RFSD  | EQU      | 22         | ; ESAI     |
| M_RCKD  | EQU      | 21         | ; ESAI     |
| M_RHCKP | EQU      | 20         | ;ESAI      |
| M_RFSP  | EQU      | 19         | ; ESAI     |
| M_RCKP  | EQU      | 18         | ;ESAI      |
| M_RFP   | EQU      | \$3C000    | ;ESAI MASK |
| M_RFP3  | EQU      | 17         | ; ESAI     |
| M_RFP2  | EQU      | 16         | ; ESAI     |
| M_RFP1  | EQU      | 15         | ; ESAI     |
| M_RFP0  | EQU      | 14         | ; ESAI     |
| M_RDC   | EQU      | \$3E00     | ;ESAI MASK |
| M_RDC4  | EQU      | 13         | ; ESAI     |
| M_RDC3  | EQU      | 12         | ; ESAI     |
| M_RDC2  | EQU      | 11         | ; ESAI     |
| M_RDC1  | EQU      | 10         | ; ESAI     |
| M_RDC0  | EQU      | 9          | ; ESAI     |
|         |          |            |            |

| M_RPSR  | EQU      | 8         | ; ESAI     |
|---------|----------|-----------|------------|
| M_RPM   | EQU      | \$FF      |            |
| M_RPM7  | EQU      | 7         | ; ESAI     |
| M_RPM6  | EQU      | 6         | ; ESAI     |
| M_RPM5  | EQU      | 5         | ; ESAI     |
| M_RPM4  | EQU      | 4         | ; ESAI     |
| M_RPM3  | EQU      | 3         | ; ESAI     |
| M_RPM2  | EQU      | 2         | ; ESAI     |
| M_RPM1  | EQU      | 1         | ; ESAI     |
| M_RPMO  | EQU      | 0         | ; ESAI     |
| ;       | RCR Regi | ster bits |            |
| M_RLIE  | EQU      | 23        | ; ESAI     |
| M_RIE   | EQU      | 22        | ; ESAI     |
| M_REDIE | EQU      | 21        | ; ESAI     |
| M_REIE  | EQU      | 20        | ; ESAI     |
| M_RPR   | EQU      | 19 ;      | ESAI       |
| M_RFSR  | EQU      | 16        | ; ESAI     |
| M_RFSL  | EQU      | 15        | ; ESAI     |
| M_RSWS  | EQU      | \$7C00    | ;ESAI MASK |
| M_RSWS4 | EQU      | 14        | ; ESAI     |
| M_RSWS3 | EQU      | 13        | ; ESAI     |
| M_RSWS2 | EQU      | 12        | ; ESAI     |
| M_RSWS1 | EQU      | 11        | ; ESAI     |
| M_RSWS0 | EQU      | 10        | ; ESAI     |
| M_RMOD  | EQU      | \$300     |            |
| M_RMOD1 | EQU      | 9         | ; ESAI     |

| M_RMOD0 | EQU  | 8             | ; ESAI |
|---------|------|---------------|--------|
| M_RWA   | EQU  | 7             | ; ESAI |
| M_RSHFD | EQU  | 6             | ; ESAI |
| M_RE    | EQU  | \$F           |        |
| M_RE3   | EQU  | 3             | ; ESAI |
| M_RE2   | EQU  | 2             | ; ESAI |
| M_RE1   | EQU  | 1             | ; ESAI |
| M_REO   | EQU  | 0             | ; ESAI |
| ;       | TCCR | Register bits |        |
| M_THCKD | EQU  | 23            | ; ESAI |
| M_TFSD  | EQU  | 22            | ; ESAI |
| M_TCKD  | EQU  | 21            | ; ESAI |
| M_THCKP | EQU  | 20            | ;ESAI  |
| M_TFSP  | EQU  | 19            | ; ESAI |
| M_TCKP  | EQU  | 18            | ; ESAI |
| M_TFP   | EQU  | \$3C000       |        |
| M_TFP3  | EQU  | 17            | ; ESAI |
| M_TFP2  | EQU  | 16            | ; ESAI |
| M_TFP1  | EQU  | 15            | ; ESAI |
| M_TFP0  | EQU  | 14            | ; ESAI |
| M_TDC   | EQU  | \$3E00        | ;      |
| M_TDC4  | EQU  | 13            | ; ESAI |
| M_TDC3  | EQU  | 12            | ; ESAI |
| M_TDC2  | EQU  | 11            | ; ESAI |
| M_TDC1  | EQU  | 10            | ; ESAI |
| M_TDC0  | EQU  | 9             | ; ESAI |
| M_TPSR  | EQU  | 8             | ; ESAI |

| M_TPM                           | EQU                     | \$FF                                 | ;                           |
|---------------------------------|-------------------------|--------------------------------------|-----------------------------|
| M_TPM7                          | EQU                     | 7                                    | ; ESAI                      |
| M_TPM6                          | EQU                     | 6                                    | ; ESAI                      |
| M_TPM5                          | EQU                     | 5                                    | ; ESAI                      |
| M_TPM4                          | EQU                     | 4                                    | ; ESAI                      |
| M_TPM3                          | EQU                     | 3                                    | ; ESAI                      |
| M_TPM2                          | EQU                     | 2                                    | ; ESAI                      |
| M_TPM1                          | EQU                     | 1                                    | ; ESAI                      |
| M_TPM0                          | EQU                     | 0                                    | ; ESAI                      |
| ;                               | TCR Regi                | ster bits                            |                             |
| M_TLIE                          | EQU                     | 23                                   | ; ESAI                      |
| M_TIE                           | EQU                     | 22                                   | ; ESAI                      |
| M_TEDIE                         | EQU                     | 21                                   | ; ESAI                      |
| M_TEIE                          | EQU                     | 20                                   | ; ESAI                      |
| M_TPR                           | EQU                     | 19                                   | ; ESAI                      |
| M_PADC                          | EQU                     | 17                                   | ; ESAI                      |
| M_TFSR                          | EOU                     |                                      |                             |
|                                 | -2-                     | 16                                   | ; ESAI                      |
| M_TFSL                          | EQU                     |                                      | ; ESAI<br>; ESAI            |
| M_TFSL M_TSWS                   | EQU                     | 15                                   |                             |
|                                 | EQU<br>EQU              | 15                                   |                             |
| M_TSWS                          | EQU<br>EQU              | 15<br>\$7C00                         | ; ESAI                      |
| M_TSWS                          | EQU<br>EQU<br>EQU       | 15<br>\$7C00<br>14                   | ; ESAI                      |
| M_TSWS4 M_TSWS3                 | EQU<br>EQU<br>EQU       | 15<br>\$7C00<br>14<br>13             | ; ESAI<br>; ESAI<br>; ESAI  |
| M_TSWS4 M_TSWS3 M_TSWS2 M_TSWS1 | EQU EQU EQU EQU         | 15<br>\$7C00<br>14<br>13<br>12       | ; ESAI ; ESAI ; ESAI        |
| M_TSWS4 M_TSWS3 M_TSWS2 M_TSWS1 | EQU EQU EQU EQU EQU EQU | 15<br>\$7C00<br>14<br>13<br>12<br>11 | ; ESAI ; ESAI ; ESAI ; ESAI |

| M_TMOD0 | EQU   | 8       |            | ;    | ESAI |
|---------|-------|---------|------------|------|------|
| M_TWA   | EQU   | 7       |            | ;    | ESAI |
| M_TSHFD | EQU   | 6       |            | ;    | ESAI |
| M_TEM   | E     | QU      | \$3F       |      |      |
| M_TE5   | EQU   | 5       |            | ;    | ESAI |
| M_TE4   | EQU   | 4       |            | ;    | ESAI |
| M_TE3   | EQU   | 3       |            | ;    | ESAI |
| M_TE2   | EQU   | 2       |            | ;    | ESAI |
| M_TE1   | EQU   | 1       |            | ;    | ESAI |
| M_TEO   | EQU   | 0       |            | ;    | ESAI |
| ;       | contr | ol bits | s of SAICR |      |      |
| M_ALC   | EQU   | 8       |            | ;ESA | I    |
| M_TEBE  | EQU   | 7       |            | ;    | ESAI |
| M_SYN   | EQU   | 6       |            | ;    | ESAI |
| M_OF2   | EQU   | 2       |            | ;    | ESAI |
| M_OF1   | EQU   | 1       |            | ;    | ESAI |
| M_OF0   | EQU   | 0       |            | ;    | ESAI |
| ;       | statu | s bits  | of SAISR   |      |      |
| M_TODE  | EQU   | 17      |            | ;    | ESAI |
| M_TEDE  | EQU   | 16      |            | ;    | ESAI |
| M_TDE   | EQU   | 15      |            | ;    | ESAI |
| M_TUE   | EQU   | 14      |            | ;    | ESAI |
| M_TFS   | EQU   | 13      |            | ;    | ESAI |
| M_RODF  | EQU   | 10      |            | ;    | ESAI |
| M_REDF  | EQU   | 9       |            | ;    | ESAI |
| M_RDF   | EQU   | 8       |            | ;    | ESAI |
| M_ROE   | EQU   | 7       |            | ;    | ESAI |

```
M_RFS EQU 6
                         ; ESAI
M_IF2 EQU
                          ; ESAI
M_IF1 EQU 1
                          ; ESAI
M_IFO EQU 0
                          ; ESAI
;
; EQUATES for HDI08
; Register Addresses
M_HOTX EQU
                          ; HOST Transmit Register (HOTX)
             $FFFFC7
M_HORX EQU
             $FFFFC6
                          ; HOST Receive Register (HORX)
M_HBAR EQU $FFFFC5 ; HOST Base Address Register (HBAR)
M_HPCR EQU $FFFFC4
                          ; HOST Port Control Register (HPCR)
M_HSR EQU $FFFFC3 ; HOST Status Register (HSR)
M_HCR EQU
             $FFFFC2
                         ; HOST Control Register (HCR)
; HCR bits
M_HRIE EQU $0
                         ; HOST Receive interrupts Enable
M_HOTIE EQU $1
                          ; HOST Transmit Interrupt Enable
M HCIE EQU $2
                          ; HOST Command Interrupt Enable
M_HF2
       EQU $3
                          ; HOST Flag 2
M_HF3 EQU
                          ; HOST Flag 3
            $4
M_HODMO EQU
             $5
                          ; HOST DMA Mode Control Bit 0
M HODM1 EQU
             $6
                          ; HOST DMA Mode Control Bit 1
            $7
M_HODM2 EQU
                          ; HOST DMA Mode Control Bit 2
```

```
HSR bits
M_HRDF
         EQU
                 $0
                                 ; HOST Receive Data Full
M_HOTDE
          EQU
                  $1
                                  ; HOST Receive Data Emptiy
M_HCP
         EQU
                 $2
                                  ; HOST Command Pending
                 $3
                                  ; HOST Flag 0
M_{HF0}
         EQU
                                  ; HOST Flag 1
M_HF1
         EQU
                 $4
M DMA
                                  ; HOST DMA Status
         EQU
                 $7
        HPCR bits
M_HGEN
         EQU
                 $0
                                  ; HOST Port Enable
M HA8EN
        EQU
                 $1
                                  ; HOST Address 8 Enable
M_HA9EN
                                  ; HOST Address 9 Enable
         EQU
                 $2
M_HCSEN
        EQU
                 $3
                                  ; HOST Chip Select Enable
M_HREN
                                  ; HOST Request Enable
         EQU
                 $4
M_HAEN
         EQU
                 $5
                                  ; HOST Acknowledge Enable
M_HOEN
          EQU
                  $6
                                   ; HOST Enable
M_HROD
          EQU
                  $8
                                   ; HOST Request Open Dranin mode
M_HDSP
         EQU
                                  ; HOST Data Strobe Polarity
                 $9
                                  ; HOST Address Strobe Polarity
M_HASP
         EQU
                                  ; HOST Multiplexed bus select
M_HMUX
         EQU
                 $b
                                 ; HOST Double/Single Strobe select
M_HDDS
        EQU
                $c
M_HCSP
         EQU
                 $d
                                  ; HOST Chip Select Polarity
M_HRP
                                  ; HOST Request Polarity
         EQU
                 $e
M_HAP
         EQU
                 $f
                                  ; HOST Acknowledge Polarity
                   HBAR BITS
M BA
       EQU
             $FF
```

```
M_BA10 EQU 7
M BA9 EQU 6
M BA8 EQU 5
M_BA7 EQU 4
M_BA6 EQU 3
M_BA5 EQU 2
M_BA4 EQU 1
M_BA3 EQU 0
; EQUATES for TIMER
   Register Addresses Of TIMERO
M_TCSR0 EQU $FFFF8F ; TIMER0 Control/Status Register
M_TLRO EQU $FFFF8E ; TIMERO Load Reg
M_TCPR0 EQU $FFFF8D
                        ; TIMERO Compare Register
M_TCRO EQU $FFFF8C ; TIMERO Count Register
; Register Addresses Of TIMER1
M_TCSR1 EQU $FFFF8B ; TIMER1 Control/Status Register
M_TLR1 EQU $FFFF8A ; TIMER1 Load Reg
M_TCPR1 EQU $FFFF89 ; TIMER1 Compare Register
M_TCR1 EQU $FFFF88 ; TIMER1 Count Register
Register Addresses Of TIMER2
M_TCSR2 EQU $FFFF87 ; TIMER2 Control/Status Register
M_TLR2 EQU $FFFF86 ; TIMER2 Load Reg
```

```
M_TCPR2 EQU
              $FFFF85
                             ; TIMER2 Compare Register
M_TCR2
        EQU
               $FFFF84
                          ; TIMER2 Count Register
M_TPLR
               $FFFF83
                         ; TIMER Prescaler Load Register
        EQU
M_TPCR
       EQU
                $FFFF82 ; TIMER Prescalar Count Register
       Timer Control/Status Register Bit Flags
M_TE
        EQU
                              ; Timer Enable
                              ; Timer Overflow Interrupt Enable
M_TOIE
        EQU
M TCIE
                              ; Timer Compare Interrupt Enable
        EQU
M_TC
        EQU
               $F0
                             ; Timer Control Mask (TC0-TC3)
M_INV
        EQU
                              ; Inverter Bit
M\_TRM
        EQU
                              ; Timer Restart Mode
M DIR
        EOU
              11
                              ; Direction Bit
                              ; Data Input
M_DI
        EQU
               12
M_DO
        EQU
              13
                              ; Data Output
M_PCE
                   ; Prescaled Clock Enable
        EQU
              15
M_TOF
        EQU
               20
                               ; Timer Overflow Flag
M_TCF
        EQU
                21
                              ; Timer Compare Flag
       Timer Prescaler Register Bit Flags
M_PS
       EQU $600000 ; Prescaler Source Mask
M_PS0
       EQU 21
M_PS1
       EQU 22
; Timer Control Bits
M TC0
        EQU
                             ; Timer Control 0
M_TC1
        EQU
                              ; Timer Control 1
M_TC2
        EQU
                              ; Timer Control 2
M TC3 EQU
                              ; Timer Control 3
;----- end of ioequ.asm ------
```

# APPENDIX C JTAG BSDL

```
-- MOTOROLA SSDT JTAG SOFTWARE
-- BSDL File Generated: Wed May 20 10:08:50 1998
-- Revision History:
entity DSP56362 is
      generic (PHYSICAL_PIN_MAP : string := "TQFP144");
      port (TRST_N: in
                          bit;
                   out
                          bit;
             TDO:
             TDI:
                    in
                           bit;
             TMS:
                   in
                           bit;
             TCK:
                  in
                          bit;
             SCK:
                  inout bit;
            SDO0:
                  inout bit;
                   inout bit;
            SDO1:
                   inout bit;
           SDOI23:
            DE_N: inout bit;
           PINIT: in
                         bit;
           SDOI32: inout bit;
            SVCC: linkage bit_vector(0 to 1);
            SGND:
                   linkage bit_vector(0 to 1);
           SDOI41:
                  inout bit;
           SDOI50: inout bit;
             FST:
                  inout bit;
                  inout bit;
             FSR:
                   inout bit;
            SCKT:
            SCKR:
                   inout bit;
           HSCKT:
                  inout bit;
           HSCKR: inout bit;
            OVCC:
                  linkage bit_vector(0 to 3);
                  linkage bit_vector(0 to 3);
            QGND:
            QVCCH:
                    linkage bit_vector(0 to 2);
              HP:
                   inout bit_vector(0 to 15);
             ADO: inout bit;
             ACI:
                  inout bit;
             TIO:
                   inout bit;
            HVCC:
                    linkage bit;
            HGND:
                   linkage bit;
            SS_N:
                  in bit;
           HREQ_N:
                  inout bit;
          RESET_N:
                   in
                         bit;
```

```
PVCC:
               linkage bit;
       PCAP:
               linkage bit;
       PGND:
                linkage bit;
     PGND1:
               linkage bit;
        AA:
               out
                       bit_vector(0 to 3);
     CAS N:
               out
                        bit;
                        bit;
     EXTAL:
                in
                linkage bit_vector(0 to 1);
       CVCC:
       CGND:
               linkage bit_vector(0 to 1);
     CLKOUT:
               buffer bit;
       TA_N:
               in
                        bit;
       BR N:
               buffer bit;
      BB_N:
               inout
                       bit;
       WR_N:
               out
                        bit;
      RD N:
               out
                       bit;
       BG_N:
               in
                       bit;
         A:
                       bit_vector(0 to 17);
       AVCC:
               linkage bit_vector(0 to 2);
       AGND:
                linkage bit_vector(0 to 3);
                inout bit_vector(0 to 23);
       DVCC:
                linkage bit_vector(0 to 3);
      DGND:
               linkage bit_vector(0 to 3);
      MODD:
                       bit;
                in
      MODC:
               in
                       bit;
      MODB:
                in
                        bit;
      MODA:
               in
                       bit;
      MOSI:
               inout bit;
        SDA:
                inout
                      bit;
        R0:
               linkage bit);
use STD_1149_1_1994.all;
attribute COMPONENT_CONFORMANCE of DSP56362 : entity is "STD_1149_1_1993";
attribute PIN_MAP of DSP56362 : entity is PHYSICAL_PIN_MAP;
constant TQFP144 : PIN_MAP_STRING :=
        "SCK:
                  1, " &
                    2, " &
        "SS_N:
                    3, " &
        "HREQ_N:
                    4, "&
        "SD00:
                    5, " &
        "SD01:
        "SDOI23:
                    6, " &
                   7, "&
        "SDOI32:
        "SVCC:
                   (8, 25), " &
        "SGND:
                   (9, 26), " &
                   10, " &
        "SDOI41:
        "SDOI50:
                    11, " &
        "FST:
                    12, " &
                    13, " &
        "FSR:
                    14, " &
        "SCKT:
                    15, " &
        "SCKR:
                    16, " &
        "HSCKT:
```

```
"HSCKR:
                             17, " &
                            (18, 56, 91, 126), " &
                 "QVCC:
                 "QGND:
                            (19, 54, 90, 127), " &
                            (20, 49, 95), " &
                "QVCCH:
                "HP:
                           (43, 42, 41, 40, 37, 36, 35, 34, 33, 32, 31, 22, 21, 30, 24,
23), " &
                 "ADO:
                             27, " &
                 "ACI:
                             28, " &
                 "TIO:
                             29, " &
                "HVCC:
                             38, " &
                             39, " &
                "HGND:
                             44, " &
                "RESET N:
                             45, " &
                "PVCC:
                             46, " &
                 "PCAP:
                             47, " &
                "PGND:
                             48, " &
                "PGND1:
                "AA:
                            (70, 69, 51, 50), " &
                "CAS N:
                             52, " &
                             53, " &
                "DE_N:
                 "EXTAL:
                             55, " &
                "CVCC:
                            (57, 65), " &
                "CGND:
                            (58, 66), " &
                "CLKOUT:
                             59, " &
                             60, " &
                "R0:
                             61, " &
                 "PINIT:
                             62, " &
                 "TA N:
                             63, " &
                "BR_N:
                             64, " &
                "BB_N:
                             67, " &
                "WR_N:
                             68, " &
                "RD_N:
                "BG_N:
                             71, " &
                "A:
                           (72, 73, 76, 77, 78, 79, 82, 83, 84, 85, 88, 89, 92, 93, 94,
97, 98, 99), " &
                            (74, 80, 86), " &
                 "AVCC:
                            (75, 81, 87, 96), " &
                "AGND:
                "D:
                           (100, 101, 102, 105, 106, 107, 108, 109, 110, 113, 114, 115,
116, 117, 118, 121,
                         "122, 123, 124, 125, 128, 131, 132, 133), " &
                "DVCC:
                           (103, 111, 119, 129), " &
                            (104, 112, 120, 130), " &
                 "DGND:
                 "MODD:
                             134, " &
                             135, " &
                 "MODC:
                "MODB:
                             136, " &
                "MODA:
                             137, " &
                "TRST_N:
                             138, " &
                "TDO:
                             139, " &
                             140, " &
                 "TDI:
                 "TCK:
                             141, " &
                "TMS:
                             142, " &
                 "MOSI:
                             143, " &
                "SDA:
                             144 ";
        attribute TAP SCAN IN of
                                         TDI : signal is true;
```

```
attribute TAP SCAN OUT of
                            TDO: signal is true;
attribute TAP_SCAN_MODE of
                            TMS: signal is true;
attribute TAP_SCAN_RESET of TRST_N : signal is true;
attribute TAP SCAN CLOCK of
                              TCK : signal is (20.0e6, BOTH);
attribute INSTRUCTION LENGTH of DSP56362 : entity is 4;
attribute INSTRUCTION_OPCODE of DSP56362 : entity is
                      (0000)," &
   "SAMPLE
                      (0001)," &
   "IDCODE
                      (0010)," &
   "CLAMP
                      (0101)," &
   "HIGHZ
                      (0100)," &
   "ENABLE ONCE
                      (0110)," &
   "DEBUG REOUEST
                      (0111)," &
   "BYPASS
                      (1111)";
attribute INSTRUCTION CAPTURE of DSP56362 : entity is "0001";
attribute IDCODE_REGISTER of DSP56362 : entity is
   "0000"
                 & -- version
   "000110"
                 & -- manufacturer's use
   "0001100010"
                & -- sequence number
   "0000001110" & -- manufacturer identity
   "1";
                   -- 1149.1 requirement
attribute REGISTER_ACCESS of DSP56362 : entity is
   "ONCE[8] (ENABLE_ONCE, DEBUG_REQUEST)";
attribute BOUNDARY_LENGTH of DSP56362 : entity is 145;
attribute BOUNDARY_REGISTER of DSP56362 : entity is
-- ทเm
         cell port func
                                   safe [ccell dis rslt]
   " ()
                                    X),"&
         (BC_1, MODA,
                      input,
                                      X),"&
   "1
         (BC 1, MODB,
                         input,
   "2
         (BC_1, MODC,
                       input,
                                      X),"&
   "3
         (BC_1, MODD,
                                       X),"&
                         input,
   " 4
                                      1,
         (BC_6, D(23), bidir,
                                              13,
                                                  1,
                                                       Z)," &
   "5
                                                   1,
         (BC_6, D(22), bidir,
                                      Χ,
                                              13,
                                                        Z)," &
                                      Χ,
   "б
         (BC_6, D(21),
                       bidir,
                                            13,
                                                  1,
                                                        Z)," &
                                                   1,
   "7
                                                        Z)," &
         (BC_6, D(20),
                        bidir,
                                      Х,
                                            13,
                                                        Z),"&
   "8
                                            13,
                                                   1,
         (BC_6, D(19),
                        bidir,
                                      Х,
   "9
         (BC_6, D(18),
                         bidir,
                                       Х,
                                              13,
                                                    1,
                                                        Z)," &
   "10
                       bidir,
                                      Х,
                                              13,
         (BC_6, D(17),
                                                    1,
                                                        Z)," &
   "11
         (BC_6, D(16), bidir,
                                      Χ,
                                              13,
                                                  1,
                                                        Z)," &
   "12
         (BC_6, D(15), bidir,
                                      Χ,
                                             13,
                                                   1,
                                                        Z)," &
   "13
                                      1)," &
         (BC_1, *,
                         control,
   "14
         (BC_6, D(14),
                         bidir,
                                      Х,
                                              13,
                                                    1,
                                                        Z)," &
   "15
         (BC_6, D(13),
                        bidir,
                                       Χ,
                                              13,
                                                    1,
                                                        Z)," &
                                              13,
   "16
         (BC_6, D(12),
                       bidir,
                                      Х,
                                                   1,
                                                        Z)," &
                                                        Z),"&
   "17
         (BC_6, D(11),
                         bidir,
                                      Χ,
                                              26,
                                                  1,
                                                        Z),"&
   "18
         (BC_6, D(10),
                         bidir,
                                      Χ.
                                              26,
                                                   1.
   "19
                                      Х,
                                                        Z),"&
         (BC_6, D(9),
                         bidir,
                                              26,
                                                    1,
         cell port func
-- num
                                  safe [ccell dis rslt]
```

```
"20
           (BC_6, D(8),
                              bidir,
                                                       26,
                                                              1,
                                                                    Z),"&
                                               Χ,
   "21
                                                                    Z),"&
           (BC_6, D(7),
                              bidir,
                                               Х,
                                                       26,
                                                              1,
   "22
           (BC_6, D(6),
                              bidir,
                                               Х,
                                                       26,
                                                              1,
                                                                    Z),"&
   "23
           (BC_6, D(5),
                              bidir,
                                               Χ,
                                                       26,
                                                              1,
                                                                    Z)," &
   "24
                                                       26,
           (BC_6, D(4),
                              bidir,
                                               Х,
                                                              1,
                                                                    Z)," &
   "25
           (BC_6, D(3),
                              bidir,
                                                       26,
                                                              1.
                                                                    Z)," &
                                               Х,
                                               1)," &
   "26
           (BC_1, *,
                              control,
   "27
           (BC_6, D(2),
                              bidir,
                                                       26,
                                                                    Z)," &
                                               Х,
                                                              1,
   "28
           (BC_6, D(1),
                              bidir,
                                                       26,
                                                              1,
                                                                    Z)," &
                                               Х,
   "29
                              bidir,
                                                       26,
                                                              1,
                                                                    Z)," &
           (BC_6, D(0),
                                               Χ,
   "30
           (BC_1, A(17),
                              output3,
                                               Х,
                                                       33,
                                                              1,
                                                                    Z)," &
   "31
                                                                    Z)," &
           (BC_1, A(16),
                              output3,
                                               Х,
                                                       33,
                                                              1,
   "32
                                                                    Z)," &
           (BC_1, A(15),
                                                       33,
                              output3,
                                               Х,
                                                              1,
                                               1)," &
   "33
           (BC_1, *,
                              control,
   "34
           (BC_1, A(14),
                              output3,
                                               Χ.
                                                       33,
                                                              1.
                                                                    Z)," &
   "35
           (BC_1, A(13),
                              output3,
                                               Χ,
                                                       33,
                                                              1,
                                                                    Z)," &
   "36
           (BC_1, A(12),
                              output3,
                                               Х,
                                                       33,
                                                              1,
                                                                    Z)," &
   "37
           (BC_1, A(11),
                              output3,
                                               Χ,
                                                       33,
                                                              1,
                                                                    Z),"&
   "38
           (BC_1, A(10),
                                               Х,
                                                       33,
                                                                    Z)," &
                              output3,
                                                              1,
   "39
           (BC_1, A(9),
                              output3,
                                               Х,
                                                       33,
                                                              1,
                                                                    Z)," &
                  port
                                            safe [ccell
                                                          dis rslt]
-- num
           cell
                           func
                                                                    Z)," &
   "40
                                               Х,
                                                       43,
           (BC_1, A(8),
                              output3,
                                                              1,
   "41
           (BC 1, A(7),
                                                                    Z)," &
                              output3,
                                               Χ,
                                                       43,
                                                              1,
   "42
           (BC_1, A(6),
                                                              1,
                                                                    Z),"&
                              output3,
                                                       43,
                                               Χ,
   "43
                                               1)," &
           (BC_1, *,
                              control,
   "44
           (BC_1, A(5),
                              output3,
                                               Χ,
                                                       43,
                                                              1,
                                                                    Z)," &
   "45
                                                       43,
                                                                    Z),"&
           (BC_1, A(4),
                              output3,
                                               Х,
                                                              1,
   "46
           (BC_1, A(3),
                              output3,
                                               Х,
                                                       43,
                                                              1,
                                                                    Z)," &
                                                                    Z),"&
   "47
           (BC_1, A(2),
                              output3,
                                               Χ,
                                                       43,
                                                              1,
                                                                    Z),"&
   "48
           (BC_1, A(1),
                              output3,
                                               Х,
                                                       43,
                                                              1,
   "49
           (BC_1, A(0),
                              output3,
                                               Х,
                                                       43,
                                                              1,
                                                                    Z)," &
                                               X),"&
   "50
           (BC_1, BG_N,
                              input,
   "51
                                               1)," &
           (BC_1, *,
                              control,
   "52
           (BC_1, AA(0),
                              output3,
                                               Χ,
                                                       51,
                                                              1,
                                                                    Z)," &
                                               1)," &
   "53
           (BC_1, *,
                              control,
   "54
           (BC_1, AA(1),
                                                       53,
                                                                    Z)," &
                              output3,
                                               Х,
                                                              1,
   "55
           (BC_1, RD_N,
                              output3,
                                               Χ,
                                                       63,
                                                              1,
                                                                    Z)," &
   "56
           (BC_1, WR_N,
                              output3,
                                                       63,
                                                              1,
                                                                    Z)," &
                                               Х,
                                               1)," &
   "57
           (BC_1, *,
                              control,
   "58
           (BC_6, BB_N,
                              bidir,
                                                       57,
                                                                    Z)," &
                                               Х,
                                                              1,
                                               X),"&
   "59
           (BC_1, BR_N,
                              output2,
-- num
           cell
                  port
                                            safe [ccell dis rslt]
   "60
                                               X)," &
           (BC_1, TA_N,
                              input,
   "61
           (BC_1, PINIT,
                              input,
                                               X)," &
   "62
           (BC_1, CLKOUT,
                              output2,
                                               X),"&
   "63
           (BC_1, *,
                                               1)," &
                              control,
           (BC_1, EXTAL,
                                               X),"&
   "64
                              input,
   "65
           (BC_1, *,
                              control,
                                               1)," &
   "66
                              bidir,
                                                       65,
           (BC_6, DE_N,
                                               Х,
                                                                    Pull1)," &
                                                              1,
                                               1)," &
   "67
           (BC 1, *,
                              control,
   "68
           (BC 1, CAS N,
                              output3,
                                               Χ.
                                                       67.
                                                              1.
                                                                    Z)," &
                                               1)," &
   "69
           (BC_1, *,
                              control,
   "70
           (BC 1, AA(2),
                              output3,
                                               Х,
                                                       69,
                                                                    Z)," &
```

```
"71
           (BC_1, *,
                             control,
                                              1)," &
   "72
           (BC_1, AA(3),
                             output3,
                                             Χ,
                                                     71,
                                                            1,
                                                                 Z)," &
                                             X),"&
   "73
           (BC_1, RESET_N,
                             input,
   "74
           (BC_1, *,
                             control,
                                              1)," &
   "75
           (BC_6, HP(0),
                             bidir,
                                             Х,
                                                     74,
                                                                 Z)," &
                                                            1,
   "76
           (BC 1, *,
                             control,
                                              1)," &
                                                     76,
   "77
           (BC_6, HP(1),
                             bidir,
                                             Х,
                                                            1,
                                                                 Z)," &
   "78
                                              1)," &
           (BC_1, *,
                             control,
   "79
           (BC_6, HP(2),
                             bidir,
                                                     78,
                                             Χ,
                                                            1,
                                                                 Z)," &
                port
                          func
                                          safe [ccell dis rslt]
-- num
          cell
   "80
           (BC_1, *,
                             control,
                                             1)," &
                                                                 Z),"&
   "81
           (BC_6, HP(3),
                             bidir,
                                              Χ,
                                                     80,
                                              1)," &
   "82
           (BC_1, *,
                             control,
   "83
           (BC_6, HP(4),
                             bidir,
                                              Χ,
                                                     82,
                                                                 Z)," &
   "84
                                              1)," &
           (BC_1, *,
                             control,
   "85
                                                                 Z),"&
           (BC_6, HP(5),
                             bidir,
                                             Χ,
                                                     84,
                                                            1,
   "86
           (BC_1, *,
                             control,
                                              1)," &
   "87
           (BC_6, HP(6),
                             bidir,
                                             Χ,
                                                     86,
                                                            1,
                                                                 Z),"&
   "88
           (BC_1, *,
                                              1)," &
                             control,
   "89
           (BC_6, HP(7),
                             bidir,
                                             Х,
                                                     88,
                                                                 Z)," &
                                                            1,
   "90
                             control,
                                             1)," &
           (BC_1, *,
   "91
                                                     90,
                             bidir,
                                             Χ,
                                                                 Z)," &
           (BC_6, HP(8),
                                                            1,
   "92
                             control,
                                              1)," &
           (BC_1, *,
   "93
                                                                 Z),"&
           (BC_6, HP(9),
                             bidir,
                                                     92,
                                             Χ.
                                                            1,
   "94
                                              1)," &
           (BC_1, *,
                             control,
   "95
           (BC_6, HP(10),
                             bidir,
                                             Χ,
                                                     94,
                                                            1,
                                                                 Z)," &
                                             1),"&
   "96
           (BC_1, *,
                             control,
   "97
           (BC_6, HP(13),
                             bidir,
                                              Х,
                                                     96,
                                                                 Z)," &
                                                            1,
                                             1)," &
   "98
           (BC_1, *,
                             control,
   "99
           (BC_6, TIO,
                                                                 Z),"&
                             bidir,
                                             Χ,
                                                     98,
                                                            1,
-- num
          cell
                  port
                          func
                                          safe [ccell dis rslt]
           (BC_1, *,
                                             1)," &
   "100
                             control,
   "101
                             bidir,
           (BC_6, ACI,
                                             Χ,
                                                    100,
                                                            1,
                                                                 Z)," &
   "102
                                             1)," &
           (BC_1, *,
                             control,
   "103
           (BC_6, ADO,
                             bidir,
                                             Χ,
                                                    102,
                                                            1,
                                                                 Z)," &
   "104
           (BC_1, *,
                                              1)," &
                             control,
   "105
           (BC_6, HP(14),
                             bidir,
                                             Χ,
                                                    104,
                                                                 Z)," &
                                                            1,
                                             1)," &
   "106
           (BC_1, *,
                             control,
   "107
           (BC_6, HP(15),
                             bidir,
                                             Χ,
                                                    106,
                                                                 Z)," &
                                             1)," &
   "108
           (BC_1, *,
                             control,
   "109
           (BC_6, HP(11),
                                                                 Z)," &
                             bidir,
                                             Х,
                                                    108,
                                                            1,
   "110
           (BC 1, *,
                             control,
                                              1)," &
   "111
                             bidir,
           (BC_6, HP(12),
                                             Χ,
                                                    110,
                                                            1,
                                                                 Z)," &
                                             1)," &
   "112
           (BC_1, *,
                             control,
           (BC_6, HSCKR,
   "113
                             bidir,
                                             Χ,
                                                    112,
                                                                 Z)," &
   "114
                                              1)," &
           (BC_1, *,
                             control,
   "115
           (BC_6, HSCKT,
                             bidir,
                                             Х,
                                                    114,
                                                            1,
                                                                 Z)," &
   "116
           (BC_1, *,
                             control,
                                              1)," &
   "117
                             bidir,
                                                                 Z)," &
           (BC_6, SCKR,
                                             Х,
                                                    116,
                                                            1,
                                              1)," &
   "118
           (BC 1, *,
                             control,
   "119
           (BC 6, SCKT,
                             bidir.
                                             Χ,
                                                    118,
                                                            1,
                                                                 Z)," &
-- num
          cell
                                          safe [ccell dis rslt]
                  port
                          func
   "120
           (BC 1, *,
                             control,
                                              1)," &
```

```
"121
         (BC_6, FSR,
                         bidir,
                                      X, 120, 1, Z), " &
                                       1),"&
  "122
         (BC_1, *,
                         control,
  "123
         (BC_6, FST,
                         bidir,
                                       Х,
                                            122,
                                                    1,
                                                        Z)," &
  "124
         (BC_1, *,
                         control,
                                       1)," &
  "125
         (BC_6, SDOI50,
                         bidir,
                                       X, 124,
                                                        Z)," &
                                                    1,
                                      1)," &
  "126
         (BC_1, *,
                         control,
  "127
         (BC_6, SDOI41,
                         bidir,
                                       Х,
                                                    1,
                                                        Z)," &
                                            126,
                                       1)," &
  "128
         (BC_1, *,
                         control,
  "129
         (BC_6, SDOI32,
                         bidir,
                                       X, 128,
                                                    1,
                                                        Z)," &
  "130
                                       1),"&
         (BC_1, *,
                         control,
                                             130,
  "131
         (BC_6, SDOI23,
                         bidir,
                                       Х,
                                                         Z)," &
                                                    1,
  "132
         (BC_1, *,
                         control,
                                       1),"&
         (BC_6, SDO1,
  "133
                                       Х,
                         bidir,
                                            132,
                                                    1,
                                                        Z)," &
                                       1)," &
  "134
         (BC_1, *,
                         control,
  "135
         (BC_6, SDO0,
                         bidir.
                                       x, 134,
                                                   1,
                                                        Z)," &
         (BC_1, *,
                                       1)," &
  "136
                         control,
  "137
         (BC_6, HREQ_N,
                         bidir,
                                       Х,
                                            136,
                                                  1,
                                                        Z)," &
  "138
         (BC_1, SS_N,
                         input,
                                       X),"&
                                       1),"&
  "139
         (BC_1, *,
                         control,
-- num
         cell port
                      func
                                    safe [ccell dis rslt]
  "140
         (BC_6, SCK,
                         bidir,
                                       X, 139, 1,
                                                        Z),"&
  "141
                         control,
                                       1)," &
         (BC_1, *,
  "142
         (BC_6, SDA,
                         bidir,
                                       Χ,
                                            141, 1,
                                                        Z)," &
                                       1),"&
  "143
         (BC_1, *,
                         control,
  "144
         (BC_6, MOSI,
                                       Х,
                         bidir,
                                            143, 1,
                                                         Z)";
```

end DSP56362;

# APPENDIX D PROGRAMMER'S REFERENCE

#### **D.1 INTRODUCTION**

This section has been compiled as a reference for programmers. It contains a table showing the addresses of all the DSPs memory-mapped peripherals, an interrupt address table, an interrupt exception priority table, a quick reference to the host interface, and programming sheets for the major programmable registers on the DSP.

### **D.1.1** Peripheral Addresses

**Table D-1** lists the memory addresses of all on-chip peripherals.

### D.1.2 Interrupt Addresses

**Table D-2** lists the interrupt starting addresses and sources.

### **D.1.3** Interrupt Priorities

**Table D-3** lists the priorities of specific interrupts within interrupt priority levels.

#### D.1.4 Host Interface Quick Reference

**Table D-4** is a quick reference guide to the host interface (HDI08).

#### **D.1.5** Programming Sheets

The remaining figures describe major programmable registers on the DSP56362.

#### D.2 INTERNAL I/O MEMORY MAP

 Table D-1
 Internal I/O Memory Map

| Peripheral | Address    | Register Name                                  |
|------------|------------|------------------------------------------------|
| IPR        | X:\$FFFFF  | INTERRUPT PRIORITY REGISTER CORE (IPR-C)       |
|            | X:\$FFFFE  | INTERRUPT PRIORITY REGISTER PERIPHERAL (IPR-P) |
| PLL        | X:\$FFFFD  | PLL CONTROL REGISTER (PCTL)                    |
| ONCE       | X:\$FFFFC  | ONCE GDB REGISTER (OGDB)                       |
| BIU        | X:\$FFFFB  | BUS CONTROL REGISTER (BCR)                     |
|            | X:\$FFFFA  | DRAM CONTROL REGISTER (DCR)                    |
|            | X:\$FFFF9  | ADDRESS ATTRIBUTE REGISTER 0 (AAR0)            |
|            | X:\$FFFF8  | ADDRESS ATTRIBUTE REGISTER 1 (AAR1)            |
|            | X:\$FFFFF7 | ADDRESS ATTRIBUTE REGISTER 2 (AAR2)            |
|            | X:\$FFFF6  | ADDRESS ATTRIBUTE REGISTER 3 (AAR3)            |
|            | X:\$FFFF5  | ID REGISTER (IDR)                              |
| DMA        | X:\$FFFFF4 | DMA STATUS REGISTER (DSTR)                     |
|            | X:\$FFFFF3 | DMA OFFSET REGISTER 0 (DOR0)                   |
|            | X:\$FFFFF2 | DMA OFFSET REGISTER 1 (DOR1)                   |
|            | X:\$FFFFF1 | DMA OFFSET REGISTER 2 (DOR2)                   |
|            | X:\$FFFFF0 | DMA OFFSET REGISTER 3 (DOR3)                   |
| DMA0       | X:\$FFFFEF | DMA SOURCE ADDRESS REGISTER (DSR0)             |
|            | X:\$FFFFEE | DMA DESTINATION ADDRESS REGISTER (DDR0)        |
|            | X:\$FFFFED | DMA COUNTER (DCO0)                             |
|            | X:\$FFFFEC | DMA CONTROL REGISTER (DCR0)                    |
| DMA1       | X:\$FFFEB  | DMA SOURCE ADDRESS REGISTER (DSR1)             |
|            | X:\$FFFEA  | DMA DESTINATION ADDRESS REGISTER (DDR1)        |
|            | X:\$FFFFE9 | DMA COUNTER (DCO1)                             |
|            | X:\$FFFE8  | DMA CONTROL REGISTER (DCR1)                    |
| DMA2       | X:\$FFFFE7 | DMA SOURCE ADDRESS REGISTER (DSR2)             |
|            | X:\$FFFE6  | DMA DESTINATION ADDRESS REGISTER (DDR2)        |
|            | X:\$FFFE5  | DMA COUNTER (DCO2)                             |
|            | X:\$FFFE4  | DMA CONTROL REGISTER (DCR2)                    |
| DMA3       | X:\$FFFE3  | DMA SOURCE ADDRESS REGISTER (DSR3)             |
|            | X:\$FFFFE2 | DMA DESTINATION ADDRESS REGISTER (DDR3)        |
|            | X:\$FFFE1  | DMA COUNTER (DCO3)                             |
|            | X:\$FFFE0  | DMA CONTROL REGISTER (DCR3)                    |
| DMA4       | X:\$FFFFDF | DMA SOURCE ADDRESS REGISTER (DSR4)             |
|            | X:\$FFFFDE | DMA DESTINATION ADDRESS REGISTER (DDR4)        |
|            | X:\$FFFFDD | DMA COUNTER (DCO4)                             |
|            | X:\$FFFFDC | DMA CONTROL REGISTER (DCR4)                    |
| DMA5       | X:\$FFFFDB | DMA SOURCE ADDRESS REGISTER (DSR5)             |
|            | X:\$FFFFDA | DMA DESTINATION ADDRESS REGISTER (DDR5)        |
|            | X:\$FFFFD9 | DMA COUNTER (DCO5)                             |
|            | X:\$FFFFD8 | DMA CONTROL REGISTER (DCR5)                    |
| PORT D     | X:\$FFFFD7 | PORT D CONTROL REGISTER (PCRD)                 |
|            | X:\$FFFD6  | PORT D DIRECTION REGISTER (PRRD)               |
|            | X:\$FFFFD5 | PORT D DATA REGISTER (PDRD)                    |

Table D-1 Internal I/O Memory Map (Continued)

| Peripheral | Address    | Register Name                            |
|------------|------------|------------------------------------------|
| DAX        | X:\$FFFD4  | DAX STATUS REGISTER (XSTR)               |
|            | X:\$FFFD3  | DAX AUDIO DATA REGISTER B (XADRB)        |
|            | X:\$FFFFD2 | DAX AUDIO DATA REGISTER A (XADRA)        |
|            | X:\$FFFFD1 | DAX NON-AUDIO DATA REGISTER (XNADR)      |
|            | X:\$FFFFD0 | DAX CONTROL REGISTER (XCTR)              |
|            | X:\$FFFFCF | RESERVED                                 |
|            | X:\$FFFCE  | RESERVED                                 |
|            | X:\$FFFCD  | RESERVED                                 |
|            | X:\$FFFCC  | RESERVED                                 |
|            | X:\$FFFCB  | RESERVED                                 |
|            | X:\$FFFCA  | RESERVED                                 |
| PORT B     | X:\$FFFFC9 | HOST PORT GPIO DATA REGISTER (HDR)       |
|            | X:\$FFFC8  | HOST PORT GPIO DIRECTION REGISTER (HDDR) |
| HDI08      | X:\$FFFC7  | HOST TRANSMIT REGISTER (HOTX)            |
|            | X:\$FFFC6  | HOST RECEIVE REGISTER (HORX)             |
|            | X:\$FFFC5  | HOST BASE ADDRESS REGISTER (HBAR)        |
|            | X:\$FFFC4  | HOST PORT CONTROL REGISTER (HPCR)        |
|            | X:\$FFFC3  | HOST STATUS REGISTER (HSR)               |
|            | X:\$FFFC2  | HOST CONTROL REGISTER (HCR)              |
|            | X:\$FFFC1  | RESERVED                                 |
|            | X:\$FFFC0  | RESERVED                                 |
| PORT C     | X:\$FFFFBF | PORT C CONTROL REGISTER (PCRC)           |
|            | X:\$FFFBE  | PORT C DIRECTION REGISTER (PRRC)         |
|            | X:\$FFFBD  | PORT C GPIO DATA REGISTER (PDRC)         |

Table D-1 Internal I/O Memory Map (Continued)

| Peripheral | Address    | Register Name                                      |
|------------|------------|----------------------------------------------------|
| ESAI       | X:\$FFFBC  | ESAI RECEIVE SLOT MASK REGISTER B (RSMB)           |
|            | X:\$FFFBB  | ESAI RECEIVE SLOT MASK REGISTER A (RSMA)           |
|            | X:\$FFFFBA | ESAI TRANSMIT SLOT MASK REGISTER B (TSMB)          |
|            | X:\$FFFFB9 | ESAI TRANSMIT SLOT MASK REGISTER A (TSMA)          |
|            | X:\$FFFFB8 | ESAI RECEIVE CLOCK CONTROL REGISTER (RCCR)         |
|            | X:\$FFFFB7 | ESAI RECEIVE CONTROL REGISTER (RCR)                |
|            | X:\$FFFFB6 | ESAI TRANSMIT CLOCK CONTROL REGISTER (TCCR)        |
|            | X:\$FFFFB5 | ESAI TRANSMIT CONTROL REGISTER (TCR)               |
|            | X:\$FFFFB4 | ESAI COMMON CONTROL REGISTER (SAICR)               |
|            | X:\$FFFFB3 | ESAI STATUS REGISTER (SAISR)                       |
|            | X:\$FFFFB2 | RESERVED                                           |
|            | X:\$FFFFB1 | RESERVED                                           |
|            | X:\$FFFB0  | RESERVED                                           |
|            | X:\$FFFFAF | RESERVED                                           |
|            | X:\$FFFFAE | RESERVED                                           |
|            | X:\$FFFFAD | RESERVED                                           |
|            | X:\$FFFFAC | RESERVED                                           |
|            | X:\$FFFFAB | ESAI RECEIVE DATA REGISTER 3 (RX3)                 |
|            | X:\$FFFFAA | ESAI RECEIVE DATA REGISTER 2 (RX2)                 |
|            | X:\$FFFFA9 | ESAI RECEIVE DATA REGISTER 1 (RX1)                 |
|            | X:\$FFFFA8 | ESAI RECEIVE DATA REGISTER 0 (RX0)                 |
|            | X:\$FFFFA7 | RESERVED                                           |
|            | X:\$FFFFA6 | ESAI TIME SLOT REGISTER (TSR)                      |
|            | X:\$FFFFA5 | ESAI TRANSMIT DATA REGISTER 5 (TX5)                |
|            | X:\$FFFFA4 | ESAI TRANSMIT DATA REGISTER 4 (TX4)                |
|            | X:\$FFFFA3 | ESAI TRANSMIT DATA REGISTER 3 (TX3)                |
|            | X:\$FFFFA2 | ESAI TRANSMIT DATA REGISTER 2 (TX2)                |
|            | X:\$FFFFA1 | ESAI TRANSMIT DATA REGISTER 1 (TX1)                |
|            | X:\$FFFFA0 | ESAI TRANSMIT DATA REGISTER 0 (TX0)                |
|            | X:\$FFFF9F | RESERVED                                           |
|            | X:\$FFFF9E | RESERVED                                           |
|            | X:\$FFFF9D | RESERVED                                           |
|            | X:\$FFFF9C | RESERVED                                           |
|            | X:\$FFFF9B | RESERVED                                           |
|            | X:\$FFFF9A | RESERVED                                           |
|            | X:\$FFFF99 | RESERVED                                           |
|            | X:\$FFFF98 | RESERVED                                           |
|            | X:\$FFFF97 | RESERVED                                           |
|            | X:\$FFFF96 | RESERVED                                           |
|            | X:\$FFFF95 | RESERVED                                           |
| SHI        | X:\$FFFF94 | SHI RECEIVE FIFO (HRX)                             |
|            | X:\$FFFF93 | SHI TRANSMIT REGISTER (HTX)                        |
|            | X:\$FFFF92 | SHI I <sup>2</sup> C SLAVE ADDRESS REGISTER (HSAR) |
|            | X:\$FFFF91 | SHI CONTROL/STATUS REGISTER (HCSR)                 |
|            | X:\$FFFF90 | SHI CLOCK CONTROL REGISTER (HCKR)                  |

Table D-1 Internal I/O Memory Map (Continued)

| Peripheral   | Address    | Register Name                           |
|--------------|------------|-----------------------------------------|
| TRIPLE TIMER | X:\$FFFF8F | TIMER 0 CONTROL/STATUS REGISTER (TCSR0) |
|              | X:\$FFFF8E | TIMER 0 LOAD REGISTER (TLR0)            |
|              | X:\$FFFF8D | TIMER 0 COMPARE REGISTER (TCPR0)        |
|              | X:\$FFFF8C | TIMER 0 COUNT REGISTER (TCR0)           |
|              | X:\$FFFF8B | TIMER 1 CONTROL/STATUS REGISTER (TCSR1) |
|              | X:\$FFFF8A | TIMER 1 LOAD REGISTER (TLR1)            |
|              | X:\$FFFF89 | TIMER 1 COMPARE REGISTER (TCPR1)        |
|              | X:\$FFFF88 | TIMER 1 COUNT REGISTER (TCR1)           |
|              | X:\$FFFF87 | TIMER 2 CONTROL/STATUS REGISTER (TCSR2) |
|              | X:\$FFFF86 | TIMER 2 LOAD REGISTER (TLR2)            |
|              | X:\$FFFF85 | TIMER 2 COMPARE REGISTER (TCPR2)        |
|              | X:\$FFFF84 | TIMER 2 COUNT REGISTER (TCR2)           |
|              | X:\$FFFF83 | TIMER PRESCALER LOAD REGISTER (TPLR)    |
|              | X:\$FFFF82 | TIMER PRESCALER COUNT REGISTER (TPCR)   |
|              | X:\$FFFF81 | RESERVED                                |
|              | X:\$FFFF80 | RESERVED                                |

#### D.3 INTERRUPT VECTOR ADDRESSES

 Table D-2
 DSP56362 Interrupt Vectors

| Interrupt<br>Starting Address | Interrupt<br>Priority<br>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                                       | Trap                                         |  |
| VBA:\$0A                      | 3                                       | Non-Maskable Interrupt (NMI)                 |  |
| VBA:\$0C                      | 3                                       | Reserved For Future Level-3 Interrupt Source |  |
| VBA:\$0E                      | 3                                       | Reserved For Future Level-3 Interrupt Source |  |
| VBA:\$10                      | 0 - 2                                   | IRQA                                         |  |
| VBA:\$12                      | 0 - 2                                   | IRQB                                         |  |
| VBA:\$14                      | 0 - 2                                   | IRQC                                         |  |
| VBA:\$16                      | 0 - 2                                   | IRQD                                         |  |
| 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                                   | Reserved                                     |  |
| VBA:\$26                      | 0 - 2                                   | Reserved                                     |  |
| VBA:\$28                      | 0 - 2                                   | DAX Underrun Error                           |  |
| VBA:\$2A                      | 0 - 2                                   | DAX Block Transferred                        |  |
| VBA:\$2C                      | 0 - 2                                   | Reserved                                     |  |
| VBA:\$2E                      | 0 - 2                                   | DAX Audio Data Empty                         |  |
| VBA:\$30                      | 0 - 2                                   | ESAI Receive Data                            |  |
| VBA:\$32                      | 0 - 2                                   | ESAI Receive Even Data                       |  |
| VBA:\$34                      | 0 - 2                                   | ESAI Receive Data With Exception Status      |  |
| VBA:\$36                      | 0 - 2                                   | ESAI Receive Last Slot                       |  |
| VBA:\$38                      | 0 - 2                                   | ESAI Transmit Data                           |  |
| VBA:\$3A                      | 0 - 2                                   | ESAI Transmit Even Data                      |  |
| VBA:\$3C                      | 0 - 2                                   | ESAI Transmit Data with Exception Status     |  |

 Table D-2
 DSP56362 Interrupt Vectors (Continued)

| Interrupt<br>Starting Address | Interrupt<br>Priority<br>Level<br>Range | Interrupt Source            |  |  |
|-------------------------------|-----------------------------------------|-----------------------------|--|--|
| VBA:\$3E                      | 0 - 2                                   | ESAI Transmit Last Slot     |  |  |
| VBA:\$40                      | 0 - 2                                   | SHI Transmit Data           |  |  |
| VBA:\$42                      | 0 - 2                                   | SHI Transmit Underrun Error |  |  |
| VBA:\$44                      | 0 - 2                                   | SHI Receive FIFO Not Empty  |  |  |
| VBA:\$46                      | 0 - 2                                   | Reserved                    |  |  |
| VBA:\$48                      | 0 - 2                                   | SHI Receive FIFO Full       |  |  |
| VBA:\$4A                      | 0 - 2                                   | SHI Receive Overrun Error   |  |  |
| VBA:\$4C                      | 0 - 2                                   | SHI Bus Error               |  |  |
| VBA:\$4E                      | 0 - 2                                   | Reserved                    |  |  |
| VBA:\$50                      | 0 - 2                                   | Reserved                    |  |  |
| VBA:\$52                      | 0 - 2                                   | Reserved                    |  |  |
| VBA:\$54                      | 0 - 2                                   | TIMER0 Compare              |  |  |
| VBA:\$56                      | 0 - 2                                   | TIMER0 Overflow             |  |  |
| VBA:\$58                      | 0 - 2                                   | TIMER1 Compare              |  |  |
| VBA:\$5A                      | 0 - 2                                   | TIMER1 Overflow             |  |  |
| VBA:\$5C                      | 0 - 2                                   | TIMER2 Compare              |  |  |
| VBA:\$5E                      | 0 - 2                                   | TIMER2 Overflow             |  |  |
| 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:\$FE                      | 0 - 2                                   | Reserved                    |  |  |

## D.4 INTERRUPT SOURCE PRIORITIES (WITHIN AN IPL)

 Table D-3
 Interrupt Sources Priorities Within an IPL

| Priority                  | Interrupt Source                         |  |  |  |
|---------------------------|------------------------------------------|--|--|--|
| Level 3 (Nonmaskable)     |                                          |  |  |  |
| Highest                   | Hardware RESET                           |  |  |  |
|                           | Stack Error                              |  |  |  |
|                           | Illegal Instruction                      |  |  |  |
|                           | Debug Request Interrupt                  |  |  |  |
|                           | Trap                                     |  |  |  |
| 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                  |  |  |  |
|                           | DMA Channel 5 Interrupt                  |  |  |  |
|                           | ESAI Receive Data with Exception Status  |  |  |  |
|                           | ESAI Receive Even Data                   |  |  |  |
|                           | ESAI Receive Data                        |  |  |  |
|                           | ESAI Receive Last Slot                   |  |  |  |
|                           | ESAI Transmit Data with Exception Status |  |  |  |
|                           | ESAI Transmit Last Slot                  |  |  |  |
|                           | ESAI Transmit Even Data                  |  |  |  |
|                           | ESAI Transmit Data                       |  |  |  |
|                           | SHI Bus Error                            |  |  |  |
|                           | SHI Receive Overrun Error                |  |  |  |
|                           | SHI Transmit Underrun Error              |  |  |  |
|                           | SHI Receive FIFO Full                    |  |  |  |
|                           | SHI Transmit Data                        |  |  |  |
|                           | SHI Receive FIFO Not Empty               |  |  |  |
|                           | HOST Command Interrupt                   |  |  |  |

 Table D-3
 Interrupt Sources Priorities Within an IPL (Continued)

| Priority | Interrupt Source             |  |  |  |
|----------|------------------------------|--|--|--|
|          | HOST Receive Data Interrupt  |  |  |  |
|          | HOST Transmit Data Interrupt |  |  |  |
|          | DAX Transmit Underrun Error  |  |  |  |
|          | DAX Block Transferred        |  |  |  |
|          | DAX Transmit Register Empty  |  |  |  |
|          | TIMER0 Overflow Interrupt    |  |  |  |
|          | TIMER0 Compare Interrupt     |  |  |  |
|          | TIMER1 Overflow Interrupt    |  |  |  |
|          | TIMER1 Compare Interrupt     |  |  |  |
|          | TIMER2 Overflow Interrupt    |  |  |  |
| Lowest   | TIMER2 Compare Interrupt     |  |  |  |

#### D.5 HOST INTERFACE—QUICK REFERENCE

 Table D-4
 HDI08 Programming Model

|     |     |          | Bit                              |                                               |                                                                                                                                                                                                                                      |          | Reset Typ  |    |    |
|-----|-----|----------|----------------------------------|-----------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|------------|----|----|
| Reg | Num | Mnemonic | Name                             | Val                                           | Function                                                                                                                                                                                                                             | Comments | HW /<br>SW | IR | ST |
|     |     |          |                                  |                                               | OSP SIDE                                                                                                                                                                                                                             |          |            |    |    |
| HCR | 0   | HRIE     | Receive Interrupt Enable         | 0                                             | HRRQ interrupt disabled<br>HRRQ interrupt enabled                                                                                                                                                                                    |          | 0          | -  | -  |
|     | 1   | HTIE     | Transmit Interrupt Enable        | 0                                             | HTRQ interrupt disabled HTRQ interrupt enabled                                                                                                                                                                                       |          | 0          | -  | -  |
|     | 2   | HCIE     | Host Command Interrupt<br>Enable | 0                                             | HCP interrupt disabled HCP interrupt enabled                                                                                                                                                                                         |          | 0          | -  | -  |
|     | 3   | HF2      | Host Flag 2                      |                                               | •                                                                                                                                                                                                                                    |          | 0          |    |    |
|     | 4   | HF3      | Host Flag 3                      |                                               |                                                                                                                                                                                                                                      |          | 0          | -  | -  |
|     | 7-5 | HDM[2:0] | Host DMA Mode                    | 000<br>100<br>001<br>010<br>011<br>101<br>110 | DMA operation disabled DMA operation enabled 24-bit host-to-DSP DMA enabled 16-bit host-to-DSP DMA enabled 8-bit host-to-DSP DMA enabled 24-bit DSP-to-host DMA enabled 16-bit DSP-to-host DMA enabled 8-bit DSP-to-host DMA enabled |          | 000        |    |    |

 Table D-4
 HDI08 Programming Model

|      |     |            | Bit                           |                                       | Reset Type                                                    |                                                                 |            |    |    |
|------|-----|------------|-------------------------------|---------------------------------------|---------------------------------------------------------------|-----------------------------------------------------------------|------------|----|----|
| Reg  | Num | Mnemonic   | Name                          | Val                                   | Function                                                      | Comments                                                        | HW /<br>SW | IR | ST |
| HPCR | 0   | HGEN       | Host GPIO Enable              | 0                                     | GPIO pin disconnected                                         |                                                                 | 0          | -  | -  |
|      | -   | II A OFFIN | TT                            | 1                                     | GPIO pins active                                              | 11.1                                                            | 0          |    |    |
|      | 1   | HA8EN      | Host Address Line 8<br>Enable | 0                                     | HA8/HA1 = GPIO                                                | this bit is treated as 1 if HMUX=0                              | 0          | -  | -  |
|      |     |            |                               | 1                                     | HA8/HA1 = HA8/HA1<br>HA9/HA2 = GPIO                           | this bit is treated as 0 if<br>HEN=0                            |            |    |    |
|      | 2   | HA9EN      | Host Address Line 9<br>Enable | this bit is treated as 1 if<br>HMUX=0 | 0                                                             | -                                                               | -          |    |    |
|      |     |            |                               | 1                                     | HA9/HA2 = HA9/HA2                                             | this bit is treated as 0 if<br>HEN=0                            |            |    |    |
|      | 3   | HCSEN      | Host Chip Select Enable       | 0                                     | HCS/HA10 = GPIO                                               | this bit is treated as 0 if                                     | 0          | -  | -  |
|      | -   | HDEN       | II (D (E 11                   | 1                                     | HCS/HA10 = HCS/HA10                                           | HEN=0                                                           | 0          |    |    |
|      | 4   | HREN       | Host Request Enable           | 0                                     | HOREQ/HTRQ = GPIO<br>HACK/HRRQ=GPIO<br>HOREQ/HTRQ=HOREQ/HTRQ  | this bit is treated as 0 if<br>HEN=0                            | 0          | -  | -  |
|      |     |            |                               |                                       | HACK/HRRQ=HACK/HRRQ                                           |                                                                 |            |    |    |
|      | 5   | HAEN       | Host Acknowledge<br>Enable    | 0                                     | HACK/HRRQ = GPIO                                              | this bit is ignored if<br>HDRQ=1<br>this bit is treated as 0 if | 0          | -  | -  |
|      |     |            |                               | 1                                     | HACK/HRRQ= HACK                                               | HREN=0<br>this bit is treated as 0 if<br>HEN=0                  |            |    |    |
|      | 6   | HEN        | Host Enable                   | 0                                     | Host Port=GPIO<br>Host Port Active                            | IIIEN-0                                                         | 0          | -  | -  |
|      | 8   | HROD       | Host Request Open Drain       | 0                                     | HOREQ/HTRQ/HRRQ=driven<br>HOREQ/HTRQ/HRRQ=open<br>drain       | this bit is ignored if<br>HEN=0                                 | 0          | -  | -  |
|      | 9   | HDSP       | Host Data Strobe Polarity     | 0                                     | HDS/HRD/HWR active low<br>HDS/HRD/HWR active high             | this bit is ignored if                                          | 0          | -  | -  |
|      | 10  | HASP       | Host Address Strobe           | 0                                     | HAS active low                                                | this bit is ignored if                                          | 0          | -  | -  |
|      |     |            | Polarity                      | 1                                     | HAS active high                                               | HEN=0                                                           |            |    |    |
|      | 11  | HMUX       | Host Multiplxed Bus           | 0<br>1                                | Separate address and data<br>lines                            | this bit is ignored if<br>HEN=0                                 | 0          | -  | -  |
|      | 12  | HDDS       | Host Dual Data Strobe         | 0                                     | Multiplexed address/data<br>Single Data Strobe (HDS)          | this bit is ignored if                                          | 0          | _  | _  |
|      | 12  | TIDDS      | Host Duai Data Strote         | 1                                     | Double Data Strobe (HWR, HRD)                                 | HEN=0                                                           | O          | _  |    |
|      | 13  | HCSP       | Host Chip Select Polarity     | 0                                     | HCS active low                                                | this bit is ignored if                                          | 0          | _  | _  |
|      | 13  | 11001      | 2205t Chip Sciect i Guilty    | 1                                     | HCSactive high                                                | HEN=0                                                           |            |    |    |
|      | 14  | HRP        | Host Request polarity         | 0                                     | HOREQ/HTRQ/HRRQ active low                                    | this bit is ignored if<br>HEN=0                                 | 0          | -  | -  |
|      |     |            |                               | 1                                     | HOREQ/HTRQ/HRRQ active high                                   | HEN=U                                                           |            |    |    |
|      | 15  | HAP        | Host Acknowledge<br>Polarity  | 0                                     | HACK active low HACK active high                              | this bit is ignored if<br>HEN=0                                 | 0          | -  | -  |
| HSR  | 0   | HRDF       | Host Receive Data Full        | 0                                     | no receive data to be read                                    | 110                                                             | 0          | 0  | 0  |
|      | 1   | HTDE       | Host Transmit Data            | 1                                     | receive data register is full<br>transmit data register empty |                                                                 | 1          | 1  | 1  |
|      | 2   | НСР        | Empty Host Command Pending    | 0                                     | transmit data reg. not empty no host command pending          |                                                                 | 0          | 0  | 0  |
|      |     |            |                               | 1                                     | host command pending                                          |                                                                 |            | J  | Ü  |
|      | 3   | HF0        | Host Flag0                    |                                       |                                                               |                                                                 | 0          | -  | -  |
|      | 4   | HF1        | Host Flag1                    |                                       | DMA 1 1' 11 1                                                 |                                                                 | 0          | -  | -  |
|      | 7   | DMA        | DMA Status                    | 0<br>1                                | DMA mode disabled<br>DMA mode enabled                         |                                                                 | 0          | -  | -  |

 Table D-4
 HDI08 Programming Model

|             |      | Bit      |                                     |                |                                                                  |                                                                   | Reset Type |      |    |  |
|-------------|------|----------|-------------------------------------|----------------|------------------------------------------------------------------|-------------------------------------------------------------------|------------|------|----|--|
| Reg         | Num  | Mnemonic | Name                                | Val            | Function                                                         | Comments                                                          | HW /<br>SW | IR   | ST |  |
| HBAR        | 7-0  | BA10-BA3 | Host base Address<br>Register       |                |                                                                  |                                                                   | \$80       |      |    |  |
| HORX        | 23-0 |          | DSP Receive Data                    |                |                                                                  |                                                                   | e          | mpty |    |  |
| НОТХ        | 23-0 |          | Register DSP Transmit Data Register |                |                                                                  |                                                                   | e          | mpty |    |  |
| HDR         | 15-0 | D15-D0   | GPIO Pin Data                       |                |                                                                  |                                                                   | \$0000     | -    | _  |  |
| HDDR        |      | DR15-DR0 | GPIO Pin Direction                  | 0              | Input<br>Output                                                  |                                                                   | \$0000     | -    | -  |  |
|             |      |          |                                     |                | Host Side                                                        |                                                                   |            |      |    |  |
| ICR         | 0    | RREQ     | Receive Request Enable              | 0              | HRRQ interrupt disabled<br>HRRQ interrupt enabled                |                                                                   | 0          | -    | -  |  |
|             | 1    | TREQ     | Transmit Request Enable             | 0              | HTRQ interrupt disabled<br>HTRQ interrupt enabled                |                                                                   | 0          | -    | -  |  |
|             | 2    | HDRQ     | Double Host Request                 | 0              | HOREQ/HTRQ=HOREQ,<br>HACK/HRRQ=HACK<br>HOREQ/HTRQ=HTRQ,          | available if<br>HDM2-HDM0=000                                     | 0          | -    | -  |  |
|             | 3    | HF0      | Host Flag 0                         |                | HACK/HRRQ=HRRQ                                                   |                                                                   | 0          |      | _  |  |
|             | 4    | HF1      | Host Flag 1                         |                |                                                                  |                                                                   | 0          | -    | _  |  |
|             | 5    | HLEND    | Host Little Endian                  | 0              | "Big Endian" order "Little Endian" order                         | available if<br>HDM2-HDM0=000                                     | 0          | -    | -  |  |
|             | 6-5  | HM1-HM0  | Host Mode Control                   | 00<br>01<br>10 | Interrupt Mode<br>24-bit DMA enabled<br>16-bit DMA enabled       | available if<br>HDM2-HDM0=100                                     | 00         | -    | -  |  |
|             | 7    | INIT     | Initialize                          | 11             | 8-bit DMA enabled Reset data paths according to TREQ and RREQ    | cleared by HDI08<br>hardware                                      | 0          | -    | -  |  |
| ISR         | 0    | RXDF     | Receive Data Register<br>Full       | 0              | host receive register is empty<br>host receive register is full  | naidwaie                                                          | 0          | 0    | 0  |  |
|             | 1    | TXDE     | Transmit Data Register              | 1 0            | host transmit register empty<br>host transmit register full      |                                                                   | 1          | 1    | 1  |  |
|             | 2    | TRDY     | Empty Transmitter Ready             | 1              | transmit FIF O (6 deep) is empty                                 |                                                                   | 1          | 1    | 1  |  |
|             | 3    | HF2      | Host Flag2                          | 0              | transmit FIFO is not empty                                       |                                                                   | 0          | -    | -  |  |
|             | 4    | HF3      | Host Flag3                          |                |                                                                  |                                                                   | 0          | -    | -  |  |
|             | 7    | HREQ     | Host Request                        | 0              | HOREQ pin is deasserted<br>HOREQ pin is asserted (if<br>enabled) |                                                                   | 0          | 0    | 0  |  |
| CVR         | 6-0  | HV6-HV0  | Host Command Vector                 |                |                                                                  | default vector                                                    | \$2A       | -    | -  |  |
|             | 7    | НС       | Host Command                        | 0              | no host command pending<br>host command pending                  | cleared by HDI08<br>hardware when the HC<br>int. req. is serviced | 0          | 0    | 0  |  |
| RXH/        | 7-0  |          | Host Receive Data                   |                |                                                                  | 1111. 10q. 15 301 VICCU                                           | e          | mpty | l  |  |
| M/L         |      |          | Register                            |                |                                                                  |                                                                   |            | 1.7  |    |  |
| TXH/<br>M/L | 7-0  |          | Host Transmit Data<br>Register      |                |                                                                  |                                                                   | e          | mpty |    |  |
| IVR         | 7-0  | IV7-IV0  | Interrupt Register                  |                | 68000 family vector register                                     |                                                                   | \$0F       | -    | -  |  |

#### D.6 PROGRAMMING SHEETS

The worksheets shown on the following pages contain listings of major programmable registers for the DSP56362. The programming sheets are grouped into the following order:

- Central Processor
- Host Interface (HDI08)
- Serial Host Interface (SHI)
- Enhanced Serial Audio Interfaces (ESAI)
- Digital Audio Interface (DAX)
- Timer/Event Controller (TEC)
- GPIO (Ports B-D)

Each sheet provides room to write in the value of each bit and the hexadecimal value for each register. Programmers can photocopy these sheets and reuse them for each application development project.

For details on the instruction set of the DSP56300 family chips, see the *DSP56300 Family Manual*.

| Application:                                               | Date:                                       |
|------------------------------------------------------------|---------------------------------------------|
|                                                            | Programmer:                                 |
|                                                            | Sheet 1 of 5                                |
|                                                            | Carry —                                     |
| Central Processor                                          | Overfow —                                   |
|                                                            | ∠ero —                                      |
|                                                            | Negative—                                   |
| Unnormalized ( U = Acc(47) xnor Acc(46) )                  |                                             |
| Extension———————————————————————————————————               |                                             |
| Limit —                                                    |                                             |
| FFT Scaling (S = Acc(46) xor Acc(45))                      |                                             |
| Interrupt Mask                                             |                                             |
| Scaling Mode I(1:0) Exceptions M                           | sked                                        |
| S(1:0) Scaling Mode 00 None                                |                                             |
| 00 No scaling 01 IPL 0 01 Scale down 10 IPL 0, 1           |                                             |
| 01 Scale down<br>10 Scale up 10 IPL 0, 1<br>11 IPL 0, 1, 2 |                                             |
| 11 Reserved                                                | =-,                                         |
| Reserved                                                   | _,                                          |
| Sixteen-Bit Compatibilitity                                |                                             |
| Double Precision Multiply Mode ————                        |                                             |
| Loop Flag                                                  |                                             |
| DO-Forever Flag                                            |                                             |
| Sixteenth-Bit Arithmetic                                   |                                             |
| Reserved                                                   |                                             |
| Instruction Cache Enable —                                 |                                             |
| Arithmetic Saturation                                      |                                             |
| Rounding Mode —                                            |                                             |
| Core Priority                                              |                                             |
| CP(1:0) Core Priority                                      |                                             |
| 00 0 (lowest)                                              |                                             |
|                                                            |                                             |
| 10   2                                                     |                                             |
|                                                            |                                             |
|                                                            |                                             |
|                                                            |                                             |
| 23 22 21 20 19 18 17 16 15 14 13                           | 12   11 10 9 8   7 6 5 4   3 2 1 0          |
| CP1 CP0 RM SM CE * SA FV LF DM SC                          | * S1 S0 I1 I0 S L E U N Z V C               |
|                                                            | 0                                           |
|                                                            |                                             |
|                                                            |                                             |
|                                                            |                                             |
| Extended Mode Register (MR) Mode                           | Register (MR) Condition Code Register (CCR) |
| Status Register (SR) Read/Write Reset = \$0                | 00300 * = Reserved, Program as 0            |

Figure D-1 Status Register (SR)

| Application:                              |                               |               |            | Date:     |            |          |         |         |            |
|-------------------------------------------|-------------------------------|---------------|------------|-----------|------------|----------|---------|---------|------------|
|                                           |                               |               |            |           | _ P        | rogran   | nmer:   |         | <u> </u>   |
|                                           |                               |               |            |           |            |          |         |         | Sheet 2 of |
| Central Pro                               | 0222                          | $\overline{}$ |            |           |            |          |         |         |            |
| Centian it                                | <u> </u>                      | <u> </u>      |            |           |            |          |         |         |            |
|                                           |                               |               |            | Chip Ope  | erating N  | Nodes    |         |         |            |
|                                           | M                             | OD(D:A)       | Reset Vec  |           |            |          | criptio | n       |            |
|                                           |                               |               | ;          | See Table | 4-1 in S   | ection 4 | 1       |         |            |
| External Bus Disable ———                  |                               |               |            |           |            |          | _       |         |            |
| Stop Delay                                |                               |               |            |           |            |          |         |         |            |
| Memory Switch Mode ———                    |                               |               |            |           |            |          |         |         |            |
| Core-DMA Priorit                          | /                             |               |            |           |            |          |         |         |            |
| CDP(1:0) Core-DMA                         | Priority                      |               |            |           |            |          |         |         |            |
| 00 Core vs DMA P                          | ,                             |               |            |           |            |          |         |         |            |
| 01 DMA accesses<br>10 DMA accesses        |                               |               |            |           |            |          |         |         |            |
| 11 DMA accesses                           |                               |               |            |           |            |          |         |         |            |
| Burst Mode Enable                         |                               |               |            |           |            |          |         |         |            |
| TA Synchronize Select——                   |                               |               |            |           |            |          |         |         |            |
| Bus Release Timing———                     |                               |               |            |           |            |          |         |         |            |
| Asynchronous Bus Arbitration              | Enable ——                     | <u> </u>      |            |           |            |          |         |         |            |
| Address Priority Disable ——               |                               |               |            |           |            |          |         |         |            |
| Address Tracing Enable ——                 |                               |               |            |           |            |          |         |         |            |
| Stack Extension Space Selec               | t                             |               |            |           |            |          |         |         |            |
| Extended Stack Underflow FI               | ag——                          |               |            |           |            |          |         |         |            |
| Extended Stack Overflow Fla               | g                             |               |            |           |            |          |         |         |            |
| Extended Stack Wrap Flag                  |                               |               |            |           |            |          |         |         |            |
| Stack Extension Enable                    |                               |               |            |           |            |          |         |         |            |
| Patch Enable                              | ]                             |               |            |           |            |          |         |         |            |
|                                           |                               |               |            |           |            |          |         |         |            |
|                                           |                               |               |            | ¥         |            |          |         |         | <b>V</b>   |
| 23 22 21 20 <sub>1</sub> 19 18 17         | 16   15 14                    | 13 12         | 11 10      | 9 8       | 7 <b>7</b> | 5        | 4 (     | 3 2     | 1 0        |
| 23 22 21 20 19 18 17 PEN * SEN WRP EOV EU | ′ 16   15 14<br>NIXYS ATELAPD | ABE BRT       | TAS BE     | CDP1CDP0  |            |          | -       | MD MC   |            |
|                                           |                               |               |            |           |            | ô        |         |         |            |
|                                           |                               |               |            |           |            | U        | -       |         |            |
|                                           |                               |               |            |           |            |          |         |         |            |
|                                           | <del></del>                   |               |            |           | $\vdash$   |          |         |         |            |
| System Stack Control                      | Ex                            | tended Ch     | in Onera   | ting      |            | Chin O   | nerat   | ting Mo | nde        |
| Status Register (SCS)                     |                               | Iode Regis    |            |           |            |          |         | (COM)   |            |
| Operating Mode Register (OMF              | Read/Wr                       | rite Rese     | t = \$0003 | 0X        | * =        | Reser    | ved.    | Progran | m as 0     |

Figure D-2 Operating Mode Register (OMR)

| Application:      |                                                | Date:                                                                |
|-------------------|------------------------------------------------|----------------------------------------------------------------------|
| _                 |                                                | Programmer:                                                          |
|                   | IRQA Mode   IRQB   IAL1   IAL0   Enabled   IPL | Sheet 3 of 5  11 10 8                                                |
| CENTRAL PROCESSOR | IRQE Mode                                      | Interrupt Priority Register (IPR-C) X:\$FFFFFF R.W  Reset = \$000000 |

Figure D-3 Interrupt Priority Register–Core (IPR–C)



Figure D-4 Interrupt Priority Register – Peripherals (IPR–P)

| Application                                                   | n: _     |                |                                                                                                                                                                                                                                          | Date:                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------------------------------------------------|----------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                               | _        |                |                                                                                                                                                                                                                                          | Programmer: _                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                               |          |                |                                                                                                                                                                                                                                          | , l                                                               | Sheet 5 of 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                                               |          |                | Multiplication Factor Bits MF0 – MF11  MF11 – MF0   Multiplication Factor MF  \$000                                                                                                                                                      | 5 4 3 2 1                                                         | MITS WITZ WITZ WITT WITD                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Power Consumption during STOP                                 | Minimal  | Higher         |                                                                                                                                                                                                                                          | 8 7                                                               | MITTI MITTO MITTO MITTO MITTO                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| PSTP and PEN Relationship  During STOP Recovery Time for STOP | Long     | Short          | XTAL Disable Bit (XTLD)  0 = Enable Xtal Oscillator  1 = EXTAL Driven From An External Source  Crystal Range Bit (XTLR)  0 = External Xtal Freq <200KHz  1 = External Xtal Freq <200KHz  Division Factor Bits (  DF2 - DF0  S1  \$1  \$2 | \$77<br>14 13 12                                                  | 012 011                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| PSTP and PEI Operation During STOP PLL Oscillator             | Disabled | Enabled        | XTAL D  0 = Enal  1 = EXT  An E                                                                                                                                                                                                          | 18 17 16                                                          | A LONG TO THE PART OF THE PART |
| Operation I<br>PLL                                            | Disabled | Enabled        | D0 – PD3)<br>Factor PDF                                                                                                                                                                                                                  | 20 19                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| PEN                                                           | ×c       | , <del>-</del> | D0 - PD3)                                                                                                                                                                                                                                | 22 23                                                             |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|                                                               | 0 -      |                | Clock Output Disable (COD)  0 = 50% Duty Cycle Clock  1 = Pin Held In High State  Predivision Factor Bits (PI PD3 - PD0   Predivision F \$0   1   \$1   \$1   2   \$2   \$3   \$                                                         | Note that bits XTLR and XTLD have no effect on DSP56362 operation | PLL Control Register (PCTL) X:\$FFFFFD Read/Write Reset = \$010005                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|                                                               |          |                | <u>0 0 4                                  </u>                                                                                                                                                                                           |                                                                   | PLL<br>Regi<br>X:\$F<br>Res                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

Figure D-5 Phase Lock Loop Control Register (PCTL)

|                                             |                    |                    |      |     |       |      |       |       |              |        |      |       |       | _    | Pro | gran | nmer  | : _   |          | et 1 |   |
|---------------------------------------------|--------------------|--------------------|------|-----|-------|------|-------|-------|--------------|--------|------|-------|-------|------|-----|------|-------|-------|----------|------|---|
| HC                                          | S                  | Γ (                | Н    | D   | 0     | 8)   |       |       |              |        |      |       | Е     | S    | βP  |      | Sic   | de    | <b>)</b> |      |   |
| Host Receive Data (usually read by program) |                    |                    |      |     |       |      |       |       |              |        |      |       |       |      |     |      |       |       |          |      |   |
| 3 22                                        | 21 2               | :0 <sub> </sub> 19 | 18   | 17  | 16    | 15   | 14    | 13    | 12           | 11     | 10   | 9     | 8     | 7    | 6   |      |       |       |          | 1    | _ |
|                                             | Recei              | ve High            | Byte |     |       |      |       | Rece  | ive M        | iddle  | Byte | •     |       |      |     | Red  | eive  | Low E | Byte     |      |   |
|                                             |                    |                    |      |     |       |      |       |       |              |        |      |       |       |      |     |      |       |       |          |      |   |
| :\$FFFE<br>eset =                           |                    |                    | nly  | Но  | st Tr | ansr | nit E | Data  | (usu         | allv   | loac | led k | ומ עם | ogra | am) |      |       |       |          |      |   |
|                                             |                    |                    |      |     |       |      |       |       | , <u>, ,</u> | 1      |      |       | , ,   |      | ,   |      |       |       |          |      |   |
|                                             | 21 2               | 0  19              | 18   | 17  | 16    | 15   | 14    | 13    | 12           | 11     | 10   | 9     | 8     | 7    | 6   | 5    | 4     | 3     | 2        | 1    |   |
| 23 22                                       | Transmit High Byte |                    |      |     |       |      |       | Trans | smit N       | liddle | Byte | )     |       |      |     | Trai | nsmit | Low   | Byte     |      |   |
| 23 22                                       |                    |                    | 1    |     |       |      |       |       |              |        |      |       |       |      |     |      |       |       |          |      |   |
| 23 22                                       |                    |                    |      |     |       |      |       |       |              |        |      |       |       | 1    |     |      |       | 1     |          |      |   |
| 23 22                                       |                    |                    |      | II. | •     |      |       |       |              |        |      |       |       |      |     |      |       |       |          |      |   |

Figure D-6 Host Receive and Host Transmit Data Registers

| Application:    |                                                                      | Date:                                              |
|-----------------|----------------------------------------------------------------------|----------------------------------------------------|
|                 |                                                                      | Programmer:                                        |
|                 |                                                                      | Sheet 2 of 6                                       |
| HOST            | Host Receive Interrupt Enable<br>0 = Disable 1 = Enable if HRDF = 1  |                                                    |
| HOST<br>(HDI08) | Host Transmit Interrupt Enable<br>0 = Disable 1 = Enable if HTDE = 1 | ]                                                  |
|                 | Host Command Interrupt Enable<br>0 = Disable 1 = Enable if HCP = 1   |                                                    |
|                 | Host Flag 2                                                          |                                                    |
|                 | Host Flag 3                                                          |                                                    |
|                 | Host DMA Control Bits 15                                             | 5::: 8 7 6 5 4 1 3 2 1 0                           |
|                 | See Table 6-5 in Section 6                                           | <del>-                                      </del> |
|                 | Host Control Register (HCR) X:\$FFFFC2 Read /Write Reset = \$0       |                                                    |
|                 | DSP Side                                                             | ** = Reserved, Program as 0                        |
|                 | Host Receive Data Full 0 = Wait 1 = Read                             |                                                    |
|                 | Host Transmit Data Empty 0 = Wait 1 = Write                          |                                                    |
|                 | Host Command Pending 0 = Wait 1 = Ready                              |                                                    |
|                 | Host Flags<br>Read Only                                              |                                                    |
|                 | DMA status 0 = DMA Mode Disabled 1 = DMA Mode Enabled 0              |                                                    |
|                 | Host Status Register (HSR) X:\$FFFFC3 Reset = \$2                    |                                                    |
|                 | •                                                                    | * = Reserved, Program as 0                         |

Figure D-7 Host Control and Status Registers

| Application:                         |                                       |                    |                |          |          |          |          |         | Da                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | ıte: _       |              |          |              |              |
|--------------------------------------|---------------------------------------|--------------------|----------------|----------|----------|----------|----------|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|----------|--------------|--------------|
|                                      |                                       |                    |                |          |          |          |          |         | Pro                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ogran        | nmer:        |          |              |              |
|                                      |                                       |                    |                |          |          |          |          |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |              | S        | heet 3       | of 6         |
| HOST                                 | (HD                                   | (801               |                | 1!       | 5 ;;; {  | d /      |          |         | ) S                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Sid          | le<br>3      | 2        | 1            | 0            |
|                                      |                                       |                    |                | *        |          |          |          |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 3A7          | BA6          | BA5      | BA4          | BA3          |
| Host Bas                             | e Address R                           |                    |                | 0        |          | )        |          |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |              |          |              |              |
|                                      |                                       | X:\$FFF<br>Reset = |                |          | ┧        |          |          |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              | I            | I.       | I            |              |
|                                      |                                       | Neset =            | ΨΟΟ            |          | Ш        |          |          |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |              |          |              |              |
|                                      |                                       |                    |                | <u> </u> | ⊣⊢       |          | Нос      | + GDI   | Port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Enabl        | ۱۵           |          |              |              |
| Host R                               | equest Open                           | Drain              |                |          |          |          |          |         | Pins Di                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |              |              |          |              |              |
| HDRQ                                 | HROD                                  | HREN/HEV           | ٧              |          |          |          | _        | -       | Pin Ena                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |              | lecteu       |          |              |              |
| 0                                    | 0                                     | 1                  |                |          |          |          | <u> </u> | 01 10   | III LII                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | abie         |              |          |              |              |
| 0                                    | 1                                     | 1                  |                |          |          |          |          |         | ress L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |              |              |          |              |              |
|                                      | 0                                     | 1                  |                |          |          |          | 0 —      | → HA8   | = GPIC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ), 1 →       | HA8 :        | = HA8    |              |              |
| 1                                    | 1                                     | 1                  |                |          |          |          |          |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |              |          |              |              |
| Host Data Strob                      | no Bolority                           |                    |                | Ī        |          |          |          |         | ress L                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |              |              |          |              |              |
| Host Data Strob<br>0 = Strobe Active | elow 1 = St                           | robe Active I      | Hiah           |          | $\neg$   |          | 0 –      | → HA9   | = GPIC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | ), 1 →       | HA9 :        | = HA9    |              |              |
| -                                    | · · · · · · · · · · · · · · · · · · · |                    | ng             |          |          |          | lla.     | -4 Ob.: | Calaa                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 4 5          | L-1-         |          | <b></b>      |              |
| Host Address                         | Strobe Pola                           | arity              | ماند:ا ا       |          | - I      |          |          |         | Selection Select |              |              |          |              |              |
| 0 = Strobe Active                    | e Low, 1 = St                         | robe Active        | High           |          |          |          |          |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |              | ЛUX = (  | o            |              |
| Host Multiplex                       | ed Bus                                |                    |                |          |          |          |          |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |              | MUX =    |              |              |
| 0 = Nonmultiple                      | exed, $1 = Mul$                       | tiplexed           |                |          |          |          |          | - 1 D   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |              |          | T'           |              |
| Host Dual Data                       | Strobe                                |                    | T              |          |          |          |          |         | uest E                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |              |              |          |              |              |
| 0 = Single Strob                     | oe, 1 = Dual \$                       | Strobe             |                | $\neg$   |          |          |          |         | EQ/HA<br>EQ = F                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |              | '        |              |              |
| Host Chip Sele                       | ot Polarity                           |                    | ᆿ              |          |          |          | ' -      |         | RQ = (                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |              | Q,           |          |              |              |
| 0 = HCS Active                       |                                       |                    |                |          |          |          | Hos      |         | nowled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |              | nable        | Ī        |              |              |
| HTRQ & HR                            | RQ Enable                             |                    |                | 1        |          |          |          |         | < = GP                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |              | i i a b i o  |          |              |              |
| 1 = HCS Active                       | High                                  |                    |                |          |          |          |          |         | HRE                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | N = 1,       |              |          |              |              |
| Host                                 | Request Pola                          | ritv               |                |          |          |          | HA       | CK = F  | IACK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |              | •            |          |              |              |
| HDRQ HRP                             |                                       | ···· <b>·</b>      |                |          |          |          | Но       | st Ena  | hla                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | _            |              |          |              |              |
| 0 0                                  | HOREQ Ad                              | ctive Low          |                |          |          |          | _        |         | 8 Disal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | ole          |              |          |              |              |
| 0 1                                  | HOREQ Ad                              | ctive High         | П              |          |          |          |          | Pins :  | = GPIC                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | )            |              |          |              |              |
| 1 0                                  | ,                                     | RQ Active Low      | 1 1            |          |          |          | 1 -      | HDI0    | 8 Enab                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | le           |              |          |              |              |
| 1 1                                  | HTRQ,HRF                              | RQ Active High     | า              |          |          |          |          |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |              |          |              |              |
| Host Acknowled                       | ge Polarity                           |                    | $\exists \bot$ |          |          |          |          |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              | i            |          |              |              |
| 0 = HACK Active                      | Low, 1 = HAC                          | K Active High      |                |          |          |          |          |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |              |          | _            |              |
|                                      |                                       |                    |                |          |          |          |          |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |              |          |              |              |
|                                      |                                       |                    | _              |          |          |          |          |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |              |          |              | <sup>1</sup> |
|                                      | ↓ ↓                                   | ↓ ↓                | $\downarrow$   | √        | <b>」</b> | <b>\</b> |          | ₩       | <b>V</b>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | $\downarrow$ | $\downarrow$ | <b>V</b> | $\downarrow$ | . ↓          |
|                                      | 15 14                                 | 13 12 <sub>1</sub> | 11             | 10       | 9        | 8 1      | 7        | 6       | 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 4            | ı 3          | 2        | 1            | ó            |
| Host Port Control                    | HAP HRP                               | HCSP HDDS          | HMUX           | HASP     | HDSP     | HROD     | *        | HEN     | HAEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | HREN         | HCSE         | N HA9EN  | HA8EN        | HGEN         |
| Register (HPCR)                      | - 1 1 1                               |                    |                |          |          |          | 0        |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |              |          |              |              |
| X:\$FFFFC4                           | <b>├</b> ──                           | 1                  |                | 1        | l        | l        | •        | 1       | l                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |              | 1            | 1        | 1            | l            |
| Read/Write                           |                                       |                    |                |          |          |          |          |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |              |          |              |              |
| Reset = \$0                          | •                                     |                    |                |          |          |          |          |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |              |          |              |              |
|                                      | * = Reserve                           | ed, Progran        | n as           | 0        |          |          |          |         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |              |              |          |              |              |

Figure D-8 Host Base Address and Host Port Control



Figure D-9 Host Interrupt Control and Interrupt Status

| Application:                                                                                           | Date:                                                          |
|--------------------------------------------------------------------------------------------------------|----------------------------------------------------------------|
|                                                                                                        | Programmer:                                                    |
|                                                                                                        | Sheet 5 of 6                                                   |
| HOST (HDI08)                                                                                           | Processor Side                                                 |
| Interrupt Vector Register (IVR)<br>\$3 R/W<br>Reset = \$0F                                             | 7 6 5 4 3 2 1 0  IV7   IV6   IV5   IV4   IV3   IV2   IV1   IV0 |
| Host Vector                                                                                            | Contains the interrupt vector or number                        |
| Contains Host Command Interrupt Address ÷ 2  Host Command Handshakes Executing Host Command Interrupts |                                                                |
|                                                                                                        | 7 6 5 4 3 2 1 0                                                |
| Command Vector Register (CVR)<br>\$1 R/W                                                               | HC HV6 HV5 HV4 HV3 HV2 HV1 HV0                                 |
| Reset = \$32                                                                                           |                                                                |
|                                                                                                        | Contains the host command interrupt address                    |

Figure D-10 Host Interrupt Vector and Command Vector

| Application:                                                              | Date:                                            |
|---------------------------------------------------------------------------|--------------------------------------------------|
|                                                                           | Programmer:                                      |
|                                                                           | Sheet 6 of 6                                     |
| HOST (HDI08)                                                              | Processor Side                                   |
| Host Receive I                                                            | Data (HLEND = 0)                                 |
| 7   0 7   0                                                               | 0 7 0 7 0                                        |
| Receive Low Byte Receive Middle Byte                                      | Receive High Byte Not Used                       |
|                                                                           | <del>                                     </del> |
| \$7 \$6                                                                   | \$5 \$4                                          |
| Host Receive I                                                            | Data (HLEND = 1)  ▼                              |
| 7   0 7   0                                                               | 0 7 1 0 7 1 0                                    |
| Receive Low Byte Receive Middle Byte                                      | Receive High Byte Not Used                       |
|                                                                           | 0 0 0 0 0 0 0                                    |
| \$5 \$6                                                                   | \$7 \$4                                          |
| \$7, \$6, \$5, \$4 Read Only<br>Reset = Empty                             | rte Registers  Data (HLEND = 0)                  |
| HOST Hansinit                                                             | V                                                |
|                                                                           | 0 7   0 7   0                                    |
| Transmit Low Byte Transmit Middle Byte                                    | Transmit High Byte Not Used                      |
|                                                                           | <del>                                     </del> |
| \$7 \$6                                                                   | \$5 \$4                                          |
| Host Transmit I                                                           | Data (HLEND = 1)                                 |
|                                                                           | 0 7   0 7   0                                    |
| Transmit Low Byte Transmit Middle Byte                                    | Transmit High Byte Not Used                      |
|                                                                           |                                                  |
| \$5 \$6                                                                   | \$7 \$4                                          |
| Transmit Byte Registers<br>\$7, \$6, \$5, \$4 Write Only<br>Reset = Empty | yte Registers                                    |

Figure D-11 Host Receive and Transmit Byte Registers



Figure D-12 SHI Slave Address and Clock Control Registers

| Application:                    |                                                                                                                                                          |                                       |                            |                                                                                                     | Dat                                    |                                                           |                    |
|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------|----------------------------|-----------------------------------------------------------------------------------------------------|----------------------------------------|-----------------------------------------------------------|--------------------|
|                                 |                                                                                                                                                          |                                       |                            |                                                                                                     | Pro                                    | gramme                                                    | r:<br>Sheet 2 of 3 |
| SHI Host Transmit Data Register | SHI Host Transmit <sup>23</sup> 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0  Data Register (HTX)  X:\$FFFF93 Write Only  Reset = \$xxxxxx | SHI Host Transmit Data Register (HTX) | Host Receive Data Register | SHI Host Receive 23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1 0  Data Register (HRX) | X:\$FFFF94 Read Only Reset = \$xxxxxxx | SHI Host Receive Data Register (HRX) (FIFO) 10 words deep |                    |

Figure D-13 SHI Transmit and Receive Data Registers



Figure D-14 SHI Host Control/Status Register



Figure D-15 ESAI Transmit Clock Control Register



Figure D-16 ESAI Transmit Control Register

| Picke is input   | Application:                                                                                   |                                                                                                                                                                              | Date:                                                                                                             |
|------------------|------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------|
| Control Register |                                                                                                |                                                                                                                                                                              | Programmer:                                                                                                       |
| Pescription      | _                                                                                              | Bets divide rate for receiver high freque Range \$0 - \$F (1 -16). See 8.3.3.4  [4:0] Description  Controls frame rate dividers Range 00000 - 11111 (1-32)  RPSR Description | 1   Divide by 8 prescaler operational   1   Divide by 8 prescaler bypassed     1   Divide by 8 prescaler bypassed |
| !   <del>-</del> | HCKR is input HCKR is output HCKR is output  RFSD Description  O FSR is input  T FSR is output | Interr   1   1   RFS                                                                                                                                                         | RCKP RFSP RCKP RFSP RFP2 RFP2 RFP2 RFP2 RFP2 RFP2 RFP2 RFP                                                        |

Figure D-17 ESAI Receive Clock Control Register



Figure D-18 ESAI Receive Control Register



Figure D-19 ESAI Common Control Register



Figure D-20 ESAI Status Register

| Application: |                                                    |                                                                                                                                               | Date:        |              |
|--------------|----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|
|              |                                                    |                                                                                                                                               | Programmer:_ |              |
|              |                                                    |                                                                                                                                               |              | Sheet 1 of 2 |
|              | Channel A Validity (XVA) Channel A User Data (XUA) | Channel B Validity (XVB) Channel B User Data (XUB)  23 22 21 20 19 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 4 4 4 8 8 8 8 8 8 8 8 8 8 8 8 8 8 8 |              |              |

Figure D-21 DAX Non-Audio Data Register



Figure D-22 DAX Control and Status Registers

| Application:             |               |      |      |    |       |     |     |       |       |      |       |      |      | _   | Da    | ite:_ |       |      |      |      |        |
|--------------------------|---------------|------|------|----|-------|-----|-----|-------|-------|------|-------|------|------|-----|-------|-------|-------|------|------|------|--------|
|                          |               |      |      |    |       |     |     |       |       |      |       |      |      |     | Pro   | ogra  | mm    | er:_ |      |      |        |
|                          |               |      |      |    |       |     |     |       |       |      |       |      |      |     |       |       |       |      | Sh   | eet  | 1 of 3 |
| TE(                      | $\mathcal{L}$ |      |      |    |       |     |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |
| PS (1:0)                 |               |      |      |    | ource | •   |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |
| 00                       | Inter         |      | LK/2 |    |       |     |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |
| 01                       | TIO0          |      |      |    |       |     |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |
| 10<br>11                 | Rese          |      |      |    |       |     |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |
|                          | Nese          | iveu |      |    |       |     |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |
| 23 22 21                 | 20            | 19   | 18   | 17 | 16    | 15  | 14  | 13    | 12    | 11   | 10    | 9    | 8    | 7   | 6     | 5     | 4     | 3    | 2    | 1    | 0_     |
| <b>*</b> PS1 PS0         |               |      |      |    |       |     |     |       |       |      | oad \ |      |      |     |       |       |       |      |      |      |        |
|                          |               |      |      |    |       |     |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |
| Timer Pres               |               |      |      |    |       | r   |     |       |       |      |       |      |      |     | * =   | Res   | erve  | d, P | rogr | am a | as 0   |
| Reset = \$0              |               |      |      |    |       |     |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |
|                          |               |      |      |    |       |     |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |
|                          |               |      |      |    |       |     |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |
|                          |               |      |      |    |       |     |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |
|                          |               |      |      |    |       |     |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |
|                          |               |      |      |    |       |     |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |
|                          |               |      |      |    |       |     |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |
| 00 00 04                 | 00            | 40   | 40   | 47 | 40    | 4.5 | 4.4 | 40    | 40    | 44   | 40    | ^    | _    | 7   | •     | _     | 4     | 0    | _    | ,    | 0      |
| 23 22 21<br><b>* * *</b> | <u> 20</u>    | 19   | 18   | 17 | 16    | 15  |     |       |       |      |       |      |      | 7   | 6     |       |       | 3    |      | 1    | 0      |
|                          |               |      |      |    |       |     | Cυ  | ırrer | nt Va | llue | of P  | resc | aler | Cou | ınteı | r (PC | C [0: | 20]) |      |      |        |
|                          | •             |      |      |    |       |     |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |
|                          |               |      |      |    |       |     |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |
| Timer Pres               |               |      |      |    |       | er  |     |       |       |      |       |      |      |     | *=    | Rese  | erve  | d, P | rogr | am a | as 0   |
| Reset = \$0              |               |      |      |    | •     |     |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |
|                          |               |      |      |    |       |     |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |
|                          |               |      |      |    |       |     |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |
|                          |               |      |      |    |       |     |     |       |       |      |       |      |      |     |       |       |       |      |      |      |        |

Figure D-23 Timer Prescaler Load and Prescaler Count Registers (TPLR, TPCR)

| Application:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                   |                                      |                                   | Date:                                        |                                                                              |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|--------------------------------------|-----------------------------------|----------------------------------------------|------------------------------------------------------------------------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                   |                                      |                                   | Progra                                       | ammer:                                                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                   |                                      |                                   |                                              | Sheet 2 of 3                                                                 |
| Inverter Bit 8  0 = 0- to-1 transit or high pulse widtlen and the second of the second | h measured, or hi | gh pulse out<br>ncrement the         | put on TI<br>counter.             | Ó                                            |                                                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                   | Т                                    | imer Co                           | ntrol Bits                                   | 4 – 7 (TC0 – TC3)                                                            |
| Timer Reload Mode Bit 9 0 = Timer operates as a free running counter                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                   | TC (3:0)                             | TIO                               | Clock                                        | Mode                                                                         |
| 1 = Timer is reloaded when selected condition occurs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                   | 0000<br>0001<br>0010<br>0011         | GPIO<br>Output<br>Output<br>Input | Internal<br>Internal<br>Internal<br>External | Timer Timer Pulse Timer Toggle Event Counter                                 |
| Direction Bit 11 0 = TIO pin is input 1 = TIO pin is output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                   | 0100<br>0101<br>0110<br>0111         | Input<br>Input<br>Input<br>Output | Internal<br>Internal<br>Internal<br>Internal | Input Width Input Period Capture Pulse Width Modulation                      |
| Data Input Bit 12 0 = Zero read on TIO pin 1 = One read on TIO pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                   | 1000<br>1001<br>1010<br>1011<br>1100 | –<br>Output<br>Output<br>–<br>–   | –<br>Internal<br>Internal<br>–<br>–          | Reserved Watchdog Pulse Watchdog Toggle Reserved Reserved                    |
| Data Output Bit 13 0 = Zero written to TIO pin 1 = One written to TIO pin                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | 7                 | 1101<br>1110<br>1111                 | -<br>-<br>-                       | -<br>-<br>-                                  | Reserved<br>Reserved                                                         |
| Prescaled Clock Enable Bit 15 0 = Clock source is CLK/2 or TIO 1 = Clock source is prescaler output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                   |                                      | Timer O                           | verflow In                                   | Timer Enable Bit 0 0 = Timer Disabled 1 = Timer Enabled terrupt Enable Bit 1 |
| Timer Compare Flag Bit 21 0 = "1" has been written to TCSR(TCF),                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                   |                                      |                                   |                                              | upts Disabled<br>upts Enabled                                                |
| or timer compare interrupt serviced  1 = Timer Compare has occurred                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                   | 0 = C                                | ompare I                          | re Interru<br>nterrupts [<br>nterrupts E     |                                                                              |
| Timer Overflow Flag Bit 20 0 = "1" has been written to TCSR(TOF), or timer Overflow interrupt serviced                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                   |                                      |                                   |                                              |                                                                              |
| 1 = Counter wraparound has occurred                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                   |                                      |                                   |                                              |                                                                              |
| 23 22 21 20 19 18 17 16 15<br>* * TCF TOF * * * * * PCE<br>0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                   | 1 10 9<br>IR <b>*</b> TRM            | 8 7<br>INV TC:                    | 6 5<br>3 TC2 TC                              |                                                                              |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                   |                                      |                                   |                                              |                                                                              |
| Timer Control/Status Register TCSR0:\$FFFF8F Read/Write TCSR1:\$FFFF8B Read/Write TCSR2:\$FFFF87 Read/Write Reset = \$000000                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | Note that for Tim |                                      |                                   |                                              | served, Program as 0 the only valid combination.                             |

Figure D-24 Timer Control/Status Register

| Application:                                                                                  |                      |           |       |           |         |    | _ | Da  | te: _ |     |      |     |       |      |
|-----------------------------------------------------------------------------------------------|----------------------|-----------|-------|-----------|---------|----|---|-----|-------|-----|------|-----|-------|------|
|                                                                                               |                      |           |       |           |         |    | _ | Pro | grai  | nme | r: _ |     |       |      |
|                                                                                               |                      |           |       |           |         |    |   |     |       |     |      | She | eet 3 | of 3 |
| TEC                                                                                           |                      |           |       |           |         |    |   |     |       |     |      |     |       |      |
| 23 22 21 20 19 1                                                                              | 8 17 16 15           | 5 14 13   | 12    | 11 10     | 9       | 8  | 7 | 6   | 5     | 4   | 3    | 2   | 1     | 0    |
|                                                                                               | Timer Reload Value   |           |       |           |         |    |   |     |       |     |      |     |       |      |
|                                                                                               |                      |           |       |           |         |    |   |     |       |     |      |     |       |      |
| Timer Load Register TLR0:\$FFFF8E Write TLR1:\$FFFF8A Write TLR2:\$FFFF86 Write               | e Only<br>e Only     |           |       |           |         |    |   |     |       |     |      |     |       |      |
| Reset = \$XXXXXX                                                                              |                      |           |       |           |         |    |   |     |       |     |      |     |       |      |
|                                                                                               |                      |           |       |           |         |    |   |     |       |     |      |     |       |      |
| 23 22 21 20 19 1                                                                              | 8 17 16 15           | 5 14 13   | 12    | 11 10     | 9       | 8  | 7 | 6   | 5     | 4   | 3    | 2   | 1     | 0    |
|                                                                                               | V                    | alue Comp | ared  | to Counte | er Valu | ıe |   |     |       |     |      |     |       |      |
|                                                                                               |                      |           |       |           |         |    |   |     |       |     |      |     |       |      |
| Timer Compare Regi<br>TCPR0:\$FFFF8D Re<br>TCPR1:\$FFFF89 Red<br>TCPR2:\$FFFF85 Red           | ad/Write<br>ad/Write |           |       |           |         |    |   |     |       |     |      |     |       |      |
| Reset = \$XXXXXX                                                                              |                      |           |       |           |         |    |   |     |       |     |      |     |       |      |
|                                                                                               |                      |           |       |           |         |    |   |     |       |     |      |     |       |      |
| 23 22 21 20 19 1                                                                              | 8 17 16 15           | 5 14 13   | 12    | 11 10     | 9       | 8  | 7 | 6   | 5     | 4   | 3    | 2   | 1     | 0    |
|                                                                                               |                      | Time      | er Co | unt Value |         |    |   |     |       |     |      |     |       |      |
|                                                                                               |                      |           |       |           |         |    |   |     |       |     |      |     |       |      |
| Timer Count Registe TCR0:\$FFFF8C Reac TCR1:\$FFFF88 Reac TCR2:\$FFFF84 Reac Reset = \$000000 | d Only<br>d Only     |           |       |           |         |    |   |     |       |     |      |     |       |      |

Figure D-25 Timer Load, Compare and Count Registers

| Application:                                                                          |            |                |            |                |                |            |              |          |          |          | Dat      | e:           |          |              |          |          |
|---------------------------------------------------------------------------------------|------------|----------------|------------|----------------|----------------|------------|--------------|----------|----------|----------|----------|--------------|----------|--------------|----------|----------|
|                                                                                       |            |                |            |                |                |            |              |          |          |          | Pro      | gramr        | ner:     |              |          |          |
|                                                                                       |            |                |            |                |                |            |              |          |          |          |          |              |          | She          | eet 1 of | f 3      |
| GPIO                                                                                  | )          |                |            |                | F              | Port E     | 3 (HD        | 108)     |          |          |          |              |          |              |          |          |
| Host Data<br>Direction Register                                                       | 15<br>DR15 | <b>14</b> DR14 | 13<br>DR13 | <b>12</b> DR12 | <b>11</b> DR11 | 10<br>DR10 | <b>9</b> DR9 | 8<br>DR8 | <b>7</b> | 6<br>DR6 | 5<br>DR5 | <b>4</b> DR4 | 3<br>DR3 | <b>2</b> DR2 | <b>1</b> | O<br>DR0 |
| (HDDR) X:\$FFFFC8 Read/Write                                                          |            |                |            |                |                |            |              |          |          |          |          |              |          |              |          |          |
| Reset = $\$0$ DRx = 1 $\rightarrow$ PBx is Output  DRx = 0 $\rightarrow$ PBx is Input |            |                |            |                |                |            |              |          |          |          |          |              |          |              |          |          |
| Host Data                                                                             | 15         | 14             | 13         | 12             | 11             | 10         | 9            | 8        | 7        | 6        | 5        | 4            | 3        | 2            | 1        | 0        |
| Register<br>(HDR)                                                                     | D15        | D14            | D13        | D12            | D11            | D10        | D9           | D8       | D7       | D6       | D5       | D4           | D3       | D2           | D1       | D0       |
| X:\$FFFFC9<br>Read/Write<br>Reset = Undefined                                         |            |                |            |                |                | ı          |              |          |          |          |          |              |          |              |          |          |
| Dx holds value of corresponding HDI08 GPIO pin. Function depends on HDDR.             |            |                |            |                |                |            |              |          |          |          |          |              |          |              |          |          |
| See the HDI08 HPCR Register (Figure D-8) for additional Port B GPIO control bits.     |            |                |            |                |                |            |              |          |          |          |          |              |          |              |          |          |

Figure D-26 GPIO Port B

|                                                                                                                                                                                                                  | Date:                                                                                                                                   |  |  |  |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
|                                                                                                                                                                                                                  | Programmer: Sheet 2 c                                                                                                                   |  |  |  |  |  |
| GPIO                                                                                                                                                                                                             | Port C (ESAI)                                                                                                                           |  |  |  |  |  |
| Port C Control Register<br>(PCRC)<br>X:\$FFFFBF<br>Read/Write<br>Reset = \$0                                                                                                                                     | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$                                                                                  |  |  |  |  |  |
| Port C Direction Register<br>(PRRC)<br>X:\$FFFFBE<br>Read/Write<br>Reset = \$0                                                                                                                                   | 23 ··· 11 10 9 8 7 6 5 4 3 2 1 (  * PDC11 PDC10 PDC9 PDC8 PDC7 PDC6 PDC5 PDC4 PDC3 PDC2 PDC1 PD  * = Reserved, Program as 0             |  |  |  |  |  |
| PCn = 0 & PDCn = 0 -> Port pin PCn disconnected PCn = 1 & PDCn = 0 -> Port pin PCn configured as input PCn = 0 & PDCn = 1 -> Port pin PCn configured as output PCn = 1 & PDCn = 1 -> Port pin configured as ESAI |                                                                                                                                         |  |  |  |  |  |
| Port C GPIO Data Register                                                                                                                                                                                        | 23···11 10 9 8 7 6 5 4 3 2 1 0  * PD11 PD10 PD9 PD8 PD7 PD6 PD5 PD4 PD3 PD2 PD1 PD0  * PD1 PD10 PD9 PD8 PD7 PD6 PD5 PD4 PD3 PD2 PD1 PD0 |  |  |  |  |  |

Figure D-27 GPIO Port C

| Application:                                                                                                         | _                                              | Date:                               | _            |
|----------------------------------------------------------------------------------------------------------------------|------------------------------------------------|-------------------------------------|--------------|
|                                                                                                                      |                                                | Programmer: _                       |              |
|                                                                                                                      |                                                |                                     | Sheet 3 of 3 |
| GPIO                                                                                                                 | Port D (DAX)                                   |                                     |              |
| Port D Control Register (PCRD) X:\$FFFD7 Read/Write Reset = \$0                                                      | 36 5 4 3<br>* X * X * X<br>0 0 0 0             | 2 1 0<br>* PC1 PC0<br>0 as 0        |              |
| Port D Direction Register (PRRD) X:\$FFFFD6 Read/Write Reset = \$0                                                   |                                                | 2 1 0<br>* PDC1 PDC0<br>0 as 0      |              |
| PCn = 0 & PDCn = 0 -> Port<br>PCn = 1 & PDCn = 0 -> Port<br>PCn = 0 & PDCn = 1 -> Port<br>PCn = 1 & PDCn = 1 -> Port | pin PDn configured as<br>pin PDn configured as | s input<br>s output                 |              |
| Port D GPIO Data Register (PDRD) X:\$FFFFD5 Read/Write Reset = \$0                                                   | * * * *                                        | 3 2 1 0<br>* * PD1 PD0<br>0 0 0 PD1 |              |
| If port pin n is GPIO input, th                                                                                      |                                                |                                     | in n         |
|                                                                                                                      |                                                |                                     |              |

Figure D-28 GPIO Port D

| A                                                    | Transmit Register Empty Interrupt Handling, 10-13                                    |
|------------------------------------------------------|--------------------------------------------------------------------------------------|
| adder                                                | DAX Audio Data register Empty (XADE) status                                          |
| modulo, 1-5                                          | flag, 10-9                                                                           |
| offset, 1-6                                          | DAX Audio Data Registers (XADRA/XADRB), 10-5                                         |
| reverse-carry, 1-6                                   | DAX Audio Data Shift Register (XADSR), 10-6, 10-6<br>DAX biphase encoder, 10-10      |
| Address Generation Unit, 1-5                         | DAX biphase encoder, 10-10 DAX Block transfer (XBLK) flag, 10-9                      |
| addressing modes, 1-6                                | DAX Channel A Channel status (XCA) bit, 10-7                                         |
| AES/EBU, 1-13, 10-1                                  | DAX Channel A Channel status (ACA) bit, 10-7 DAX Channel A User data (XUA) bit, 10-6 |
| AGU, 1-5                                             | DAX Channel A Validity (XVA) bit, 10-6                                               |
|                                                      | DAX Channel B Channel Status (XCB) bit, 10-7                                         |
| D                                                    | DAX Channel B User Data (XUB) bit, 10-7                                              |
| В                                                    | DAX Channel B Validity (XVB) bit, 10-7                                               |
| barrel shifter, 1-4                                  | DAX Clock input Select bits, 10-8                                                    |
| bootstrap, 4-4                                       | DAX clock multiplexer, 10-11                                                         |
| bootstrap from byte-wide external memory, 4-6        | DAX clock selection, 10-8                                                            |
| bootstrap program options                            | DAX Control Register (XCTR), 10-7                                                    |
| invoking, 4-5                                        | DAX internal architecture, 10-5                                                      |
| bootstrap ROM, 3-2                                   | DAX Interrupt Enable (XIEN) bit, 10-8, 10-8, 10-8                                    |
| bootstrap through HI08 (68302/68360), 4-11           | DAX Non-Audio Data Buffer (XNADBUF), 10-7                                            |
| bootstrap through HI08 (ISA), 4-7, 4-7, 4-8, 4-8, 4- | DAX Operation During Stop, 10-15                                                     |
| 9, 4-9, 4-9, 4-10                                    | DAX Parity Generator (PRTYG), 10-10                                                  |
| bootstrap through HI08 (Multiplexed), 4-11           | DAX preamble generator, 10-10                                                        |
| bootstrap through HI08 (non-multiplexed), 4-10       | DAX Preamble sequence, 10-11, 10-15                                                  |
| bootstrap through SCI, 4-6                           | DAX Programming Considerations, 10-12                                                |
| bus                                                  | DAX programming model, 10-4                                                          |
| address, 2-2                                         | DAX Status Register (XSTR), 10-9                                                     |
| data, 2-2                                            | DAX Transmit Underrun error (XAUR) status                                            |
| multiplexed, 2-2                                     | flag, 10-9                                                                           |
| non-multiplexed, 2-2<br>buses                        | DI, 9-11                                                                             |
| internal, 1-7                                        | Digital Audio Transmitter, 2-16                                                      |
| internal, 1-7                                        | Digital Audio Transmitter (DAX), 1-13, 10-1                                          |
|                                                      | DIR, 9-10                                                                            |
| C                                                    | Divide Factor (DF), 1-8                                                              |
| Central Processing Unit (CPU), 1-1                   | DMA, 1-8                                                                             |
| CLKGEN, 1-8                                          | triggered by timer, 9-24                                                             |
| clock, 1-2                                           | DO bit, 9-11                                                                         |
| Clock divider, 8-14                                  | DO loop, 1-6                                                                         |
| Clock Generator (CLKGEN), 1-8                        | DRAM, 1-10                                                                           |
| CMOS, 1-2                                            | DSP56300 core, 1-1                                                                   |
| code                                                 | DSP56300 Family Manual, 1-1, 1-2                                                     |
| compatible, 1-2                                      | DSP56303 Technical Data, 1-1                                                         |
| CP-340, 1-13, 10-1                                   |                                                                                      |
| CPHA and CPOL (HCKR Clock Phase and Polarity         | E                                                                                    |
| Controls), 7-9                                       | ESAI, 2-2                                                                            |
|                                                      | ESAI block diagram, 8-1                                                              |
| D                                                    | ESSI0 (GPIO), 5-2                                                                    |
|                                                      | ESSI1 (GPIO), 5-2                                                                    |
| data ALU, 1-4                                        | expanded mode, 4-5                                                                   |
| registers, 1-5                                       | external bus control, 2-7, 2-7                                                       |
| Data Output bit (DO), 9-11                           |                                                                                      |
| DAX, 2-2, 2-16                                       | _                                                                                    |
| Block Transferred Interrupt Handling, 10-13          | F                                                                                    |
| Initiating A Transmit Session, 10-12                 | frequency                                                                            |

MOTOROLA Index-1

| operation, 1-2<br>functional groups, 2-2<br>functional signal groups, 2-1                 | HRQE0-HRQE1 (HCSR Host Request Enable), 7-14<br>HTDE (HCSR Host Transmit Data Empty), 7-16<br>HTIE (HCSR Transmit Interrupt Enable), 7-15<br>HTUE (HCSR Host Transmit Underrun Error), 7-16 |
|-------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| G                                                                                         |                                                                                                                                                                                             |
| Global Data Bus, 1-7                                                                      | I                                                                                                                                                                                           |
| GPIO, 1-11, 2-2, 2-2, 2-20                                                                | I <sup>2</sup> C, 1-12, 7-1, 7-18                                                                                                                                                           |
| GPIO (ESSI0, Port C), 5-2                                                                 | Bit Transfer, 7-19                                                                                                                                                                          |
| GPIO (ESSI1, Port D), 5-2                                                                 | Bus Protocol For Host Read Cycle, 7-21                                                                                                                                                      |
| GPIO (HI08, Port B), 5-1                                                                  | Bus Protocol For Host Write Cycle, 7-21                                                                                                                                                     |
| GPIO (Timer), 5-2                                                                         | Data Transfer Formats, 7-21                                                                                                                                                                 |
| Ground, 2-4                                                                               | Master Mode, 7-26                                                                                                                                                                           |
| PLL, 2-4                                                                                  | Protocol for Host Write Cycle, 7-21                                                                                                                                                         |
|                                                                                           | Receive Data In Master Mode, 7-27                                                                                                                                                           |
|                                                                                           | Receive Data In Slave Mode, 7-25                                                                                                                                                            |
| Н                                                                                         | Slave Mode, 7-24                                                                                                                                                                            |
| HA1, HA3-HA6 (HSAR I <sup>2</sup> C Slave Address), 7-8                                   | Start and Stop Events, 7-20                                                                                                                                                                 |
| hardware stack, 1-6                                                                       | Transmit Data In Master Mode, 7-28, 7-28                                                                                                                                                    |
| HBER (HCSR Bus Error), 7-17                                                               | Transmit Data In Slave Mode, 7-25, 7-25                                                                                                                                                     |
| HBIE (HCSR Bus Error Interrupt Enable), 7-15                                              | I <sup>2</sup> C Bus Acknowledgment, 7-20                                                                                                                                                   |
| HBUSY (HCSR Host Busy), 7-18                                                              | I <sup>2</sup> C Mode, 7-1                                                                                                                                                                  |
| HCKR (SHI Clock Control Register), 7-8                                                    | IEC958, 1-13, 10-1                                                                                                                                                                          |
| HCSR                                                                                      | instruction cache, 3-2                                                                                                                                                                      |
| Receive Interrupt Enable Bits, 7-16                                                       | instruction set, 1-2                                                                                                                                                                        |
| SHI Control/Status Register, 7-12                                                         | Inter Integrated Circuit Bus, 1-12, 7-1                                                                                                                                                     |
| HDI08, 2-2, 2-10, 2-11, 2-12, 2-13, 2-13<br>HDM0-HDM5 (HCKR Divider Modulus Select), 7-10 | internal buses, 1-7                                                                                                                                                                         |
| HEN (HCSR SHI Enable), 7-12                                                               | Internal Exception Priorities                                                                                                                                                               |
| HFIFO (HCSR FIFO Enable Control), 7-13                                                    | SHI, 7-6 interrupt, 1-6                                                                                                                                                                     |
| HFM0-HFM1 (HCKR Filter Mode), 7-11                                                        | interrupt, 1-0 interrupt and mode control, 2-8, 2-9                                                                                                                                         |
| HI08, 1-11                                                                                | interrupt and mode control, 2-6, 2-9                                                                                                                                                        |
| (GPIO), 5-1                                                                               | Interrupt Vectors                                                                                                                                                                           |
| HI <sup>2</sup> C (HCSR Serial Host Interface I <sup>2</sup> C/SPI                        | SHI, 7-6                                                                                                                                                                                    |
| Selection), 7-12                                                                          | INV, 9-9                                                                                                                                                                                    |
| HIDLE (HCSR Idle), 7-14                                                                   |                                                                                                                                                                                             |
| HM0-HM1 (HCSR Serial Host Interface Mode), 7-12                                           |                                                                                                                                                                                             |
| HMST (HCSR Master Mode), 7-13                                                             | J                                                                                                                                                                                           |
| Host                                                                                      | JTAG, 1-2, 1-8, 1-8, 2-21                                                                                                                                                                   |
| Receive Data FIFO (HRX), 7-7                                                              |                                                                                                                                                                                             |
| Receive Data FIFO—DSP Side, 7-7                                                           | L                                                                                                                                                                                           |
| Transmit Data Register (HTX), 7-7                                                         |                                                                                                                                                                                             |
| Transmit Data Register—DSP Side, 7-7                                                      | LA register, 1-7                                                                                                                                                                            |
| Host Interface, 1-11, 2-2, 2-10, 2-11, 2-12, 2-13, 2-13                                   | LC register, 1-7                                                                                                                                                                            |
| host port                                                                                 | logic, 1-2<br>Loop Address register (LA), 1-7                                                                                                                                               |
| configuration, 2-10                                                                       | Loop Counter register (LC), 1-7                                                                                                                                                             |
| Host Request<br>Double, 2-2                                                               | Loop Counter register (LC), 1-7                                                                                                                                                             |
| Single, 2-2                                                                               |                                                                                                                                                                                             |
| HREQ Function In SHI Slave Modes, 7-14                                                    | M                                                                                                                                                                                           |
| HRFF (HCSR Host Receive FIFO Full), 7-17                                                  | MAC, 1-5                                                                                                                                                                                    |
| HRIE0-HRIE1 (HCSR Receive Interrupt Enable), 7-                                           | Manual Conventions, ii, ii                                                                                                                                                                  |
| 15                                                                                        | memory                                                                                                                                                                                      |
| HRNE (HCSR Host Receive FIFO Not Empty), 7-17                                             | bootstrap ROM, 3-2                                                                                                                                                                          |
| HROE (HCSR Host Receive Overrun Error), 7-17                                              | expansion, 1-10                                                                                                                                                                             |
|                                                                                           |                                                                                                                                                                                             |

Index-2 MOTOROLA

| external expansion port, 1-10 off-chip, 1-10 on-chip, 1-9, 1-9 program RAM, 3-2 X data RAM, 3-4 Y data RAM, 3-4 MIPS, 1-2 mode control, 2-8, 2-9 modulo adder, 1-5 multiplexed bus, 2-2 multiplier-accumulator (MAC), 1-4, 1-5 | Peripheral I/O Expansion Bus, 1-7 PIC, 1-6 PL0-PL20 bits, 9-5 PL21-PL22 bits, 9-5 PLL, 1-8 Port A, 2-2 Port B, 2-2, 2-2, 2-11, 2-11, 2-12, 2-12, 2-13, 5-1 Port C, 2-2, 2-16, 5-2 Port D, 2-2, 2-16, 5-2 power low, 1-2 management, 1-2 Prescaler Counter, 9-5 |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| non-multiplexed bus, 2-2                                                                                                                                                                                                       | Prescaler Counter Value bits (PC0-PC20), 9-6<br>Prescaler Load Value bits (PL0-PL20), 9-5<br>Prescaler Source bits (PL21-PL22), 9-5                                                                                                                            |
| 0                                                                                                                                                                                                                              | Program Address Bus (PAB), 1-7                                                                                                                                                                                                                                 |
|                                                                                                                                                                                                                                | Program Address Generator (PAG), 1-6                                                                                                                                                                                                                           |
| offset adder, 1-6<br>OMR register, 1-7                                                                                                                                                                                         | Program Control Unit (PCU), 1-6                                                                                                                                                                                                                                |
| OnCE, 1-2                                                                                                                                                                                                                      | Program Counter register (PC), 1-6<br>Program Data Bus (PDB), 1-7                                                                                                                                                                                              |
| OnCE module, 1-9, 2-21                                                                                                                                                                                                         | Program Decode Controller (PDC), 1-6                                                                                                                                                                                                                           |
| On-Chip Emulation (OnCE) module, 1-9                                                                                                                                                                                           | Program Interrupt Controller (PIC), 1-6                                                                                                                                                                                                                        |
| on-chip memory, 1-9                                                                                                                                                                                                            | Program Memory Expansion Bus, 1-7                                                                                                                                                                                                                              |
| program, 3-2                                                                                                                                                                                                                   | program RAM, 3-2                                                                                                                                                                                                                                               |
| X data RAM, 3-4                                                                                                                                                                                                                | Programming Model                                                                                                                                                                                                                                              |
| Y data RAM, 3-4                                                                                                                                                                                                                | SHI—DSP Side, 7-5                                                                                                                                                                                                                                              |
| operating mode                                                                                                                                                                                                                 | SHI—Host Side, 7-4                                                                                                                                                                                                                                             |
| bootstrap from byte-wide external memory, 4-6                                                                                                                                                                                  |                                                                                                                                                                                                                                                                |
| bootstrap thorugh HI08 (68302/68360), 4-11 bootstrap through HI08 (ISA), 4-7, 4-7, 4-8, 4-8, 4-                                                                                                                                | R                                                                                                                                                                                                                                                              |
| 9, 4-9, 4-9, 4-10                                                                                                                                                                                                              | reserved bits                                                                                                                                                                                                                                                  |
| bootstrap through HI08 (multiplexed), 4-11                                                                                                                                                                                     | in TCSR register                                                                                                                                                                                                                                               |
| bootstrap through HI08 (non-multiplexed), 4-10                                                                                                                                                                                 | bits 3, 10, 14, 16–19, 22, 23, 9-12                                                                                                                                                                                                                            |
| bootstrap through SCI, 4-6                                                                                                                                                                                                     | in TPCR, 9-6                                                                                                                                                                                                                                                   |
| expanded, 4-5                                                                                                                                                                                                                  | in TPLR, 9-6                                                                                                                                                                                                                                                   |
| expanded mode, 4-8                                                                                                                                                                                                             | RESET, 2-9                                                                                                                                                                                                                                                     |
| Operating Mode Register (OMR), 1-7                                                                                                                                                                                             | reverse-carry adder, 1-6                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                | ROM                                                                                                                                                                                                                                                            |
| P                                                                                                                                                                                                                              | bootstrap, 3-2                                                                                                                                                                                                                                                 |
| PAB, 1-7                                                                                                                                                                                                                       |                                                                                                                                                                                                                                                                |
| PAG, 1-6                                                                                                                                                                                                                       | S                                                                                                                                                                                                                                                              |
| Patch Enable (PEN) bit (OMR bit 23), 3-9                                                                                                                                                                                       | SC register, 1-7                                                                                                                                                                                                                                               |
| Patch Mode, 3-9                                                                                                                                                                                                                | Serial Host Interface, 2-14                                                                                                                                                                                                                                    |
| initializing, 3-9                                                                                                                                                                                                              | Serial Host Interface (SHI), 1-12, 7-1                                                                                                                                                                                                                         |
| example code, 3-9                                                                                                                                                                                                              | Serial Host Interface—See Section 5                                                                                                                                                                                                                            |
| PC register, 1-6                                                                                                                                                                                                               | Serial Peripheral Interface Bus, 1-12, 7-1                                                                                                                                                                                                                     |
| PC0-PC20 bits, 9-6                                                                                                                                                                                                             | SHI, 1-12, 2-2, 2-14, 7-1                                                                                                                                                                                                                                      |
| PCE, 9-11                                                                                                                                                                                                                      | Block Diagram, 7-3                                                                                                                                                                                                                                             |
| PCU, 1-6                                                                                                                                                                                                                       | Clock Control Register—DSP Side, 7-8                                                                                                                                                                                                                           |
| PDB, 1-7                                                                                                                                                                                                                       | Clock Generator, 7-3, 7-4, 7-4                                                                                                                                                                                                                                 |
| PDC, 1-6                                                                                                                                                                                                                       | Control/Status Register—DSP Side, 7-12                                                                                                                                                                                                                         |
| PEN, 3-9 DEN bit (OMB bit 23), 3, 0                                                                                                                                                                                            | Data Size, 7-12                                                                                                                                                                                                                                                |
| PEN bit (OMR bit 23), 3-9                                                                                                                                                                                                      | Exception Priorities, 7-6                                                                                                                                                                                                                                      |

MOTOROLA Index-3

| HCKR                                                       | SPI Mode, 7-1                                     |
|------------------------------------------------------------|---------------------------------------------------|
| Clock Phase and Polarity Controls, 7-9                     | SR register, 1-6                                  |
| Divider Modulus Select, 7-10                               | SRAM                                              |
| Prescaler Rate Select, 7-10                                | interfacing, 1-10                                 |
| HCKR Filter Mode, 7-11                                     | SS, 1-7                                           |
| HCSR                                                       | Stack Counter register (SC), 1-7                  |
| Bus Error Interrupt Enable, 7-15                           | Stack Pointer (SP), 1-7                           |
| FIFO Enable Control, 7-13                                  | standby                                           |
| Host Request Enable, 7-14                                  | mode                                              |
| Idle, 7-14                                                 | Stop, 1-2                                         |
| Master Mode, 7-13                                          | Wait, 1-2                                         |
| Serial Host Interface I <sup>2</sup> C/SPI Selection, 7-12 | Status Register (SR), 1-6                         |
| Serial Host Interface Mode, 7-12                           | stop                                              |
| SHI Enable, 7-12                                           | standby mode, 1-2                                 |
| Host Receive Data FIFO—DSP Side, 7-7                       | System Stack (SS), 1-7                            |
| Host Transmit Data Register—DSP Side, 7-7                  | SZ register, 1-7                                  |
| HREQ                                                       |                                                   |
| Function In SHI Slave Modes, 7-14<br>HSAR                  | Т                                                 |
| I <sup>2</sup> C Slave Address, 7-8                        | TAP, 1-8                                          |
| Slave Address Register, 7-8                                | TC0–TC3 bits, 9-7                                 |
| I/O Shift Register, 7-7                                    | TCF, 9-12                                         |
| Input/Output Shift Register—Host Side, 7-6                 | TCIE bit, 9-7                                     |
| Internal Architecture, 7-2, 7-2                            | TCPR, 9-13                                        |
| Internal Interrupt Priorities, 7-6                         | TCR, 9-13                                         |
| Interrupt Vectors, 7-6                                     | TCSR register, 9-7                                |
| Introduction, 7-1                                          | bit 0—Timer Enable bit (TE), 9-7                  |
| Operation During Stop, 7-29                                | bit 2—Timer Compare Interrupt Enable bit          |
| Programming Considerations, 7-22                           | (TCIE), 9-7                                       |
| Programming Model, 7-4                                     | bits 4–7—Timer Control bits (TC0–TC3), 9-7        |
| Programming Model—DSP Side, 7-5                            | bit 13—Data Output bit (DO), 9-11                 |
| Programming Model—Host Side, 7-4                           | reserved bits—bits 3, 10, 14, 16–19, 22, 23, 9-12 |
| Slave Address Register—DSP Side, 7-8                       | TE bit, 9-7                                       |
| SHI Noise Reduction Filter Mode, 7-11                      | Test Access Port (TAP), 1-8                       |
| signal groupings, 2-1                                      | Timer, 2-2, 2-20                                  |
| signals, 2-1                                               | timer                                             |
| functional grouping, 2-2                                   | special cases, 9-24                               |
| Sixteen-bit Compatibility, 3-1                             | Timer (GPIO), 5-2                                 |
| Size register (SZ), 1-7                                    | Timer Compare Interrupt Enable bit (TCIE), 9-7    |
| SP, 1-7                                                    | Timer Control bits (TC0–TC3), 9-7                 |
| SPI, 1-12, 7-1                                             | Timer Control/Status Register (TCSR), 9-7         |
| HCSR                                                       | Timer Enable bit (TE), 9-7                        |
| Bus Error, 7-17                                            | timer mode                                        |
| Host Busy, 7-18                                            | mode 0—GPIO, 9-14                                 |
| Host Receive FIFO Full, 7-17                               | mode 1—timer pulse, 9-15                          |
| Host Receive FIFO Not Empty, 7-17                          | mode 2—timer toggle, 9-16                         |
| Host Receive Overrun Error, 7-17                           | mode 3—timer event counter, 9-17                  |
| Host Transmit Data Empty, 7-16                             | mode 4—measurement input width, 9-18              |
| Host Transmit Underrun Error, 7-16                         | mode 5—measurement input period, 9-19             |
| Receive Interrupt Enable, 7-15, 7-15                       | mode 6—measurement capture, 9-20                  |
| Master Mode, 7-23                                          | mode 7—pulse width modulation, 9-21               |
| Slave Mode, 7-22                                           | mode 8—reserved, 9-22                             |
| SPI Data-To-Clock Timing, 7-9                              | mode 9—watchdog pulse, 9-22, 9-23                 |
| SPI Data-To-Clock Timing Diagram, 7-9                      | modes 11–15—reserved, 9-24                        |
|                                                            |                                                   |

Index-4 MOTOROLA

```
Timer module
  architecture, 9-1
Timer Prescaler Count Register (TPCR), 9-6
Timer Prescaler Load Register (TPLR), 9-5
Timer/Event Counter module, 1-12
TLR, 9-12
TOF, 9-11
TOIE, 9-7
TPCR register, 9-6
  bits 0-20—Prescaler Counter Value bits (PC0-
      PC20), 9-6
  bit 21-23—reserved bits, 9-6
  reserved bits-bits 21-23, 9-6
TPLR register, 9-5
  bits 0-20-Prescaler Load Value bits (PL0-
      PL20), 9-5
  bits 21-22—Prescaler Source bits (PL0-PL20), 9-5
  bit 23—reserved bit, 9-6
  reserved bit-bit 23, 9-6
Transmitter High Frequency Clock Divider, 8-14
triple timer module, 1-12
TRM, 9-10
٧
VBA register, 1-7
Vector Base Address register (VBA), 1-7
W
  standby mode, 1-2
X
X data RAM, 3-4
X Memory Address Bus (XAB), 1-7
X Memory Data Bus (XDB), 1-7
X Memory Expansion Bus, 1-7
XAB, 1-7
XDB, 1-7
Υ
Y data RAM, 3-4
Y Memory Address Bus (YAB), 1-7
Y Memory Data Bus (YDB), 1-7
Y Memory Expansion Bus, 1-7
YAB, 1-7
YDB, 1-7
```

MOTOROLA Index-5

Index-6 MOTOROLA



How to reach us:

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

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

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

#### Japan:

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

#### Internet:

http://www.motorola-dsp.com

 $\label{eq:DSP} \textbf{DSP helpline email:}$ 

dsphelp@dsp.sps.motcom

DSP56362UM/D Revision 2 09/00