# **DSP56301**

## 24-BIT DIGITAL SIGNAL PROCESSOR USER'S MANUAL



Motorola, Inc. Semiconductor Products Sector DSP Division 6501 William Cannon Drive, West Austin, Texas 78735-8598



## **TABLE OF CONTENTS**

| Paragraph<br>Number | Title        | Page<br>Number |
|---------------------|--------------|----------------|
|                     | INTRODUCTION |                |

| 1 CHIP DESCRIPTION |  |
|--------------------|--|
| DSP56301 Features  |  |

## **PINS DESCRIPTION**

| 2 PINS DESCRIPTION                                              | 2-3  |
|-----------------------------------------------------------------|------|
| 2.1 PACKAGE                                                     | 2-3  |
| 2.2 PINOUT                                                      | 2-3  |
| 2.2.1 Interrupt And Mode Control (5 Pins)                       |      |
| 2.2.2 Clock (2 Pins)                                            |      |
| 2.2.3 On-chip Emulator Interface (OnCE)/JTAG Interface (6 Pins) | 2-5  |
| 2.2.4 Expansion Port (Port A) (63 Pins)                         |      |
| 2.2.5 Host Interface (HI32) (52 Pins)                           | 2-10 |
| 2.2.6 Enhanced Synchronous Serial Interface 0 (ESSI 0) (6 Pins) | 2-13 |
| 2.2.7 Enhanced Synchronous Serial Interface 1 (ESSI 1) (6 Pins) | 2-14 |
| 2.2.8 Serial Communication Interface (SCI) (3 Pins)             | 2-16 |
| 2.2.9 Triple Timer (3 Pins)                                     | 2-16 |
| 2.2.10 Phase-Locked Loop (PLL) (3 Pins)                         |      |
| 2.2.11 Power & Ground (51 Pins)                                 |      |
|                                                                 |      |

## **MEMORY MAPS**

| 3 MEMORY MAPS                                            | 3-3      |
|----------------------------------------------------------|----------|
| 3.1 INTRODUCTION                                         | 3-3      |
| 3.2 DSP56301 MEMORY MAPS                                 | 3-3      |
| 3.2.1 On-chip X Data Memory                              |          |
| 3.2.2 On-chip Y Data Memory                              | 3-4      |
| 3.2.3 On-chip Program Memory                             |          |
| 3.3 DSP56301 INTERNAL I/O MEMORY MAP                     | 3-5      |
| 3.4 DSP56301 MEMORY MAPS IN SIXTEEN-BIT COMPATIBILITY MC | DDE 3-12 |

## **CORE CONFIGURATION**

| 4 CORE CONFIGURATION                                                   | 4-3         |
|------------------------------------------------------------------------|-------------|
| 4.1 INTRODUCTION                                                       |             |
| 4.2 CHIP OPERATING MODES                                               | 4-3         |
| 4.2.1 Mode 0: Expanded mode                                            |             |
| 4.2.2 Mode 1: Bootstrap from byte-wide external memory                 |             |
| 4.2.3 Mode 2: Bootstrap thru SCI                                       | 4-4         |
| 4.2.4 Mode 3: Reserved                                                 | 4-4         |
| 4.2.5 Mode 4: Bootstrap thru HI32 in PCI mode                          |             |
| 4.2.6 Mode 5: Bootstrap thru HI32 in 16-bit-wide UB mode (ISA)         |             |
| 4.2.7 Mode 6: Bootstrap thru HI32 in 8-bit-wide UB mode in double-stro | be pin con- |
| figuration                                                             |             |
| 4.2.8 Mode 7: Bootstrap thru HI32 in 8-bit-wide UB mode in single-stro |             |
| figuration                                                             |             |
| 4.2.9 Mode 8: Expanded mode                                            |             |
| 4.3 BOOTSTRAP PROGRAM                                                  |             |
| 4.4 INTERRUPT SOURCES AND PRIORITIES                                   |             |
| 4.4.1 Interrupt Sources                                                |             |
| 4.4.2 Interrupt Priority Levels                                        |             |
| 4.4.2.1 Interrupt Sources Priorities within an IPL                     | 4-11        |

| Paragraph<br>Number | Title | Page<br>Number |
|---------------------|-------|----------------|
|                     |       |                |

| 4.5 DMA REQUEST SOURCES                 | 4-13 |
|-----------------------------------------|------|
| 4.6 OPERATING MODE REGISTER             |      |
| 4.7 PLL MULTIPLICATION FACTOR           | 4-15 |
| 4.8 DEVICE IDENTIFICATION (ID) REGISTER | 4-15 |
| 4.9 JTAG IDENTIFICATION (ID) REGISTER   |      |
| 4.10 JTAG BOUNDARY SCAN REGISTER        | 4-16 |

## PERIPHERALS

| 5 GENERAL PURPOSE I/O                                       | 5-3  |
|-------------------------------------------------------------|------|
| 5.1 INTRODUCTION                                            |      |
| 5.2 PROGRAMMING MODEL                                       | 5-3  |
| 5.2.1 Port B pins and registers                             | 5-3  |
| 5.2.2 Port C pins and registers                             |      |
| 5.2.3 Port D pins and registers                             | 5-3  |
| 5.2.4 Port E pins and registers                             |      |
| 5.2.5 Triple Timer pins                                     | 5-4  |
| 6 HOST INTERFACE (HI32)                                     | 6-1  |
| 6.1 HI32 - DSP SIDE                                         | 6-8  |
| 6.1.1 DSP Control Register (DCTR)                           |      |
| 6.1.1.1 Host Command Interrupt Enable (HCIE) Bit 0          | 6-9  |
| 6.1.1.2 Slave Transmit Interrupt Enable (STIE) Bit 1        |      |
| 6.1.1.3 Slave Receive Interrupt Enable (SRIE) Bit 2         | 6-10 |
| 6.1.1.4 Host Flags (HF5-HF3) Bits 5-3                       | 6-10 |
| 6.1.1.5 Host Interrupt A (HINT) Bit 6                       | 6-10 |
| 6.1.1.6 Host Data Strobe Mode (HDSM) Bit 13                 | 6-10 |
| 6.1.1.7 Host Read/Write Polarity (HRWP) Bit 14              |      |
| 6.1.1.8 Host Transfer Acknowledge Polarity (HTAP) Bit 15    | 6-11 |
| 6.1.1.9 Host DMA Request Polarity (HDRP) Bit 16             | 6-11 |
| 6.1.1.10 Host Reset Polarity (HRSP) Bit 17                  |      |
| 6.1.1.11 Host Interrupt Request Handshake Mode(HIRH) Bit 18 |      |
| 6.1.1.12 Host Interrupt Request Drive Control (HIRD) Bit 19 |      |
| 6.1.1.13 HI32 Mode (HM2-HM0) Bits 22-20                     |      |
| 6.1.1.14 DCTR Reserved Control Bits 23, 12-7                |      |
| 6.1.2 DSP PCI Control Register (DPCR)                       |      |
| 6.1.2.1 Master Transmit Interrupt Enable (MTIE) Bit 1       | 6-17 |

| Table of Contents (Continued) |                                                                      |                |
|-------------------------------|----------------------------------------------------------------------|----------------|
| Paragraph<br>Number           | Title                                                                | Page<br>Number |
|                               |                                                                      |                |
| 6.1                           | .2.2 Master Receive Interrupt Enable (MRIE) Bit 2                    | 6-17           |
|                               | .2.3 Master Address Interrupt Enable (MAIE) Bit 4                    |                |
|                               | .2.4 Parity Error Interrupt Enable (PEIE) Bit 5                      |                |
|                               | .2.5 Transaction Abort Interrupt Enable (TAIE) Bit 7                 |                |
|                               | .2.6 Transaction Termination Interrupt Enable (TTIE) Bit 9           |                |
|                               | .2.7 Transfer Complete Interrupt Enable (TCIE) Bit 12                |                |
|                               | .2.8 Clear Transmitter (CLRT) Bit 14                                 |                |
|                               | .2.9 Master Transaction Termination (MTT) Bit 15                     |                |
| 6.1                           | .2.10 System Error Force (SERF) Bit 16                               | 6-19           |
| 6.1                           | .2.11 Master Access Counter Enable (MACE) Bit 18                     | 6-20           |
| 6.1                           | .2.12 Master Wait State Disable (MWSD) Bit 19                        | 6-20           |
| 6.1                           | .2.13 Receive Buffer Lock Enable (RBLE) Bit 20                       | 6-21           |
|                               | .2.14 Insert Address Enable (IAE) Bit 21                             |                |
|                               | .2.15 DPCR Reserved Control Bits 23,22,17,13,11,10,8,6,3,0           |                |
| 6.1.3 E                       | OSP PCI Master Control Register (DPMC)                               | 6-22           |
|                               | .3.1 DSP PCI Transaction Address (AR31-AR16) Bits 15-0               |                |
|                               | .3.2 DSP PCI Data Burst Length (BL5-BL0) Bits 21-16                  |                |
|                               | .3.3 DSP Data Transfer Format Control (FC1-FC0) Bits 23 and          |                |
|                               | OSP PCI Address Register (DPAR)                                      |                |
|                               | .4.1 PCI Bus Command (C3-C0) Bits 11-8                               |                |
|                               | .4.2 PCI Byte Enables (BE3-BE0) Bits 15-12                           |                |
|                               | OSP Status Register (DSR)                                            |                |
|                               | .5.1 Host Command Pending (HCP) Bit 0                                |                |
|                               | .5.2 Slave Transmit Data Request (STRQ) Bit 1                        |                |
|                               | .5.3 Slave Receive Data Request (SRRQ) Bit 2                         |                |
| 6.1                           | .5.4 Host Flags (HF2-HF0) Bits 5-3                                   |                |
|                               | .5.5 HI32 Active (HACT) Bit 23                                       |                |
|                               | .5.6 DSR Reserved Status Bits 22-6                                   |                |
| 6.1.6 L                       | OSP PCI Status Register (DPSR)                                       |                |
|                               | .6.1 PCI Master Wait State (MWS) Bit 0                               |                |
|                               | .6.2 PCI Master Transmit Data Request (MTRQ) Bit 1                   |                |
|                               | .6.3 PCI Master Receive Data Request (MRRQ) Bit 2                    |                |
|                               | .6.4 Master Address Request (MARQ) Bit 4                             |                |
|                               | .6.5 Address Parity Error (APER) Bit 5                               |                |
|                               | .6.6 Data Parity Error (DPER) Bit 6                                  |                |
|                               | .6.7 Master Abort (MAB) Bit 7                                        |                |
| 0.1                           | .6.8 Target Abort (TAB) Bit 8<br>.6.9 Target Disconnect (TDIS) Bit 9 |                |
|                               | .6.10 Target Retry (TRTY) Bit 10                                     |                |
| 0.1                           |                                                                      | 0-34           |

|          | Table of Contents (Continued)                                   |        |
|----------|-----------------------------------------------------------------|--------|
| aragraph |                                                                 | Page   |
| Number   | Title                                                           | Numb   |
|          |                                                                 |        |
| 6.1.6    | 6.11 PCI Time Out (TO) Bit 11                                   | 6-34   |
|          | 6.12 Host Data Transfer Complete (HDTC) Bit 12                  |        |
|          | 5.13 Remaining Data Count (RDC5-RDC0) Bits 21-16                |        |
|          | 6.14 DPSR Reserved Bits 23-22, 15-12 and 3                      |        |
|          | ost To DSP Data Path                                            |        |
| 6.1.8 DS | SP Receive Data FIFO (DRXR)                                     | 6-36   |
| 6.1.9 DS | SP To Host Data Path                                            | 6-36   |
| 6.1.10 D | OSP Master Transmit Data Register (DTXM)                        | 6-37   |
|          | OSP Slave Transmit Data Register (DTXS)                         |        |
|          | OSP Host Port GPIO Data Register (DATH)                         |        |
|          | SP Host Port GPIO Direction Register (DIRH)                     |        |
|          | IOST SIDE                                                       |        |
| 6.2.1 HI | 32 Control Register (HCTR)                                      | 6-44   |
|          | .1 Transmit Request Enable (TREQ) Bit 1                         |        |
| 6.2.1    | .2 Receive Request Enable (RREQ) Bit 2                          | 6-45   |
|          | .3 Host Flags (HF2-HF0) Bits 5 and 3                            |        |
| 6.2.1    | .4 DMA Enable (DMAE) Bit 6                                      | 6-46   |
|          | .5 Slave Fetch Type (SFT) Bit 7                                 |        |
| 6.2.1    | .6 Host Transmit Data Transfer Format (HTF1-HTF0) Bits 9 and 8. | 6-49   |
| 6.2.1    | .7 Host Receive Data Transfer Format (HRF1-HRF0) Bits 12 and 1  | 1 6-52 |
| 6.2.1    | .8 Host Semaphores (HS2-HS0) Bits 16 and 14                     | 6-53   |
| 6.2.1    | .9 Target Wait State Disable (TWSD) Bit 19                      | 6-53   |
| 6.2.1    | .10 HCTR Reserved Control Bits 31-20, 18-17, 13, 10 and 0       | 6-55   |
| 6.2.2 HI | 32 Status Register (HSTR)                                       | 6-55   |
|          | 2.1 Transmitter Ready (TRDY) Bit 0                              |        |
| 6.2.2    | 2.2 Host Transmit Data Request (HTRQ) Bit 1                     | 6-56   |
| 6.2.2    | 2.3 Host Receive Data Request (HRRQ) Bit 2                      | 6-57   |
|          | 2.4 Host Flags (HF5-HF3) Bits 5, 4 and 3                        |        |
| 6.2.2    | 2.5 Host Interrupt A (HINT) Bit 6                               | 6-57   |
| 6.2.2    | 2.6 Host Request (HREQ) Bit 7                                   | 6-58   |
| 6.2.2    | 2.7 HSTR Reserved Status Bits 31-8                              | 6-58   |
| 6.2.3 Ho | ost Command Vector Register (HCVR)                              | 6-58   |
| 6.2.3    | 8.1 Host Command (HC) Bit 0                                     | 6-59   |
| 6.2.3    | 3.2 Host Vector (HV6-HV0) Bits 7-1                              | 6-60   |
| 6.2.3    | 3.3 Host Non-Maskable Interrupt (HNMI) Bit 15                   | 6-60   |
|          | 3.4 HCVR Reserved Bits 31-16, 14-8                              |        |
|          | ost Slave Receive Data Register (HRXS)                          |        |
|          | ost Master Receive Data Register (HRXM)                         |        |
|          | ost Transmit Data Register (HTXR)                               |        |

|             | Table of Contents (Continued)                             |          |
|-------------|-----------------------------------------------------------|----------|
| Paragraph   |                                                           | Page     |
| Number      | Title                                                     | Number   |
|             |                                                           |          |
| 6.2.7 Devi  | ice/Vendor ID Configuration Register (CDID/CVID)          | 6-64     |
| 6.2.8 Stat  | us/Command Configuration Register (CSTR/CCMR)             | 6-65     |
|             | Memory Space Enable (MSE) Bit 1                           |          |
|             | 2 Bus Master Enable (BM) Bit 2                            |          |
|             | B Parity Error Response (PERR) Bit 6                      |          |
|             | Wait Cycle Control (WCC) Bit 7                            |          |
|             | 5 System Error Enable (SERE) Bit 8                        |          |
|             | S Fast Back-to-Back Capable (FBBC) Bit 23                 |          |
| 6.2.8.7     | Z Data Parity Reported (DPR) Bit 24                       | 6-67     |
|             | B DEVSEL Timing (DST1-DST0) Bits 26 and 25                |          |
|             | Signaled Target Abort (STA) Bit 27                        |          |
|             | 0 Received Target Abort (RTA) Bit 28                      |          |
|             | 1 Received Master Abort (RMA) Bit 29                      |          |
|             | 2 Signaled System Error (SSE) Bit 30                      |          |
|             | 3 Detected Parity Error (DPE) Bit 31                      |          |
|             | 4 CSTR Reserved Bits 23-16                                |          |
|             | 5 CCMR Reserved Bits 15-10                                |          |
|             | 6 CCMR Not Implemented Bits 9, 5-3                        |          |
|             | s Code/Revision ID Configuration Register (CCCR/CRID)     |          |
| 6.2.10 He   | ader Type/Latency Timer Configuration Register (CHTY/CL/  | AT) 6-69 |
|             | .1 Header Type (HT7-HT0) Bits 23-16                       |          |
|             | .2 Latency Timer (LT7-LT0) Bits 15-8                      |          |
|             | .3 CHTY/CLAT Not Implemented Bits 31-24,7-0               |          |
|             | mory Space Base Address Configuration Register (CBMA).    |          |
|             | .1 Memory Space Indicator (MSI) Bit 0                     |          |
|             | .2 Memory Space (MS1-MS0) Bits 2 and 1                    |          |
|             | .3 Pre-fetch (PF) Bit 3                                   |          |
|             | .4 Memory Base Address (PM31-PM16) Bits 31-4              |          |
|             | .5 Universal Bus Mode Base Address (GB10-GB3) Bits 23-1   |          |
|             | errupt Line - Interrupt Pin Configuration Register (CILP) |          |
| 6.3 SELF CO | NFIGURATION MODE                                          | 6-73     |
| 6.3.1 Self  | Configuration Procedure for the PCI Mode                  | 6-73     |
| 6.3.2 Self  | Configuration Procedure for the Universal Bus Mode        | 6-73     |

| Paragraph<br>Number  | Title                                       | Page<br>Number |
|----------------------|---------------------------------------------|----------------|
|                      |                                             | 0.74           |
|                      |                                             |                |
|                      | TATUS AND CONFIGURATION REGISTERS           |                |
|                      | ING MODEL - QUICK REFERENCE                 |                |
|                      | URS                                         |                |
|                      | DST TO HI32 CONNECTIONS                     |                |
|                      | onnection to PCI Bus                        |                |
| 6.9.2 Example of C   | onnection to PCI bus                        | 0-90           |
| 6.9.2 Example of C   | onnection to 16-bit Data Bus (ISA/EISA Bus) |                |
| •                    | onnection to DSP56300 Core Port A Bus       |                |
| 7 TRIPLE HIMER MOL   | DULE                                        |                |
| 7.1 INTRODUCTION     |                                             | 7-1            |
| 7.2 TRIPLE TIMER MC  | DULE - PROGRAMMING MODEL                    | 7-1            |
| 7.3 TRIPLE TIMER MC  | DULE ARCHITECTURE                           | 7-2            |
| 7.3.1 Triple Timer N | lodule Block Diagram                        | 7-2            |
|                      | Inter                                       |                |
|                      | er Load Register (TPLR)                     |                |
| 7.3.3.1 Prescale     | r Preload Value (PL0-PL20) Bits 0-20        | 7-3            |
|                      | r Source (PS0-PS1) Bits 21-22               |                |
|                      | eserved bit (Bit 23)                        |                |
|                      | er Count Register (TPCR)                    |                |
|                      | r Counter Value (PC0-PC20) Bits 0-20        |                |
|                      | eserved bits (Bits 21,22,23)                |                |
|                      | TURE                                        |                |
| 7.4.1 Timer Block D  | Diagram                                     | 7-5            |
| 7.4.2 Timer Count F  | Register (TCR)                              | 7-5            |
| 7.4.3 Timer Load R   | egister (TLR)                               | 7-5            |
|                      | re Register (TCPR)                          |                |
| 7.4.5 Timer Control  | /Status Register (TCSR)                     | 7-6            |
| 7.4.5.1 Timer Er     | nable (TE) Bit 0                            | 7-6            |
| 7.4.5.2 Timer Ov     | verflow Interrupt Enable (TOIE) Bit 1       | 7-7            |
|                      | ompare Interrupt Enable (TCIE) Bit 2        |                |
|                      | ontrol (TC0-TC3) Bits 4-7                   |                |
|                      | (INV) Bit 8                                 |                |
| 7.4.5.6 Timer re     | load mode (TRM) Bit 9                       | 7-9            |
| 7.4.5.7 Direction    | ) (DIR) Bit 11                              | 7-9            |
|                      | uṫ (DI)́ Bit 12                             |                |
| 7.4.5.9 Data Ou      | tput (DO) Bit 13                            | 7-10           |
|                      | ed Clock Enable (PCE) Bit 15                |                |
|                      | Overflow Flag (TOF) Bit 20                  |                |

| Paragraph<br>Number                                                                                                                                                                                                        | Title                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Page<br>Number                                                                                                                    |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|
| 7.4.5.1<br>7.5 TIMER FU<br>7.5.1 Time<br>7.5.1.1<br>7.5.1.2<br>7.5.1.3<br>7.5.1.4<br>7.5.2 Mea<br>7.5.2.1<br>7.5.2.2<br>7.5.2.3<br>7.5.2.3<br>7.5.2.4<br>7.5.3 PWN<br>7.5.3.1<br>(mode<br>7.5.4 Wato<br>7.5.4.1<br>7.5.4.2 | 2 Timer Compare Flag (TCF) Bit 21                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 7-11<br>7-11<br>7-11<br>7-11<br>7-11<br>7-12<br>7-12<br>7-12                                                                      |
| 7.5.6 Spec<br>7.5.6.1                                                                                                                                                                                                      | cial Cases<br>Timer behavior during WAIT and STOP<br>A trigger                                                                                                                                                                                                                                                                                                                                                                                                                                             | 7-15<br>7-15                                                                                                                      |
|                                                                                                                                                                                                                            | SYNCHRONOUS SERIAL INTERFACE (ESSI)                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                   |
| 8.2 ESSI DAT<br>8.2.1 Seria<br>8.2.2 Seria<br>8.2.3 Seria<br>8.2.4 Seria<br>8.2.6 Seria<br>8.3 ESSI PRO<br>8.3.1 ESS<br>8.3.1.1<br>8.3.1.2<br>8.3.1.3<br>8.3.1.4                                                           | JCTION<br>TA AND CONTROL PINS<br>al Transmit Data Pin (STD)<br>al Receive Data Pin (SRD)<br>al Clock (SCK)<br>al Control Pin (SC0)<br>al Control Pin (SC1)<br>al Control Pin (SC2)<br>DGRAMMING MODEL<br>I Control Register A (CRA)<br>CRA Prescale Modulus Select (PM7–PM0) Bits 7–0<br>CRA Prescale Range (PSR) Bit 11<br>CRA Prescaler Range (PSR) Bit 11<br>CRA Frame Rate Divider Control (DC4–DC0) Bits 16–12<br>CRA Alignment Control (ALC) Bit 18<br>CRA Word Length Control (WL2- WL0) Bits 21-19 | 8-1<br>8-2<br>8-2<br>8-3<br>8-3<br>8-3<br>8-3<br>8-3<br>8-3<br>8-4<br>8-4<br>8-4<br>8-6<br>8-6<br>8-6<br>8-7<br>8-7<br>8-7<br>8-7 |

|                  | Table of Contents (Continued)                                        |               |
|------------------|----------------------------------------------------------------------|---------------|
| Paragra<br>Numbe |                                                                      | Page<br>Numbe |
|                  |                                                                      |               |
|                  | 8.3.1.6 CRA Reserved Bits 8-10,17,18,22,23                           | 8-8           |
|                  | 8.3.1.7 CRA Select SC1 as Transmitter#0 drive enable (SSC1) Bit 22   |               |
| 8.               | 3.2 ESSI Control Register B (CRB)                                    |               |
| •                | 8.3.2.1 CRB Serial Output Flag 0 (OF0) Bit 0                         | 8-9           |
|                  | 8.3.2.2 CRB Serial Output Flag 1 (OF1) Bit 1                         |               |
|                  | 8.3.2.3 CRB Serial Control 0 Direction (SCD0) Bit 2                  |               |
|                  | 8.3.2.4 CRB Serial Control 1 Direction (SCD1) Bit 3                  |               |
|                  | 8.3.2.5 CRB Serial Control 2 Direction (SCD2) Bit 4                  |               |
|                  | 8.3.2.6 CRB Clock Source Direction (SCKD) Bit 5                      |               |
|                  | 8.3.2.7 CRB Shift Direction (SHFD) Bit 6.                            |               |
|                  | 8.3.2.8 CRB Frame Sync Length (FSL0 and FSL1) Bits 7 and 8           |               |
|                  | 8.3.2.9 CRB Frame Sync Relative Timing (FSR) Bit 9                   |               |
|                  | 8.3.2.10 CRB Frame Sync Polarity (FSP) Bit 10                        |               |
|                  | 8.3.2.11 CRB Clock Polarity (CKP) Bit 11                             |               |
|                  | 8.3.2.12 CRB Synchronous /Asynchronous (SYN) Bit 12                  |               |
|                  | 8.3.2.13 CRB ESSI Mode Select (MOD) Bit 13                           |               |
|                  | 8.3.2.14 CRB ESSI Transmit #2 Enable (TE2) Bit 14                    |               |
|                  | 8.3.2.15 CRB ESSI Transmit #1 Enable (TE1) Bit 15                    |               |
|                  | 8.3.2.16 CRB ESSI Transmit #0 Enable (TE0) Bit 16                    |               |
|                  | 8.3.2.17 CRB ESSI Receive Enable (RE) Bit 17                         | 8-14          |
|                  | 8.3.2.18 CRB ESSI Transmit Interrupt Enable (TIE) Bit 18             |               |
|                  | 8.3.2.19 CRB ESSI Receive Interrupt Enable (RIE) Bit 19              | 8-14          |
|                  | 8.3.2.20 CRB ESSI Transmit Last slot Interrupt Enable (TLIE) Bit 20  | 8-14          |
|                  | 8.3.2.21 CRB ESSI Receive Last slot Interrupt Enable (RLIE) Bit 21   | 8-15          |
|                  | 8.3.2.22 CRB ESSI Transmit Exception Interrupt Enable (TEIE) Bit 22. | 8-15          |
|                  | 8.3.2.23 CRB ESSI Receive Exception Interrupt Enable (REIE) Bit 23   |               |
| 8.               | 3.3 ESSI Status Register (SSISR)                                     | 8-15          |
|                  | 8.3.3.1 SSISR Serial Input Flag 0 (IF0) Bit 0                        | 8-15          |
|                  | 8.3.3.2 SSISR Serial Input Flag 1 (IF1) Bit 1                        | 8-15          |
|                  | 8.3.3.3 SSISR Transmit Frame Sync Flag (TFS) Bit 2                   |               |
|                  | 8.3.3.4 SSISR Receive Frame Sync Flag (RFS) Bit 3                    | 8-16          |
|                  | 8.3.3.5 SSISR Transmitter Underrun Error Flag (TUE) Bit 4            | 8-16          |
|                  | 8.3.3.6 SSISR Receiver Overrun Error Flag (ROE) Bit 5                | 8-16          |
|                  | 8.3.3.7 SSISR ESSI Transmit Data Register Empty (TDE) Bit 6          |               |
|                  | 8.3.3.8 SSISR ESSI Receive Data Register Full (RDF) Bit 7            | 8-17          |
|                  | 3.4 ESSI Receive Shift Register                                      | 8-17          |
|                  | 3.5 ESSI Receive Data Register (RX)                                  |               |
| 8.               | 3.6 ESSI Transmit Shift Registers                                    | 8-17          |
| 8.               | 3.7 ESSI Transmit Data Registers (TX2,TX1,TX0)                       | 8-18          |

| Paragraph      |                                                     | Page   |
|----------------|-----------------------------------------------------|--------|
| Number         | Title                                               | Number |
|                |                                                     |        |
|                | I Time Slot Register (TSR)                          |        |
|                | smit Slot Mask Registers (TSMA, TSMB)               |        |
|                | ceive Slot Mask Registers (RSMA, RSMB)              |        |
|                | NG MODES                                            |        |
|                | I After Reset                                       |        |
|                | I Initialization                                    |        |
|                | I Exceptions                                        |        |
|                | rating Modes – Normal, Network, and On-Demand       |        |
|                | Normal/Network/On-Demand Mode Selection             |        |
|                | Synchronous/Asynchronous Operating Modes            |        |
|                | Frame Sync Selection                                |        |
|                | Shift Direction Selection                           |        |
| 0              | S                                                   |        |
| •              | ns and registers                                    |        |
|                | Control Register (PCR)                              |        |
|                | Direction Register (PRR)                            |        |
| 8.5.3 Port     | Data register (PDR)                                 | 8-25   |
| 9 SERIAL CO    | MMUNICATION INTERFACE (SCI)                         |        |
| 9.1 INTRODU    | ICTION                                              |        |
| 9.2 SCI I/O Pi | ns                                                  |        |
| 9.2.1 Rece     | eive Data (RXD)                                     |        |
|                | smit Data (TXD)                                     |        |
|                | Serial Clock (SĆLK)                                 |        |
|                | GRAMMING MODEL                                      |        |
|                | Control Register (SCR)                              |        |
|                | SCR Word Select (WDS0, WDS1, WDS2) Bits 0, 1, and 2 |        |
|                | SCR SCI Shift Direction (SSFTD) Bit 3               |        |
|                | SCR Send Break (SBK) Bit 4                          |        |
|                | SCR Wakeup Mode Select (WAKE) Bit 5                 |        |
|                | SCR Receiver Wakeup Enable (RŴU) Bit 6              |        |
|                | SCR Wired-OR Mode Select (WOMS) Bit 7               |        |
|                | SCR Receiver Enable (RE) Bit 8                      |        |
| 9.3.1.8        | SCR Transmitter Enable (TE) Bit 9                   |        |
|                | SCR Idle Line Interrupt Enable (ILIE) Bit 10        |        |
|                | 0 SCR SCI Receive Interrupt Enable (RIE) Bit 11     |        |
|                | 1 SCR SCI Transmit Interrupt Enable (TIE) Bit 12    |        |
|                | 2 SCR Timer Interrupt Enable (TMIE) Bit 13          |        |
|                | 3 SCI Timer Interrupt Rate (STIR) Bit 14            |        |
|                | 4 SCR SCI Clock Polarity (SCKP) Bit 15              |        |
| 3.3.1.1        |                                                     |        |

|                  | Table of Contents (Continued)                       |             |
|------------------|-----------------------------------------------------|-------------|
| Paragraph        |                                                     | Page        |
| Number           | Title                                               | Numbe       |
|                  |                                                     |             |
| 9.3.1.15 SC      | R SCI Receive with Exception Interrupt Enable (REIE | ) Bit 169-8 |
| 9.3.2 SCI Statu  | s Register (SSR)                                    |             |
| 9.3.2.1 SSR      | Transmitter Empty (TRNE) Bit 0                      | 9-8         |
| 9.3.2.2 SSR      | Transmit Data Register Empty (TDRE) Bit 1           | 9-8         |
| 9.3.2.3 SSR      | Receive Data Register Full (RDRF) Bit 2             | 9-9         |
|                  | Idle Line Flag (IDLE) Bit 3                         |             |
| 9.3.2.5 SSR      | Overrun Error Flag (OR) Bit 4                       | 9-9         |
|                  | Parity Error (PE) Bit 5                             |             |
| 9.3.2.7 SSR      | Framing Error Flag (FE) Bit 6                       | 9-9         |
| 9.3.2.8 SSR      | Received Bit 8 (R8) Address Bit 7                   | 9-10        |
| 9.3.3 SCI Clock  | Control Register (SCCR)                             | 9-10        |
| 9.3.3.1 SCC      | R Clock Divider (CD11–CD0) Bits 11–0                | 9-10        |
| 9.3.3.2 SCC      | R Clock Out Divider (COD) Bit 12                    | 9-11        |
|                  | R SCI Clock Prescaler (SCP) Bit 13                  |             |
| 9.3.3.4 SCC      | R Receive Clock Mode Source Bit (RCM) Bit 14        | 9-11        |
|                  | R Transmit Clock Source Bit (TCM) Bit 15            |             |
| 9.3.4 SCI Data   | Registers                                           | 9-11        |
| 9.3.4.1 SCI      | Receive Registers                                   | 9-11        |
|                  | Transmit Registers                                  |             |
|                  | , Break, and Data Transmission Priority             |             |
|                  | NODES                                               |             |
| 9.4.1 Register ( | Contents After Reset                                | 9-14        |
|                  | ization                                             |             |
| 9.4.3 SCI Exce   | ptions                                              | 9-16        |
|                  | d registers                                         |             |
|                  | rol Register (PCR)                                  |             |
|                  | ction Register (PRR)                                |             |
|                  | register (PDR)                                      |             |

## APPENDIX

| A-1 BOOTSTRAP PROGRAM | A-3  |
|-----------------------|------|
| A-2 XI/O EQUATES      | A-12 |
| A-3 INTERRUPT EQUATES | A-24 |

## LIST of FIGURES

| Figure<br>Number                                                        | Title                                                                                                                                                                                                                        | Page<br>Number       |
|-------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|
|                                                                         |                                                                                                                                                                                                                              |                      |
| 1                                                                       | CHIP DESCRIPTION                                                                                                                                                                                                             |                      |
| Figure 1-1.                                                             | DSP56301 Block Diagram                                                                                                                                                                                                       | 1-5                  |
| 2                                                                       | PINS DESCRIPTION                                                                                                                                                                                                             |                      |
| Figure 2-1.<br>Figure 2-2.                                              | DSP56301 Functional Signal Groups (w/PCI port)<br>DSP56301 Functional Signal Groups (w/universal bus port)                                                                                                                   |                      |
| 3                                                                       | MEMORY MAPS                                                                                                                                                                                                                  |                      |
| Figure 3-1.<br>Figure 3-2.                                              | DSP56301 Memory Map<br>DSP56301 Memory Map in Sixteen Bit Compatibility Mode                                                                                                                                                 |                      |
| 4                                                                       | CORE CONFIGURATION                                                                                                                                                                                                           |                      |
| Figure 4-1.<br>Figure 4-2.<br>Figure 4-3.<br>Figure 4-4.<br>Figure 4-5. | Interrupt Priority Register P<br>Interrupt Priority Register C<br>DSP56301 Operating Mode Register (OMR) Format<br>Identification Register Configuration<br>JTAG Identification Register Configuration                       | 4-10<br>4-15<br>4-16 |
| 5                                                                       | GENERAL PURPOSE I/O                                                                                                                                                                                                          |                      |
| 6                                                                       | HOST INTERFACE (HI32)                                                                                                                                                                                                        |                      |
| Figure 6-1.<br>Figure 6-2.<br>Figure 6-3.<br>Figure 6-4.<br>Figure 6-5. | HI32 Block Diagram<br>HI32 Programming Model - DSP Side<br>Host Side Registers (PCI Memory Address Space)<br>Host Side Registers (PCI Configuration Address Space)<br>Host Side Registers (Universal Bus Mode Address Space) | 6-8<br>6-43<br>6-43  |
| 7                                                                       | TRIPLE TIMER MODULE                                                                                                                                                                                                          |                      |
| Figure 7-1.<br>Figure 7-2.<br>Figure 7-3.                               | Timer Prescaler Load Register<br>Triple Timer Module Block Diagram<br>Timer Prescaler Count Register                                                                                                                         | 7-3                  |

| List of Figures (Continued)                                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Figure<br>Number                                                                                                                                                    | Page<br>Title Numb                                                                                                                                                                                                                                                                                                                                                                             |
| Figure 7-4.<br>Figure 7-5.                                                                                                                                          | 24 bit Timer Module Block Diagram7-<br>Timer Module Programming Model7-                                                                                                                                                                                                                                                                                                                        |
| 8                                                                                                                                                                   | ENHANCED SYNCHRONOUS SERIAL INTERFACE (ESSI)                                                                                                                                                                                                                                                                                                                                                   |
| Figure 8-1.<br>Figure 8-2.<br>Figure 8-3.<br>Figure 8-4.<br>Figure 8-5.<br>Figure 8-6.<br>Figure 8-7.<br>Figure 8-8.<br>Figure 8-9.<br>Figure 8-10.<br>Figure 8-11. | ESSI Block Diagram8-2ESSI Control Register A (CRA)8-3ESSI Control Register B (CRB)8-4ESSI Status Register (SSISR)8-4ESSI Transmit Slot Mask Register A (TSMA)8-4ESSI Transmit Slot Mask Register B (TSMB)8-4ESSI Receive Slot Mask Register A (RSMA)8-4ESSI Receive Slot Mask Register B (RSMB)8-4Port Control Register (PCR)8-24Port Direction Register (PDR)8-24Port Data Register (PDR)8-24 |
| 9                                                                                                                                                                   | SERIAL COMMUNICATION INTERFACE (SCI)                                                                                                                                                                                                                                                                                                                                                           |
| Figure 9-1.<br>Figure 9-2.<br>Figure 9-3.<br>Figure 9-4.                                                                                                            | SCI Programming Model – Control and Status Registers                                                                                                                                                                                                                                                                                                                                           |

## LIST of TABLES

| Table<br>Number                                                                                                                                          | Title                                                                                                                                                                                                                                                                                                                                                         | Page<br>Number                                                       |
|----------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|
| 1                                                                                                                                                        | CHIP DESCRIPTION                                                                                                                                                                                                                                                                                                                                              |                                                                      |
| 2                                                                                                                                                        | PINS DESCRIPTION                                                                                                                                                                                                                                                                                                                                              |                                                                      |
| 3                                                                                                                                                        | MEMORY MAPS                                                                                                                                                                                                                                                                                                                                                   |                                                                      |
| Table 3-1.                                                                                                                                               | Internal I/O Memory Map                                                                                                                                                                                                                                                                                                                                       |                                                                      |
| 4                                                                                                                                                        | CORE CONFIGURATION                                                                                                                                                                                                                                                                                                                                            |                                                                      |
| Table 4-1.<br>Table 4-2.<br>Table 4-3.<br>Table 4-4.<br>Table 4-5.                                                                                       | DSP56301 Operating Modes<br>Interrupt Sources<br>Interrupt Priority Level Bits<br>Interrupt Sources Priorities within an IPL<br>DSP56301 BSR Bit Definition                                                                                                                                                                                                   | 4-6<br>4-8<br>4-11                                                   |
| 5                                                                                                                                                        | GENERAL PURPOSE I/O                                                                                                                                                                                                                                                                                                                                           |                                                                      |
| 6                                                                                                                                                        | HOST INTERFACE (HI32)                                                                                                                                                                                                                                                                                                                                         |                                                                      |
| Table 6-1.<br>Table 6-2.<br>Table 6-3.<br>Table 6-4.<br>Table 6-5.<br>Table 6-6.<br>Table 6-7.<br>Table 6-8.<br>Table 6-9.<br>Table 6-10.<br>Table 6-11. | HI32 Modes<br>Host Port Pin Functionality<br>HI32 (PCI Master) Data Transfer Formats<br>PCI Bus Commands Supported by the HI32 as PCI Master<br>DATH and DIRH Functionality<br>HIRQ and HDRQ Pin Definition<br>DMAE Definition<br>Transmit Data Transfer Format<br>Receive Data Transfer Format<br>Host Port Pins - Detailed Description<br>Interrupt Vectors | 6-16<br>6-24<br>6-26<br>6-39<br>6-46<br>6-47<br>6-51<br>6-54<br>6-75 |
| 7                                                                                                                                                        | TRIPLE TIMER MODULE                                                                                                                                                                                                                                                                                                                                           |                                                                      |
| Table 7-1.<br>Table 7-2.<br>Table 7-3.<br>Table 7-4.<br>Table 7-5.                                                                                       | Triple Timer Module Programming Model - Timer 0<br>Triple Timer Module Programming Model - Timer 1<br>Triple Timer Module Programming Model - Timer 2<br>Common Prescaler Registers<br>Prescaler Source Selection.                                                                                                                                            | 7-1<br>7-2<br>7-2                                                    |

### List of Tables (Continued)

| Table<br>Number          | Title                                                                                            | Page<br>Number |
|--------------------------|--------------------------------------------------------------------------------------------------|----------------|
|                          |                                                                                                  |                |
| Table 7-6.               | Timer Control Bits                                                                               | 7-8            |
| 8                        | ENHANCED SYNCHRONOUS SERIAL INTERFACE                                                            | E (ESSI)       |
| Table 8-1.               | ESSI Clock Sources                                                                               |                |
| Table 8-2.               | ESSI word length selection                                                                       |                |
| Table 8-3.<br>Table 8-4. | Mode and Pin Definition Table<br>Port Control Register and Port Direction Register bits function |                |
|                          |                                                                                                  | anty . 0-20    |
| 9                        | SERIAL COMMUNICATION INTERFACE (SCI)                                                             |                |
| Table 9-1.               | Word Formats                                                                                     | 9-4            |
| Table 9-2.               | SCI Registers after Reset                                                                        |                |
| Table 9-3.               | Port Control Register and Port Direction Register bits function                                  | ality.9-18     |

## 1 CHIP DESCRIPTION

This document describes the DSP56301, a new member of the 56300 DSP family of programmable CMOS digital signal processors. The DSP56301 is based on the powerful New DSP Engine (DSP56300) core capable of executing an instruction on every clock cycle, thus yielding a twofold performance increase as compared to the existing 56000 core while maintaining object code compatibility with it.

The DSP56300 core is composed of the Data ALU, Address Generation Unit, Program Controller, Instruction-Cache Controller, Bus Interface Unit, DMA Controller, On-chip Emulator and a PLL based clock oscillator. The DSP56300 core-based family members are DSP chips that contain the DSP56300 core and additional modules. The modules are chosen from a library of standard pre-designed elements such as memories, peripherals etc. New modules may be added to the library as required by customer specifications. A standard interface between the DSP56300 core and the on-chip memory and peripherals supports all memory and peripheral configurations.

The DSP56301 block diagram is shown in Figure 1-1 and its key feature are listed below.

The design priorities for the DSP56301 chip are:

- 1. Low-cost
- 2. Low-power dissipation
- 3. High-performance
- 4. High integration

### DSP56301 Features

High performance DSP56300 core

- 66/80 Million Instructions per Second (Mips) with a 66/80 Mhz clock
- Object Code Compatible with the 56K Core
- Fully pipelined 24 x 24 Bit Parallel Multiplier-Accumulator
- 56 Bit Parallel Barrel Shifter
- 16 Bit Arithmetic Support
- Highly Parallel Instruction Set
- Position Independent Code (PIC) support
- Unique DSP Addressing Modes
- On-Chip Memory-Expandable Hardware Stack
- Nested Hardware Do Loops
- Fast Auto-Return Interrupts
- On-Chip Concurrent Six-Channel DMA Controller
- On-Chip PLL
- On-Chip Emulator (OnCE)
- JTAG port

On-chip memories

- On-Chip 2048 x 24 Bit X Data RAM
- On-Chip 2048 x 24 Bit Y Data RAM
- On-Chip 3072 x 24 Bit Program RAM
- On-Chip 1024 x 24 Bit Instruction Cache/Program RAM
- On-Chip 192 x 24 Bit Bootstrap ROM

Off-chip memory expansion

- Off-Chip Expansion to two 2<sup>24</sup> 24-Bit Words of Data Memory
- Off-Chip Expansion to 2<sup>24</sup> 24-Bit Words of Program Memory
- External Memory Expansion Port
- Chip Select Logic for glueless interface to SRAMs and SSRAMs
- On-chip DRAM Controller for glueless interface to DRAMs

On-chip peripherals

- 32-Bit Parallel PCI/Universal Host Interface
- Two Enhanced Synchronous Serial Interfaces (ESSI)
- Serial Communications Interface with Baud Rate Generator (SCI)
- Triple Timer Module
- 42 Programmable General Purpose I/O Pins (GPIO)

Reduced power dissipation

- Very low power CMOS design
- Wait and Stop low power standby modes
- Fully-static logic, operation frequency down to DC.
- Power Management special circuitry



Figure 1-1. DSP56301 Block Diagram

## 2 PINS DESCRIPTION

### 2.1 PACKAGE

There are total 208 pins: 148 signal pins, 25 power pins, 26 ground pins, and 9 reserved pins.

### 2.2 PINOUT

The functional signal groups of the DSP56301 are shown in Figure 2-1 on page 2-8 and in Figure 2-1 on page 2-8 (the difference between the two configuration is the host port functionality) and are described in the following sections.

Although the DSP56301 is operated from a 3.3 volt supply, some of the input pins can tolerate 5 volt. A special notice for this feature is added to the description of those pins.

#### 2.2.1 Interrupt And Mode Control (5 Pins)

- RESET (Reset) Active low, Schmitt trigger input. RESET is internally synchronized to the clock out (CLKOUT). 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 reliably reset the chip. If RESET is negated synchronous to the clock out (CLKOUT), exact start-up timing is guaranteed, allowing multiple processors to start-up synchronously and operate together in "lock-step". When the RESET pin is negated, the initial chip operating mode is latched from the MODA, MODB, MODC and MODD pins. RESET pin can tolerate 5V.
- MODA/IRQA (Mode Select A/External Interrupt Request A) Active low Schmitt trigger input, internally synchronized to the clock out (CLKOUT). 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 operating mode register (OMR) when the RESET pin is negated. If IRQA is asserted synchronous to the clock out (CLKOUT), multiple processors can be re-synchronized using the WAIT instruction and asserting IRQA to exit the wait state. If the processor is in the STOP standby state and IRQA is asserted, the processor will exit the STOP state.

MODA/IRQA pin can tolerate 5V.

- MODB/IRQB (Mode Select B/External Interrupt Request B) Active low Schmitt trigger input, internally synchronized to the clock out (CLKOUT). 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 the operating mode register (OMR) when the RESET pin is negated. If IRQB is asserted synchronous to the clock out (CLKOUT), multiple processors can be re-synchronized using the WAIT instruction and asserting IRQB to exit the wait state. MODB/IRQB pin can tolerate 5V
- MODC/IRQC (Mode Select C/External Interrupt Request C) Active low Schmitt trigger input, internally synchronized to the clock out (CLKOUT). 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 the operating mode register (OMR) when the RESET pin is negated. If IRQC is asserted synchronous to the clock out (CLKOUT), multiple processors can be re-synchronized using the WAIT instruction and asserting IRQC to exit the wait state. MODC/IRQC pin can tolerate 5V.
- MODD/IRQD (Mode Select D/External Interrupt Request D) Active low Schmitt trigger input, internally synchronized to the clock out (CLKOUT). 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 the operating mode register (OMR) when the RESET pin is negated. If IRQD is asserted synchronous to the clock out (CLKOUT), multiple processors can be re-synchronized using the WAIT instruction and asserting IRQD to exit the wait state. MODD/IRQD pin can tolerate 5V.

#### 2.2.2 Clock (2 Pins)

- EXTAL (External Clock/Crystal Input) Interfaces the internal crystal oscillator input to an external crystal or an external clock.
- XTAL (Crystal Output) This output connects the internal crystal oscillator output to an external crystal. If an external clock is used, XTAL should not be connected.

#### 2.2.3 On-chip Emulator Interface (OnCE)/JTAG Interface (6 Pins)

- DE (Debug Event) This open drain bidirectional active low pin provides, 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 pin 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 pin 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. DE pin can tolerate 5V.
- TCK (Test Clock) The test clock input TCK pin is the test clock used to synchronize the JTAG test logic TCK pin can tolerate 5V.
- TDI (Test Data Input) The test data input TDI pin is the serial input for test instructions and data. TDI is sampled on the rising edge of TCK and it has an internal pullup resistor. TDI pin can tolerate 5V.
- TDO (Test data output) The test data output TDO pin is the serial output for test instructions and data. TDO is three-stateable and is actively driven in the shift-IR and shift-DR controller states. TDO changes on the falling edge of TCK.
- TMS (Test Mode Select) The test mode select input (TMS) pin is used to sequence the test controller's state machine. The TMS is sampled on the rising edge of TCK and it has an internal pullup resistor TMS pin can tolerate 5V.
- TRST(Test Reset) This active low Schmitt trigger input pin TRST is used to<br/>asynchronously initialize the test controller. The TRST has an internal<br/>pullup resistor<br/>TRST pin can tolerate 5V.

#### 2.2.4 Expansion Port (Port A) (63 Pins)

- A0-A23 (Address Bus) Three-state. Active high outputs when a bus master, three-stated otherwise, specify the address for external program and data memory accesses. To minimize power dissipation, A0–A23 do not change state when external memory spaces are not being accessed. A0–A23 are three-stated during hardware reset.
- D0-D23 (Data Bus) Three-state, active high, bidirectional input/outputs when a bus master. These pins provide the bidirectional data bus for external

program and data memory accesses. D0–D23 are in the high impedance state when not a bus master. They are also three-stated during hardware reset.

- AA(3:0)/RAS(3:0)(Address Attribute or Row Address Strobe) Three-state outputs with a programmable polarity. When defined as Address Attribute these signals can be used as chip selects or additional address lines. When defined as RAS these signals can be used as Row Address Strobe for DRAM interface. The AA/RAS pins are three stated during hardware reset.
- RD(Read Enable) Three-state. Active low output when bus master, three-<br/>stated otherwise. RD is asserted to read external memory on the data<br/>bus (D0–D23). RD is three-stated during hardware reset.
- WR(Write Enable) Three-state. Active low output when bus master, three-<br/>stated otherwise. WR is asserted to write external memory on the data<br/>bus (D0–D23). WR is three-stated during hardware reset.
- TA (Transfer Acknowledge) - Active low input. If the DSP56301 is the bus master and there is no external bus activity or the DSP56301 is not the bus master, the TA input is ignored. The TA input is a synchronous/ asynchronous (according to TAS bit in the OMR register) "DTACK" function which 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 TA negated. In typical operation, TA is negated at the start of a bus cycle, is asserted to enable completion of the bus cycle and is negated before the next bus cycle. The current bus cycle completes one clock period after TA is asserted synchronous to CLKOUT. The number of wait states is determined by the 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. If  $\overline{TA}$  is tied low (asserted) and no wait states are specified in the BCR register, zero wait states will be inserted into external bus cycles.
- **NOTE1** In order to use the  $\overline{TA}$  functionality the BCR must be programmed to at least one wait state. A zero wait state access can not be extended by  $\overline{TA}$  negation, otherwise improper operation may result.
- **NOTE2** TA functionality may not be used while performing DRAM type accesses, Otherwise improper operation may result.
- BR(Bus Request) Active low output, never three-stated. BR is asserted<br/>when the CPU or DMA is requesting bus mastership. BR is negated<br/>when the CPU or DMA no longer needs the bus. BR may be asserted<br/>or negated independent of whether the DSP56301 is a bus master or a<br/>bus slave. Bus "parking" allows BR to be negated even though the

DSP56301 is the bus master. See the description of bus "parking" in the  $\overline{BB}$  pin description. The BRH bit in the Bus Control Register allows  $\overline{BR}$  to be asserted under software control even though the CPU or DMA does not need the bus.  $\overline{BR}$  is typically sent to an external bus arbitrator which controls the priority, parking and tenure of each master on the same external bus.  $\overline{BR}$  is only affected by CPU or DMA requests for the external bus, never for the internal bus. During hardware reset,  $\overline{BR}$  is negated and the arbitration is reset to the bus slave state.

- BG (Bus Grant) Active low input. BG must be asserted/negated synchronous to the clock out (CLKOUT) for proper operation. BG is asserted by an external bus arbitration circuit when the DSP56301 may become the next bus master. When BG is asserted, the DSP56301 must wait until BB is negated before taking bus mastership. When BG is negated, bus mastership is typically given up at the end of the current bus cycle. This may occur in the middle of an instruction which requires more than one external bus cycle for execution. BG is ignored during hardware reset.
- BB (Bus Busy) Bidirectional active low input/output, must be asserted and negated synchronous to the clock out (CLKOUT). This signal indicates that the bus is active. Only after this signal is negated the pending bus master can become the bus master (and then assert it again). The bus master may keep BB asserted after ceasing bus activity regardless of whether BR is asserted or negated, this is called "bus parking" and allows the current bus master to reuse the bus without re-arbitration until other device requires the bus. The negation of BB is done by an "active pull-up" method i.e. BB is driven high and then released and held high by an external pull-up resistor. BB is an active low input during hardware reset.
- **NOTE**: BB requires an external pullup resistor.
- BL(Bus Lock) Active low output, never three-stated. Asserted at the start<br/>of an external indivisible Read-Modify-Write (RMW) bus cycle and<br/>negated at the end of the write bus cycle. BL remains asserted between<br/>the read and write bus cycles of the RMW bus sequence. BL may be<br/>used to "resource lock" an external multi-port memory for secure<br/>semaphore updates. The only instructions which automatically assert<br/>BL are BSET, BCLR or BCHG instruction which accesses external<br/>memory. BL can also be asserted by setting the BLH bit in the BCR<br/>register. BL is negated during hardware reset.



Figure 2-1. DSP56301 Functional Signal Groups (w/PCI port)

OnCE<sup>TM</sup> is a trademark of Motorola Inc.



Figure 2-2. DSP56301 Functional Signal Groups (w/universal bus port)

OnCE<sup>TM</sup> is a trademark of Motorola Inc.

| BS   | (Bus Strobe) - Three-state. Active low output when a bus master, three-<br>stated otherwise. Asserted at the start of a bus cycle (for half of a clock<br>cycle) providing an "early bus start" signal for a bus controller. If the<br>external bus is not used during an instruction cycle BS remains negated<br>until the next external bus cycle. BS is three-stated during hardware<br>reset. |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CAS  | (Column Address Strobe) - Active low output when bus master and three stated otherwise (If BME bit in the DRAM Control Register is cleared), CAS is used by DRAM to strobe column address. CAS is three stated during hardware reset.                                                                                                                                                             |
| BCLK | (Bus Clock) - three-state. Active high output when a bus master three stated otherwise. BCLK is used by synchronous SRAM to sample address, data and control signals. BCLK is active only during SSRAM accesses. When active BCLK is synchronized to CLKOUT by the internal Phase Lock Loop, BCLK precedes CLKOUT by 1/4 of a clock cycle. BCLK is three stated during hardware reset             |

RESERVED (1) There is one reserved pin for use in the expansion port interface and in the peripherals interface. This pin should be left unconnected.

#### 2.2.5 Host Interface (HI32) (52 Pins)

The Host Interface (HI32) provides a fast parallel data port up to 32 bits wide, which may be connected directly to the host bus.

The HI32 supports a variety of standard buses, and provides glue-less connection with the emerging PCI bus standard and with a number of industry standard microcomputers, microprocessors, DSPs and DMA hardware.

The complete HI32 pin functionality is described in the HI32 port chapter.

HP0-HP7 When the HI32 is programmed to interface the PCI bus these pins are lines 0-7 of the Address/Data multiplexed bidirectional three-state bus (HAD0-HAD7).
When the HI32 is programmed to interface any other host bus these pins are lines 3-10 of the input address bus (HA3-HA10).
HP0-HP7 may be programmed as general purpose I/O pins called HIO0-HIO7.
HP0-HP7 can tolerate 5V.

HP8-HP15 When the HI32 is programmed to interface the PCI bus these pins are lines 8-15 of the Address/Data multiplexed bidirectional three-state bus (HAD8-HAD15).
When the HI32 is programmed to interface any other host bus these pins are lines 0-7 of the bidirectional three-state Data bus (HD0-HD7). HP8-HP15 may be programmed as general purpose I/O pins called HIO8-HIO15.

HP8-HP15 can tolerate 5V.

| HP16-HP19 | When the HI32 is programmed to interface the PCI bus these pins are<br>the Command/Byte enable bidirectional three-state bus (HC0/HBE0 -<br>HC3/HBE3).<br>When the HI32 is programmed to interface any other host bus HP16-<br>HP18 pins are lines 0-2 of the Address input bus (HA0-HA2).<br>HP16-HP19 may be programmed as general purpose I/O pins called<br>HIO16-HIO19.<br>HP16-HP19 can tolerate 5V. |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HP20      | When the HI32 is programmed to interface the PCI bus this pin is the Target Ready bidirectional three-state pin (HTRDY).<br>When the HI32 is programmed to interface any other host bus this pin is the Host Data Bus Enable output pin (HDBEN).<br>HP20 may be programmed as general purpose I/O pin called HIO20.<br>HP20 can tolerate 5V.                                                               |
| HP21      | When the HI32 is programmed to interface the PCI bus this pin is the<br>Initiator Ready bidirectional three-state pin (HIRDY).<br>When the HI32 is programmed to interface any other host bus this pin is<br>the Host Data Bus Direction output pin (HDBDR).<br>HP21 may be programmed as general purpose I/O pin called HIO21.<br>HP21 can tolerate 5V.                                                   |
| HP22      | When the HI32 is programmed to interface the PCI bus this pin is the Device Select bidirectional three-state pin (HDEVSEL).<br>When the HI32 is programmed to interface any other host bus this pin is the Host Select Acknowledge output pin (HSAK).<br>HP22 may be programmed as general purpose I/O pin called HIO22.<br>HP22 can tolerate 5V.                                                          |
| HP23      | When the HI32 is programmed to interface the PCI bus this pin is the Lock bidirectional three-state pin (HLOCK).<br>When the HI32 is programmed to interface any other host bus this pin is the Host Bus Strobe Schmitt trigger input pin (HBS).<br>HP23 may be programmed as general purpose I/O pin called HIO23.<br>HP23 can tolerate 5V.                                                               |
| HP24      | When the HI32 is programmed to interface the PCI bus this pin is the Parity bidirectional three-state pin (HPAR).<br>When the HI32 is programmed to interface any other host bus this pin is the Host DMA Acknowledge Schmitt trigger input pin (HDAK).<br>HP24 can tolerate 5V.                                                                                                                           |
| HP25      | When the HI32 is programmed to interface the PCI bus this pin is the Parity Error bidirectional three-state pin (HPERR).                                                                                                                                                                                                                                                                                   |

|           | When the HI32 is programmed to interface any other host bus this pin is the Host DMA Request output pin (HDRQ). HP25 can tolerate 5V.                                                                                                                                                      |
|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HP26      | When the HI32 is programmed to interface the PCI bus this pin is the Bus Grant input pin (HGNT).<br>When the HI32 is programmed to interface any other host bus this pin is the Host Address Enable input pin (HAEN).<br>HP26 can tolerate 5V.                                             |
| HP27      | When the HI32 is programmed to interface the PCI bus this pin is the Bus Request three-stated output pin (HREQ).<br>When the HI32 is programmed to interface any other host bus this pin is the Host Transfer Acknowledge three stated output pin (HTA).                                   |
| HP28      | When the HI32 is programmed to interface the PCI bus this pin is the System Error open drain output pin (HSERR).<br>When the HI32 is programmed to interface any other host bus this pin is the Host Interrupt Request programmable open drain output pin (HIRQ).<br>HP28 can tolerate 5V. |
| HP29      | When the HI32 is programmed to interface the PCI bus this pin is the Stop bidirectional three-state pin (HSTOP).<br>When the HI32 is programmed to interface any other host bus this pin is the Host Write/Read-Write Schmitt trigger input pin (HWR/HRW).<br>HP29 can tolerate 5V.        |
| HP30      | When the HI32 is programmed to interface the PCI bus this pin is the Initialization Device Select input pin (HIDSEL). When the HI32 is programmed to interface any other host bus this pin is the Host Read/Data Strobe Schmitt trigger input pin (HRD/HDS). HP30 can tolerate 5V.         |
| HP31      | When the HI32 is programmed to interface the PCI bus this pin is the cycle Frame bidirectional three-state pin (HFRAME). When the HI32 is programmed to interface any other host bus this pin must be tied to $V_{CC}$ or pullup resistor. HP31 can tolerate 5V.                           |
| HP32      | When the HI32 is programmed to interface the PCI bus this pin is the Bus Clock input pin (HCLK). When the HI32 is programmed to interface any other host bus this pin must be tied to $V_{CC}$ or pullup resistor. HP32 can tolerate 5V.                                                   |
| HP33-HP48 | When the HI32 is programmed to interface the PCI bus these pins are lines 16-31 of the Address/Data Multiplexed bidirectional three-state                                                                                                                                                  |

|      | Bus (HAD16 - HAD31).<br>When the HI32 is programmed to interface any other host bus these<br>pins are lines 8-23 of the bidirectional three-state Host Data bus (HD8-<br>HD23).<br>HP33 - HP48 can tolerate 5V.                                                                                                           |
|------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| HP49 | When the HI32 is programmed to interface the PCI bus this pin is the Hardware Reset input pin (HRST).<br>When the HI32 is programmed to interface any other host bus this pin is Hardware Reset Schmitt trigger input pin (HRST).<br>HP49 can tolerate 5V.                                                                |
| HP50 | When the HI32 is programmed to interface the PCI bus this pin is the interrupt A open drain output pin (HINTA)<br>In all other modes this pin is an open drain output pin (HINTA).<br>HP50 can tolerate 5V.                                                                                                               |
| PVCL | When the HI32 is connected to a PCI bus that operates in a 3V signaling environment this pin should be connected to $V_{CC}$ (3.3V) in order enable the high voltage clamping required by the PCI specifications. In other cases (including PCI bus with a 5V signaling environment) this pin should be left unconnected. |

#### 2.2.6 Enhanced Synchronous Serial Interface 0 (ESSI 0) (6 Pins)

There are two synchronous serial interfaces (ESSI 0 and ESSI 1) that provide a full-duplex serial port for serial communication with a variety of serial devices including one or more industry-standard codecs, other DSPs, microprocessors, and peripherals which implement the Motorola SPI.

- STD0 (Serial Transmit Data Pin) is used for transmitting data from the serial transmit shift register. STD0 is an output when data is being transmitted. STD0 may be programmed as a general purpose I/O pin called PC5 when the ESSI0 STD function is not being used. STD0 pin can tolerate 5V.
- SRD0 (Serial Receive Data Pin) receives serial data and transfers the data to the ESSI receive shift register. SRD0 is input when data is being received. SRD0 may be programmed as a general-purpose I/O pin called PC4 when the ESSI0 SRD function is not being used. SRD0 pin can tolerate 5V.
- SCK0 (Serial Clock) is a bidirectional (Schmitt trigger input) pin providing the serial bit rate clock for the ESSI interface. The SCK0 is a clock input or output used by both the transmitter and receiver in synchronous modes or by the transmitter in asynchronous modes. SCK0 may be programmed as a general purpose I/O pin called PC3 when the ESSI0

SCK function is not being used. SCK0 pin can tolerate 5V.

- **NOTE:** Although an external serial clock can be independent of and asynchronous to the DSP system clock, it must exceed the minimum clock cycle time of 6T (i.e., the system clock frequency must be at least three times the external ESSI clock frequency). The ESSI needs at least three DSP phases (DSP phase = T) inside each half of the serial clock.
- SC00 (Serial Control Pin 0) The function of this pin is determined by the selection of either synchronous or asynchronous mode. For asynchronous mode, this pin will be used for the receive clock I/O (Schmitt trigger input). For synchronous mode, this pin is used either for transmitter1 output or for serial I/O flag 0. SC00 may be programmed as a general purpose I/O pin called PC0 when the ESSI0 SC0 function is not being used.
   SC00 pin can tolerate 5V.
- SC01 (Serial Control Pin 1) The function of this pin is determined by the selection of either synchronous or asynchronous mode. For asynchronous mode, this pin is the receiver frame sync I/O. For synchronous mode, this pin is used either for transmitter2 output or for serial I/O flag 1. SC01 may be programmed as a general purpose I/O pin called PC1 when the ESSI0 SC1 function is not being used. SC01 pin can tolerate 5V.
- SC02 (Serial Control Pin 2) This pin is used for frame sync I/O. SC02 is the frame sync for both the transmitter and receiver in synchronous mode and for the transmitter only in asynchronous mode. When configured as an output, this pin is the internally generated frame sync signal. When configured as an input, this pin receives an external frame sync signal for the transmitter (and the receiver in synchronous operation). SC02 may be programmed as a general purpose I/O pin called PC2 when the ESSI0 SC2 function is not being used. SC02 pin can tolerate 5V.

#### 2.2.7 Enhanced Synchronous Serial Interface 1 (ESSI 1) (6 Pins)

ESSI1 is identical to ESSI0.

- STD1 (Serial Transmit Data Pin) is used for transmitting data from the serial transmit shift register. STD1 is an output when data is being transmitted. STD1 may be programmed as a general purpose I/O pin called PD5 when the ESSI1 STD function is not being used. STD1 pin can tolerate 5V.
- SRD1 (Serial Receive Data Pin) receives serial data and transfers the data to

the ESSI receive shift register. SRD1 may be programmed as a generalpurpose I/O pin called PD4 when the ESSI1 SRD function is not being used.

SRD1 pin can tolerate 5V.

- SCK1 (Serial Clock) is a bidirectional (Schmitt trigger input) pin providing the serial bit rate clock for the ESSI interface. The SCK1 is a clock input or output used by both the transmitter and receiver in synchronous modes or by the transmitter in asynchronous modes. SCK1 may be programmed as a general purpose I/O pin called PD3 when the ESSI1 SCK function is not being used. SCK1 pin can tolerate 5V.
- **NOTE**: Although an external serial clock can be independent of and asynchronous to the DSP system clock, it must exceed the minimum clock cycle time of 6T (i.e., the system clock frequency must be at least three times the external ESSI clock frequency). The ESSI needs at least three DSP phases (DSP phase = T) inside each half of the serial clock.
- SC10 (Serial Control Pin 0) The function of this pin is determined by the selection of either synchronous or asynchronous mode. For asynchronous mode, this pin will be used for the receive clock I/O (Schmitt trigger input). For synchronous mode, this pin is used either for transmitter 1 output or for serial I/O flag 0. SC10 may be programmed as a general purpose I/O pin called PD0 when the ESSI1 SC0 function is not being used.
   SC10 pin can tolerate 5V.
- SC11 (Serial Control Pin 1) The function of this pin is determined by the selection of either synchronous or asynchronous mode. For asynchronous mode, this pin is the receiver frame sync I/O. For synchronous mode, this pin is used either for transmitter2 output or for serial I/O flag 1. SC11 may be programmed as a general purpose I/O pin called PD1 when the ESSI1 SC1 function is not being used. SC11 pin can tolerate 5V.
- SC12 (Serial Control Pin 2) This pin is used for frame sync I/O. SC12 is the frame sync for both the transmitter and receiver in synchronous mode and for the transmitter only in asynchronous mode. When configured as an output, this pin is the internally generated frame sync signal. When configured as an input, this pin receives an external frame sync signal for the transmitter (and the receiver in synchronous operation). SC12 may be programmed as a general purpose I/O pin called PD2 when the ESSI1 SC2 function is not being used. SC12 pin can tolerate 5V.

#### 2.2.8 Serial Communication Interface (SCI) (3 Pins)

The Serial Communication interface (SCI) provides a full duplex port for serial communication to other DSPs, microprocessors, or peripherals such as modems.

- TXD (Serial Transmit Data Pin) This output transmits data from SCI transmit data register. TXD can be programmed as general purpose I/O pin (PE1) when SCI TXD function is not being used TXD pin can tolerate 5V.
- RXD (Serial Receive Data Pin) This input receives byte oriented serial data and transfers the data to the SCI receive shift register. RXD can be programmed as general purpose I/O pin (PE0) when the SCI RXD function is not being used. RXD pin can tolerate 5V.
- SCLK (Serial Clock) This bidirectional (Schmitt trigger input) pin providing the input or output clock used by the transmitter and/or the receiver. SCLK may be programmed as a general purpose I/O pin (PE2) when the SCI SCLK function is not being used. SCLK pin can tolerate 5V.

#### 2.2.9 Triple Timer (3 Pins)

Three identical and independent Timers are implemented in the DSP56301. Each timer can use internal or external clocking and can interrupt the DSP56301 after a specified number of events (clocks) or can signal an external device after counting a specific number of internal events. Each timer connects to the external world through one bidirectional pin TIO.

- TIO0 (Timer-0 Schmitt trigger input/output pin) When TIO0 is used as input, the module is functioning as an external event counter or measures external pulse width or signal period. When TIO0 is used as output the module is functioning as timer and the TIO0 becomes timer pulse. When the TIO0 pin is not used by the timer module, it can be used as a general purpose Input/Output Pin. TIO0 pin can tolerate 5V.
- TIO1 (Timer-1 Schmitt trigger Input/output pin) When TIO1 is used as input, the module is functioning as an external event counter or measures external pulse width or signal period. When TIO1 is used as output the module is functioning as timer and the TIO1 becomes timer pulse. When the TIO1 pin is not used by the timer module, it can be used as a general purpose Input/Output Pin. TIO1 pin can tolerate 5V.
- TIO2 (Timer-2 Schmitt trigger Input/output pin) When TIO2 is used as input, the module is functioning as an external event counter or measures

external pulse width or signal period. When TIO2 is used as output the module is functioning as timer and the TIO2 becomes timer pulse. When the TIO2 pin is not used by the timer module, it can be used as a general purpose Input/Output Pin. TIO2 pin can tolerate 5V.

#### 2.2.10 Phase-Locked Loop (PLL) (3 Pins)

- PCAP (PLL capacitor) This input connects the off-chip capacitor for PLL filter. One terminal of the capacitor is connected to PCAP while the other terminal is connected to V<sub>CCP</sub>
- CLKOUT (Clock Output) This output pin provides an output clock synchronized to the internal core clock phase.
- **NOTE 1**: If PLL is enabled and both the multiplication and division factors are equal to one, then CLKOUT is also synchronized to EXTAL.
- **NOTE 2**: If PLL is disabled, CLKOUT frequency is half the frequency of EXTAL.
- PINIT/NMI (PLL Initial/Non Maskable Interrupt) During the assertion of hardware reset, PINIT/NMI is configured as PINIT and its value is written into the PEN bit of the PLL control register and determines whether the PLL is enabled or disabled. After hardware reset negation and during normal instruction processing, the PINIT/NMI Schmitt trigger pin is configured as NMI, a negative edge triggered, non maskable interrupt request, internally synchronized to the clock out (CLKOUT). PINIT/NMI pin can tolerate 5V.

#### 2.2.11 Power & Ground (51 Pins)

- V<sub>CCQ</sub> (4) (Quiet Power) isolated power for the CPU logic. Must be tied to all other chip power pins externally. User must provide adequate external decoupling capacitors.
- GNDQ (4) (Quiet Ground) isolated ground for the CPU logic. Must be tied to all other chip ground pins externally. User must provide adequate external decoupling capacitors.
- V<sub>CCA</sub> (6) (Address Bus Power) isolated power for sections of address bus I/O drivers. Must be tied to all other chip power pins externally. User must provide adequate external decoupling capacitors.
- GNDA (6) (Address Bus Ground) isolated ground for sections of address bus I/O drivers. Must be tied to all other chip ground pins externally. User must provide adequate external decoupling capacitors.
- V<sub>CCD</sub> (4) (Data Bus Power) isolated power for sections of data bus I/O drivers.

Must be tied to all other chip power pins externally. User must provide adequate external decoupling capacitors.

- GNDD (4) (Data Bus Ground) isolated ground for sections of data bus I/O drivers. Must be tied to all other chip ground pins externally. User must provide adequate external decoupling capacitors.
- V<sub>CCN</sub> (2) (Bus Control Power) isolated power for the bus control I/O drivers. Must be tied to all other chip power pins externally. User must provide adequate external decoupling capacitors.
- GNDN (2) (Bus Control Ground) isolated ground for the bus control I/O drivers. Must be tied to all other chip ground pins externally. User must provide adequate external decoupling capacitors.
- V<sub>CCH</sub> (6) (Host Power) isolated power for the HI logic. Must be tied to all other chip power pins externally. User must provide adequate external decoupling capacitors.
- GNDH (6) (Host Ground) isolated ground for the HI logic. Must be tied to all other chip ground pins externally. User must provide adequate external decoupling capacitors.
- V<sub>CCS</sub> (2) (ESSIs, SCI and Timers Power) isolated power for the ESSIs and Timers logic. Must be tied to all other chip power pins externally. User must provide adequate external decoupling capacitors.
- GNDS (2) (ESSIs, SCI and Timers Ground) isolated ground for the ESSIs and Timers logic. Must be tied to all other chip ground pins externally. User must provide adequate external decoupling capacitors.
- $V_{CCP}$  (PLL Power)  $V_{CC}$  dedicated for PLL use. The voltage should be well regulated and the pin should be provided with an extremely low impedance path to the  $V_{CC}$  power rail.
- $\begin{array}{lll} \text{GNDP} & (\text{PLL Ground}) & \mbox{ Gnd dedicated for PLL use. The pin should be provided} \\ & \mbox{with en extremely low impedance path to ground. } V_{CCP} \mbox{ should be} \\ & \mbox{ bypassed to GNDP by a } 0.1 \mu\mbox{F} \mbox{ capacitor located as close as possible to} \\ & \mbox{ the chip package.} \end{array}$
- GND1P (PLL Ground 1) Gnd dedicated for PLL use. The pin should be provided with en extremely low impedance path to ground.

## 3.1 INTRODUCTION

The memory space of the DSP56301 is partitioned into program memory space (P), X data memory space and Y data memory space. The program memory space (P) includes internal PRAM, internal Instruction Cache (that behaves as a PRAM when the cache is disabled), a boot program ROM and an optional off-chip memory expansion. The data memory space is divided into X data memory and Y data memory in order to work with the two address arithmetic logic units (ALUs) and to feed two operands simultaneously to the data ALU. Each data memory space includes internal RAM and an optional off-chip memory expansion.

## 3.2 DSP56301 MEMORY MAPS

The three independent memory spaces of the DSP56301: X data, Y data, and program, are shown in Figure 3-1.



#### Figure 3-1. DSP56301 Memory Map

**NOTE** If CE bit in SR is set, program memory space \$000C00-\$000FFF becomes an instruction cache (I-Cache).

#### 3.2.1 On-chip X Data Memory

The on-chip X data RAM is a 24-bit-wide, internal, static memory occupying the lowest 2048 locations (0–2047) in X memory space. The on-chip X data RAM is organized in eight banks, 256 locations each.

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

The X memory space located at locations \$FF0000-\$FFEFFF is reserved and should not be accessed.

#### 3.2.2 On-chip Y Data Memory

The on-chip Y data RAM is a 24-bit-wide, internal, static memory occupying the lowest 2048 locations (0–2047) in the Y memory space. The on-chip Y data RAM is organized in eight banks, 256 locations each.

The off-chip peripheral registers should be mapped into the top 128 locations (\$FFF80– \$FFFFF) to take advantage of the move peripheral data (MOVEP) instruction and the bit oriented instructions (BCHG, BCLR, BSET, BTST, BRCLR, BRSET, BSCLR, BSSET, JCLR, JSET, JSCLR and JSSET).

The Y memory space located at locations \$FF0000-\$FFEFFF is reserved and should not be accessed.

#### 3.2.3 On-chip Program Memory

The on-chip program memory consists of a 24-bit-wide, high-speed, static RAM occupying the lowest 4096 locations (0–4095) in the P memory space. The on-chip P data RAM is organized in 16 banks, 256 locations each. Of these on-chip 4096 program words, the upper 1024 program words located at locations \$000C00-\$000FFF, can be used as an internal Instruction Cache when setting the CE bit in the SR.

The P memory space occupying locations \$FF0000-\$FF00BF includes the internal Bootstrap ROM. This ROM contains 192 words combining the bootstrap program for the DSP56301.

The P memory space located at locations \$FF00C0-\$FFFFFF is reserved and should not be accessed.

## 3.3 DSP56301 INTERNAL I/O MEMORY MAP

The mapping of the DSP56301 internal X-I/O space (the top 128 locations of the X data memory space) appears in the following table:

| Table 3-1. | Internal I/O Memory | Map |
|------------|---------------------|-----|
|------------|---------------------|-----|

| Peripheral | Address  | Register Name                                  |
|------------|----------|------------------------------------------------|
| IPR        | \$FFFFFF | INTERRUPT PRIORITY REGISTER CORE (IPR-C)       |
|            | \$FFFFFE | INTERRUPT PRIORITY REGISTER PERIPHERAL (IPR-P) |
| PLL        | \$FFFFFD | PLL CONTROL REGISTER (PCTL)                    |
| ONCE       | \$FFFFFC | ONCE GDB REGISTER (OGDB)                       |

| Peripheral | Address  | Register Name                           |
|------------|----------|-----------------------------------------|
| BIU        | \$FFFFFB | BUS CONTROL REGISTER (BCR)              |
|            | \$FFFFFA | DRAM CONTROL REGISTER (DCR)             |
|            | \$FFFFF9 | ADDRESS ATTRIBUTE REGISTER 0 (AAR0)     |
|            | \$FFFFF8 | ADDRESS ATTRIBUTE REGISTER 1 (AAR1)     |
|            | \$FFFFF7 | ADDRESS ATTRIBUTE REGISTER 2 (AAR2)     |
|            | \$FFFFF6 | ADDRESS ATTRIBUTE REGISTER 3 (AAR3)     |
|            | \$FFFFF5 | ID REGISTER (IDR)                       |
| DMA        | \$FFFFF4 | DMA STATUS REGISTER (DSTR)              |
|            | \$FFFFF3 | DMA OFFSET REGISTER 0 (DOR0)            |
|            | \$FFFFF2 | DMA OFFSET REGISTER 1 (DOR1)            |
|            | \$FFFFF1 | DMA OFFSET REGISTER 2 (DOR2)            |
|            | \$FFFFF0 | DMA OFFSET REGISTER 3 (DOR3)            |
| DMA0       | \$FFFFEF | DMA SOURCE ADDRESS REGISTER (DSR0)      |
|            | \$FFFFEE | DMA DESTINATION ADDRESS REGISTER (DDR0) |
|            | \$FFFFED | DMA COUNTER (DCO0)                      |
|            | \$FFFFEC | DMA CONTROL REGISTER (DCR0)             |
| DMA1       | \$FFFFEB | DMA SOURCE ADDRESS REGISTER (DSR1)      |
|            | \$FFFFEA | DMA DESTINATION ADDRESS REGISTER (DDR1) |
|            | \$FFFFE9 | DMA COUNTER (DCO1)                      |
|            | \$FFFFE8 | DMA CONTROL REGISTER (DCR1)             |
| DMA2       | \$FFFFE7 | DMA SOURCE ADDRESS REGISTER (DSR2)      |
|            | \$FFFFE6 | DMA DESTINATION ADDRESS REGISTER (DDR2) |
|            | \$FFFFE5 | DMA COUNTER (DCO2)                      |
|            | \$FFFFE4 | DMA CONTROL REGISTER (DCR2)             |

| Peripheral | Address  | Register Name                            |
|------------|----------|------------------------------------------|
| DMA3       | \$FFFFE3 | DMA SOURCE ADDRESS REGISTER (DSR3)       |
|            | \$FFFFE2 | DMA DESTINATION ADDRESS REGISTER (DDR3)  |
|            | \$FFFFE1 | DMA COUNTER (DCO3)                       |
|            | \$FFFFE0 | DMA CONTROL REGISTER (DCR3)              |
| DMA4       | \$FFFFDF | DMA SOURCE ADDRESS REGISTER (DSR4)       |
|            | \$FFFFDE | DMA DESTINATION ADDRESS REGISTER (DDR4)  |
|            | \$FFFFDD | DMA COUNTER (DCO4)                       |
|            | \$FFFFDC | DMA CONTROL REGISTER (DCR4)              |
| DMA5       | \$FFFFDB | DMA SOURCE ADDRESS REGISTER (DSR5)       |
|            | \$FFFFDA | DMA DESTINATION ADDRESS REGISTER (DDR5)  |
|            | \$FFFFD9 | DMA COUNTER (DCO5)                       |
|            | \$FFFFD8 | DMA CONTROL REGISTER (DCR5)              |
|            | \$FFFFD7 | RESERVED                                 |
|            | \$FFFFD6 | RESERVED                                 |
|            | \$FFFFD5 | RESERVED                                 |
|            | \$FFFFD4 | RESERVED                                 |
|            | \$FFFFD3 | RESERVED                                 |
|            | \$FFFFD2 | RESERVED                                 |
|            | \$FFFFD1 | RESERVED                                 |
|            | \$FFFFD0 | RESERVED                                 |
| PORT B     | \$FFFFCF | HOST PORT GPIO DATA REGISTER (DATH)      |
|            | \$FFFFCE | HOST PORT GPIO DIRECTION REGISTER (DIRH) |

| Peripheral | Address  | Register Name                          |
|------------|----------|----------------------------------------|
| HI32       | \$FFFFCD | DSP SLAVE TRANSMIT DATA FIFO (DTXS)    |
|            | \$FFFFCC | DSP MASTER TRANSMIT DATA FIFO (DTXM)   |
|            | \$FFFFCB | DSP RECEIVE DATA FIFO (DRXR)           |
|            | \$FFFFCA | DSP PCI STATUS REGISTER (DPSR)         |
|            | \$FFFFC9 | DSP STATUS REGISTER (DSR)              |
|            | \$FFFFC8 | DSP PCI ADDRESS REGISTER (DPAR)        |
|            | \$FFFFC7 | DSP PCI MASTER CONTROL REGISTER (DPMC) |
|            | \$FFFFC6 | DSP PCI CONTROL REGISTER (DPCR)        |
|            | \$FFFFC5 | DSP CONTROL REGISTER (DCTR)            |
|            | \$FFFFC4 | RESERVED                               |
|            | \$FFFFC3 | RESERVED                               |
|            | \$FFFFC2 | RESERVED                               |
|            | \$FFFFC1 | RESERVED                               |
|            | \$FFFFC0 | RESERVED                               |
| PORT C     | \$FFFFBF | PORT C CONTROL REGISTER (PCRC)         |
|            | \$FFFFBE | PORT C DIRECTION REGISTER (PRRC)       |
|            | \$FFFFBD | PORT C GPIO DATA REGISTER (PDRC)       |

| Peripheral | Address  | Register Name                                |
|------------|----------|----------------------------------------------|
| ESSI 0     | \$FFFFBC | ESSI 0 TRANSMIT DATA REGISTER 0 (TX00)       |
|            | \$FFFFBB | ESSI 0 TRANSMIT DATA REGISTER 1 (TX01)       |
|            | \$FFFFBA | ESSI 0 TRANSMIT DATA REGISTER 2 (TX02)       |
|            | \$FFFFB9 | ESSI 0 TIME SLOT REGISTER (TSR0)             |
|            | \$FFFFB8 | ESSI 0 RECEIVE DATA REGISTER (RX0)           |
|            | \$FFFFB7 | ESSI 0 STATUS REGISTER (SSISR0)              |
|            | \$FFFFB6 | ESSI 0 CONTROL REGISTER B (CRB0)             |
|            | \$FFFFB5 | ESSI 0 CONTROL REGISTER A (CRA0)             |
|            | \$FFFFB4 | ESSI 0 TRANSMIT SLOT MASK REGISTER A (TSMA0) |
|            | \$FFFFB3 | ESSI 0 TRANSMIT SLOT MASK REGISTER B (TSMB0) |
|            | \$FFFFB2 | ESSI 0 RECEIVE SLOT MASK REGISTER A (RSMA0)  |
|            | \$FFFFB1 | ESSI 0 RECEIVE SLOT MASK REGISTER B (RSMB0)  |
|            | \$FFFFB0 | RESERVED                                     |
| PORT D     | \$FFFFAF | PORT D CONTROL REGISTER (PCRD)               |
|            | \$FFFFAE | PORT D DIRECTION REGISTER (PRRD)             |
|            | \$FFFFAD | PORT C GPIO DATA REGISTER (PDRD)             |

| Device     | ۸ ما ما به م                                 | Desister Neme                                                                                                                                                             |
|------------|----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Peripheral | Address                                      | Register Name                                                                                                                                                             |
| ESSI 1     | \$FFFFAC                                     | ESSI 1 TRANSMIT DATA REGISTER 0 (TX10)                                                                                                                                    |
|            | \$FFFFAB                                     | ESSI 1 TRANSMIT DATA REGISTER 1 (TX11)                                                                                                                                    |
|            | \$FFFFAA                                     | ESSI 1 TRANSMIT DATA REGISTER 2 (TX12)                                                                                                                                    |
|            | \$FFFFA9                                     | ESSI 1 TIME SLOT REGISTER (TSR1)                                                                                                                                          |
|            | \$FFFFA8                                     | ESSI 1 RECEIVE DATA REGISTER (RX1)                                                                                                                                        |
|            | \$FFFFA7                                     | ESSI 1 STATUS REGISTER (SSISR1)                                                                                                                                           |
|            | \$FFFFA6                                     | ESSI 1 CONTROL REGISTER B (CRB1)                                                                                                                                          |
|            | \$FFFFA5                                     | ESSI 1 CONTROL REGISTER A (CRA1)                                                                                                                                          |
|            | \$FFFFA4                                     | ESSI 1 TRANSMIT SLOT MASK REGISTER A (TSMA1)                                                                                                                              |
|            | \$FFFFA3                                     | ESSI 1 TRANSMIT SLOT MASK REGISTER B (TSMB1)                                                                                                                              |
|            | \$FFFFA2                                     | ESSI 1 RECEIVE SLOT MASK REGISTER A (RSMA1)                                                                                                                               |
|            | \$FFFFA1                                     | ESSI 1 RECEIVE SLOT MASK REGISTER B (RSMB1)                                                                                                                               |
|            | \$FFFFA0                                     | RESERVED                                                                                                                                                                  |
| PORT E     | \$FFFF9F                                     | PORT E CONTROL REGISTER (PCRE)                                                                                                                                            |
|            | \$FFFF9E                                     | PORT E DIRECTION REGISTER (PRRE)                                                                                                                                          |
|            | \$FFFF9D                                     | PORT E GPIO DATA REGISTER (PDRE)                                                                                                                                          |
| SCI        | \$FFFF9C                                     | SCI CONTROL REGISTER (SCR)                                                                                                                                                |
|            | \$FFFF9B                                     | SCI CLOCK CONTROL REGISTER (SCCR)                                                                                                                                         |
|            | \$FFFF9A                                     | SCI RECEIVE DATA REGISTER - HIGH (SRXH)                                                                                                                                   |
|            | \$FFFF99                                     | SCI RECEIVE DATA REGISTER - MIDDLE (SRXM)                                                                                                                                 |
|            | \$FFFF98                                     | SCI RECIEVE DATA REGISTER - LOW (SRXL)                                                                                                                                    |
|            | \$FFFF97                                     | SCI TRANSMIT DATA REGISTER - HIGH (STXH)                                                                                                                                  |
|            | \$FFFF96                                     | SCI TRANSMIT DATA REGISTER - MIDDLE (STXM)                                                                                                                                |
|            | \$FFFF95                                     | SCI TRANSMIT DATA REGISTER - LOW (STXL)                                                                                                                                   |
|            | \$FFFF94                                     | SCI TRANSMIT ADDRESS REGISTER (STXA)                                                                                                                                      |
|            | \$FFFF93                                     | SCI STATUS REGISTER (SSR)                                                                                                                                                 |
|            | \$FFFF97<br>\$FFFF96<br>\$FFFF95<br>\$FFFF94 | SCI TRANSMIT DATA REGISTER - HIGH (STXH)<br>SCI TRANSMIT DATA REGISTER - MIDDLE (STXM)<br>SCI TRANSMIT DATA REGISTER - LOW (STXL)<br>SCI TRANSMIT ADDRESS REGISTER (STXA) |

| Peripheral  | Address  | Register Name                           |
|-------------|----------|-----------------------------------------|
| i enprierar |          |                                         |
|             | \$FFFF92 | RESERVED                                |
|             | \$FFFF91 | RESERVED                                |
|             | \$FFFF90 | RESERVED                                |
| TRIPLE      | \$FFFF8F | TIMER 0 CONTROL/STATUS REGISTER (TCSR0) |
| TIMER       | \$FFFF8E | TIMER 0 LOAD REGISTER (TLR0)            |
|             | \$FFFF8D | TIMER 0 COMPARE REGISTER (TCPR0)        |
|             | \$FFFF8C | TIMER 0 COUNT REGISTER (TCR0)           |
|             | \$FFFF8B | TIMER 1 CONTROL/STATUS REGISTER (TCSR1) |
|             | \$FFFF8A | TIMER 1 LOAD REGISTER (TLR1)            |
|             | \$FFFF89 | TIMER 1 COMPARE REGISTER (TCPR1)        |
|             | \$FFFF88 | TIMER1 COUNT REGISTER (TCR1)            |
|             | \$FFFF87 | TIMER 2 CONTROL/STATUS REGISTER (TCSR2) |
|             | \$FFFF86 | TIMER 2 LOAD REGISTER (TLR2)            |
|             | \$FFFF85 | TIMER 2 COMPARE REGISTER (TCPR2)        |
|             | \$FFFF84 | TIMER 2 COUNT REGISTER (TCR2)           |
|             | \$FFFF83 | TIMER PRESCALER LOAD REGISTER (TPLR)    |
|             | \$FFFF82 | TIMER PRESCALER COUNT REGISTER (TPCR)   |
|             | \$FFFF81 | RESERVED                                |
|             | \$FFFF80 | RESERVED                                |

## 3.4 DSP56301 MEMORY MAPS IN SIXTEEN-BIT COMPATIBILITY MODE

When the Sixteen-Bit-Compatibility mode bit is set, the DSP56301 memory map is changed to enable 16-bit wide address access to the memory mapped X-I/O, as described in the following figure:



Figure 3-2. DSP56301 Memory Map in Sixteen Bit Compatibility Mode

# 4 CORE CONFIGURATION

### 4.1 INTRODUCTION

This chapter contains DSP56300 Core configuration details specific to the DSP56301 device. For more information on the described registers or modules, refer to the appropriate chapters in the DSP56300 Core spec.

#### 4.2 CHIP OPERATING MODES

The DSP56301 operating modes determine the chip operating modes and the start-up procedure location when the DSP56301 leaves the reset state. The MODA, MODB, MODC and MODD pins are sampled as the DSP56301 exits the reset state. Table 4-1 depicts the mode assignments.

| Mode | MOD<br>D | MOD<br>C | MOD<br>B | MOD<br>A | Reset<br>Vector | Description                                                            |
|------|----------|----------|----------|----------|-----------------|------------------------------------------------------------------------|
| 0    | 0        | 0        | 0        | 0        | \$C00000        | Expanded mode                                                          |
| 1    | 0 or 1   | 0        | 0        | 1        | \$FF0000        | Bootstrap from byte-wide memory                                        |
| 2    | 0 or 1   | 0        | 1        | 0        | \$FF0000        | Bootstrap thru SCI                                                     |
| 3    | 0 or 1   | 0        | 1        | 1        | -               | Reserved                                                               |
| 4    | 0 or 1   | 1        | 0        | 0        | \$FF0000        | Host Bootstrap PCI Mode (32-bit-wide)                                  |
| 5    | 0 or 1   | 1        | 0        | 1        | \$FF0000        | Host Bootstrap 16-bit-wide UB Mode<br>(ISA)                            |
| 6    | 0 or 1   | 1        | 1        | 0        | \$FF0000        | Host Bootstrap 8-bit-wide UB Mode<br>in double-strob pin configuration |
| 7    | 0 or 1   | 1        | 1        | 1        | \$FF0000        | Host Bootstrap 8-bit-wide UB Mode in single-strob pin configuration    |
| 8    | 1        | 0        | 0        | 0        | \$008000        | Expanded mode                                                          |

#### Table 4-1. DSP56301 Operating Modes

## 4.2.1 Mode 0: Expanded mode

In this mode the Bootstrap ROM is bypassed and the DSP56301 will start fetching instructions beginning with the address \$C00000 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).

#### 4.2.2 Mode 1: Bootstrap from byte-wide external memory

In this mode the hardware reset vector is located at address \$FF0000 in the Bootstrap ROM. The program stored in this location, after testing MODA, MODB and MODC, bootstraps thru Port A from an external byte-wide memory, starting at P:\$D00000 (bits 7-0). The memory is selected by the Address Attribute AA1 and is accessed with 31 wait states. The boot program concatenates every 3 bytes read from the external memory into a 24-bit wide DSP56301 word.

#### 4.2.3 Mode 2: Bootstrap thru SCI

In this mode the hardware reset vector is located at address \$FF0000 in the Bootstrap ROM. The program stored in this location, after testing MODA, MODB and MODC, bootstraps thru the SCI. The boot program concatenates every 3 bytes read from the SCI into a 24-bit wide DSP56301 word.

#### 4.2.4 Mode 3: Reserved

This mode is reserved for future use.

#### 4.2.5 Mode 4: Bootstrap thru HI32 in PCI mode

In this mode the hardware reset vector is located at address \$FF0000 in the Bootstrap ROM. The program stored in this location, after testing MODA, MODB and MODC, bootstraps thru HI32 in standard PCI slave configuration. The DSP56301 is written with 24-bit wide words encapsulated in 32-bit wide PCI transfers.

#### 4.2.6 Mode 5: Bootstrap thru HI32 in 16-bit-wide UB mode (ISA)

In this mode the hardware reset vector is located at address \$FF0000 in the Bootstrap ROM. The program stored in this location, after testing MODA, MODB and MODC, bootstraps thru HI32 in ISA slave configuration. The DSP56301 is written with 24-bit wide words broken into 16-bit wide ISA transfers.

# 4.2.7 Mode 6: Bootstrap thru HI32 in 8-bit-wide UB mode in double-strobe pin configuration

In this mode the hardware reset vector is located at address \$FF0000 in the Bootstrap ROM. The program stored in this location, after testing MODA, MODB and MODC, boot-

straps thru HI32 in UB slave double-strobe (HWR, HRD) configuration. The DSP56301 is written with 24-bit wide words broken into 8-bit wide host bus transfers. This mode may be used for booting from various micro-processors or micro-controllers, as for booting a slave DSP56301 from port A of a master DSP56301.

# 4.2.8 Mode 7: Bootstrap thru HI32 in 8-bit-wide UB mode in single-strobe pin configuration

In this mode the hardware reset vector is located at address \$FF0000 in the Bootstrap ROM. The program stored in this location, after testing MODA, MODB and MODC, bootstraps thru HI32 in UB slave single-strobe (HRW, HDS) configuration. The DSP56301 is written with 24-bit wide words broken into 8-bit wide host bus transfers. This mode may be used for booting from various micro-processors or micro-controllers.

#### 4.2.9 Mode 8: Expanded mode

In this mode the Bootstrap ROM is bypassed and the DSP56301 will start fetching instructions beginning with the address \$008000 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).

## 4.3 BOOTSTRAP PROGRAM

The Bootstrap Program is factory-programmed in an internal 192-words by 24-bit Bootstrap ROM located in P memory space at locations \$FF0000-\$FF00BF. The Bootstrap program can load any program RAM segment from an external DSP56301 port.

When exiting reset, the DSP56301 samples MODA, MODB, and MODC pins to determine the reset vector location. In any of the bootstrap modes, program execution begins from internal P memory location \$FF0000. The Bootstrap Program tests MODA, MODB and MODC bits in the Operating Mode Register (OMR) to determine the bootstrap mode, and then boots from the specified port. As part of the booting process, the Bootstrap Program reads, from the external port, the number of words to be loaded and the starting address in the DSP56301 P space. At the end of the Bootstrap Program, a jump is performed to the specified starting address in the DSP56301 P space and normal execution begins.

In the course of normal execution, any jump to Program location \$FF0000 will activate the Bootstrap program according to the MODA, MODB and MODC values in the OMR.

The Bootstrap Program code is listed in Appendix A-1.

## 4.4 INTERRUPT SOURCES AND PRIORITIES

#### 4.4.1 Interrupt Sources

The corresponding interrupt starting address for each interrupt source is shown in Table 4-2. These addresses are located in the 256 locations of program memory pointed to by the VBA (Vector Base Address) register in the program control unit.

In the DSP56301 only 46 of the 128 vector addresses are used for specific interrupt sources. The remaining 82 are defined reserved and may be used for Host NMI (IPL = 3) or for Host Command interrupt (IPL = 0-2). If it is known a-priori that certain interrupts will not be used at all, those interrupt vector locations can be used for program or data storage.

| Interrupt<br>Starting<br>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                                       | Тгар                                         |
| VBA:\$0A                         | 3                                       | Non-Maskable Interrupt (MMI)                 |
| VBA:\$0C                         | 3                                       | Reserved For Future Level-3 Interrupt Source |
| VBA:\$0E                         | 3                                       | Reserved For Future Level-3 Interrupt Source |
| VBA:\$10                         | 0 - 2                                   | ĪRQA                                         |
| VBA:\$12                         | 0 - 2                                   | ĪRQB                                         |
| VBA:\$14                         | 0 - 2                                   | ĪRQC                                         |
| VBA:\$16                         | 0 - 2                                   | ĪRQD                                         |
| VBA:\$18                         | 0 - 2                                   | DMA Channel 0                                |
| VBA:\$1A                         | 0 - 2                                   | DMA Channel 1                                |
| VBA:\$1C                         | 0 - 2                                   | DMA Channel 2                                |
| VBA:\$1E                         | 0 - 2                                   | DMA Channel 3                                |
| VBA:\$20                         | 0 - 2                                   | DMA Channel 4                                |

 Table 4-2. Interrupt Sources

| Interrupt<br>Starting<br>Address | Interrupt<br>Priority<br>Level<br>Range | Interrupt Source                          |  |
|----------------------------------|-----------------------------------------|-------------------------------------------|--|
| VBA:\$22                         | 0 - 2                                   | DMA Channel 5                             |  |
| VBA:\$24                         | 0 - 2                                   | TIMER 0 Compare                           |  |
| VBA:\$26                         | 0 - 2                                   | TIMER 0 Overflow                          |  |
| VBA:\$28                         | 0 - 2                                   | TIMER 1 Compare                           |  |
| VBA:\$2A                         | 0 - 2                                   | TIMER 1 Overflow                          |  |
| VBA:\$2C                         | 0 - 2                                   | TIMER 2 Compare                           |  |
| VBA:\$2E                         | 0 - 2                                   | TIMER 2 Overflow                          |  |
| VBA:\$30                         | 0 - 2                                   | ESSI0 Receive Data                        |  |
| VBA:\$32                         | 0 - 2                                   | ESSI0 Receive Data With Exception Status  |  |
| VBA:\$34                         | 0 - 2                                   | ESSI0 Receive last slot                   |  |
| VBA:\$36                         | 0 - 2                                   | ESSI0 Transmit Data                       |  |
| VBA:\$38                         | 0 - 2                                   | ESSI0 Transmit Data with Exception Status |  |
| VBA:\$3A                         | 0 - 2                                   | ESSI0 Transmit last slot                  |  |
| VBA:\$3C                         | 0 - 2                                   | Reserved                                  |  |
| VBA:\$3E                         | 0 - 2                                   | Reserved                                  |  |
| VBA:\$40                         | 0 - 2                                   | ESSI1 Receive Data                        |  |
| VBA:\$42                         | 0 - 2                                   | ESSI1 Receive Data With Exception Status  |  |
| VBA:\$44                         | 0 - 2                                   | ESSI1 Receive last slot                   |  |
| VBA:\$46                         | 0 - 2                                   | ESSI1 Transmit Data                       |  |
| VBA:\$48                         | 0 - 2                                   | ESSI1 Transmit Data with Exception Status |  |
| VBA:\$4A                         | 0 - 2                                   | ESSI1 Transmit last slot                  |  |
| VBA:\$4C                         | 0 - 2                                   | Reserved                                  |  |
| VBA:\$4E                         | 0 - 2                                   | Reserved                                  |  |
| VBA:\$50                         | 0 - 2                                   | SCI Receive Data                          |  |
| VBA:\$52                         | 0 - 2                                   | SCI Receive Data with Exception Status    |  |
| VBA:\$54                         | 0 - 2                                   | SCI Transmit Data                         |  |
| VBA:\$56                         | 0 - 2                                   | SCI idle Line                             |  |
| VBA:\$58                         | 0 - 2                                   | SCI Timer                                 |  |
| VBA:\$5A                         | 0 - 2                                   | Reserved                                  |  |
| VBA:\$5C                         | 0 - 2                                   | Reserved                                  |  |
| VBA:\$5E                         | 0 - 2                                   | Reserved                                  |  |

| Interrupt<br>Starting<br>Address | Interrupt<br>Priority<br>Level<br>Range | Interrupt Source                  |
|----------------------------------|-----------------------------------------|-----------------------------------|
| VBA:\$60                         | 0 - 2                                   | Host PCI Transaction Termination  |
| VBA:\$62                         | 0 - 2                                   | Host PCI Transaction Abort        |
| VBA:\$64                         | 0 - 2                                   | Host PCI Parity Error             |
| VBA:\$66                         | 0 - 2                                   | Host PCI Transfer Complete        |
| VBA:\$68                         | 0 - 2                                   | Host PCI Master Receive Request   |
| VBA:\$6A                         | 0 - 2                                   | Host Slave Receive Request        |
| VBA:\$6C                         | 0 - 2                                   | Host PCI Master Transmit Request  |
| VBA:\$6E                         | 0 - 2                                   | Host Slave Transmit Request       |
| VBA:\$70                         | 0 - 2                                   | Host PCI Master Address Request   |
| VBA:\$72                         | 0 - 2 / 3                               | Host Command / Host NMI (Default) |
| VBA:\$74                         | 0 - 2                                   | Reserved                          |
| :                                | :                                       | :                                 |
| VBA:\$FE                         | 0 - 2                                   | Reserved                          |

**NOTE** Any Interrupt starting address (including reserved addresses) may be used for Host NMI (IPL = 3) and for Host command interrupt (IPL = 0-2).

#### 4.4.2 Interrupt Priority Levels

There are two interrupt priority registers in the DSP56301: IPR-C is dedicated for DSP56300 Core interrupt sources and IPR-P is dedicated for DSP56301 peripheral interrupt sources. The interrupt priority registers shown in Figure 4-2 and Figure 4-1. Table 4-3 defines the IPL bits.

| 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-3. Interrupt Priority Level Bits



Figure 4-1. Interrupt Priority Register P

Figure 4-2. Interrupt Priority Register C



#### 4.4.2.1 Interrupt Sources Priorities within an IPL

If more than one interrupt request is pending when an instruction is executed, the interrupt source with the highest priority level is serviced first. When multiple interrupt requests having the same IPL are pending, a second fixed-priority structure within that IPL determines which interrupt source is serviced. The fixed priority of interrupts sources within an IPL are shown in Table 4-4.

| Priority | Interrupt Source                    |  |  |  |  |  |  |
|----------|-------------------------------------|--|--|--|--|--|--|
|          | Level 3 (Nonmaskable)               |  |  |  |  |  |  |
| Highest  | Hardware RESET                      |  |  |  |  |  |  |
|          | Stack Error                         |  |  |  |  |  |  |
|          | Illegal Instruction                 |  |  |  |  |  |  |
|          | Debug Request Interrupt             |  |  |  |  |  |  |
|          | Тгар                                |  |  |  |  |  |  |
|          | Non-Maskable Interrupt              |  |  |  |  |  |  |
| Lowest   | Non-Maskable Host Command 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             |  |  |  |  |  |  |

#### Table 4-4. Interrupt Sources Priorities within an IPL

| Priority | Interrupt Source                       |
|----------|----------------------------------------|
|          | DMA Channel 3 Interrupt                |
|          | DMA Channel 4 Interrupt                |
|          | DMA Channel 5 Interrupt                |
|          | Host Command Interrupt                 |
|          | Host PCI Transaction Termination       |
|          | Host PCI Transaction Abort             |
|          | Host PCI Parity Error                  |
|          | Host PCI Transfer Complete             |
|          | Host PCI Master Receive Request        |
|          | Host Slave Receive Request             |
|          | Host PCI Master Transmit Request       |
|          | Host Slave Transmit Request            |
|          | Host PCI Master Address Request        |
|          | ESSI0 RX Data with Exception Interrupt |
|          | ESSI0 RX Data Interrupt                |
|          | ESSI0 Receive last slot interrupt      |
|          | ESSI0 TX Data with Exception Interrupt |
|          | ESSI0 Transmit last slot interrupt     |
|          | ESSI0 TX Data Interrupt                |
|          | ESSI1 RX Data with Exception Interrupt |
|          | ESSI1 RX Data Interrupt                |
|          | ESSI1 Receive last slot interrupt      |

| Priority | Interrupt Source                          |
|----------|-------------------------------------------|
|          | ESSI1 TX Data with Exception Interrupt    |
|          | ESSI1 Transmit last slot interrupt        |
|          | ESSI1 TX Data Interrupt                   |
|          | SCI Receive Data with Exception Interrupt |
|          | SCI Receive Data                          |
|          | SCI Transmit Data                         |
|          | SCI idle Line                             |
|          | SCI Timer                                 |
|          | TIMER0 Overflow Interrupt                 |
|          | TIMER0 Compare Interrupt                  |
|          | TIMER1 Overflow Interrupt                 |
|          | TIMER1 Compare Interrupt                  |
|          | TIMER2 Overflow Interrupt                 |
| Lowest   | TIMER2 Compare Interrupt                  |

## 4.5 DMA REQUEST SOURCES

The DMA Request Source bits (DRS0-DRS4 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.

| DMA Request Source Bits | Requesting Device                  |
|-------------------------|------------------------------------|
| DRS4DRS0                |                                    |
| 00000                   | External (IRQA pin)                |
| 00001                   | External (IRQB pin)                |
| 00010                   | External (IRQC pin)                |
| 00011                   | External (IRQD 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   |
| 01001                   | Transfer Done from DMA channel 5   |
| 01010                   | ESSI0 Receive Data (RDF0=1)        |
| 01011                   | ESSI0 Transmit Data (TDE0=1)       |
| 01100                   | ESSI1 Receive Data (RDF1=1)        |
| 01101                   | ESSI1 Transmit Data (TDE1=1)       |
| 01110                   | SCI Receive Data (RDRF=1)          |
| 01111                   | SCI Transmit Data (TDRE=1)         |
| 10000                   | Timer0 (TCF0=1)                    |
| 10001                   | Timer1 (TCF1=1)                    |
| 10010                   | Timer2 (TCF2=1)                    |
| 10011-11011             | RESERVED                           |
| 11100                   | Host Slave Receive Data (SRRQ=1)   |
| 11101                   | Host Master Receive Data (MRRQ=1)  |
| 11110                   | Host Slave Transmit Data (STRQ=1)  |
| 11111                   | Host Master Transmit Data (MTRQ=1) |

## 4.6 **OPERATING MODE REGISTER**

The Operating Mode Register (OMR) in the DSP56301 is described in the following figure:

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

|    | SCS                                |        |        |                            |       | EOM     |        |    |    | СОМ    |         |        |        |     |      |    |    |        |         |       |        |    |    |
|----|------------------------------------|--------|--------|----------------------------|-------|---------|--------|----|----|--------|---------|--------|--------|-----|------|----|----|--------|---------|-------|--------|----|----|
| 23 | 22                                 | 21     | 20     | 19                         | 18    | 17      | 16     | 15 | 14 | 13     | 12      | 11     | 10     | 9   | 8    | 7  | 6  | 5      | 4       | 3     | 2      | 1  | 0  |
|    |                                    |        | SEN    | WRP                        | EOV   | EUN     | XYS    |    |    |        | BRT     | TAS    | BE     | CDI | P1:0 |    | SD |        | EBD     | MD    | MC     | MB | MA |
| SE | ΞN                                 | - Stad | ck Ext | ensio                      | n Ena | able    |        | Bł | RΤ | - Bus  | Rele    | ase Ti | ming   |     |      | S  | D  | - Sto  | p Dela  | ıy    |        |    |    |
| W  | RP                                 | - Exte | ended  | Stack                      | k Wra | p Flag  | 9      | TA | S  | - TA : | Synch   | ronize | e Sele | ct  |      | EE | BD | - Exte | ernal E | Bus D | isable | ;  |    |
| EC | V                                  | - Exte | ended  | Stack                      | k Ove | erflow  | Flag   | В  | E  | - Bur  | st Mo   | de En  | able   |     |      | Μ  | D  | - Ope  | erating | Mod   | e D    |    |    |
| ΕL | JN                                 | - Exte | ended  | Stack                      | k Und | lerflov | / Flag | CD | P1 | - Cor  | e-Dm    | a Prio | rity 1 |     |      | Μ  | С  | - Ope  | erating | Mod   | e C    |    |    |
| X١ | XYS - Stack Extension Space Select |        |        | CDP0 - Core-Dma Priority 0 |       |         |        | Μ  | В  | - Ope  | erating | Mod    | e B    |     |      |    |    |        |         |       |        |    |    |
|    |                                    |        |        |                            |       |         |        |    |    |        |         |        |        |     |      | Μ  | А  | - Ope  | erating | Mod   | e A    |    |    |

- Reserved bit. Read as zero, should be written with zero for future compatibility

## 4.7 PLL MULTIPLICATION FACTOR

The Multiplication Factor Bits MF0-MF11 in the **PLL Control Register (PCTL)** define the multiplication factor MF that will be applied to the PLL input frequency. The multiplication factor bits (MF0-MF11) are set to a predetermined value during hardware reset; in the DSP56301 this value is \$000 which correspond to a multiplication factor MF of 1.

## 4.8 DEVICE IDENTIFICATION (ID) REGISTER

The Device Identification 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 |
|----------|-----|--------|-------|----|-------------------|---|
| Ze       | ros | Rev. N | umber |    | Derivative Number |   |
| 00000000 |     | 00     | 01    |    | 001100000001      |   |

The Derivative Number (bits 11:0) for the DSP56301 are 001100000001 (i.e. 301 for 56301).

The Revision Number (bits 15:12) for the DSP56301 first silicon is 0001. Therefore the ID register value for DSP56301 first silicon is \$001301.

## 4.9 JTAG IDENTIFICATION (ID) REGISTER

The JTAG Identification (ID) Register is a 32 bit, read only thought 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 Configurati | on |
|------------------------------------------------------|----|
|------------------------------------------------------|----|

| 31      | 28          | 27         | 12          | 11      | 1              | 0 |
|---------|-------------|------------|-------------|---------|----------------|---|
| Version | Information | Customer F | Part Number | Manufac | turer Identity | 1 |
| 0001    |             | 000110   0 | 000000001   | 00000   | 0001 110       | 1 |

Motorola's Manufacturer Identity is 0000001110. The Customer Part Number consists of two parts: Motorola Design Center Number (bits 27:22) and a sequence number (bits 21:12). MSIL Design Center Number is 000110. The sequence number for the DSP56301 is 000000001. The Version Information for DSP56301 first silicon is 0001. Therefore the ID register value for DSP56301 first silicon is \$1180101d.

## 4.10 JTAG BOUNDARY SCAN REGISTER

The boundary scan register (BSR) in the DSP56301 JTAG implementation contains bits for all device signal and clock pins and associated control signals. All DSP56301 bidirectional pins have a single register bit in the boundary scan register for pin data, and are controlled by an associated control bit in the boundary scan register.

The DSP56301 boundary scan register bit definitions are described in the following table:

| 17 |
|----|
|    |
|    |

| Bit Number | Pin Name | Pin Type     | BSR Cell Type |
|------------|----------|--------------|---------------|
| 219        | DE       | INPUT/OUTPUT | DATA          |
| 218        | DE       | -            | CONTROL       |
| 217        | SC20     | INPUT/OUTPUT | DATA          |
| 216        | SC20     | -            | CONTROL       |
| 215        | SC10     | INPUT/OUTPUT | DATA          |
| 214        | SC10     | -            | CONTROL       |
| 213        | SC00     | INPUT/OUTPUT | DATA          |
| 212        | SC00     | -            | CONTROL       |
| 211        | STD0     | INPUT/OUTPUT | DATA          |
| 210        | STD0     | -            | CONTROL       |
| 209        | SCK0     | INPUT/OUTPUT | DATA          |
| 208        | SCK0     | -            | CONTROL       |
| 207        | SRD0     | INPUT/OUTPUT | DATA          |
| 206        | SRD0     | -            | CONTROL       |
| 205        | SRD1     | INPUT/OUTPUT | DATA          |
| 204        | SRD1     | -            | CONTROL       |
| 203        | SCK1     | INPUT/OUTPUT | DATA          |
| 202        | SCK1     | -            | CONTROL       |
| 201        | STD1     | INPUT/OUTPUT | DATA          |
| 200        | STD1     | -            | CONTROL       |
| 199        | SC01     | INPUT/OUTPUT | DATA          |
| 198        | SC01     | -            | CONTROL       |
| 197        | SC11     | INPUT/OUTPUT | DATA          |
| 196        | SC11     | -            | CONTROL       |
| 195        | SC21     | INPUT/OUTPUT | DATA          |

#### Table 4-5. DSP56301 BSR Bit Definition

| Bit Number | Pin Name | Pin Type     | BSR Cell Type |
|------------|----------|--------------|---------------|
| 194        | SC21     | -            | CONTROL       |
| 193        | STX      | INPUT/OUTPUT | DATA          |
| 192        | STX      | -            | CONTROL       |
| 191        | HINTA    | TS           | DATA          |
| 190        | HINTA    | -            | CONTROL       |
| 189        | SCLK     | INPUT/OUTPUT | DATA          |
| 188        | SCLK     | INPUT/OUTPUT | CONTROL       |
| 187        | SRX      | INPUT/OUTPUT | DATA          |
| 186        | SRX      | INPUT/OUTPUT | CONTROL       |
| 185        | TIO0     | INPUT/OUTPUT | DATA          |
| 184        | TIO0     | INPUT/OUTPUT | CONTROL       |
| 183        | TIO1     | INPUT/OUTPUT | DATA          |
| 182        | TIO1     | INPUT/OUTPUT | CONTROL       |
| 181        | TIO2     | INPUT/OUTPUT | DATA          |
| 180        | TIO2     | INPUT/OUTPUT | CONTROL       |
| 179        | HAD0     | INPUT/OUTPUT | DATA          |
| 178        | HAD0     | INPUT/OUTPUT | CONTROL       |
| 177        | HAD1     | INPUT/OUTPUT | DATA          |
| 176        | HAD1     | INPUT/OUTPUT | CONTROL       |
| 175        | HAD2     | INPUT/OUTPUT | DATA          |
| 174        | HAD2     | INPUT/OUTPUT | CONTROL       |
| 173        | HAD3     | INPUT/OUTPUT | DATA          |
| 172        | HAD3     | INPUT/OUTPUT | CONTROL       |
| 171        | HAD4     | INPUT/OUTPUT | DATA          |
| 170        | HAD4     | INPUT/OUTPUT | CONTROL       |
| 169        | HAD5     | INPUT/OUTPUT | DATA          |

| Bit Number | Pin Name | Pin Type     | BSR Cell Type |
|------------|----------|--------------|---------------|
| 168        | HAD5     | INPUT/OUTPUT | CONTROL       |
| 167        | HAD6     | INPUT/OUTPUT | DATA          |
| 166        | HAD6     | INPUT/OUTPUT | CONTROL       |
| 165        | HAD7     | INPUT/OUTPUT | DATA          |
| 164        | HAD7     | INPUT/OUTPUT | CONTROL       |
| 163        | HC/HBE0  | INPUT/OUTPUT | DATA          |
| 162        | HC/HBE0  | INPUT/OUTPUT | CONTROL       |
| 161        | HAD8     | INPUT/OUTPUT | DATA          |
| 160        | HAD8     | INPUT/OUTPUT | CONTROL       |
| 159        | HAD9     | INPUT/OUTPUT | DATA          |
| 158        | HAD9     | INPUT/OUTPUT | CONTROL       |
| 157        | HAD10    | INPUT/OUTPUT | DATA          |
| 156        | HAD10    | INPUT/OUTPUT | CONTROL       |
| 155        | HAD11    | INPUT/OUTPUT | DATA          |
| 154        | HAD11    | INPUT/OUTPUT | CONTROL       |
| 153        | HAD12    | INPUT/OUTPUT | DATA          |
| 152        | HAD12    | INPUT/OUTPUT | CONTROL       |
| 151        | HAD13    | INPUT/OUTPUT | DATA          |
| 150        | HAD13    | INPUT/OUTPUT | CONTROL       |
| 149        | HAD14    | INPUT/OUTPUT | DATA          |
| 148        | HAD14    | INPUT/OUTPUT | CONTROL       |
| 147        | HAD15    | INPUT/OUTPUT | DATA          |
| 146        | HAD15    | INPUT/OUTPUT | CONTROL       |
| 145        | HC/HBE1  | INPUT/OUTPUT | DATA          |
| 144        | HC/HBE1  | INPUT/OUTPUT | CONTROL       |
| 143        | HGNT     | INPUT        | DATA          |

| Bit Number | Pin Name | Pin Type     | BSR Cell Type |
|------------|----------|--------------|---------------|
| 142        | HGNT     | INPUT        | CONTROL       |
| 141        | HCLK     | INPUT        | DATA          |
| 140        | HRST     | INPUT        | DATA          |
| 139        | HRST     | INPUT        | CONTROL       |
| 138        | HREQ     | TS           | DATA          |
| 137        | HREQ     | TS           | CONTROL       |
| 136        | HPAR     | INPUT/OUTPUT | DATA          |
| 135        | HPAR     | INPUT/OUTPUT | CONTROL       |
| 134        | HSERR    | TS           | DATA          |
| 133        | HSERR    | TS           | CONTROL       |
| 132        | HPERR    | INPUT/OUTPUT | DATA          |
| 131        | HPERR    | INPUT/OUTPUT | CONTROL       |
| 130        | HLOCK    | INPUT/OUTPUT | DATA          |
| 129        | HLOCK    | INPUT/OUTPUT | CONTROL       |
| 128        | HSTOP    | INPUT/OUTPUT | DATA          |
| 127        | HSTOP    | INPUT/OUTPUT | CONTROL       |
| 126        | HDEVSEL  | INPUT/OUTPUT | DATA          |
| 125        | HDEVSEL  | INPUT/OUTPUT | CONTROL       |
| 124        | HTRDY    | INPUT/OUTPUT | DATA          |
| 123        | HTRDY    | INPUT/OUTPUT | CONTROL       |
| 122        | HIRDY    | INPUT/OUTPUT | DATA          |
| 121        | HIRDY    | INPUT/OUTPUT | CONTROL       |
| 120        | HFRAME   | INPUT/OUTPUT | DATA          |
| 119        | HFRAME   | INPUT/OUTPUT | CONTROL       |
| 118        | HIDSEL   | INPUT        | DATA          |
| 117        | HIDSEL   | INPUT        | CONTROL       |

| Bit Number | Pin Name | Pin Type     | BSR Cell Type |
|------------|----------|--------------|---------------|
| 116        | HC/HBE2  | INPUT/OUTPUT | DATA          |
| 115        | HC/HBE2  | INPUT/OUTPUT | CONTROL       |
| 114        | HAD16    | INPUT/OUTPUT | DATA          |
| 113        | HAD16    | INPUT/OUTPUT | CONTROL       |
| 112        | HAD17    | INPUT/OUTPUT | DATA          |
| 111        | HAD17    | INPUT/OUTPUT | CONTROL       |
| 110        | HAD18    | INPUT/OUTPUT | DATA          |
| 109        | HAD18    | INPUT/OUTPUT | CONTROL       |
| 108        | HAD19    | INPUT/OUTPUT | DATA          |
| 107        | HAD19    | INPUT/OUTPUT | CONTROL       |
| 106        | HAD20    | INPUT/OUTPUT | DATA          |
| 105        | HAD20    | INPUT/OUTPUT | CONTROL       |
| 104        | HAD21    | INPUT/OUTPUT | DATA          |
| 103        | HAD21    | INPUT/OUTPUT | CONTROL       |
| 102        | HAD22    | INPUT/OUTPUT | DATA          |
| 101        | HAD22    | INPUT/OUTPUT | CONTROL       |
| 100        | HAD23    | INPUT/OUTPUT | DATA          |
| 99         | HAD23    | INPUT/OUTPUT | CONTROL       |
| 98         | HC/HBE3  | INPUT/OUTPUT | DATA          |
| 97         | HC/HBE3  | INPUT/OUTPUT | CONTROL       |
| 96         | HAD24    | INPUT/OUTPUT | DATA          |
| 95         | HAD24    | INPUT/OUTPUT | CONTROL       |
| 94         | HAD25    | INPUT/OUTPUT | DATA          |
| 93         | HAD25    | INPUT/OUTPUT | CONTROL       |
| 92         | HAD26    | INPUT/OUTPUT | DATA          |
| 91         | HAD26    | INPUT/OUTPUT | CONTROL       |

| Bit Number | Pin Name | Pin Type     | BSR Cell Type |
|------------|----------|--------------|---------------|
| 90         | HAD27    | INPUT/OUTPUT | DATA          |
| 89         | HAD27    | INPUT/OUTPUT | CONTROL       |
| 88         | HAD28    | INPUT/OUTPUT | DATA          |
| 87         | HAD28    | INPUT/OUTPUT | CONTROL       |
| 86         | HAD29    | INPUT/OUTPUT | DATA          |
| 85         | HAD29    | INPUT/OUTPUT | CONTROL       |
| 84         | HAD30    | INPUT/OUTPUT | DATA          |
| 83         | HAD30    | INPUT/OUTPUT | CONTROL       |
| 82         | HAD31    | INPUT/OUTPUT | DATA          |
| 81         | HAD31    | -            | CONTROL       |
| 80         | IRQD     | INPUT        | DATA          |
| 79         | IRQC     | INPUT        | DATA          |
| 78         | ĪRQB     | INPUT        | DATA          |
| 77         | ĪRQĀ     | INPUT        | DATA          |
| 76         | D23      | INPUT/OUTPUT | DATA          |
| 75         | D22      | INPUT/OUTPUT | DATA          |
| 74         | D21      | INPUT/OUTPUT | DATA          |
| 73         | D20      | INPUT/OUTPUT | DATA          |
| 72         | D19      | INPUT/OUTPUT | DATA          |
| 71         | D18      | INPUT/OUTPUT | DATA          |
| 70         | D17      | INPUT/OUTPUT | DATA          |
| 69         | D16      | INPUT/OUTPUT | DATA          |
| 68         | D15      | INPUT/OUTPUT | DATA          |
| 67         | D[23:12] | -            | CONTROL       |
| 66         | D14      | INPUT/OUTPUT | DATA          |
| 65         | D13      | INPUT/OUTPUT | DATA          |

| 4- | 23 |
|----|----|
|    |    |

| Bit Number | Pin Name | Pin Type     | BSR Cell Type |
|------------|----------|--------------|---------------|
| 64         | D12      | INPUT/OUTPUT | DATA          |
| 63         | D11      | INPUT/OUTPUT | DATA          |
| 62         | D10      | INPUT/OUTPUT | DATA          |
| 61         | D9       | INPUT/OUTPUT | DATA          |
| 60         | D8       | INPUT/OUTPUT | DATA          |
| 59         | D7       | INPUT/OUTPUT | DATA          |
| 58         | D6       | INPUT/OUTPUT | DATA          |
| 57         | D5       | INPUT/OUTPUT | DATA          |
| 56         | D4       | INPUT/OUTPUT | DATA          |
| 55         | D3       | INPUT/OUTPUT | DATA          |
| 54         | D[11:0]  | -            | CONTROL       |
| 53         | D2       | INPUT/OUTPUT | DATA          |
| 52         | D1       | INPUT/OUTPUT | DATA          |
| 51         | D0       | INPUT/OUTPUT | DATA          |
| 50         | A23      | TS           | DATA          |
| 49         | A22      | TS           | DATA          |
| 48         | A21      | TS           | DATA          |
| 47         | A20      | TS           | DATA          |
| 46         | A19      | TS           | DATA          |
| 45         | A18      | TS           | DATA          |
| 44         | A[23:12] | -            | CONTROL       |
| 43         | A17      | TS           | DATA          |
| 42         | A16      | TS           | DATA          |
| 41         | A15      | TS           | DATA          |
| 40         | A14      | TS           | DATA          |
| 39         | A13      | TS           | DATA          |

| Bit Number | Pin Name | Pin Type     | BSR Cell Type |
|------------|----------|--------------|---------------|
| 38         | A12      | TS           | DATA          |
| 37         | A11      | TS           | DATA          |
| 36         | A10      | TS           | DATA          |
| 35         | A9       | TS           | DATA          |
| 34         | A8       | TS           | DATA          |
| 33         | A7       | TS           | DATA          |
| 32         | A6       | TS           | DATA          |
| 31         | A[11:0]  | -            | CONTROL       |
| 30         | A5       | TS           | DATA          |
| 29         | A4       | TS           | DATA          |
| 28         | A3       | TS           | DATA          |
| 27         | A2       | TS           | DATA          |
| 26         | A1       | TS           | DATA          |
| 25         | A0       | TS           | DATA          |
| 24         | EXTAL    | INPUT        | DATA          |
| 23         | RD       | TS           | DATA          |
| 22         | WR       | TS           | DATA          |
| 21         | AA3      | TS           | DATA          |
| 20         | AA2      | TS           | DATA          |
| 19         | AA3      | -            | CONTROL       |
| 18         | AA2      | -            | CONTROL       |
| 17         | BB       | -            | CONTROL       |
| 16         | BR       | OUTPUT       | DATA          |
| 15         | BG       | INPUT        | DATA          |
| 14         | BB       | INPUT/OUTPUT | DATA          |
| 13         | RES      | INPUT        | DATA          |

| Bit Number | Pin Name      | Pin Type | BSR Cell Type |
|------------|---------------|----------|---------------|
| 12         | PINIT         | INPUT    | DATA          |
| 11         | TA            | INPUT    | DATA          |
| 10         | CAS           | TS       | DATA          |
| 9          | BCLK          | TS       | DATA          |
| 8          | CLKOUT        | OUTPUT   | DATA          |
| 7          | RD,WR,BCLK,BS | -        | CONTROL       |
| 6          | CAS           | -        | CONTROL       |
| 5          | AA1           | -        | CONTROL       |
| 4          | AA0           | -        | CONTROL       |
| 3          | AA1           | TS       | DATA          |
| 2          | AA0           | TS       | DATA          |
| 1          | BL            | OUTPUT   | DATA          |
| 0          | BS            | TS       | DATA          |

# 5 GENERAL PURPOSE I/O

## 5.1 INTRODUCTION

The general purpose I/O capability of the DSP56301 consists of 42 bidirectional pins separated into five different groups, each group being separately controlled. The groups are:

- 1. Port B -24 Pins (shared with part of the host interface pins)
- 2. Port C 6 Pins (shared with ESSI0 pins)
- 3. Port D 6 Pins (shared with ESSI1 pins)
- 4. Port E 3 Pins (shared with SCI pins)
- 5. Timers -3 Pins (shared with Triple Timer pins)

## 5.2 PROGRAMMING MODEL

#### 5.2.1 Port B pins and registers

24 pins of the HI32 pin may be configured as a GPIO pin. The GPIO functionality of port B is controlled by three registers: DSP Control Register (DCTR), DSP Host Port GPIO Direction Register (DIRH) and DSP Host Port GPIO Data Register (DATH). These registers are described in Paragraphs 6.1.1, 6.1.13 and 6.1.12.

#### 5.2.2 Port C pins and registers

Each one of the six ESSI0 pins may be configured individually as a GPIO pin. 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 Paragraphs 8.5.1, 8.5.2 and 8.5.3.

#### 5.2.3 Port D pins and registers

Each one of the six ESSI1 pins may be configured individually as a GPIO pin. 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 Paragraphs 8.5.1, 8.5.2 and 8.5.3.

## 5.2.4 Port E pins and registers

Each one of the three SCI pins may be configured individually as a GPIO pin. The GPIO functionality of port E is controlled by three registers: Port E Control register (PCRE), Port E Direction register (PRRE) and Port E Data register (PDRE). These registers are described in Paragraphs 9.5.1, 9.5.2 and 9.5.3.

## 5.2.5 Triple Timer pins

Each one of the three Timers in the DSP56301 Triple Timer interface has one pin that may be configured individually as a GPIO pin. Each pin is controlled by the appropriate Timer Control register, as described in Paragraph 7.4.5.

## 6 HOST INTERFACE (HI32)

The Host Interface (HI32) provides a fast parallel host port up to 32 bits wide, which may be connected directly to the host bus.

The HI32 supports a variety of standard buses, and provides glue-less connection with a number of industry standard microcomputers, microprocessors, DSPs and DMA controllers.

The host bus may operate asynchronously to the DSP clock, therefore the HI32 registers are divided into two banks – the 'Host side' bank is accessible to the external host, and the 'DSP side' bank is accessible to the DSP56300 Core. Figure 6-1 on page 6-7 is a block diagram showing the registers in the HI32.

The HI32 supports three classes of interfaces:

- Peripheral Component Interconnect (PCI) bus (PCI Specification Revision 2.0)
- Universal bus interface
- General purpose I/O (GPIO) port

In the PCI mode, the HI32 is a dedicated, bidirectional, target (slave) / initiator (master) parallel port, with a 32-bit wide, data path, up to eight words deep. In this mode, the HI32 may be connected directly to the PCI bus.

In the Universal Bus (UB) modes, the HI32 is a dedicated, bidirectional, slave only parallel port, with a six word deep data path up to 24 bits wide. In this mode, the HI32 may be connected directly to 8-bit data buses, 16-bit data buses (e.g. ISA/EISA, Micro Channel) and 24-bit data buses (e.g. DSP56300 Core based DSP Port A bus).

The host port pin functionality and polarity are controlled by the DSP56300 Core programming the DSP control register (DCTR).

Host port pins that are not used may be programmed by the DSP56300 Core as general purpose I/O pins. The HI32 provides up to 24 general purpose I/O pins.

Below is a brief list of the HI32 features:

## Interface - DSP56300 Core Side

Mapping: 11 internal I/O space locations

Word Size: 24 bits

Data Format Conversion:

PCI Mode:

Output data alignment of 16 bit words to 16 bit double words (Dwords)

Output data alignment of 24 bit words to 32 bit Dwords

(left aligned and zero filled, right aligned and zero extended, right aligned and sign extended).

Input data alignment of 32 bit Dwords to 24 bit words

(three most significant bytes, three least significant bytes).

True 32-bit (Dword) input and output data transfers.

(32-bit PCI bus data to two DSP56300 Core 16-bit words, and vice versa)

UB Mode:

Output data alignment of 24 bit words to 16 bit words

(two most significant bytes, two least significant bytes).

Input data alignment of 16 bit words to 24 bit words

(left aligned and zero filled, right aligned and zero extended, right aligned and sign extended).

Data Buffers: FIFOs, up to eight words deep, on both transmit and receive data paths

Handshake Protocols:

Software Polled Interrupt Driven (Fast or Long) Direct Memory Access (up to four DSP56300 Core DMA channels)

GPIO:

Up to 24 I/O pins (data and pin direction are programmable)

Self Configuration:

The DSP56300 Core can access, indirectly, the CCMR, CLAT and CBMA HI32 configuration registers.

Instructions:

Memory mapped registers allow the standard MOVE instruction to be used. The special MOVEP instruction provides for I/O service capability using fast interrupts, and provides faster execution with fewer instruction words.

## Interface - Host Side

| Мар      | ping:                                              |                                                                                                                                                                                                                                                            |
|----------|----------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| •        | CI Mode:                                           |                                                                                                                                                                                                                                                            |
|          | Memory Space:                                      | <ul> <li>16K Dword (32-bit wide) locations composed of:</li> <li>3 Dword read/write registers <ul> <li>(control, status and host command)</li> </ul> </li> <li>16377 Dword read/write locations corresponding to one Dword input data FIFO, and</li> </ul> |
|          |                                                    | one Dword output data FIFO.<br>4 Dword reserved locations (read only)                                                                                                                                                                                      |
| U        | Configuration Space:<br>niversal Bus Mode:         | <ul> <li>64 32-bit Dword locations</li> <li>8 locations up to 24-bits wide (of which 4 locations are reserved)</li> </ul>                                                                                                                                  |
| P        | ress Decoding:<br>CI Mode:<br>niversal Bus Mode:   | 32 bit internal address decoding<br>11 bit (12 with HAEN) internal address decoding                                                                                                                                                                        |
| Word     | d Size: 8, 16, 24 or 32 bi                         | ts                                                                                                                                                                                                                                                         |
| Data     | a Buffers: FIFOs, six or e                         | ight words deep, on transmit and receive data paths                                                                                                                                                                                                        |
| Fe       | a Fetch Types in HI32 (sla<br>etch<br>re-fetch     | ave) to Host Data Transfers:                                                                                                                                                                                                                               |
|          | aphores:<br>emaphore flags are supp                | plied for HI32 allocation in a multi-host system                                                                                                                                                                                                           |
| Hane     | dshake Protocols:                                  |                                                                                                                                                                                                                                                            |
|          | Software Polle<br>Interrupt Drive<br>Data Acknowle | Handshake Protocols:<br>ed<br>en - Data Request (HIRQ pin) and Interrupt A (HINTA pin)<br>edge (HTA pin)<br>y Access (External DMA - HDRQ and HDAK pins)                                                                                                   |
|          |                                                    | ed                                                                                                                                                                                                                                                         |
| HI32 fe  | atures in the PCI mode                             | e:                                                                                                                                                                                                                                                         |
| 1.<br>2. | Up to 33 Mword/sec                                 | tor (master) or target (slave).<br>c zero-wait-state data transfers (with a 33MHz PCI<br>ck frequency of 66MHz or more).                                                                                                                                   |
| 3.       |                                                    | . 24 and 32 bits wide (as defined by the HBE3-HBE0                                                                                                                                                                                                         |

3. Supports words 8,16, 24 and 32 bits wide (as defined by the HBE3-HBE0 lines).

- 4. Supports output data alignment of 24 bit words to 32 bit Dwords (left aligned and zero filled, right aligned and zero extended, right aligned and sign extended).
- 5. Supports input data alignment of 32 bit Dwords to 24 bit words (three most significant bytes, three least significant bytes).
- 6. Supports true 32-bit (Dword) input and output data transfers. (32-bit PCI bus data to two DSP56300 Core 16-bit words, and vice versa)
- 7. Supports bursts of up to 16384 Dwords when accessed as a memory space mapped target.
- 8. Generates bursts of up to 64 Dwords or unlimited length (as master).
- 9. Supports high speed ("fast peripheral") DSP56300 Core DMA transfers (two Core clock cycles per DMA transfer).
- 10. Supports memory-space and configuration transactions as a target.
- 11. Supports memory-space, I/O-space and configuration transactions as an initiator.
- 12. Supports exclusive (locked) accesses.
- 13. Supports a self configuration mode, for initialization of the configuration registers in a system without an external system configurator.
- 14. Supports PCI Interrupt Requests (Interrupt A). This interrupt request is software driven.
- 15. Generates vectored DSP56300 Core interrupts; separately for receive, transmit, transaction termination, error events and host commands.
- 16. Supports both 3.3V and 5V PCI signalling environments.
- 17. Supports address insertion in the data written to the HI32.
- 18. Supports parity generation, detection and reporting.
- 19. Supports system error generation and reporting.

## HI32 features in the Universal Bus modes:

- 1. Operates as a slave in many standard bus environments (e.g. ISA bus or DSP56300 Core based DSP Port A bus).
- 2. Transfers data at three clock cycles per transfer (i.e. 22 Mword/sec for a 66MHz DSP clock), when operating synchronously with an DSP56300 Core based DSP host (two wait states per access).
- 3. Supports high speed ("fast peripheral") DSP56300 Core DMA transfers (two Core clock cycles per DMA transfer).
- 4. Supports words 8,16, and 24 bits wide.
- 5. Supports output data alignment of 24 bit words to 16 bit words (two most significant bytes, two least significant bytes).
- 6. Supports input data alignment of 16 bit words to 24 bit words (left aligned and zero filled, right aligned and zero extended, right aligned and sign extended).
- 7. Supports an external data buffer for drive and voltage level compatibility with the external bus (e.g. ISA bus).
- 8. Generates interrupt requests: hardware driven (HIRQ) and software driven (HINTA).

# 9. Generates vectored DSP56300 Core interrupts; separately for receive and transmit events and host commands.

|                             | Туре                          |    | Entered when                                                                                                                                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------------------|-------------------------------|----|-------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                             | Hardware<br>Reset             | HS | The DSP56300<br>Core RESET pin is<br>asserted.                                                                                                  | These resets force the HI32 DSP side state machines, control and status registers to their initial states.                                                                                                                                                                                                                                                                                                                                                                                           |
| Core                        | Software<br>Reset             |    | The RESET<br>instruction is<br>executed.                                                                                                        | These resets also activate the Personal Software (PS) reset (see below).                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Initiated by the DSP56300 C | Personal<br>Software<br>Reset | PS | The DSP56300<br>Core writes zeros<br>to the HI32 mode<br>bits HM2-HM0 in<br>the DSP control<br>register or the HS<br>reset has been<br>executed | The HI32 terminates the current PCI transaction (if it<br>is an active PCI agent), clears the HACT bit in the<br>DSP status register (DSR) and enters the personal<br>software (PS) reset state. All data paths are cleared.<br>In the personal software reset state, the HI32 is a<br>PCI agent and will respond to all memory space<br>transactions with a retry event. If connected to other<br>buses (e.g. ISA bus, DSP56300 Core based DSP<br>Port A bus, etc.) all outputs are high impedance. |
| Initi                       | STOP<br>Reset                 | ST | The STOP<br>instruction is<br>executed.                                                                                                         | This reset forces all host port pins to the disconnect-<br>ed state: all outputs are high impedance, all inputs<br>are electrically disconnected.<br>The host port pins are affected immediately.<br>Note: this reset may be executed only when the<br>HACT bit in the DSP status register (DSR) is zero.                                                                                                                                                                                            |
| Initiated by the Host       | Personal<br>Hardware<br>Reset | PH | The HI32<br>HRST/HRST pin is<br>asserted.                                                                                                       | This reset forces the HI32 host side state machines, control registers, and configuration registers to their initial states. All host port pins, except HRST/HRST, are forced to the disconnected state: all outputs are high impedance, inputs are electrically disconnected. The DSP side state machines are not affected. The HRST/HRST pin is ignored in the self configuration mode.                                                                                                            |

Below is a description of the various HI32 resets.

Figure 6-1 on page 6-7 is a block diagram showing the registers in the HI32. These registers are divided into two banks:

- The "Host side" registers can be accessed by the host bus:
  - control, status, vector and data registers and FIFOs (HCTR, HSTR, HCVR, HTXR, HRXS and HRXM<sup>1</sup>)
  - PCI configuration registers (CSTR/CCMR, CDID/CVID, CCCR/CRID, CHTY/CLAT, CBMA and CILP)
- The "DSP side" registers can be accessed by the DSP56300 Core
  - internal I/O space registers (DCTR, DSR, DPCR, DPAR, DPMC, DPSR, DRXR, DTXS and DTXM)

•

<sup>1.</sup> The HRXM is used by the HI32, as the PCI master, to output data, and cannot actually be accessed by the host bus.

## Figure 6-1. HI32 Block Diagram



## 6.1 HI32 - DSP SIDE

The DSP56300 Core views the HI32 as a memory-mapped peripheral occupying 11 24-bit words in data memory space.

The HI32 DSP side programming model is shown in Figure 6-2.

| Address                               | Register                                 |
|---------------------------------------|------------------------------------------|
| HI32 via programmed base address: \$5 | DSP Control Register (DCTR)              |
| HI32 via programmed base address: \$6 | DSP PCI Control Register (DPCR)          |
| HI32 via programmed base address: \$7 | DSP PCI Master Control Register (DPMC)   |
| HI32 via programmed base address: \$8 | DSP PCI Address Register (DPAR)          |
| HI32 via programmed base address: \$9 | DSP Status Register (DSR)                |
| HI32 via programmed base address: \$A | DSP PCI Status Register (DPSR)           |
| HI32 via programmed base address: \$B | DSP Receive Data FIFO (DRXR)             |
| HI32 via programmed base address: \$C | DSP Master Transmit Data FIFO (DTXM)     |
| HI32 via programmed base address: \$D | DSP Slave Transmit Data FIFO (DTXS)      |
| HI32 via programmed base address: \$E | Host Port GPIO Direction Register (DIRH) |
| HI32 via programmed base address: \$F | Host Port GPIO Data Register (DATH)      |

The separate host-to-DSP and DSP-to-host data paths are FIFOs to allow the HI32 and the host processor to transfer data efficiently and at high speeds.

Memory mapping allows DSP56300 Core data transfers with the HI32 registers to be accomplished using standard instructions and addressing modes. In addition, the MOVEP instruction allows HI32-to-memory and memory-to-HI32 data transfers without going through an intermediate register.

The on-chip general purpose DMA channels, in the DSP56300 Core, can be programmed to transfer data between the HI32 data FIFOs and other DMA accessible resources at maximum throughput, without DSP56300 Core intervention.

The DSP56300 Core may access the HI32, using either standard polling, interrupt or DMA techniques.

The following paragraphs describe the purpose and operation of each bit in each register of the HI32, visible to the DSP56300 Core. The effects of the different types of reset on these registers are shown.

The HI32 host side programming model is described in Section 6.2.

## 6.1.1 DSP Control Register (DCTR)

| 23 | 22  | 21  | 20  | 19   | 18   | 17       | 16       | 15   | 14       | 13       | 12 | 11 | 10 | 9 | 8 | 7 | 6    | 5   | 4   | 3   | 2    | 1    | 0    |
|----|-----|-----|-----|------|------|----------|----------|------|----------|----------|----|----|----|---|---|---|------|-----|-----|-----|------|------|------|
|    | HM2 | HM1 | HM0 | HIRD | HIRH | HRS<br>P | HDR<br>P | HTAP | HRW<br>P | HDS<br>M |    |    |    |   |   |   | HINT | HF5 | HF4 | HF3 | SRIE | STIE | HCIE |

Reserved, read as zero and should be written with zero

| Bit     | Name     | Function                              |
|---------|----------|---------------------------------------|
| 0       | HCIE     | Host Command Interrupt Enable         |
| 1       | STIE     | Slave Transmit Interrupt Enable       |
| 2       | SRIE     | Slave Receive Interrupt Enable        |
| 5-3     | HF5-HF3  | Host Flags                            |
| 6       | HINT     | Host Interrupt A                      |
| 13      | HDSM     | Host Data Strobe Mode                 |
| 14      | HRWP     | Host RD/WR Polarity                   |
| 15      | HTAP     | Host Transfer Acknowledge Polarity    |
| 16      | HDRP     | Host DMA Request Polarity             |
| 17      | HRSP     | Host Reset Polarity                   |
| 18      | HIRH     | Host Interrupt Request Handshake Mode |
| 19      | HIRD     | Host Interrupt Request Drive Control  |
| 22-20   | HM2-HM0  | HI32 Mode                             |
| 23,12-7 | reserved |                                       |

The DCTR is a 24-bit read/write control register used by the DSP56300 Core to control the HI32 interrupts, flags and the host port pin functionality. The DCTR cannot be accessed by the host processor. All reserved bits are read as zeros and should be programmed as zeros for future compatibility. The bit manipulation instructions are useful for accessing individual bits in the DCTR. The DCTR bits are described in the following paragraphs.

6.1.1.1 Host Command Interrupt Enable (HCIE) Bit 0

The HCIE bit is used to enable a vectored DSP56300 Core interrupt request when the host command pending (HCP) status bit in the DSP status register (DSR) is set. If HCIE is cleared, HCP interrupt requests are disabled. With HCIE set, a host command interrupt request will be generated if HCP is set. The starting address of this interrupt is determined by the host vector HV6-HV0 in the host command vector register (HCVR).

If the host non-maskable interrupt (HNMI) bit is set in the host command vector register (HCVR), HCIE is ignored, and an interrupt is generated if HCP is set regardless of HCIE.

Hardware and software resets clear HCIE.

## 6.1.1.2 Slave Transmit Interrupt Enable (STIE) Bit 1

The STIE bit is used to enable an DSP56300 Core interrupt request when the slave transmit data request (STRQ) status bit in the DSR is set. If STIE is cleared, STRQ interrupt requests are disabled. If STIE is set an slave transmit data interrupt request will be generated if STRQ is set.

Hardware and software resets clear STIE.

## 6.1.1.3 Slave Receive Interrupt Enable (SRIE) Bit 2

The SRIE bit is used to enable an DSP56300 Core interrupt request when the slave receive data request (SRRQ) status bit in the DSR is set. If SRIE is cleared, SRRQ interrupt requests are disabled. If SRIE is set, a slave receive data interrupt request will be generated if SRRQ is set.

Hardware and software resets clear SRIE.

## 6.1.1.4 Host Flags (HF5-HF3) Bits 5-3

The HF5-HF3 bits are used as general purpose flags for DSP-to-host communication. HF5-HF3 may be set or cleared by the DSP56300 Core. HF5-HF3 are visible to the external host in the HSTR register.

Hardware and software resets clear host flags.

NOTE: There are six host flags: three used by the host to signal the DSP56300 Core (HF2-HF0) and three used by the DSP56300 Core to signal the host processor (HF5-HF3). These are general purpose flags. The host flags do not cause interrupts; they must be polled to see if they have changed. These flags can be used individually or as encoded triads.

### 6.1.1.5 Host Interrupt A (HINT) Bit 6

The HINT bit controls the HINTA pin. When HINT is set by the DSP56300 Core, the HINTA pin is driven low. When HINT is cleared by the DSP56300 Core, the HINTA pin is released.

Hardware and software resets clear HINT.

## 6.1.1.6 Host Data Strobe Mode (HDSM) Bit 13

The HDSM bit controls the data strobe mode of the host port pins when in a Universal Bus mode (HM = 2 or 3). If HDSM is cleared, the double-strobe pin mode is selected: HWR/HRW pin (HP29) functions as host write strobe HWR and HRD/HDS (HP30) functions as host read strobe HRD. If HDSM is set, the single-strobe pin mode is selected: HWR/HRW pin functions as host read/write HRW and HRD/HDS functions as host data strobe HDS.

The value of HDSM may be changed only when HACT=0 in the DSR.

HDSM is ignored when not in a Universal Bus mode (HM  $\neq$  \$2 or \$3).

Hardware and software resets clear HDSM.

## 6.1.1.7 Host Read/Write Polarity (HRWP) Bit 14

The HRWP bit controls the polarity of  $\overline{HWR}$ /HRW pin, when in single-strobe Universal Bus modes (HM = \$2 or \$3 and HDSM=1), that is, when  $\overline{HWR}$ /HRW pin (HP29) functions as the host read/write (HRW) pin.

If HRWP is cleared, the host-to-DSP data transfer direction corresponds to low level of HRW pin, and DSP-to-host data transfer direction corresponds to high level of HRW pin.

If HRWP is set, the host-to-DSP data transfer direction corresponds to high level of HRW pin, and DSP-to-host data transfer direction corresponds to low level of HRW pin.

The value of HRWP may be changed only when HACT=0.

HRWP is ignored when not in a Universal Bus mode or double-strobe host port mode is selected (HM  $\neq$  \$2 or \$3, or HDSM = 0).

Hardware and software resets clear HRWP.

## 6.1.1.8 Host Transfer Acknowledge Polarity (HTAP) Bit 15

The HTAP bit controls the polarity of the HTA pin when the HI32 is in a Universal Bus mode (HM = \$2 or \$3). If HTAP is cleared, the HTA pin is active high and the HI32 will request to extend the access by driving the HTA pin low (i.e. negated). If HTAP is set, the HTA pin is active low and the HI32 will request to extend the access by driving the HTA pin high (i.e. negated).

NOTE: HTA is driven in the Universal Bus modes (HM = 2 or 3) while the HI32 is being accessed by an external host. If the HI32 is not being accessed, the HTA pin is high impedance.

The value of HTAP may be changed only when HACT=0.

HTAP is ignored when not in a Universal Bus mode (HM  $\neq$  \$2 or \$3).

Hardware and software resets clear HTAP.

## 6.1.1.9 Host DMA Request Polarity (HDRP) Bit 16

The HDRP bit controls the polarity of HDRQ pin when the HI32 is in a Universal Bus mode (HM = \$2 or \$3). If HDRP is cleared, the HDRQ pin is active high and the HI32 will request DMA service by driving the HDRQ pin high (i.e. asserted). If HDRP is set, the HDRQ pin is active low and the HI32 will request DMA service by driving the HDRQ pin low (i.e. asserted).

The value of HDRP may be changed only when HACT=0.

HDRP is ignored when not in a Universal Bus mode (HM  $\neq$  \$2 or \$3).

Hardware and software resets clear HDRP.

## 6.1.1.10 Host Reset Polarity (HRSP) Bit 17

The HRSP bit controls the polarity of HRST pin when the HI32 is in a Universal Bus or the GPIO mode (HM = 2, 3 or 4). If HRSP is cleared, the HRST pin is active high and the HI32 will be reset if the HRST pin is high (i.e. asserted). If HRSP is set, the HRST pin is active low and the HI32 will be reset if HRST pin is low (i.e. asserted).

The value of HRSP may be changed only when HACT=0.

HRSP is ignored in the PCI mode (HM = 1).

Hardware and software resets clear HRSP.

6.1.1.11 Host Interrupt Request Handshake Mode(HIRH) Bit 18

The HIRH bit controls the handshake mode of the  $\overline{\text{HIRQ}}$  pin when the HI32 is in a Universal Bus mode (HM = \$2 or \$3).  $\overline{\text{HIRQ}}$  is asserted by the HI32 when a host interrupt request (receive and/or transmit) is generated in the HI32. With HIRH cleared, when a host interrupt request is generated,  $\overline{\text{HIRQ}}$  is asserted for the number of DSP56300-Core clock cycles specified by the LT7-LT0 bits in the CLAT and then negated. The duration of the HIRQ pulse is given by the following equation:

HIRQ\_PULSE\_WIDTH = (LT[7:0]\_Value + 1) • DSP56300\_Core\_clock\_cycle

If HIRH is set: HIRQ is negated when the interrupt request source is cleared (by the corresponding host data access), masked (by TREQ=0 or RREQ=0) or disabled by the DMA enable bit (DMAE) in the HCTR.

The value of HIRH may be changed only when HACT=0.

HIRH is ignored when not in a Universal Bus mode (HM  $\neq$  \$2 or \$3).

Hardware and software resets clear HIRH.

6.1.1.12 Host Interrupt Request Drive Control (HIRD) Bit 19

The HIRD bit controls the output drive of  $\overline{\text{HIRQ}}$  pin when the HI32 is in a Universal Bus mode (HM = \$2 or \$3). With HIRD cleared, the  $\overline{\text{HIRQ}}$  pin is an open drain output (i.e. driven low when asserted, released (high impedance) when negated). With HIRD set, the  $\overline{\text{HIRQ}}$  pin is always driven.

The value of HIRD may be changed only when HACT=0.

HIRD is ignored when not in a Universal Bus mode (HM  $\neq$  \$2 or \$3).

Hardware and software resets clear HIRD.

NOTE: Each of the bits HDSM, HRWP, HTAP, HDRP, HRSP, HIRH, and HIRD affect the host port pins directly. To assure proper operation, these pins may be changed only when HACT=0. The HM2-HM0 bits must not be changed together with these bits (i.e. in the same Core write).

6.1.1.13 HI32 Mode (HM2-HM0) Bits 22-20

The HM bits control the operation modes and pin functionality of the HI32 (see Table 6-1). The host port pins in the different modes are shown in Table 6-2.

| HM2-HM0 | HI32 Mode              |
|---------|------------------------|
| 0 0 0   | Terminate and Reset    |
| 001     | PCI                    |
| 0 1 0   | Universal Bus          |
| 0 1 1   | Enhanced Universal Bus |
| 100     | GPIO                   |
| 101     | Self Configuration     |
| 1 1 0   | reserved               |
| 1 1 1   | reserved               |

### Table 6-1. HI32 Modes

## Terminate and Reset (HM=\$0):

### When HM2-HM0 is written \$0:

If the HI32 was in the PCI mode (HM=\$1), as an active PCI master: the HI32 generates a master initiated termination; if a selected target in a memory space transaction, the HI32 generates a target-disconnect-C/retry event, thus completing the PCI transaction. When the PCI idle state is subsequently detected, the HI32 clears HACT in the DSR and enters the personal software (PS) reset state. In the personal software reset state all data paths are cleared, and the HI32 will respond to all memory space transactions with a retry event. If the HI32 was not an active target in the PCI mode (HM $\neq$ \$1) memory space transaction, the HI32 immediately clears HACT in the DSR and enters the personal software (PS) reset state.

Configuration space transactions are not affected by clearing the HM bits.

In the personal software reset the HI32 consumes very little current. This is a low-power state. For even greater power saving, the HI32 may be programmed to the GPIO mode.

## PCI Mode (HM=\$1):

The HI32 supports:

- Glue-less connection to the standard PCI bus.
- Operation as an initiator (master) or target (slave).
- 24- to 32-bit, 32- to 24-bit data formatting and true 32-bit (Dword) data transfers.
- Memory-space and configuration transactions as a target.
- Memory-space, I/O-space and configuration transactions as an initiator.

### Universal Bus Mode (HM=\$2):

The HI32 supports:

- Glue-less connection to various external buses (e.g. ISA/EISA, DSP56300 Core based DSP Port A bus).
- 24-bit, 16-bit (with data alignment) and 8-bit buses.
- ISA/EISA bus DMA-type accesses.
- Pins HP22-HP20 are general purpose I/O.
- HP19, HP31 and HP32 are unused and must be forced or pulled up to Vcc.
- When operating with a host bus less than 24 bits wide, the data pins that are not used for transferring data must be forced or pulled up or down to Vcc or to GND respectively. For example: when operating with a 16-bit bus (e.g. ISA bus), HP48-HP41 must be forced or pulled up to Vcc or pulled down to GND.

### Enhanced Universal Bus Mode (HM=\$3):

The HI32 supports:

- Glue-less connection to various external buses (e.g. ISA/EISA, DSP56300 Core based DSP Port A bus).
- 24-bit, 16-bit (with data alignment) and 8-bit buses.
- ISA/EISA bus DMA-type accesses.
- Two control signals (data direction and data output enable) are output to an optional external data buffer.

- Host select acknowledge output is provided.
- HP19, HP31 and HP32 are unused and must be forced or pulled up to Vcc.
- When operating with a host bus less than 24 bits wide, the data pins that are not used for transferring data must be forced or pulled up or down to Vcc or to GND respectively. For example: when operating with a 16-bit bus (e.g. ISA bus), HP48-HP41 must be forced or pulled up to Vcc or pulled down to GND.

## GPIO Mode (HM=\$4):

The HI32 supports:

- General purpose I/O (GPIO) port.
- Pins HP23-HP0 are GPIO.
- Pins HP48-HP33, HP30-24 are disconnected.
- HP31 and HP32 are unused and must be forced or pulled up to Vcc.
- Minimum current consumption.

## Self Configuration Mode (HM=\$5):

The HI32 supports:

- Indirect DSP56300 Core access to the CCMR, CLAT and CBMA HI32 configuration registers.
- All the host port pins are in the disconnected state.

The value of the HM bits may be changed to a non zero value by the DSP56300 Core only when the HI32 is in the personal software reset state (HM=\$0, HACT=0), they must not be changed together (i.e. in the same Core write) with any of the following bits: HDSM, HRWP, HTAP, HDRP, HRSP, HIRH, or HIRD.

The combinations HM=\$6, HM=\$7 are reserved for future expansion and should not be used.

Hardware and software resets clear the HM bits.

| Table 6-2. | Host Port | Pin | Functionality |
|------------|-----------|-----|---------------|
|------------|-----------|-----|---------------|

|                     | PCI Bus           | Universal B                                     | us Mode <sup>(a)</sup> | GPIO         |  |  |  |  |  |
|---------------------|-------------------|-------------------------------------------------|------------------------|--------------|--|--|--|--|--|
| HI32<br>Port<br>Pin | Mode              | Enhanced Universal<br>Bus Mode                  | Universal Bus Mode     | Mode         |  |  |  |  |  |
| 1 111               | HM=\$1            | HM=\$3                                          | HM=\$3 HM=\$2          |              |  |  |  |  |  |
| HP7-0               | HAD15-HAD0        | HA10                                            | -HA3                   | HIO7-0       |  |  |  |  |  |
| HP15-8              |                   | HD7-                                            | -HD0                   | HIO15-8      |  |  |  |  |  |
|                     | HC3/HBE3-HC0/HBE0 | HA2-                                            | -HA0                   | HIO18-16     |  |  |  |  |  |
| HP19-16             |                   | UNUS                                            | SED <sup>(b)</sup>     | HIO19        |  |  |  |  |  |
| HP20                | HTRDY             | HDBEN                                           | HIC                    | D20          |  |  |  |  |  |
| HP21                | HIRDY             | HDBDR                                           | HIC                    | D21          |  |  |  |  |  |
| HP22                | HDEVSEL           | HSAK                                            | HIC                    | 022          |  |  |  |  |  |
| HP23                | HLOCK             | HBS                                             | <u>S</u> (c)           | HIO23        |  |  |  |  |  |
| HP24                | HPAR              | HDA                                             | K (c)                  |              |  |  |  |  |  |
| HP25                | HPERR             | HD                                              | RQ                     |              |  |  |  |  |  |
| HP26                | HGNT              | HA                                              | EN                     |              |  |  |  |  |  |
| HP27                | HREQ              | H                                               | ГА                     | disconnected |  |  |  |  |  |
| HP28                | HSERR             | HI                                              | र्                     |              |  |  |  |  |  |
| HP29                | HSTOP             | HWR                                             | /HRW                   |              |  |  |  |  |  |
| HP30                | HIDSEL            | HRD                                             | /HDS                   |              |  |  |  |  |  |
| HP31                | HFRAME            |                                                 | UNUSED <sup>(d)</sup>  |              |  |  |  |  |  |
| HP32                | HCLK              |                                                 | UNUSED <sup>(d)</sup>  |              |  |  |  |  |  |
| HP40-33             | HAD23-HAD16       | HD                                              | 15-8                   |              |  |  |  |  |  |
| HP48-41             | HAD31-HAD24       | HD2<br>Output is high impo<br>Input is disconne | edance if HRF≠\$0.     | disconnected |  |  |  |  |  |
| HP49                | HRST              |                                                 | HRST                   |              |  |  |  |  |  |
| HP50                |                   | HINTA                                           |                        |              |  |  |  |  |  |

a. When operating with a host bus less than 24 bits wide, the data pins that are not used for transferring data must be forced or pulled to Vcc or to GND.

b. Must be forced or pulled to Vcc or GND.

c. HBS/HDAK should be forced or pulled up to Vcc if not used.

d. Must be forced or pulled up to Vcc.

## 6.1.1.14 DCTR Reserved Control Bits 23, 12-7

These bits are reserved for future expansion, they are read as zeros and should be written with zeros for upward compatibility.

| 6.1.2 DSP PCI Control Register (DPCR) |    |     |      |          |          |    |      |     |      |    |      |    |    |      |   |      |   |      |      |   |      |      |   |
|---------------------------------------|----|-----|------|----------|----------|----|------|-----|------|----|------|----|----|------|---|------|---|------|------|---|------|------|---|
| 23                                    | 22 | 21  | 20   | 19       | 18       | 17 | 16   | 15  | 14   | 13 | 12   | 11 | 10 | 9    | 8 | 7    | 6 | 5    | 4    | 3 | 2    | 1    | 0 |
|                                       |    | IAE | RBLE | MWS<br>D | MAC<br>E |    | SERF | мтт | CLRT |    | TCIE |    |    | TTIE |   | TAIE |   | PEIE | MAIE |   | MRIE | MTIE |   |

Reserved, read as zero and should be written with zero

| Bit                           | Name     | Function                                 |
|-------------------------------|----------|------------------------------------------|
| 1                             | MTIE     | Master Transmit Interrupt Enable         |
| 2                             | MRIE     | Master Receive Interrupt Enable          |
| 4                             | MAIE     | Master Address Interrupt Enable          |
| 5                             | PEIE     | Parity Error Interrupt Enable            |
| 7                             | TAIE     | Transaction Abort Interrupt Enable       |
| 9                             | TTIE     | Transaction Termination Interrupt Enable |
| 12                            | TCIE     | Transfer Complete Interrupt Enable       |
| 14                            | CLRT     | Clear Transmitter                        |
| 15                            | MTT      | Master Transfer Terminate                |
| 16                            | SERF     | HSERR Force                              |
| 18                            | MACE     | Master Access Counter Enable             |
| 19                            | MWSD     | Master Wait State Disable                |
| 20                            | RBLE     | Receive Buffer Lock Enable               |
| 21                            | IAE      | Insert Address Enable                    |
| 23-22,17,13,<br>11-10,8,6,3,0 | reserved |                                          |

The DPCR is a 24-bit read/write control register used by the DSP56300 Core to control the HI32 PCI interrupts, and interface logic. The DPCR cannot be accessed by the host processor. All reserved bits are read as zeros and should be programmed as zeros for future compatibility. The bit manipulation instructions are useful for accessing individual bits in the DPCR. The DPCR bits are described in the following paragraphs.

## 6.1.2.1 Master Transmit Interrupt Enable (MTIE) Bit 1

The MTIE bit is used to enable an DSP56300 Core interrupt request when the master transmit data request (MTRQ) status bit in the DPSR is set. If MTIE is cleared, MTRQ interrupt requests are disabled. If MTIE is set a master transmit data interrupt request will be generated if MTRQ is set.

Hardware and software resets clear MTIE.

## 6.1.2.2 Master Receive Interrupt Enable (MRIE) Bit 2

The MRIE bit is used to enable an DSP56300 Core interrupt request when the master receive data request (MRRQ) status bit in the DSP status register (DPSR) is set. If MRIE

is cleared, master receive data interrupt requests are disabled. If MRIE is set, a master receive data interrupt request will be generated if MRRQ is set.

Hardware and software resets clear MRIE.

## 6.1.2.3 Master Address Interrupt Enable (MAIE) Bit 4

The MAIE bit is used to enable an DSP56300 Core interrupt request when the HI32 is currently not the PCI transaction initiator, when in the PCI mode (HM=\$1). If MAIE is cleared, master address interrupt requests are disabled. If MAIE is set, a master address interrupt request will be generated if the master address request (MARQ) status bit in the DPSR register is set.

Hardware and software resets clear MAIE.

## 6.1.2.4 Parity Error Interrupt Enable (PEIE) Bit 5

The PEIE bit is used to enable an DSP56300 Core interrupt request when a parity error is detected, when in the PCI mode (HM=\$1). If PEIE is cleared, parity error interrupt requests are disabled. If PEIE is set, a parity error interrupt request will be generated if a parity error (address or data) is detected and the address parity error (APER) status bit or the data parity error (DPER) status bit in the DPSR register is set.

Hardware and software resets clear PEIE.

## 6.1.2.5 Transaction Abort Interrupt Enable (TAIE) Bit 7

The TAIE bit is used to enable an DSP56300 Core interrupt request when in the PCI mode (HM=\$1) and the HI32, as a PCI master, has executed a master-abort termination or a target initiated target-abort termination. If TAIE is cleared, transaction abort interrupt requests are disabled. If TAIE is set, a transaction abort interrupt request will be generated if a transaction was terminated due to master-abort (MAB is set in the DPSR) or target-abort (TAB is set).

Hardware and software resets clear TAIE.

## 6.1.2.6 Transaction Termination Interrupt Enable (TTIE) Bit 9

The TTIE bit is used to enable an DSP56300 Core interrupt request when in the PCI mode (HM=\$1) and the HI32, as a PCI master, has executed a time-out termination, or a target initiated disconnect or retry termination. If TTIE is cleared, transaction termination interrupt requests are disabled. If TTIE is set, a transaction termination interrupt request will be generated if a transaction was terminated due to a disconnect (TDIS is set in the DPSR), retry (TRTY is set) or time-out (TO is set).

Hardware and software resets clear TTIE.

## 6.1.2.7 Transfer Complete Interrupt Enable (TCIE) Bit 12

The TCIE bit is used to enable an DSP56300 Core interrupt request when in the PCI mode (HM=\$1) and the host data transfer complete (HDTC) status bit in the DSP PCI status register (DPSR) is set. If TCIE is cleared, transfer complete interrupt requests are disabled. If TCIE is set, a transfer complete interrupt request will be generated if HDTC is set.

Hardware and software resets clear TCIE.

## 6.1.2.8 Clear Transmitter (CLRT) Bit 14

The CLRT bit is used to clear the HI32 master-to-host bus data path in the PCI mode (HM=\$1). When CLRT is set by the DSP56300 Core, the HI32 hardware clears the master DSP-to-host bus data path (i.e. the DTXM-HRXM FIFO is forced empty) - thus setting the PCI Master Transmit Data Request bit (MTRQ) in the DPSR, and then clears CLRT. CLRT cannot be written zero by the DSP56300 Core.

To assure operation, CLRT may be set by the DSP56300 Core, only if

- 1. MARQ is set in the DPSR (i.e. the DSP56300 Core has not initiated a PCI transaction); and
- 2. No DSP56300 Core DMA channel is enabled to service HI32 master transmit data DMA requests.

CLRT is ignored when the HI32 is not in the PCI mode (HM $\neq$ \$1).

Hardware and software resets clear CLRT.

6.1.2.9 Master Transaction Termination (MTT) Bit 15

The MTT bit is used for the generation of a PCI master initiated transaction termination. When the HI32, in the PCI mode (HM=\$1), is the active PCI master, if MTT is set, by the DSP56300 Core, a master initiated transaction termination (not master-abort) is generated. MTT is cleared by the HI32 hardware when the PCI bus is in the idle state. MTT cannot be written zero by the DSP56300 Core.

MTT is ignored when the HI32 is not in the PCI mode ( $HM \neq$ \$1).

Hardware and software resets clear MTT.

## 6.1.2.10 System Error Force (SERF) Bit 16

The SERF bit controls HSERR pin state in the PCI mode (HM=\$1). When SERF is set by the DSP56300 Core and the HI32 is the current PCI bus master or a selected target, the HSERR pin is pulsed one PCI clock cycle, if the system error enable (SERE) bit is set in the status/command configuration register (CSTR/CCMR); the signalled system error (SSE) bit is set in the CSTR/CCMR. SERF is cleared by the HI32 hardware after HSERR is asserted. If SERF is cleared, the HSERR pin is controlled by the HI32 hardware (see

HSERR pin definition in Table 6-2, on page 6-16). SERF cannot be written zero by the DSP56300 Core.

SERF is ignored when the SERE bit is cleared or when the HI32 is not an active PCI agent (i.e.  $HM \neq \$1$  or the HI32 is not the current PCI bus master or a selected target).

Hardware and software resets clear SERF.

6.1.2.11 Master Access Counter Enable (MACE) Bit 18

The MACE bit is used to enable the master access counter.

If MACE is set, the master access counter is enabled and the HI32 as the active PCI master (HM=\$1) will terminate the current PCI transaction when the counter reaches the terminal count.

If MACE is cleared, the counter is disabled, and the burst length of transactions initiated by the HI32 are unlimited.

The DSP56300 Core can terminate a transaction initiated by the HI32 by writing one to the MTT bit in the DPCR.

MACE is ignored when the HI32 is not in the PCI mode ( $HM \neq$ \$1).

The value of MACE may be changed only if MARQ=1, or HACT=0.

Hardware and software resets clear MACE.

### 6.1.2.12 Master Wait State Disable (MWSD) Bit 19

The MWSD bit is used to disable PCI wait states (inserted by negating HIRDY), during a data phase.

If MWSD is cleared, the HI32 as the active PCI master (HM=\$1) will insert wait states to extend the current data phase if it cannot guarantee the completion of the next data phase. The HI32 will assert HIRDY and complete the current data phase if:

- it can complete the next data phase, or
- it has determined to terminate the transaction due to time-out or completion.

If MWSD is set, the HI32, as the active PCI master (HM=\$1) will not insert wait states. If it cannot guarantee the completion of the next data phase, the HI32 will complete the current data phase and terminate the transaction.

MWSD is ignored when the HI32 is not in the PCI mode ( $HM \neq$ \$1).

The value of MWSD may be changed only when HACT=0.

Hardware and software resets clear MWSD.

## 6.1.2.13 Receive Buffer Lock Enable (RBLE) Bit 20

The RBLE bit is used, in the PCI mode (HM=\$1), to assure that the host-to-DSP data path contains data from only one external master at any time. This is accomplished by inhibiting the HI32 from responding to new PCI write transactions to the HTXR until the DSP56300 Core has read all the data written to the HTXR in the last access.

With RBLE set: After a non-exclusive write transaction to the HTXR, or upon HLOCK negation after completion of an exclusive write access to the HTXR; or after the completion of a read transaction initiated by the HI32:

- Forthcoming PCI write accesses to the HTXR will be disconnected (retry or disconnect-C) until the DSP56300 Core writes one to the host data transfer complete (HDTC) bit in the DPSR.
- If the host-to-DSP data path is empty (SRRQ=0 and MRRQ=0), due to DSP56300 Core reads from the DRXR, the HDTC bit will be set. The HI32 will disconnect (retry or disconnect-C) all PCI write accesses to the HTXR until the DSP56300 Core writes one to the HDTC bit to clear it.

If RBLE is cleared the HI32 will not set the HDTC bit.

If the HDTC bit is cleared the HI32 will respond to write PCI transactions according to the status of the host-to-DSP data path.

RBLE is ignored when the HI32 is not in the PCI mode (HM≠\$1).

The value of RBLE may be changed only when HACT=0 or HDTC=1.

Hardware and software resets clear RBLE.

### 6.1.2.14 Insert Address Enable (IAE) Bit 21

The IAE bit is used, in the PCI mode (HM=\$1), to insert the PCI transaction address at the head of the incoming data stream in accordance with the value of the host data transfer format (HTF) bits in the HCTR.

If IAE is set the HI32 writes the PCI transaction address to the HTXR, before the data written by the host, if the HI32 is being accessed in a write transaction.

If HTF=\$0 (32-bit mode): first, the two least significant bytes of the PCI transaction address are written to the two least significant bytes of the HTXR, then the two most significant bytes of the PCI transaction address (the address is inserted as \$00HHHH, \$00LLLL, where HHHH = HAD[31:16] and LLLL = HAD[15:0]).

If HTF $\neq$ \$0: only the two least significant bytes of the PCI transaction address are written to the two least significant bytes of the HTXR (the address is inserted as \$00LLLL, where LLLL = HAD[15:0]).

The incoming data is written to the HTXR after the address.

IAE is ignored when the HI32 is not in the PCI mode (HM $\neq$ \$1).

The value of IAE may be changed only when HACT=0 or HDTC=1.

Hardware and software resets clear IAE.

## 6.1.2.15 DPCR Reserved Control Bits 23,22,17,13,11,10,8,6,3,0

These bits are reserved for future expansion, they are read as zeros and should be written with zeros for upward compatibility.

## 6.1.3 DSP PCI Master Control Register (DPMC)

|    |      |      | 20    | -   | -   |     | -   | -        |          | -        |          |          | -        | -        | -        |          | -        | -        |          | -        |          |          | -        |
|----|------|------|-------|-----|-----|-----|-----|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|----------|
| FC | 1 FC | 0 BL | 5 BL4 | BL3 | BL2 | BL1 | BL0 | AR<br>31 | AR<br>30 | AR<br>29 | AR<br>28 | AR<br>27 | AR<br>26 | AR<br>25 | AR<br>24 | AR<br>23 | AR<br>22 | AR<br>21 | AR<br>20 | AR<br>19 | AR<br>18 | AR<br>17 | AR<br>16 |

| Bit   | Name      |                                    |  |  |  |  |  |  |  |  |  |
|-------|-----------|------------------------------------|--|--|--|--|--|--|--|--|--|
| 15-0  | AR31-AR16 | DSP PCI Transaction Address (High) |  |  |  |  |  |  |  |  |  |
| 21-16 | BL5-BL0   | PCI Data Burst Length              |  |  |  |  |  |  |  |  |  |
| 23-22 | FC1-FC0   | Data Transfer Format Control       |  |  |  |  |  |  |  |  |  |

The DPMC is a 24-bit read/write register used by the DSP56300 Core to generate the two most significant bytes of the 32-bit PCI transaction address, and to control the burst length and the data transfer format. The DPMC cannot be accessed by the host processor.

The DPMC may be written only if MARQ is set or in the Self Configuration mode. (See Section 6.1 on page 6-8).

The DPMC bits are described in the following paragraphs.

## 6.1.3.1 DSP PCI Transaction Address (AR31-AR16) Bits 15-0

The AR31-AR16 bits are the two most significant bytes of the 32-bit PCI transaction address. The two least significant bytes of the PCI transaction address are located in the DPAR register (see Section 6.1.4). When the DPAR is written by the DSP56300 Core, while in the PCI mode (HM=\$1), the PCI ownership is requested and, when granted, the HI32 will initiate a PCI transaction. The full 32-bit address (AR31-AR16 from the DPMC and AR15-AR0 from the DPAR) is driven to the HAD31-HAD0 pins during the PCI address phase.

Hardware and software resets clear AR31-AR16.

## 6.1.3.2 DSP PCI Data Burst Length (BL5-BL0) Bits 21-16

The BL5-BL0 bits control the PCI data burst length, the value of the BL5-BL0 bits being the desired number of accesses in the burst, minus one. When the DPAR is written by the DSP56300 Core, while in the PCI mode (HM=\$1), the master access counter is initialized with the value of BL5-BL0. The burst length may be programmed from 1 (BL=\$00) to 64

(BL=\$3F) accesses.

If the master access counter is enabled (MACE=1 in the DPCR) and the HI32 is the active PCI master, the value of the counter is decremented after each data cycle in which data is transferred (i.e. a data phase), until a value of \$00 is reached. When the counter value reaches \$00, the HI32 PCI master will execute one more data phase and terminate the transaction. A transaction may be terminated before the counter reaches \$00 (e.g. a target initiated transaction termination, or the bus grant was taken, or the DSP56300 Core wrote one to MTT). The value of the counter at the end of a transaction is indicated by the RDC5-RDC0 bits in the DSP PCI status register (DPSR).

Hardware and software resets clear BL5-BL0.

## 6.1.3.3 DSP Data Transfer Format Control (FC1-FC0) Bits 23 and 22

The FC1-FC0 bits define data transfer formats between the HI32 and a PCI agent when in the PCI mode (HM=\$1) and the HI32 is a bus master. The data transfer format converter (see Figure 6-1 on page 6-7) operates according to the specified FC1-FC0 (see Table 6-3).

In a PCI DSP-to-host transaction:

## If FC=\$0 (32-bit data mode):

The two least significant bytes of the first word written to the DTXM and the two least significant bytes of the second word written to the DTXM are output to the HAD31-HAD0 pins. HAD[31:0] = \$HHHHLLLL, where LLLL are the two least significant bytes of the first word written to the DTXM, and HHHH are the two least significant bytes of the second word written to the DTXM.

### If FC=\$1:

The data written to the DTXM is output to the HAD31-HAD0 pins as right aligned and zero extended in the most significant byte.

### If FC=\$2:

The data written to the DTXM is output to the HAD31-HAD0 pins as right aligned and sign extended in the most significant byte.

### If FC=\$3:

The data written to the DTXM is output to the HAD31-HAD0 pins as left aligned and zero filled in the least significant byte.

In a PCI host-to-DSP transaction:

### If FC=\$0 (32-bit data mode):

The two least significant bytes PCI data bytes from the HAD15-HAD0 pins are transferred to the two least significant bytes of the DRXR after which the two most significant bytes, from the HAD32-HAD16 pins, are transferred to the two least significant bytes of the DRXR. Thus, when the DSP56300 Core reads two words from the DRXR, the two least



 Table 6-3. HI32 (PCI Master) Data Transfer Formats

word written to the HTXR, the two least significant bytes of the second word read contain the two most significant bytes of the 32-bit word.

If FC=\$1 or \$2:

The three least significant PCI data bytes from the HAD23-HAD0 pins are transferred to the DRXR to be read by the DSP56300 Core.

If FC=\$3:

The three most significant PCI data bytes from the HAD31-HAD8 pins are transferred to the DRXR to be read by the DSP56300 Core.

To assure proper operation: FC1-FC0 may be changed only if both the host-to-DSP and the DSP-to-host master data paths are empty. In addition, switching between 32-bit data modes and non-32-bit data modes may be done only in the personal software reset state (HM=\$0 and HACT=0).

FC1-FC0 are ignored when not in the PCI mode ( $HM \neq$ \$1).

The DPMC bits are ignored when not in the PCI mode (HM $\neq$ \$1).

Hardware and software resets clear FC1-FC0.

## 6.1.4 DSP PCI Address Register (DPAR)

| 23  | 22  | 21  | 20  | 19 | 18 | 17 | 16 | 15       | 14       | 13       | 12       | 11       | 10       | 9       | 8       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
|-----|-----|-----|-----|----|----|----|----|----------|----------|----------|----------|----------|----------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|
| BE3 | BE2 | BE1 | BE0 | СЗ | C2 | C1 | C0 | AR<br>15 | AR<br>14 | AR<br>13 | AR<br>12 | AR<br>11 | AR<br>10 | AR<br>9 | AR<br>8 | AR<br>7 | AR<br>6 | AR<br>5 | AR<br>4 | AR<br>3 | AR<br>2 | AR<br>1 | AR<br>0 |

| Bit   | Name     | Function                          |
|-------|----------|-----------------------------------|
| 15-0  | AR15-AR0 | DSP PCI Transaction Address (Low) |
| 19-16 | C3-C0    | PCI Bus Command                   |
| 23-20 | BE3-BE0  | PCI Byte Enables                  |

The DPAR is a 24-bit read/write register used by the DSP56300 Core to generate the two least significant bytes of the 32-bit PCI transaction address, the PCI bus command and the PCI bus byte enables. The DPAR cannot be accessed by the host processor. The two most significant bytes of the PCI transaction address are located in the DSP PCI master control register (DPMC, see Section 6.1.3).

When the DPAR is written by the DSP56300 Core, while in the PCI mode (HM=\$1),

- MARQ is cleared,
- when the HI32 can complete the first data phase (i.e. in a write transaction, the DSP-to-host data path is not empty; in a read transaction, the host-to-DSP data path is not full) ownership of the PCI bus is requested and when granted
- the address (from the DPMC and the DPAR) is driven to the HAD31-HAD0 pins and the bus command is driven to the HC3/HBE3-HC0/HBE0 pins during the PCI address phase.

The DPAR may be written only if MARQ is set.

In memory space accesses, the AR1-AR0 bits have the following meaning:

| AR1 | AR0 | Burst Order                                                                |
|-----|-----|----------------------------------------------------------------------------|
| 0   | 0   | Linear incrementing                                                        |
| 0   | 1   | PCI Cache line toggle mode (the data must be arranged by the DSP software) |
| 1   | Х   | Reserved                                                                   |

The DPAR bits are ignored when not in the PCI mode (HM≠\$1).

Hardware and software resets clear A15-A0.

## 6.1.4.1 PCI Bus Command (C3-C0) Bits 11-8

The C3-C0 define the PCI bus command. PCI bus commands supported by the HI32 as a PCI master are listed in Table 6-4. When the DPAR is written by the DSP56300 Core, while the HI32 is in the PCI mode (HM=\$1), ownership of the PCI bus is requested and, when granted, the address is driven to the HAD31-HAD0 pins and the bus command is driven to the HC3/HBE3-HC0/HBE0 pins during the PCI address phase.

## Table 6-4. PCI Bus Commands Supported by the HI32 as PCI Master

| C3-C0 | Command Type         |
|-------|----------------------|
| 0000  | illegal              |
| 0001  | illegal              |
| 0010  | I/O read             |
| 0011  | I/O Write            |
| 0100  | illegal              |
| 0101  | illegal              |
| 0110  | Memory Read          |
| 0111  | Memory Write         |
| 1000  | illegal              |
| 1001  | illegal              |
| 1010  | Configuration Read   |
| 1011  | Configuration Write  |
| 1100  | Memory Read Multiple |
| 1101  | illegal              |
| 1110  | Memory Read Line     |
| 1111  | illegal              |

Illegal C3-C0 values are not supported by the HI32 and should not be used.

Hardware and software resets clear C3-C0.

#### 6.1.4.2 PCI Byte Enables (BE3-BE0) Bits 15-12

The BE3-BE0 determine which byte lanes carry meaningful data when in the PCI mode (HM=\$1) and the HI32 is a PCI master. BE3 applies to byte 3, and BE0 to byte 0. Byte enables are driven to HC3/HBE3-HC0/HBE0 pins during the PCI data phases.

The HI32, as master, drives all the HRXM data to the HAD31-HAD0 pins during write transactions, and writes the HAD31-HAD0 pins to the HTXR (in accordance with the FC1-FC0 bits) in read transactions, regardless of the BE3-BE0 value.

Hardware and software resets clear BE3-BE0.

## 6.1.5 DSP Status Register (DSR)

| 23   | 22 | 21  | 20   | 19     | 18   | 17            | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5   | 4   | 3   | 2        | 1        | 0   |
|------|----|-----|------|--------|------|---------------|----|----|----|----|----|----|----|---|---|---|---|-----|-----|-----|----------|----------|-----|
| НАСТ |    |     |      |        |      |               |    |    |    |    |    |    |    |   |   |   |   | HF2 | HF1 | HF0 | SRR<br>Q | STR<br>Q | HCP |
|      |    | Res | erve | d, rea | ad a | s zei         | °0 |    |    |    |    |    |    |   |   |   |   |     |     | 1   |          | 1        |     |
|      |    |     |      | Bit    |      | Name Function |    |    |    |    |    |    |    |   |   |   |   |     |     |     |          |          |     |

| Bit  | Name     | Function                    |
|------|----------|-----------------------------|
| 0    | HCP      | Host Command Pending        |
| 1    | STRQ     | Slave Transmit Data Request |
| 2    | SRRQ     | Slave Receive Data Request  |
| 5-3  | HF2-HF0  | Host Flags                  |
| 23   | HACT     | HI32 Active                 |
| 22-6 | reserved |                             |

The DSR is a 24-bit read-only status register used by the DSP56300 Core to examine the status and flags of the HI32. The DSR cannot be accessed by the host processor. The DSR bits are described in the following paragraphs.

## 6.1.5.1 Host Command Pending (HCP) Bit 0

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 HCVR. If HCP is set and HCIE is set, a host command interrupt request is generated. HC and HCP are cleared by the HI32 interrupt logic hardware when the HC interrupt request is serviced. The host cannot clear HC.

The personal software reset clears HCP.

## 6.1.5.2 Slave Transmit Data Request (STRQ) Bit 1

The STRQ bit indicates that the slave transmit data FIFO (DTXS) is not full and may be written by the DSP56300 Core. STRQ functions in accordance with the value of the slave fetch type (SFT) bit in the host control register (HCTR).

In the Fetch mode: the HI32 requests data from the DSP56300 Core (by enabling the STRQ status bit and generating Core interrupt requests or DMA requests if enabled), only after the host has begun a read transaction from the HI32.

In the Pre-Fetch mode: the HI32 requests data from the DSP56300 Core (by enabling the STRQ status bit and generating Core interrupt requests or DMA requests if enabled) whenever the DTXS is not full.

In the PCI mode (HM=\$1):

Fetch (SFT= 1): The DSP-to-host data path is a six word deep (three word deep in the

32-bit data format mode, HRF=\$0) FIFO buffer. During a read transaction from the DTXS-HRXS FIFO, STRQ reflects the status of the DTXS: STRQ is set if the DTXS is not full. STRQ is cleared when the DSP56300 Core fills the DTXS. If the host is not executing a read transaction from the HRXS, the DSP-to-host data path is forced to the reset state and STRQ is cleared.

In a Universal Bus mode (HM= \$2 or \$3):

Fetch (SFT= 1): There is no FIFO buffering of the DSP-to-host data path. At the beginning of a read data transfer from the HRXS, STRQ is set. STRQ is cleared when the DSP56300 Core writes to the DTXS. If the host is not reading from the HRXS, the DSP-to-host data path is forced to the reset and STRQ is cleared.

In both the PCI and Universal Bus modes (HM=\$1, \$2 or \$3):

Pre-fetch (SFT= 0): The DSP-to-host data path is a six word deep (three word deep in the 32-bit data format mode, HM=\$1 and HRF=\$0) FIFO buffer. STRQ reflects the status of the DTXS: STRQ is set if the DTXS is not full. STRQ is cleared when the DSP56300 Core fills the DTXS.

If STRQ is set

- if STIE is set, a slave transmit data interrupt request is generated
- if enabled by an DSP56300 Core DMA channel, a slave transmit data DMA request will be generated.

Hardware, software and personal software resets set STRQ. In the personal software reset state STRQ =0.

## 6.1.5.3 Slave Receive Data Request (SRRQ) Bit 2

The SRRQ bit indicates that the receive data FIFO (DRXR) contains data written by the host processor to the HI32 slave. When an external host writes data to the host-to-DSP FIFO (HTXR-DRXR), SRRQ is set. SRRQ is cleared if the DRXR is emptied by DSP56300 Core reads; or the data to be read from the DRXR is master data.

If SRRQ is set

- if SRIE is set, a slave receive data interrupt request is generated
- if enabled by an DSP56300 Core DMA channel, a slave receive data DMA request will be generated.

Hardware, software and personal software resets clear SRRQ.

## 6.1.5.4 Host Flags (HF2-HF0) Bits 5-3

The HF2-HF0 bits in the DSR indicate the state of host flags HF2-HF0 respectively, in the

host control register (HCTR) on the host side. HF2-HF0 can only be changed, albeit indirectly, by the host processor.

In the PCI mode (HM=\$1) the HF2-HF0 bits are updated at the end of a transaction.

NOTE: A potential problem exists when reading the status bits HF2-HF0 as an encoded triad. During personal hardware reset these bits are cleared asynchronously. For example: If HF2-HF0 change from 111 to 000, there is a small probability the DSP56300 Core could read the bits during transition and receive 001 or 110 or other combinations instead of 000. This problem can be avoided if the DSP56300 Core reads these bits twice and checks for consensus.

The personal hardware reset clears HF2-HF0.

## 6.1.5.5 HI32 Active (HACT) Bit 23

The HACT bit indicates the activity of the HI32. The HACT is cleared in response to HM=\$0 (Terminate and Reset) and set by HM = \$1, \$2, \$3, \$5.

HACT is cleared in response to Terminate and Reset (HM=\$0):

- If HM=\$0 is written (Terminate and Reset), while the HI32 is an active PCI bus master or selected target in a memory space transaction, a master initiated termination or target disconnect, respectively, is generated. When the PCI idle state is detected, the HACT status bit in the DSR is cleared.
- If HM=\$0 is written (Terminate and Reset), while the HI32 is in a Universal Bus or Self Configuration mode (HM=\$2, \$3 or \$5), the HACT status bit in the DSR is cleared immediately.

When HACT is set, the HI32 is active, and the DCTR mode and polarity bits must NOT be changed.

Hardware and software resets clear HACT.

6.1.5.6 DSR Reserved Status Bits 22-6

These bits are reserved for future expansion and read as zeros.

## 6.1.6 DSP PCI Status Register (DPSR)

| 23 | 22 | 21       | 20       | 19       | 18       | 17       | 16       | 15 | 14 | 13 | 12       | 11 | 10   | 9    | 8   | 7   | 6        | 5    | 4        | 3 | 2        | 1        | 0   |
|----|----|----------|----------|----------|----------|----------|----------|----|----|----|----------|----|------|------|-----|-----|----------|------|----------|---|----------|----------|-----|
|    |    | RDC<br>5 | RDC<br>4 | RDC<br>3 | RDC<br>2 | RDC<br>1 | RDC<br>0 |    |    |    | HDT<br>C | то | TRTY | TDIS | TAB | MAB | DPE<br>R | APER | MAR<br>Q |   | MRR<br>Q | MTR<br>Q | MWS |



Reserved, read as zero

| Bit           | Name      | Function                         |
|---------------|-----------|----------------------------------|
| 0             | MWS       | PCI Master Wait States           |
| 1             | MTRQ      | PCI Master Transmit Data Request |
| 2             | MRRQ      | PCI Master Receive Data Request  |
| 4             | MARQ      | PCI Master Address Request       |
| 5             | APER      | PCI Address Parity Error         |
| 6             | DPER      | PCI Data Parity Error            |
| 7             | MAB       | PCI Master Abort                 |
| 8             | TAB       | PCI Target Abort                 |
| 9             | TDIS      | PCI Target Disconnect            |
| 10            | TRTY      | PCI Target Retry                 |
| 11            | то        | PCI Time Out Termination         |
| 12            | HDTC      | PCI Host Data Transfer Complete  |
| 21-16         | RDC5-RDC0 | Remaining Data Count             |
| 23,22,15-13,3 | reserved  |                                  |

The DPSR is a 24-bit read-only status register used by the DSP56300 Core to examine the status and flags of the HI32, when in the PCI mode (HM=\$1). The DPSR cannot be accessed by the host processor. The DPSR bits are described in the following paragraphs.

### 6.1.6.1 PCI Master Wait State (MWS) Bit 0

The MWS bit indicates that the HI32, as master in a PCI transaction, will insert wait states (if enabled, i.e. the MWSD bit in the DPCR is cleared) to extend the current data phase (or the first data phase if the transaction has not been initiated yet) by negated HIRDY as it cannot guarantee completion of the next data phase.

MWS is set:

- In a PCI write transaction, if there is only one word in the HI32-to-host data path.
- In a PCI read transaction, if there is only one empty location in the host-to-DSP data path.

This has many applications. For example, the DSP56300 Core can set MTT, when MWS is set, to terminate a transaction after the transfer of a specific number of words. After MTT is set the HI32 will complete the data phase and terminate the transaction.

Hardware, software and personal software resets clear MWS.

## 6.1.6.2 PCI Master Transmit Data Request (MTRQ) Bit 1

The MTRQ bit indicates that the DSP master transmit data FIFO (DTXM) is not full and can be written by the DSP56300 Core. MTRQ is cleared if the DTXM is filled by DSP56300 Core writes. MTRQ is set when data is output from the DTXM-HRXM FIFO to the host bus.

If MTRQ is set

- if MTIE is set, a master transmit data interrupt request is generated
- if enabled by an DSP56300 Core DMA channel, a master transmit data DMA request will be generated.

Hardware, software and personal software resets set MTRQ. In the personal software reset state MTRQ = 0.

## 6.1.6.3 PCI Master Receive Data Request (MRRQ) Bit 2

The MRRQ bit indicates that the DSP receive data FIFO (DRXR) contains data read from the host bus by the HI32 master. When the HI32, as master, reads data from the host bus to the host-to-DSP FIFO (HTXR-DRXR), MRRQ is set. MRRQ is cleared if the DRXR is emptied by DSP56300 Core reads; or the data to be read from the DRXR is slave data.

If MRRQ is set

- if MRIE is set, a master receive data interrupt request is generated
- if enabled by an DSP56300 Core DMA channel, a master receive data DMA request will be generated.

Hardware, software and personal software resets clear MRRQ.

## 6.1.6.4 Master Address Request (MARQ) Bit 4

The MARQ bit indicates that the HI32 is currently not the initiator of a PCI transaction and the DPAR can be written with the address of the next transaction. When the HI32 with the PCI bus master enable bit (BM) set in the CCMR, is first programmed to the PCI mode (HM=\$1) or completes a PCI transaction as a master, MARQ is set and, if MAIE is set, a master address interrupt request is generated. MARQ is cleared by any of the following:

- the DSP56300 Core writes the DPAR
- the PCI bus master enable bit (BM) is cleared in the CCMR

Hardware, software, personal hardware and personal software resets clear MARQ.

## 6.1.6.5 Address Parity Error (APER) Bit 5

The APER bit indicates that an address parity error has been detected by the HI32 hardware, when in the PCI mode (HM=\$1) and the HI32 is a PCI target. At the end of a transaction, if an address parity error has been detected, APER is set and, if PEIE is set, a parity error interrupt request is generated.

If an address parity error has been detected:

- the HI32 target claims the cycles and terminates as though the address was correct.
- if the system error enable (SERE) bit in the status/command configuration register (CSTR/CCMR) is set, the HSERR pin is pulsed one PCI clock cycle, and the signalled system error (SSE) bit is set in the CSTR/CCMR.
- the detected parity error bit (DPE) in the CSTR is set.

APER is cleared when it is written one by the DSP56300 Core.

In personal software reset APER does not reflect new address parity errors.

Hardware and software resets clear APER.

6.1.6.6 Data Parity Error (DPER) Bit 6

The DPER bit indicates that a data parity error has been detected (by the HI32 hardware, or reported by the external host (HPERR asserted)), when in the PCI mode (HM=\$1) and the HI32 is a PCI master or selected target. At the end of a transaction, if a data parity error has been detected, DPER is set and, if PEIE is set, a parity error interrupt request is generated. DPER is cleared when it is written one by the DSP56300 Core.

In personal software reset DPER does not reflect new data parity errors.

Hardware and software resets clear DPER.

6.1.6.7 Master Abort (MAB) Bit 7

The MAB bit indicates that a PCI transaction, initiated by the HI32, was terminated with master abort. When a PCI transaction initiated by the HI32 is terminated with master abort, MAB is set and, if TAIE is set, a transaction abort interrupt request is generated. MAB is cleared when written one by the DSP56300 Core.

If a PCI transaction, initiated by the HI32, was terminated with master abort, the received master abort bit (RMA) in the CSTR is also set.

Hardware and software resets clear MAB.

#### 6.1.6.8 Target Abort (TAB) Bit 8

The TAB bit indicates that a PCI transaction, initiated by the HI32, was terminated with target abort. When a PCI transaction initiated by the HI32 is terminated with target abort,

TAB is set and, if TAIE is set, a transaction abort interrupt request is generated. TAB is cleared when written one by the DSP56300 Core.

If a PCI transaction, initiated by the HI32, was terminated with target abort, the received target abort bit (RTA) in the CSTR is also set.

Hardware and software resets clear TAB.

## 6.1.6.9 Target Disconnect (TDIS) Bit 9

The TDIS bit indicates that a PCI transaction, initiated by the HI32, was terminated with a target initiated disconnect. When a PCI transaction initiated by the HI32 is terminated with disconnect, TDIS is set and, if TTIE is set, a transaction termination interrupt request is generated. TDIS is cleared when written one by the DSP56300 Core.

Hardware and software resets clear TDIS.

### 6.1.6.10 Target Retry (TRTY) Bit 10

The TRTY bit indicates that a PCI transaction, initiated by the HI32, was terminated with a target initiated retry. When a PCI transaction initiated by the HI32 is terminated with retry, TRTY is set and, if TTIE is set, a transaction termination interrupt request is generated. TRTY is cleared when written one by the DSP56300 Core.

Hardware and software resets clear TRTY.

6.1.6.11 PCI Time Out (TO) Bit 11

The TO bit indicates that a PCI transaction, initiated by the HI32, was terminated due to the negation of the bus grant after the latency timer had expired. When a PCI transaction initiated by the HI32 is terminated due to time-out, TO is set and, if TTIE is set, a transaction termination interrupt request is generated. TO is cleared when written one by the DSP56300 Core.

Hardware and software resets clear TO.

## 6.1.6.12 Host Data Transfer Complete (HDTC) Bit 12

With the receive buffer lock enable (RBLE) bit in the DSP PCI control register (DPCR) set: the HDTC bit indicates that the host-to-DSP data path is empty.

HDTC is set if SRRQ and MRRQ are cleared (i.e. the host-to-DSP data path is emptied by DSP56300 Core reads) after the termination or completion a non-exclusive PCI write transaction to the HTXR, or the negation of HLOCK after the completion of an exclusive write access to the HTXR, or after a read transaction initiated by the HI32. The HI32 will disconnect (retry or disconnect-C) forthcoming write accesses to the HTXR as long as HDTC is set.

HDTC is cleared when written one by the DSP56300 Core. HDTC may be written one by the DSP56300 Core only if it is set.

If the HDTC bit is cleared the HI32 will respond to write PCI transactions according to the

status of the host-to-DSP data path.

Hardware, software and personal software resets clear HDTC.

NOTE: Each of the bits APER, DPER, MAB, TAB, TDIS, TRTY, TO and HDTC are cleared by writing one to the specific bit. In order to assure that only the desired bit is cleared, the programmer should not use the BSET command. The proper way to clear these bits is to write (MOVE(P) instruction) ones to the bits to be cleared and zeros to all the others.

## 6.1.6.13 Remaining Data Count (RDC5-RDC0) Bits 21-16

The read-only bits, RDC5-RDC0, indicate the PCI data phases remaining to complete a PCI burst after the HI32 has completed a transaction as a PCI master. The RDC5-RDC0 bits are updated each time a transaction is terminated with the HI32 as a PCI master (MARQ=1).

If the transaction terminated normally, the value of RDC5-RDC0 will be \$00 and TO=0, TRTY=0, TDIS=0, TAB=0, MAB=0.

If the master access counter was enabled and the burst was not completed for any reason (typical examples being: the target initiated transaction termination or the HI32 was required to generate a master initiated time-out transaction termination), the value of RDC5-RDC0 will be the remaining number of data phases remaining to complete the burst minus one (i.e. RDC=\$2 signifies that there remain three more words to be transferred to complete the burst). The length of the burst is limited by BL5-BL0 in the DPMC.

### 6.1.6.14 DPSR Reserved Bits 23-22, 15-12 and 3

These bits are reserved for future expansion and are read as zeros.

## 6.1.7 Host To DSP Data Path

In PCI master data transfers (HM=\$1) with FC $\neq$ \$0, the host-to-DSP data path is a six word deep, 24-bit wide FIFO. The host data is read into the host side of the FIFO (HTXR) as 24-bit words, and the DSP56300 Core reads 24-bit words from the DSP side (DRXR).

In PCI master data transfers (HM=\$1) with FC=\$0, and PCI target data transfers (HM=\$1) with HTF=\$0, the host-to-DSP data path operates as a three word deep, 32-bit wide FIFO. The host data is read into the HTXR as 32-bit words, and the DSP56300 Core reads from the DRXR 24-bit words. Each word read by the DSP56300 Core contains 16-bits of data, right aligned and zero extended. The first word read by the DSP56300 Core contains the two least significant bytes of the 32-bit word read into the HTXR. The second word read by the DSP56300 Core contains the two most significant bytes of the 32-bit word read into the HTXR.

In PCI target data transfers (HM=\$1) with HTF≠\$0 the host-to-DSP data path is a six word deep, 24-bit wide FIFO. The host writes 24-bit words to the HTXR, and the DSP56300 Core reads 24-bit words from the DRXR.

In Universal Bus mode data transfers, the host-to-DSP data path is a five word deep, 24-bit wide FIFO. The host writes 24-bit words to the HTXR, and the DSP56300 Core reads 24-bit words from the DRXR.

The DSP side of the host-to-DSP data FIFO is described below. For a detailed description of the host side see Section 6.2.6 on page 6-62.

# 6.1.8 DSP Receive Data FIFO (DRXR)

The 24-bit wide DSP receive data register (DRXR) is the output stage of the host-to-DSP data path FIFO used for host-to-DSP data transfers.

The DRXR contains master data (i.e. data read by the HI32 as PCI master from an external target) to be read if MRRQ is set in the DPSR. MRRQ is cleared if the data in the DRXR is slave data or when the host-to-DSP data path FIFO is emptied by DSP56300 Core reads. The DSP56300 Core may set the MRIE bit to cause a host receive data interrupt when MRRQ is set.

The DRXR contains slave data (i.e. data written to the HI32 from the host bus) to be read if SRRQ is set in the DSR. SRRQ is cleared if the data in the DRXR is master data or when the host-to-DSP data path FIFO is emptied by DSP56300 Core reads. The DSP56300 Core may set the SRIE bit to cause a host receive data interrupt when SRRQ is set.

In the 32-bit mode (HM=\$1 with FC=\$0 or HTF=\$0), only the two least significant bytes contain data, the most significant byte is read as zeroes. (See Table 6-3, on page 6-24 and Table 6-8, on page -51).

Hardware, software and personal software resets empty the host-to-DSP data path FIFO (SRRQ and MRRQ are cleared).

# 6.1.9 DSP To Host Data Path

In PCI master data transfers (HM=\$1) with FC≠\$0, the master DSP-to-host data path (DTXM-HRXM) is an eight word deep FIFO. The DSP56300 Core writes to the DSP side of the FIFO (DTXM). The data is output to the bus from the host side (HRXM).

In PCI master data transfers (HM=\$1) with FC=\$0, the master DSP-to-host data path is a four word deep, 32-bit wide FIFO. The DSP56300 Core writes 24-bit words to the DTXM. Each word written by the DSP56300 Core contains 16-bits of significant data, right aligned, the most significant byte is not transmitted. The first word written by the DSP56300 Core contains the two least significant bytes of the 32-bit word to be output from the HRXM. The second word written by the DSP56300 Core contains the two most significant bytes of the 32-bit word be output from the HRXM. Each time a 32-bit word is output from the HRXM, the 32-bits of significant data located in two words written to the DTXM are output.

In PCI target data transfers (HM=\$1) with HRF≠\$0 and in Universal Bus mode data transfers, the slave DSP-to-host data path (DTXS-HRXS) is a six word deep FIFO. The

DSP56300 Core writes 24-bit words to the DTXS. The data is output, a word at a time, to the bus from the HRXS.

In PCI target data transfers (HM=\$1) with HRF=\$0, the slave DSP-to-host data path is a three word deep, 32-bit wide FIFO. The DSP56300 Core writes 24-bit words to the DTXS. Each word written by the DSP56300 Core contains 16-bits of significant data, right aligned, the most significant byte is not transmitted. The first word written by the DSP56300 Core contains the two least significant bytes of the 32-bit word to be output from the HRXS. The second word written by the DSP56300 Core contains the two most significant bytes of the 32-bit word be output from the HRXS. Each time the host reads a 32-bit word from the HRXS, the 32-bits of significant data located in two locations of the slave DSP-to-host data path (DTXS and HRXS) are output.

The DSP side of the DSP-to-host data FIFOs are described in the following pages. For a detailed description of the host side see Section 6.2.4 on page 6-61 and Section 6.2.5 on page 6-62.

## 6.1.10 DSP Master Transmit Data Register (DTXM)

The 24-bit wide DSP master transmit data register (DTXM) is the input stage of the master DSP-to-host data path FIFO used for DSP-to-host master data transfers in the PCI mode (HM=\$1).

The DTXM may be written if the MTRQ bit is set in the DPSR. Data should not be written to the DTXM until MTRQ is set to prevent previous data from being overwritten. Filling the DTXM by DSP56300 Core writes (MOVE(P) instructions or DMA transfers) clears MTRQ. The DSP56300 Core may set the MTIE bit to cause a host receive data interrupt when MTRQ is set.

In the PCI mode (HM=\$1) the DSP56300 Core can clear the HI32 master-to-host bus data path and empty DTXM by setting the CLRT bit in the DPCR.

In the 32-bit mode (HM=\$1 with FC=\$0), only the two least significant bytes of the DTXM are transferred. (See Section 6.1.9, above, and Table 6-3, on page 6-24).

Hardware, software and personal software resets empty the DTXM.

## 6.1.11 DSP Slave Transmit Data Register (DTXS)

The 24-bit wide DSP slave transmit data register (DTXS) is the input stage of the slave DSP-to-host data path FIFO used for DSP-to-host slave data transfers in the PCI mode (HM=\$1).

The DTXS may be written if the STRQ bit is set in the DSR. Data should not be written to the DTXS until STRQ is set to prevent previous data from being overwritten. Filling the DTXS by DSP56300 Core writes (MOVE(P) instructions or DMA transfers) clears STRQ. The DSP56300 Core may set the STIE bit to cause a host receive data interrupt when STRQ is set.

In the 32-bit mode (HM=\$1 with HRF=\$0), only the two least significant bytes of the DTXS are transferred. (See Section 6.1.9, above, Section 6-3 on page 6-24, and Section 6-9 on page 6-54)

Hardware, software and personal software resets empty the DTXS.

## 6.1.12 DSP Host Port GPIO Data Register (DATH)

| 23        | 22        | 21        | 20        | 19        | 18        | 17 | 16        | 15        | 14 | 13 | 12 | 11        | 10  | 9 | 8 | 7 | 6        | 5        | 4        | 3        | 2        | 1        | 0        |
|-----------|-----------|-----------|-----------|-----------|-----------|----|-----------|-----------|----|----|----|-----------|-----|---|---|---|----------|----------|----------|----------|----------|----------|----------|
| DAT<br>23 | DAT<br>22 | DAT<br>21 | DAT<br>20 | DAT<br>19 | DAT<br>18 |    | DAT<br>16 | DAT<br>15 |    |    |    | DAT<br>11 |     |   |   |   | DAT<br>6 | DAT<br>5 | DAT<br>4 | DAT<br>3 | DAT<br>2 | DAT<br>1 | DAT<br>0 |
|           |           |           |           | L         | D         |    | Na        |           |    |    |    |           | Eur |   | n |   |          |          | <br>]    |          |          |          |          |

| Bit  | Name       | Function      |
|------|------------|---------------|
| 23-0 | DAT23-DAT0 | GPIO Pin Data |

The DATH is a 24-bit read/write data register used by the DSP56300 Core to read or write data to/from host port pins configured as GPIO. The DATH cannot be accessed by the host processor.

DAT23-DAT0 are used to read or write data from/to the corresponding GPIO pin. The functionality of the DAT23-DAT0 bits is defined in Table 6-5, on page 6-39.

Hardware and software resets clear all DATH bits.

## 6.1.13 DSP Host Port GPIO Direction Register (DIRH)

| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2 | 1   | 0   |
|----|----|----|----|----|----|----|----|----|----|----|----|----|----|---|---|---|---|---|-----|-----|---|-----|-----|
|    |    |    |    |    |    |    |    |    |    |    |    |    |    |   |   |   |   |   | DIR | DIR |   | DIR | DIR |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4   | 3   | 2 | 1   | 0   |

| Bit  | Name       | Function           |
|------|------------|--------------------|
| 23-0 | DIR23-DIR0 | GPIO Pin Direction |

The DIRH is a 24-bit read/write register used by the DSP56300 Core to control the direction of the host port pins in GPIO mode. The DIRH cannot be accessed by the host processor.

DIR23-DIR0 are used to define the corresponding GPIO pins as input or output. The functionality of the DIR23-DIR0 bits is defined in Table 6-5, on page 6-39.

Hardware and software resets clear all DIRH bits.

### Table 6-5. DATH and DIRH Functionality

| DIRx | x DATx                                                                                                                                                       |                                                      |  |  |  |  |  |  |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------|--|--|--|--|--|--|
|      | GPIO pin <sup>(a)</sup>                                                                                                                                      | non-GPIO pin <sup>(a)</sup>                          |  |  |  |  |  |  |
| 0    | Read only bit. The value read is the<br>binary value of the pin.<br>The corresponding pin is configured as<br>an input.                                      | Read only bit. Does not contain significant data.    |  |  |  |  |  |  |
| 1    | Read/write bit. The value written is the<br>value read. The corresponding pin is<br>configured as an output, and is driven<br>with the data written to DATx. | Read/write bit. The value written is the value read. |  |  |  |  |  |  |

a. defined by the selected mode

# 6.2 HI32 - HOST SIDE

The HI32 appears to the host processor as a bank of registers.

In the Universal Bus modes:

- The HI32 occupies eight words in the host processor address space (see Figure 6-5). The PCI configuration registers (CDID/CVID, CSTR/CCMR, CCCR/CRID, CHTY/CLAT, CBMA and CILP) cannot be accessed by the host processor in the Universal Bus modes.
- Due to the fast DSP56300 Core interrupt response, most host microprocessors can read or write data at their maximum programmed non-DMA instruction rate without testing the handshake flags for each transfer. If the full interrupt driven handshake is not needed, the high speed data transfer between the host and the HI32 may be supported with only host data strobe/acknowledge handshake mechanism. DMA hardware may be used with the handshake flags to transfer data without host processor intervention.
- When operating with a host bus less than 24 bits wide, the data pins that are not used for transferring data must be forced or pulled up or down to Vcc or to GND respectively. For example: when operating with a 16-bit bus (e.g. ISA bus), HP48-HP41 must be forced or pulled up to Vcc or pulled down to GND.

In the PCI mode:

- In memory space read/write transactions, the HI32 occupies 16384 Dwords (see Figure 6-3). The HTXR FIFO and HRXS FIFO can be accessed by the host at 16377 Dword locations. These FIFOs appear to the external host as 16377 Dwords of read/write memory. Registers are accessed as 32-bit Dwords.
- HAD1 and HAD0 should be zero during the address phase of a transaction. The HI32 will respond with a target-disconnect transaction termination with the first data phase if HAD1-HAD0≠\$0 during the address phase.
- In configuration space read/write transactions, the HI32 occupies 64 Dwords (see Figure 6-4). The configuration registers are accessed as 32-bit Dwords, thus HAD1 ad HAD0 must be zero during the address phase. The HI32 will ignore the transaction if HAD1-HAD0≠\$0 during the address phase of a configuration transaction.
- In PCI host-to-DSP data transfers to the HI32 registers (HCTR, HSTR,

HCVR and all configuration space registers): disabled byte lanes (i.e. the corresponding byte enable line is negated) are not written and the corresponding bytes do not contain significant data.

- In HI32 to PCI agent data transfers, all four byte lanes are driven with data, regardless of the value of the byte enables.
- In HCTR, HSTR, HCVR and configuration space register accesses: if all four byte lanes are disabled the HI32 completes the data phase without affecting any flags or data.
- In PCI DSP-to-host data transfers via the HRXS or HRXM, all four byte lanes are driven with data, in accordance with FC1-FC0 or HRF1-HRF0 bits, regardless of the value of the byte enable pins (HC3/HBE3-HC0/HBE0).
- In PCI host-to-DSP data transfers, data is written to the HTXR FIFO, in accordance with FC1-FC0 or HTF1-HTF0 bits, regardless of the value of the byte enable pins (HC3/HBE3-HC0/HBE0).

| HC3/HBE3-HC0/HBE0 | Executed as Command Type |
|-------------------|--------------------------|
| 0000              | ignored <sup>(a)</sup>   |
| 0001              | ignored <sup>(a)</sup>   |
| 0010              | ignored <sup>(a)</sup>   |
| 0011              | ignored <sup>(a)</sup>   |
| 0100              | ignored <sup>(a)</sup>   |
| 0101              | ignored <sup>(a)</sup>   |
| 0110              | Memory Read              |
| 0111              | Memory Write             |
| 1000              | ignored <sup>(a)</sup>   |
| 1001              | ignored <sup>(a)</sup>   |
| 1010              | Configuration Read       |
| 1011              | Configuration Write      |
| 1100              | Memory Read              |
| 1101              | ignored <sup>(a)</sup>   |
| 1110              | Memory Read              |
| 1111              | Memory Write             |

• As a PCI target the HI32 executes the PCI bus command as follows:

- a. All internal address decoding is ignored and DEVSEL is not asserted.
- The HI32 will not reach dead-lock due to illegal PCI events. Illegal PCI

### events bring the HI32 Master and Target state machines to the IDLE state.

The master data transfer format control bits (FC1-FC0 in the DPMC) affect the HTXR-DRXR and DTXM-HRXM data paths only. The target data transfer format control bits (HTF1-HTF0 and HRF1-HRF0 in the HCTR) affect the HTXR-DRXR and DTXS-HRXS data paths only. The data paths to the other host registers (HCTR, HSTR, HCVR, CDID/CVID, CSTR/CCMR, CCCR/CRID, CHTY/CLAT, CBMA and CILP) are not affected by the data transfer format control bits.

The host side registers can be accessed by the host processor. The CCMR, CLAT and CBMA HI32 configuration registers can also be accessed, indirectly, by the DSP56300 Core in the Self Configuration mode (HM=\$5 - see Section 6.1.1.13 on page 6-13).

Reserved addresses are read as zeros, and should be written with zeroes for future compatibility.

Host processors may use standard host processor instructions and addressing modes to communicate with the HI32 registers. The host processor may be any of a number of industry standard microcomputers or microprocessors, DMA controllers or standard peripheral bus (e.g. ISA/EISA), because this interface appears to the host like static RAM.

With the host command feature, the host processor can issue vectored interrupt requests to the DSP56300 Core. The host may select any one of 128 DSP56300 Core interrupt routines to be executed by writing a vector address register in the HI32. This flexibility allows the host programmer to execute up to 128 pre-programmed functions inside the DSP. For example, host exceptions can allow the host processor to read or write DSP registers, X-, Y-, or program memory locations, force exception handlers (e.g., SSI, Timer, IRQA, IRQB exception routines), and perform control and debugging operations if exception routines are implemented in the DSP to perform these tasks. The host processor can also generate non-maskable interrupt requests to the DSP56300 Core using the host commands.

# Figure 6-3. Host Side Registers (PCI Memory Address Space<sup>1</sup>)

| Base Address: \$0000 | Reserved                                              | (4 Dwords)     |
|----------------------|-------------------------------------------------------|----------------|
| Base Address: \$000C | Reserved                                              | (4 Dwords)     |
| Base Address: \$0010 | HI32 Control Register (HCTR)                          |                |
| Base Address: \$0014 | HI32 Status Register (HSTR)                           |                |
| Base Address: \$0018 | Host Command Vector Register (HCVR)                   |                |
| Base Address: \$001C |                                                       |                |
|                      | Host Transmit/Slave Receive Data Register (HTXR/HRXS) | (16377 Dwords) |
| Base Address: \$FFFC |                                                       |                |

## Figure 6-4. Host Side Registers (PCI Configuration Address Space<sup>2</sup>)

| \$00         | (CDID/CVID) | Device ID (CDID) |                    | Vendor ID (CVID)     |                    |
|--------------|-------------|------------------|--------------------|----------------------|--------------------|
| \$04         | (CSTR/CCMR) | Status (CSTR)    |                    | Command (CCMR)       |                    |
| \$08         | (CCCR/CRID) | Class Code (CCCR | )                  |                      | Revision ID (CRID) |
| \$0C         | (CLAT)      |                  | Header Type (CHTY) | Latency Timer (CLAT) |                    |
| \$10         | (CBMA)      | Memory Space Bas | e Address (CBMA)   | ·                    |                    |
| \$14<br>\$F8 |             | Reserved         |                    |                      | (58 Dwords)        |
| \$FC         | (CILP)      | MAX_LAT          | MIN_GNT            | Interrupt Line       | Interrupt Pin      |

# Figure 6-5. Host Side Registers (Universal Bus Mode Address Space<sup>3</sup>)

| Base Address: \$0 | Reserved                                          | (4 Locations) |  |  |  |
|-------------------|---------------------------------------------------|---------------|--|--|--|
| Base Address: \$3 |                                                   | (4 Locations) |  |  |  |
| Base Address: \$4 | HI32 Control Register (HCTR)                      |               |  |  |  |
| Base Address: \$5 | HI32 Status Register (HSTR)                       |               |  |  |  |
| Base Address: \$6 | Host Command Vector Register (HCVR)               |               |  |  |  |
| Base Address: \$7 | Host Transmit/Slave Receive Data FIFO (HTXR/HRXS) |               |  |  |  |

<sup>1.</sup> Addresses shown are in bytes. The base address is defined by the CBMA register

<sup>2.</sup> Addresses shown are in bytes.

<sup>3.</sup> Addresses shown are in words (locations). The base address is defined by eight bits of the CBMA register.

| 6.2.1 | H   | <del>1</del> 132 ( | Contro | ol Reg | gister | · (HC) | ΓR)  |     |      |     |     |      |      |      |     |
|-------|-----|--------------------|--------|--------|--------|--------|------|-----|------|-----|-----|------|------|------|-----|
| 31    | 30  | 29                 | 28     | 27     | 26     | 25     | 24   | 23  | 22   | 21  | 20  | 19   | 18   | 17   | 16  |
|       |     |                    |        |        |        |        |      |     |      |     |     | TWSD |      |      | HS2 |
| 15    | 14  | 13                 | 12     | 11     | 10     | 9      | 8    | 7   | 6    | 5   | 4   | 3    | 2    | 1    | 0   |
| HS1   | HS0 |                    | HRF1   | HRF0   |        | HTF1   | HTF0 | SFT | DMAE | HF2 | HF1 | HF0  | RREQ | TREQ |     |

Reserved, read as zero and should be written zero

| Bit                 | Name      | Function                           |
|---------------------|-----------|------------------------------------|
| 1                   | TREQ      | Transmit Request Enable            |
| 2                   | RREQ      | Receive Request Enable             |
| 5-3                 | HF2-HF0   | Host Flags                         |
| 6                   | DMAE      | DMA Enable (ISA/EISA)              |
| 7                   | SFT       | Slave Fetch Type                   |
| 9-8                 | HTF1-HTF0 | Host Transmit Data Transfer Format |
| 12-11               | HRF1-HRF0 | Host Receive Data Transfer Format  |
| 16-14               | HS2-HS0   | Host Semaphores                    |
| 19                  | TWSD      | Target Wait State Disable          |
| 31-20,18-17,13,10,0 | reserved  |                                    |

The HCTR is a 32-bit read/write control register used by the host processor to control the HI32 interrupts, flags, semaphores, data transfer formats and operation modes.

In the PCI mode (HM=\$1), the HAD31-HAD0 pins are driven with HCTR data during a read access; and the pins are written to the HCTR in a write access.

In a 24-bit data Universal Bus mode (HM=\$2 or \$3 and HTF=\$0 or HRF=\$0), the HD23-HD0 pins are driven with the three least significant HCTR bytes during a read access; HD23-HD0 are written to the three least significant HCTR bytes in a write access.

In a 16-bit data Universal Bus mode (HM=2 or 3 and HTF $\neq$ 0 or HRF $\neq$ 0), the HD15-HD0 pins are driven with the two least significant bytes of the HCTR in a read access; HD15-HD0 are written to the two least significant bytes of the HCTR, the most significant portion is zero filled during the HCTR write.

In PCI mode (HM=\$1) memory space transactions, the HCTR is accessed if the PCI address is HI32\_base\_address: \$010.

The HCTR is written in accordance with the byte enables (HC3/HBE3-HC0/HBE0 pins). Byte lanes that are not enabled are not written and the corresponding bits remain unchanged.

The HCTR bits affect the HI32 logic upon the completion of the transaction in they were written.

When in a Universal Bus mode (HM=\$2 or \$3), the HCTR is accessed if the HA10-HA3 value matches the HI32 base address (CBMA, see Section 6.2.11 on page 6-70) and the HA2-HA0 value is \$4.

The control bits are described in the following paragraphs.

6.2.1.1 Transmit Request Enable (TREQ) Bit 1

The TREQ bit is used to control the HIRQ and HDRQ pins for host transmit data transfers (see Table 6-6), when in a Universal Bus mode (HM=\$2 or \$3).

If DMA enable bit (DMAE) is cleared, TREQ enables the host interrupt request  $\overline{\text{HIRQ}}$  pin when the host transmit data request (HTRQ) status bit in the HI32 status register (HSTR) is set. If TREQ is cleared, HTRQ host interrupt requests are disabled. If TREQ is set, the host interrupt request  $\overline{\text{HIRQ}}$  pin will be asserted if HTRQ is set. HDRQ is negated.

If DMAE is set, TREQ enables the host DMA request (HDRQ) pin when the host transmit data request (HTRQ) status bit in the HSTR is set. If TREQ is cleared, HTRQ external DMA requests are disabled. If TREQ is set, the host DMA request HDRQ pin will be asserted if HTRQ is set. HIRQ is negated (high impedance if HIRD=0 in the DCTR).

The personal hardware reset clears TREQ.

6.2.1.2 Receive Request Enable (RREQ) Bit 2

The RREQ bit is used to control the HIRQ and HDRQ pins for DSP-to-host data transfers (see Table 6-6), when in a Universal Bus mode (HM=\$2 or \$3).

If DMAE is cleared, RREQ enables the host interrupt request (HIRQ) pin when the host receive data request (HRRQ) status bit in the HSTR is set. If RREQ is cleared, HRRQ host interrupt requests are disabled. If RREQ is set, the host interrupt request HIRQ pin will be asserted if HRRQ is set. HDRQ is negated.

If DMAE is set, RREQ enables the host DMA request (HDRQ) pin when the host receive data request (HRRQ) status bit in the HSTR is set. If RREQ is cleared, HRRQ host DMA requests are disabled. If RREQ is set, the host DMA request HDRQ pin will be asserted if HRRQ is set. HIRQ is negated (high impedance if HIRD=0 in the DCTR).

The personal hardware reset clears RREQ.

NOTE: In a Universal Bus mode (HM =\$2 or \$3), when both the TREQ and RREQ control bits (in the HCTR) are cleared, host interrupt request/strobe / acknowledge hardware handshake (using the HIRQ / Data Strobe / HTA pins) is disabled. The host may poll the HTRQ, HRRQ status bits or use the host data strobe/acknowledge hardware handshake (using the Data Strobe / HTA pins) (see Table 6-10, on page 6-75).

| DMAE | TREQ | RREQ | HIRQ Pin                                    | HDRQ pin                                |
|------|------|------|---------------------------------------------|-----------------------------------------|
| 0    | 0    | 0    | negated <sup>(a)</sup> (HRRQ, HTRQ polling) | high impedance                          |
| 0    | 0    | 1    | HRRQ Host Interrupt Requests Enabled        | high impedance                          |
| 0    | 1    | 0    | HTRQ Host Interrupt Request Enabled         | high impedance                          |
| 0    | 1    | 1    | HRRQ, HTRQ Interrupt Requests Enabled       | high impedance                          |
| 1    | 0    | 0    | negated <sup>(a)</sup>                      | high impedance                          |
| 1    | 0    | 1    | negated <sup>(a)</sup>                      | HRRQ DMA Request Enabled                |
| 1    | 1    | 0    | negated <sup>(a)</sup>                      | HTRQ DMA Request Enabled                |
| 1    | 1    | 1    | negated <sup>(a)</sup>                      | HRRQ, HTRQ Host DMA Requests<br>Enabled |

## Table 6-6. HIRQ and HDRQ Pin Definition

a. high impedance if HIRD=0 in the DCTR

## 6.2.1.3 Host Flags (HF2-HF0) Bits 5 and 3

The HF2-HF0 bits are used as general purpose flags for host-to-DSP communication. HF2-HF0 may be set or cleared by the host processor.

The personal hardware reset clears HF2-HF0.

## 6.2.1.4 DMA Enable (DMAE) Bit 6

The DMAE is used by the host processor to enable the HI32 ISA/EISA DMA-type accesses, when in a Universal Bus mode (HM=\$2 or \$3) (see Table 6-7)

### Table 6-7. DMAE Definition

| DMAE<br>bit | HAEN<br>pin | ISA/EISA Access Type                                                             | HIRQ and HDRQ<br>functionality                    |
|-------------|-------------|----------------------------------------------------------------------------------|---------------------------------------------------|
| 0           | 0           | The HI32 responds when it identifies its address (i.e. ISA/EISA I/O-type access) | HIRQ is active,<br>HDRQ is negated                |
| 0           | 1           | The HI32 will not respond to any access                                          | HIRQ is active,<br>HDRQ is negated                |
| 1           | 0           | The HI32 responds when it identifies its address (i.e. ISA/EISA I/O-type access) | HDRQ is active,<br>HIRQ is negated <sup>(a)</sup> |
| 1           | 1           | The HI32 responds when HDAK is asserted (i.e. ISA/EISA DMA-type access)          | HDRQ is active,<br>HIRQ is negated <sup>(a)</sup> |

a. high impedance if HIRD=0 in the DCTR

If the HAEN pin is driven low by the host, the HI32 responds when it identifies its address (i.e. ISA/EISA I/O-type accesses). The HI32 will not respond to ISA/EISA DMA-type accesses.

*If the HAEN pin is high:* 

- If DMAE is cleared the HI32 cannot be accessed.
- If DMAE is set, the HI32 responds to ISA/EISA DMA-type accesses.

If DMAE is cleared, the HDRQ pin is negated, HIRQ is active.

If DMAE is set, the HIRQ pin is negated, HDRQ is active. This allows the HI32 to generate host DMA requests during ISA/EISA I/O-type accesses. A typical application would be that the external host writes to the HI32 using a polling procedure, and the external DMA reads from the HI32. An external bus controller arbitrates between the two and sets or clears HAEN accordingly.

If both DMAE and HAEN are set, HTA is released (high impedance), as DMA devices cannot extend DMA cycles (ISA/EISA).

The personal hardware reset clears DMAE.

## 6.2.1.5 Slave Fetch Type (SFT) Bit 7

The SFT bit defines the fetch mode (data fetch or pre-fetch) as described below.

| SFT | Slave Fetch Type |
|-----|------------------|
| 1   | Fetch            |
| 0   | Pre-fetch        |

In the Fetch mode: the HI32 requests data from the DSP56300 Core (by enabling the STRQ status bit and generating Core interrupt requests or DMA requests if enabled), only after the host has begun a read transaction from the HI32.

In the Pre-Fetch mode: the HI32 requests data from the DSP56300 Core (by enabling the STRQ status bit and generating Core interrupt requests or DMA requests if enabled) whenever the DTXS is not full.

In the PCI mode (HM=\$1):

### Fetch (SFT=1):

The DSP-to-host data path (DTXS-HRXS) is a six word deep (three word deep if HRF=\$0) FIFO buffer. Writing SFT=1 resets the DSP-to-host data path and clears STRQ and HRRQ. During a read transaction from the HRXS, STRQ is set if the DTXS-HRXS FIFO is not full, and cleared when the DSP56300 Core fills the DTXS; HRRQ is cleared if the HRXS is empty, and set if it contains data to be read by an external host. If the host is not executing a read transaction from the HRXS, the DSP-to-host data path is forced to the reset state and STRQ and HRRQ are cleared.

In a Universal Bus mode (HM= \$2 or \$3):

### Fetch (SFT=1):

There is no FIFO buffering of the DSP-to-host data path. Writing SFT=1 resets the DSP-to-host data path and clears the STRQ and the HRRQ. At the beginning of a read data transfer from the HRXS, STRQ is set. STRQ is cleared when the DSP56300 Core writes to the DTXS; HRRQ is cleared if the HRXS is empty, and set if it contains data to be read by an external host. If the host is not reading from the HRXS, the DSP-to-host data path is forced to the reset and STRQ and HRRQ are cleared.

NOTE: Any data remaining in the DSP-to-host data path when entering the reset state, is lost.

In both the PCI and Universal Bus modes (HM=\$1, \$2 or \$3):

Pre-fetch (SFT=0):

The DSP-to-host data path is a six word deep (three word deep in the 32-bit data format mode, HM=\$1 and HRF=\$0) FIFO buffer. STRQ reflects the status of the

DTXS and HRRQ reflects the status of the HRXS. STRQ is set if the DTXS is not full, and cleared when the DSP56300 Core fills the DTXS. HRRQ is cleared if the HRXS is empty, and set when it contains data to be read by an external host.

The value of SFT may be changed only if the DTXS-HRXS data path is empty.

The personal hardware reset clears SFT.

6.2.1.6 Host Transmit Data Transfer Format (HTF1-HTF0) Bits 9 and 8

The HTF1-HTF0 bits define data transfer formats for host-to-DSP communication. The data transfer format converter (HDTFC) operates according to the specified HTF1-HTF0 (see Table Transmit Data Transfer Format on page 51).

PCI host to DSP data transfer formats (HM=\$1):

• If HTF=\$0 (32-bit data mode):

All four PCI data bytes from HAD31-HAD0 pins are written to the 32-bit HTXR. The two least significant bytes are transferred to the two least significant bytes of the DRXR FIFO after which the two most significant bytes are transferred to the two least significant bytes of the DRXR FIFO. Thus, when the DSP56300 Core reads two words from the DRXR, the two least significant bytes of the first word read contain the two least significant bytes of the 32-bit word written to the HTXR, the two least significant bytes of the second word read contain the two most significant bytes of the 32-bit word.

• If HTF=\$1 or \$2:

The three least significant PCI data bytes from the HAD23-HAD0 pins are transferred to the three least significant HTXR bytes and transferred to the DRXR to be read by the DSP56300 Core.

• If HTF=\$3:

The three most significant PCI data bytes from the HAD31-HAD8 pins are transferred to the three least significant HTXR bytes and transferred to the DRXR to be read by the DSP56300 Core.

Universal Bus mode host to DSP data transfer formats (HM=\$2 or \$3):

• If HTF=\$0:

The 24-bit data from HD23-HD0 data pins is transferred to the three least significant HTXR bytes and transferred to the DRXR to be read by the DSP56300 Core.

• If HTF=\$1:

The 16-bit data from HD15-HD0 data pins is transferred to the three least significant HTXR bytes as right aligned and zero extended and transferred to the DRXR to be read by the DSP56300 Core.

• If HTF=\$2:

The 16-bit data from HD15-HD0 data pins is transferred to the three least significant HTXR bytes as right aligned and sign extended and transferred to the DRXR to be read by the DSP56300 Core.

• If HTF=\$3:

The 16-bit data from HD15-HD0 data pins is transferred to the three least significant bytes of the HTXR, as left aligned, the least significant byte is zero filled and transferred to the DRXR to be read by the DSP56300 Core.

To assure proper operation,:

- HTF1-HTF0 may be changed only if the host-to-DSP data path is empty.
- Switching between 32-bit data modes and non-32-bit data modes may be done only in the personal software reset state (HM=\$0 and HACT=0).
- If the HTF1-HTF0 value is not equal to the value of the FC1-FC0 bits in the DPMC: PCI transactions that start in the non-data address space (i.e. the PCI address is less than HI32\_base\_address:\$007) should not extend into the data address space.

The personal hardware reset clears HTF1-HTF0.





# 6.2.1.7 Host Receive Data Transfer Format (HRF1-HRF0) Bits 12 and 11

The HRF1-HRF0 bits define data transfer formats for DSP-to-host communication. The data transfer format converter (HDTFC) operates according to the specified HRF1-HRF0 (See Table Receive Data Transfer Format on page 54).

DSP to PCI host data transfer formats (HM=\$1):

- If HRF=\$0 (32-bit data mode): The two least significant bytes of two words written to the DTXS are transferred to the HRXS. The two least significant bytes of the first word written to the DTXS are transferred to the two least significant bytes of the HRXS. The two least significant bytes of the second word written to the DTXS are transferred to the two most significant bytes of the HRXS. All four HRXS bytes are output to the HAD31-HAD0 pins.
- If HRF=\$1:

The data written to the DTXS is transferred to the three least significant HRXS bytes and output to the HAD31-HAD0 pins as right aligned and zero extended in the most significant byte.

• If HRF=\$2:

The data written to the DTXS is transferred to the three least significant HRXS bytes and output to the HAD31-HAD0 pins as left aligned and zero filled in the least significant byte.

• If HRF=\$3:

The data written to the DTXS is transferred to the three least significant HRXS bytes and output to the HAD31-HAD0 pins as right aligned and sign extended in the most significant byte.

Universal Bus mode DSP to host data transfer formats (HM=\$2 or \$3):

- If HRF=\$0: The data written to the DTXS is transferred to the HRXS and output to the HI32 data pins HD23-HD0.
- If HRF=\$1 or \$2: The two least significant bytes of the data written to the DTXS is transferred to the HRXS and output to the HI32 data pins HD15-HD0.
  - If HRF=\$3: The two most significant bytes of the data written to the DTXS is transferred to the HRXS and output to the HI32 data pins HD15-HD0.

To assure proper operation, HRF1-HRF0 may be changed only if the DSP-to-host slave data path is empty. In addition, switching between 32-bit data modes and non-32-bit data modes may be done only in the personal software reset state (HM=\$0 and HACT=0).

The personal hardware reset clears HRF1-HRF0.

6.2.1.8 Host Semaphores (HS2-HS0) Bits 16 and 14

The HS2-HS0 bits may be used by the host processors for software arbitration of mastership over the HI32. These bits do not affect the HI32 operation and only serve as a read/write semaphore repository. These bits may be used as a mailbox between the external hosts. For example: the semaphores may be used to assist HI32 bus arbitration among several external hosts.

All external host processors that compete for mastership over the HI32 should work according to the same software protocol for handling over the HI32 from one host processor to another.

The personal hardware reset clears HS2-HS0.

### 6.2.1.9 Target Wait State Disable (TWSD) Bit 19

The TWSD bit is used to disable PCI wait states (which are inserted by negating HTRDY), during a data phase.

If TWSD is cleared and the HI32 is in the PCI mode (HM=\$1):

- the HI32 as the selected target in a read data phase from the HRXS, will insert PCI wait states if the HRXS is empty (HRRQ=0). Wait states will be inserted until the data is transferred from the DSP side to the HRXS. Up to eight wait states may be inserted before a target initiated transaction termination (disconnect-C/Retry) will be generated.
- the HI32 as the selected target in a write data phase to the HTXR, will insert PCI wait states if the HTXR is full (HTRQ=0). Wait states will be inserted until the data is transferred from the HTXR to the DSP side. Up to eight wait states may be inserted before a target initiated transaction termination (disconnect-C/Retry) will be generated.
- the HI32 as the selected target in a write data phase to the HCVR, will insert PCI wait states if a host command is pending (HC=1). Wait states will be inserted until the pending host command is serviced. Up to eight wait states may be inserted before a target initiated transaction termination (disconnect-C/Retry) will be generated.

If TWSD is set and the HI32 is in the PCI mode (HM=\$1):

- the HI32 as the selected target in a read transaction from the HRXS, will generate a target initiated transaction termination (disconnect-C) if the HRXS is empty (HRRQ=0).
- the HI32 as the selected target in a write transaction to the HTXR, will generate a target initiated transaction termination (disconnect-C) if the



#### Table 6-9. Receive Data Transfer Format

HTXR is full (HTXR=0) HOST INTERFACE (HI32) • the HI32 as the selected target in a write transaction to the HCVR, will generate a target initiated transaction termination (disconnect-C) if a host command is pending (HC=1).

TWSD is ignored when the HI32 is not in the PCI mode ( $HM \neq$ \$1).

The personal hardware reset clears TWSD.

6.2.1.10 HCTR Reserved Control Bits 31-20, 18-17, 13, 10 and 0

These bits are reserved for future expansion, they are read as zeros and should be written with zeros for upward compatibility.

### 6.2.2 HI32 Status Register (HSTR)

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23   | 22   | 21  | 20  | 19  | 18   | 17   | 16   |
|----|----|----|----|----|----|----|----|------|------|-----|-----|-----|------|------|------|
|    |    |    |    |    |    |    |    |      |      |     |     |     |      |      |      |
|    |    |    |    |    |    |    |    |      |      |     |     |     |      |      |      |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7    | 6    | 5   | 4   | 3   | 2    | 1    | 0    |
|    |    |    |    |    |    |    |    | HREQ | HINT | HF5 | HF4 | HF3 | HRRQ | HTRQ | TRDY |
|    |    |    |    |    |    |    |    |      |      |     |     |     |      |      |      |

Reserved, read as zero and should be written zero

| Bit  | Name     | Function                   |
|------|----------|----------------------------|
| 0    | TRDY     | Transmitter Ready          |
| 1    | HTRQ     | Host Transmit Data Request |
| 2    | HRRQ     | Host Receive Data Request  |
| 5-3  | HF5-HF3  | Host Flags                 |
| 6    | HINT     | Host interrupt A           |
| 7    | HREQ     | Host Request               |
| 31-8 | reserved |                            |

The HSTR is a 32-bit read-only status register used by the host processor to examine the status and flags of the HI32.

When the HSTR is read to the PCI bus (HM=\$1), the HAD31-HAD0 pins are driven with the HSTR data during a read access.

In a 24-bit data Universal Bus mode (HM=\$2 or \$3 and HRF=\$0), the HD23-HD0 pins are driven with the three least significant HSTR bytes during a read access.

In a 16-bit data Universal Bus mode (HM=\$2 or \$3 and HRF $\neq$ \$0), the HD15-HD0 pins are driven with the two least significant bytes of the HSTR in a read access.

In PCI mode (HM=\$1) memory space transactions, the HSTR is accessed if the PCI

address is HI32\_base\_address: \$014.

When in a Universal Bus mode (HM=\$2 or \$3), the HSTR is accessed if the HA10-HA3 value matches the HI32 base address (CBMA, see Section 6.2.11 on page 6-70) and the HA2-HA0 value is \$5.

The status bits are described in the following paragraphs.

### 6.2.2.1 Transmitter Ready (TRDY) Bit 0

The TRDY status bit indicates that **both** the HTXR and the DRXR registers are empty. If TRDY is set to one, the data that the host processor writes to the HTXR will be immediately transferred to the DSP side of the HI32. This has many applications. For example: if the host processor issues a host command which causes the DSP56300 Core to read the DRXR, the host processor can be guaranteed that the data it just transferred to the HI32 is what is being received by the DSP56300 Core.

In order to support high speed data transfers, the HI32 host-to-DSP data path is a six word deep FIFO (five word deep in the Universal Bus modes, three word deep in the 32-bit mode, HM=\$1 and HTF=\$0). In PCI data transfers with HM=\$1 and HTF=\$0, if TRDY is set, the HI32 will not insert wait states in the next six data transfers written by the host to the HTXR. In PCI data transfers with HM=\$1 and HTF=\$0 (i.e. 32-bit mode), if TRDY is set, the HI32 will not insert wait states in the next three data phases written by the host to the HTXR. In Universal bus mode data transfers, if TRDY is set, the HI32 will not insert wait states in the next three data phases written by the host to the HTXR. In Universal bus mode data transfers, if TRDY is set, the HI32 will not insert wait states written by the host to the HTXR. In Universal bus mode data transfers, if TRDY is set, the HI32 will not insert

TRDY is cleared when the HTXR is written by the host processor.

Hardware, software and personal software resets set TRDY.

## 6.2.2.2 Host Transmit Data Request (HTRQ) Bit 1

The HTRQ bit indicates that the host transmit data FIFO (HTXR) is not full and can be written by the host processor. HTRQ is set when the HTXR data is transferred to the DRXR. HTRQ is cleared when the HTXR is filled by host processor writes.

In the PCI mode:

The HI32 as target in a write data phase to the HTXR, will negate HTRDY, and insert up to eight PCI wait cycles, if HTRQ is cleared.

In a Universal Bus mode write to the HTXR, the HI32 slave will negate HTA as long as HTRQ is cleared. HTRQ may be used to assert the external HIRQ pin if the TREQ bit is set. Regardless of whether the HTRQ host interrupt request is enabled, HTRQ provides valid status so that polling techniques may be used by the host processor.

Hardware, software and personal software resets set HTRQ.

### 6.2.2.3 Host Receive Data Request (HRRQ) Bit 2

The HRRQ bit indicates that the host slave receive data FIFO (HRXS) contains data from the DSP56300 Core and may be read by the host processor.

#### In the PCI mode:

The HI32 as a target in a read data phase from the HRXS, will negate HTRDY, and insert up to eight PCI wait cycles, if HRRQ is cleared.

In a Universal Bus mode read from the HRXS, the HI32 slave will negate HTA as long as HRRQ is cleared. HRRQ may be used to assert the HIRQ pin if the RREQ bit is set. Regardless of whether the HRRQ host interrupt request is enabled, HRRQ provides valid status so that polling techniques may be used by the host processor.

HRRQ functions in accordance with the value of the slave fetch type (SFT) bit in the HCTR.

Fetch (SFT= 1): HRRQ is always read as zero.

#### Pre-fetch (SFT= 0):

The DSP-to-host data path is FIFO buffered. HRRQ reflects the status of the HRXS. HRRQ is cleared if the HRXS is empty, and set when data is transferred from the DTXS.

Hardware, software and personal software resets clear HRRQ.

#### 6.2.2.4 Host Flags (HF5-HF3) Bits 5, 4 and 3

The HF5-HF3 bits in the HSTR indicate the state of host flags HF5-HF3 respectively, in the DSP Control Register (DCTR) on the DSP side. HF5-HF3 can be changed, albeit indirectly, only by the DSP56300 Core.

HF5-HF3 are cleared by a hardware or software reset.

### 6.2.2.5 Host Interrupt A (HINT) Bit 6

The HINT bit reflects the status of the HINT bit in the DSP Control Register (DCTR) and the HINTA pin. HINT is set if the host interrupt A bit is set in the DCTR, and the HINTA pin is driven low. HINT is cleared if the host interrupt A is cleared in the DCTR, and the HINTA pin pin is driven low.

HINT is cleared by a hardware or software reset.

# 6.2.2.6 Host Request (HREQ) Bit 7

| • | TREQ | RREQ | HREQ                                         |  |  |  |  |  |
|---|------|------|----------------------------------------------|--|--|--|--|--|
|   | 0    | 0    | cleared                                      |  |  |  |  |  |
|   | 0    | 1    | set if HRRQ=1<br>otherwise cleared           |  |  |  |  |  |
|   | 1 0  |      | set if HTRQ=1<br>otherwise cleared           |  |  |  |  |  |
|   | 1    | 1    | set if HTRQ=1 or HRRQ=1<br>otherwise cleared |  |  |  |  |  |

HREQ is set and cleared in accordance with the following table:

The personal hardware reset clears HREQ.

6.2.2.7 HSTR Reserved Status Bits 31-8

These status bits are reserved for future expansion and read as zeros during host read operations.

## 6.2.3 Host Command Vector Register (HCVR)

| 31   | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23  | 22  | 21  | 20  | 19  | 18  | 17  | 16 |
|------|----|----|----|----|----|----|----|-----|-----|-----|-----|-----|-----|-----|----|
|      |    |    |    |    |    |    |    |     |     |     |     |     |     |     |    |
| 15   | 14 | 13 | 12 | 11 | 10 | 9  | 8  | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0  |
| HNMI |    |    |    |    |    |    |    | HV6 | HV5 | HV4 | HV3 | HV2 | HV1 | HV0 | НС |

Reserved, read as zero and should be written zero

| Bit        | Name     | Function                    |
|------------|----------|-----------------------------|
| 0          | HC       | Host Command                |
| 7-1        | HV6-HV0  | Host Command Vector         |
| 15         | HNMI     | Host Non Maskable Interrupt |
| 31-16,14-8 | reserved |                             |

The HCVR is a 32-bit read/write register used by the host processor to cause the DSP56300 Core to execute a vectored interrupt. The host command feature is independent of any of the data transfer mechanisms in the HI32. It can be used to cause any of the 128 possible interrupt routines in the DSP to be executed.

When the HCVR is read to the PCI bus (HM=\$1), the HAD31-HAD0 pins are driven with the HCVR data during a read access; and these pins are written to the HCVR in a write

access.

In a 24-bit data Universal Bus mode (HM=\$2 or \$3 and HTF=\$0 or HRF=\$0), the HD23-HD0 pins are driven with the three least significant bytes of the HCVR in a read access; HD23-HD0 are written to the three least significant bytes of the HCVR, the most significant portion is zero filled during the HCVR write.

In a 16-bit data Universal Bus mode (HM=\$2 or \$3 and HTF $\neq$ \$0 or HRF $\neq$ \$0), the HD15-HD0 pins are driven with the two least significant bytes of the HCVR in a read access; HD15-HD0 are written to the two least significant bytes of the HCVR, the most significant portion is zero filled during the HCVR write.

In PCI mode (HM=\$1) memory space transactions, the HCVR is accessed if the PCI address is HI32\_base\_address: \$018.

The HCVR is written in accordance with the byte enables (HC3/HBE3-HC0/HBE0 pins). Byte lanes that are not enabled are not written and the corresponding bits remain unchanged.

When in a Universal Bus mode (HM=\$2 or \$3), the HCVR is accessed if the HA10-HA3 value matches the HI32 base address (CBMA, see Section 6.2.11 on page 6-70) and the HA2-HA0 value is \$6.

If TWSD is cleared, the HI32 as the selected PCI target (HM=\$1) in a write data phase to the HCVR will insert PCI wait states if a host command is pending (HC=1). Wait states will be inserted until the pending host command is serviced. Up to eight wait states may be inserted before a target initiated transaction termination (disconnect-C/Retry) will be generated.

In a Universal Bus mode write to the HCVR, the HI32 will insert wait states if a host command is pending (HC=1). Wait states will be inserted until the pending host command is serviced.

The HCVR bits are described in the following paragraphs.

## 6.2.3.1 Host Command (HC) Bit 0

The HC bit is used by the host processor to handshake the execution of host command interrupt requests. Normally, the host processor sets HC to request a host command interrupt from the DSP56300 Core. When the host command interrupt request is acknowledged by the DSP56300 Core, the HC bit is cleared by the HI32 hardware. The host processor can read the state of HC to determine when the host command request has been serviced. The host processor cannot clear HC.

Setting HC causes host command pending (HCP) to be set in the DSR. The host can write HC and HV in the same write cycle if desired.

If HC is set:

In the PCI mode:

The HI32 as a target in a write data phase to the HCVR, will negate HTRDY, and insert up to eight PCI wait cycles, until HC is cleared.

In a Universal Bus mode:

In a write transaction to the HCVR, the HI32 slave will negate HTA, until HC is cleared.

The personal software reset clears HC.

6.2.3.2 Host Vector (HV6-HV0) Bits 7-1

The seven HV bits select the host command interrupt address. When the host command interrupt is recognized by the DSP56300 Core interrupt control logic, the starting address of the interrupt executed is  $2 \times (HV6-HV0)$ .

The host processor can select any of the 128 possible interrupt routine starting addresses in the DSP by writing the interrupt routine starting address divided by two into HV. This means that the host processor can force any of the existing interrupt routines (SSI, Timer, IRQA, IRQB, etc.) and can use any of the reserved or otherwise unused starting addresses provided they have been pre-programmed in the DSP. Non-maskable interrupts of DSP56300 Core can be forced by the host processor by setting the host non-maskable interrupt (HNMI) bit in the HCVR. When HNMI set is recognized by the HI32 command interrupt logic, the host command interrupt is processed with the highest priority regardless of the current HI32 interrupt priority (as written in the DSP56300 Core peripheral priority register (IPRP)).

**CAUTION:** HV6-HV0 should not be used with a value of zero - the reset location, as this location is normally programmed with a JMP instruction. Doing so will cause an improper short interrupt.

The personal hardware reset sets HV to the default host command vector, which is via programmable (see Section 6.8 on page 6-89).

## 6.2.3.3 Host Non-Maskable Interrupt (HNMI) Bit 15

The HNMI bit is used by the host processor to force the generation of the host command as non-maskable interrupt request. If HNMI and HC are set, the host command interrupt is processed with the highest priority regardless of the current HI32 interrupt priority (as written in the DSP56300 Core peripheral priority register (IPRP)). If HNMI is cleared and HC is set, the host command interrupt is processed in accordance with the priority programmed in the IPRP register, and can be disabled by clearing HCIE in the DCTR.

The personal hardware reset clears HNMI.

### 6.2.3.4 HCVR Reserved Bits 31-16, 14-8

These unused bits are reserved for future expansion and should be written with zeros for upward compatibility. They are read by the host processor as zeros.

### 6.2.4 Host Slave Receive Data Register (HRXS)

The HRXS is the output stage of the slave DSP-to-host data path FIFO used for DSP-to-host data transfers. The HRXS cannot be accessed by the DSP56300 Core.

The HRXS contains valid data when the HRRQ bit is set. Emptying the HRXS by host processor reads clears HRRQ.

The HRXS transfers the data to the HI32 data pins via the data transfer format converter (HDTFC). The value of the HRF bits in the HCTR define which bytes of the HRXS are output to the pins and their alignment. (See Section 6.1.9 on page 66-36 and Section 6-9 on page 6-54).

In PCI mode (HM=\$1) memory space read transaction, the HRXS is accessed if the PCI address is between HI32\_base\_address: \$01C and HI32\_base\_address: \$FFFC.

In the PCI mode (HM=\$1), HRXS is viewed by the host processor as a 16377 Dword read-only memory.

In PCI DSP-to-host data transfers via the HRXS, all four byte lanes are driven with data, in accordance with HRF1-HRF0 bits, regardless of the value of the byte enable pins (HC3/HBE3-HC0/HBE0).

When in a Universal Bus mode (HM=\$2 or \$3), the HRXS is accessed if the HA10-HA3 value matches the HI32 base address (CBMA, see Section 6.2.11 on page 6-70) and the HA2-HA0 value is \$7.

In a 24-bit data Universal Bus mode (HM=\$2 or \$3 and HRF=\$0), the HRXS is viewed by the host processor as a 24-bit read-only register. HD23-HD0 pins are driven with all three bytes of the HRXS in a read access.

In a 16-bit data Universal Bus mode (HM= $$2 \text{ or }$3 \text{ and }HRF \neq $0$ ), the HRXS is viewed by the host processor as a 16-bit read-only register. In a read access, the HD15-HD0 pins are driven with data from the two most significant bytes or two least significant bytes of the HRXS, as defined by the HRF bits in the HCTR.

When HRRQ is set and RREQ in the HCTR is set:

- the HREQ status bit will be set in the HSTR.
- the HIRQ pin will be asserted if DMAE is cleared (in the Universal Bus modes)
- the HDRQ pin will be asserted if DMAE is set (in the Universal Bus modes)

If TWSD is cleared, the HI32 as the selected PCI target (HM=\$1) in a read data phase from the HRXS will insert PCI wait states if the HRXS is empty (HRRQ=0). Wait states will be inserted until the data is transferred from the DSP side to the HRXS. Up to eight wait states may be inserted before a target initiated transaction termination (disconnect-C/Retry) will be generated.

In a Universal Bus mode read from the HRXS the HI32 will insert wait states if the HRXS is empty (HRRQ=0). Wait states will be inserted until the data is transferred from the DSP side to the HRXS.

Hardware, software and personal software resets empty the HRXS (HRRQ is cleared).

# 6.2.5 Host Master Receive Data Register (HRXM)

The HRXM is the output stage of the master DSP-to-host data path FIFO used for DSP-to-host data transfers. The HRXM cannot be accessed by the DSP56300 Core or the host.

The HRXM transfers the data to the HI32 data pins via the data transfer format converter (HDTFC). The value of the FC bits in the DPMC define which bytes of the HRXM are output to the pins and their alignment. (See Section 6.1.9 on page 66-36 and Section 6-3 on page 66-24).

In the PCI mode (HM=\$1) the DSP56300 Core can clear the HI32 master-to-host bus data path and empty HRXM by setting the CLRT bit in the DPCR.

In PCI DSP-to-host data transfers via the HRXM, all four byte lanes are driven with data, in accordance with FC1-FC0 bits, regardless of the value of the byte enable pins (HC3/HBE3-HC0/HBE0).

Hardware, software and personal software resets empty the HRXM.

# 6.2.6 Host Transmit Data Register (HTXR)

The HTXR is the input stage of the host-to-DSP data path FIFO used for host-to-DSP data transfers. The HTXR cannot be accessed by the DSP56300 Core.

The HTXR may be written if the HTRQ bit in the HSTR is set. Data should not be written to the HTXR until HTRQ is set to prevent previous data from being overwritten. Filling the HTXR by host processor writes, clears HTRQ.

The HTXR receives data from the HI32 data pins via the data transfer format converter (HDTFC). The value of the FC bits in the HCTR or the HTF bits in the HCTR define which bytes of the PCI bus are written to the HTXR and their alignment. (See Table 6-3, on page 66-24, Section 6.1.7 on page 66-35 and Table 6-8, on page 6-51).

In the PCI mode (HM=\$1):

As the active target, in a memory space write transaction, the HTXR is accessed if the PCI

address is between HI32\_base\_address: \$01C and HI32\_base\_address: \$FFFC (i.e. the HTXR is viewed by the host processor as a 16377 Dword write-only memory). As the active master, all data read from the target being accessed is written to the HTXR.

In PCI host-to-DSP data transfers, data is written to the HTXR FIFO, in accordance with FC1-FC0 or HTF1-HTF0 bits, regardless of the value of the byte enable pins (HC3/HBE3-HC0/HBE0).

In a Universal Bus mode (HM=\$2 or \$3), the HTXR is accessed if the HA10-HA3 value matches the HI32 base address (CBMA, see Section 6.2.11 on page 6-70) and the HA2-HA0 value is \$7.

In a 24-bit data Universal Bus mode (HM=\$2 or \$3 and HTF=\$0), the HTXR is viewed by the host processor as a 24-bit write-only register. HD23-HD0 pins are written to all three bytes of the HTXR in a write access.

In a 16-bit data Universal Bus mode (HM=\$2 or \$3 and HTF $\neq$ \$0), the HTXR is viewed by the host processor as a 16-bit write-only register. In a write access, the HD15-HD0 pins are written to the two most significant bytes or least significant bytes of the HTXR, as defined by the HTF bits in the HCTR.

When HTRQ is set and TREQ in the HCTR is set:

- the HREQ status bit will be set in the HSTR.
- the HIRQ pin will be asserted if DMAE is cleared (in the Universal Bus modes)
- the HDRQ pin will be asserted if DMAE is set (in the Universal Bus modes)

If TWSD is cleared, the HI32 as the selected PCI target (HM=\$1) in a write data phase to the HTXR will insert PCI wait states if the HTXR is full (HTRQ=0). Wait states will be inserted until the data is transferred from the HTXR to the DSP side. Up to eight wait states may be inserted before a target initiated transaction termination (disconnect-C/Retry) will be generated.

In a Universal Bus mode write to the HTXR the HI32 will insert wait states if the HTXR is full (HTRQ=0). Wait states will be inserted until the data is transferred from the HTXR to the DSP side.

Hardware, software and personal software resets empty the HTXR (HTRQ is set).

| 0.2.7 | -     | 20110 | 0/ 1011 |       |       | ingai | anon | i togi | 0.01 ( | 0010 |      | ')   |      |      |      |
|-------|-------|-------|---------|-------|-------|-------|------|--------|--------|------|------|------|------|------|------|
| 31    | 30    | 29    | 28      | 27    | 26    | 25    | 24   | 23     | 22     | 21   | 20   | 19   | 18   | 17   | 16   |
| DID15 | DID14 | DID13 | DID12   | DID11 | DID10 | DID9  | DID8 | DID7   | DID6   | DID5 | DID4 | DID3 | DID2 | DID1 | DID0 |
| 15    | 14    | 13    | 12      | 11    | 10    | 9     | 8    | 7      | 6      | 5    | 4    | 3    | 2    | 1    | 0    |
| VID15 | VID14 | VID13 | VID12   | VID11 | VID10 | VID9  | VID8 | VID7   | VID6   | VID5 | VID4 | VID3 | VID2 | VID1 | VID0 |

Device/Vendor ID Configuration Register (CDID/CVID)

| В    | lit   | Name       | Value<br>(hardwired)                             | Function  |
|------|-------|------------|--------------------------------------------------|-----------|
| CVID | 15-0  | VID15-VID0 | \$1057                                           | Vendor ID |
| CDID | 31-16 | DID15-DID0 | via programmable<br>see Section 6.8 on page 6-89 | Device ID |

The CDID/CVID is a PCI standard 32-bit read-only register mapped into the PCI configuration space, when in the PCI mode or in mode 0 (HM=\$1 or \$0). CDID/CVID is accessed if a configuration read command is in progress and the PCI address is \$00.

The DID15-DID0 bits identify the DSP. The VID15-VID0 bits identify the manufacturer of the DSP. The contents of CDID/CVID is hardwired and cannot be affected by any type of reset.

The CDID/CVID cannot be accessed by the host when not in the PCI mode ( $HM \neq$ \$1).

6.2.7

| 6.2.8 | ;                                                                                               | Status   | s/Con    | nman      | d Cor    | nfigu    | ration   | Regi    | ster ( | CSTR      | R/CCI    | MR)       |          |           |      |
|-------|-------------------------------------------------------------------------------------------------|----------|----------|-----------|----------|----------|----------|---------|--------|-----------|----------|-----------|----------|-----------|------|
| 31    | 30                                                                                              | 29       | 28       | 27        | 26       | 25       | 24       | 23      | 22     | 21        | 20       | 19        | 18       | 17        | 16   |
| DPE   | SSE                                                                                             | RMA      | RTA      | STA       | DST1     | DST0     | DPR      | FBBC    |        |           |          |           |          |           |      |
| 15    | 14                                                                                              | 13       | 12       | 11        | 10       | 9        | 8        | 7       | 6      | 5         | 4        | 3         | 2        | 1         | 0    |
|       |                                                                                                 |          |          |           |          |          | SERE     | wcc     | PERR   |           |          |           | BM       | MSE       |      |
|       | Not im                                                                                          | nplement | ed, reac | l as zero | , should | be writt | en zero  |         | Rese   | erved, re | ad as ze | ero and s | should b | e written | zero |
|       |                                                                                                 | Bit      |          | 1         | Name     |          |          |         | F      | unctio    | on       |           |          |           |      |
|       |                                                                                                 |          | 1        | MSE       |          |          | Memor    | y Spac  | e Enal | ble       |          |           |          |           |      |
|       |                                                                                                 |          | 2        | BM        |          |          | Bus Ma   | aster E | nable  |           |          |           |          |           |      |
|       |                                                                                                 | Υ        | 6        | PERR      |          |          | Parity E | Error R | espons | se        |          |           |          |           |      |
|       | O     PERR     Parity Error Response       7     WCC     Wait Cycle Control (hardwired to zero) |          |          |           |          |          |          |         |        |           |          |           |          |           |      |

|      | Bit      | Name            | Function                                     |
|------|----------|-----------------|----------------------------------------------|
|      | 1        | MSE             | Memory Space Enable                          |
|      | 2        | BM              | Bus Master Enable                            |
| R    | 6        | PERR            | Parity Error Response                        |
| CCMR | 7        | WCC             | Wait Cycle Control (hardwired to zero)       |
| 0    | 8        | SERE            | System Error Enable                          |
|      | 9,5-3, 0 | not implemented |                                              |
|      | 15-10    | reserved        |                                              |
|      | 23       | FBBC            | Fast Back-to-Back Capable (hardwired to one) |
|      | 24       | DPR             | Data Parity Reported                         |
|      | 26-25    | DST1-DST0       | DEVSEL Timing (hardwired to \$1)             |
| æ    | 27       | STA             | Signaled Target Abort                        |
| CSTR | 28       | RTA             | Received Target Abort                        |
| 0    | 29       | RMA             | Received Master Abort                        |
|      | 30       | SSE             | Signaled System Error                        |
|      | 31       | DPE             | Detected Parity Error                        |
|      | 22-16    | reserved        |                                              |

The CSTR/CCMR is a PCI standard 32-bit read/write register mapped into the PCI configuration space, when in the PCI mode or in mode 0 (HM=\$1 or \$0). CSTR/CCMR is accessed if a configuration read/write command is in progress and the PCI address is \$04. In the Self Configuration mode (HM=\$5): the DSP56300 Core can indirectly access the CCMR. (See "SELF CONFIGURATION MODE" on page 73.)

The CSTR/CCMR is written by the host in accordance with the byte enables. Byte lanes that are not enabled are not written and the corresponding bits remain unchanged.

The CSTR/CCMR cannot be accessed by the host when not in the PCI mode ( $HM \neq$ \$1).

The CSTR/CCMR bits are described in the following paragraphs.

## 6.2.8.1 Memory Space Enable (MSE) Bit 1

The MSE bit is used to control the HI32 response to the PCI memory space accesses, when in the PCI mode (HM=\$1). The HI32 memory space response is disabled if MSE is cleared and enabled if MSE is set.

The personal hardware reset clears MSE.

### 6.2.8.2 Bus Master Enable (BM) Bit 2

The BM bit is used to control the HI32 ability to act as a master on the PCI bus, when in the PCI mode (HM=\$1). If BM is cleared, the HI32 is disabled from acting as a bus master. If BM is set, the HI32 can function as a bus master. This bit affects the MARQ bit in the DSP side status register (DPSR): if BM is cleared, MARQ is also cleared.

The personal hardware reset clears BM.

### 6.2.8.3 Parity Error Response (PERR) Bit 6

The PERR bit is used to control the HI32 response to parity errors, when in the PCI mode (HM=\$1). If PERR is cleared: the HI32 does not drive  $\overline{HPERR}$ . If PERR is set: if a parity error is detected the HI32 pulses the  $\overline{HPERR}$  pin. If a parity error or  $\overline{HPERR}$  low is detected, the HI32 sets the DPR bit in the CSTR/CCMR

In both cases the HI32 sets bit 15 (DPE) in the CSTR/CCMR, sets DPER in the DPSR, and generates a parity error interrupt request if PEIE, in the DPCR, is set.

The personal hardware reset clears PERE.

6.2.8.4 Wait Cycle Control (WCC) Bit 7

The WCC bit is hardwired to zero, as the HI32 never executes address stepping.

### 6.2.8.5 System Error Enable (SERE) Bit 8

The SERE bit is used to enable the HSERR pin driving by the HI32, when in the PCI mode (HM=\$1). If SERE is cleared, the HSERR pin disabled (i.e. high impedance). If SERE is set: if the force system error (SERF) bit in the DPCR is set and the HI32 is an active PCI agent, or an address parity error was detected, the HI32 pulses the HSERR pin and sets the signalled system error (SSE) bit in the CSTR.

The personal hardware reset clears SERE.

### 6.2.8.6 Fast Back-to-Back Capable (FBBC) Bit 23

The FBBC indicates the HI32 supports fast back-to-back transactions as a target, when in the PCI mode (HM=\$1). This bit is hardwired to one.

## 6.2.8.7 Data Parity Reported (DPR) Bit 24

The DPR indicates the data parity error detected, when in the PCI mode (HM=\$1). The DPR is set if the HI32 acts as a bus master and detects a data parity error or samples HPERR asserted while PERR bit is set in CCMR. The DPR bit is cleared when it is written with one by the host processor.

The personal hardware reset clears DPR.

6.2.8.8 DEVSEL Timing (DST1-DST0) Bits 26 and 25

The DST1-DST0 bits encode the timing of the HDEVSEL pin, when in the PCI mode (HM=\$1). These bits are hardwired to DST=\$1, indicating that the HI32 belongs to the 'medium DEVSEL timing' class of the PCI devices.

6.2.8.9 Signaled Target Abort (STA) Bit 27

The STA indicates a target-abort PCI bus event has been generated. When in the PCI mode (HM=\$1) and the HI32, as a target device, terminates a transaction with target-abort, the STA is set. The STA bit is cleared when it is written with one by the host processor.

The personal hardware reset clears STA.

6.2.8.10 Received Target Abort (RTA) Bit 28

The RTA indicates a target-abort PCI bus event has been generated. When in the PCI mode (HM=\$1) and the HI32, as a master device, detects that its transaction is terminated with target-abort, the RTA is set. The RTA bit is cleared when it is written with one by the host processor.

The personal hardware reset clears RTA.

### 6.2.8.11 Received Master Abort (RMA) Bit 29

The RMA indicates a master-abort PCI bus state has been generated. When in the PCI mode (HM=\$1) and the HI32, as a master device, terminates its transaction with master-abort, the RMA is set. The RMA bit is cleared when it is written with one by the host processor.

The personal hardware reset clears RMA.

### 6.2.8.12 Signaled System Error (SSE) Bit 30

The SSE indicates a system error has occurred. When in the PCI mode (HM=\$1) and the HI32 asserts  $\overline{HSERR}$  pin, the SSE is set. The SSE bit is cleared when it is written with one by the host processor.

The personal hardware reset clears SSE.

## 6.2.8.13 Detected Parity Error (DPE) Bit 31

The DPE indicates a parity error has been detected by the HI32 hardware. When in the PCI mode (HM=\$1) and the HI32 detects either address or data parity error, the DPE is set. The DPE bit is cleared when it is written with one by the host processor.

The personal hardware reset clears DPE.

6.2.8.14 CSTR Reserved Bits 23-16

These unused bits are reserved for future PCI expansion and read by the host processor as zeros.

### 6.2.8.15 CCMR Reserved Bits 15-10

These bits are reserved for future PCI expansion and should be written with zeros for upward compatibility. They are read by the host processor as zeros.

### 6.2.8.16 CCMR Not Implemented Bits 9, 5-3

These not implemented bits are reserved for future expansion and should be written with zeros for upward compatibility. They are read by the host processor as zeros.

| 6.2.9 | Class Code/Revision ID | Configuration | Register | (CCCR/CRID) |
|-------|------------------------|---------------|----------|-------------|
|       |                        |               |          | . /         |

| 31  | 30  | 29  | 28  | 27  | 26  | 25  | 24  | 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   |
|-----|-----|-----|-----|-----|-----|-----|-----|------|------|------|------|------|------|------|------|
| BC7 | BC6 | BC5 | BC4 | BC3 | BC2 | BC1 | BC0 | SC7  | SC6  | SC5  | SC4  | SC3  | SC2  | SC1  | SC0  |
| 15  | 14  | 13  | 12  | 11  | 10  | 9   | 8   | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
| PI7 | PI6 | PI5 | PI4 | PI3 | PI2 | PI1 | PI0 | RID7 | RID6 | RID5 | RID4 | RID3 | RID2 | RID1 | RID0 |

|      | Bit   | Name      | Value<br>(hardwired)     | Function                     |  |  |  |
|------|-------|-----------|--------------------------|------------------------------|--|--|--|
| CRID | 7-0   | RID7-RID0 | via programmable         | Revision ID                  |  |  |  |
| R    | 15-8  | PI7-PI0   | see                      | PCI Device Program Interface |  |  |  |
| CCR  | 23-16 | SC7-SC0   | Section 6.8 on page 6-89 | PCI Device Sub-Class         |  |  |  |
| 0    | 31-24 | BC7-BC0   |                          | PCI Device Base Class        |  |  |  |

The CCCR/CRID is a PCI standard 32-bit read-only register mapped into the PCI configuration space, when in the PCI mode or in mode 0 (HM=\$1 or \$0). CCCR/CRID is accessed if a configuration read command is in progress and the PCI address is \$08.

The RID7-RID0 bits specify the DSP specific identifier (as en extension of Device ID).

The CCCR/CRID cannot be accessed by the host when not in the PCI mode (HM≠\$1)

The contents of CCCR/CRID is hardwired and are not affected by any type of reset.

| 0.2.1 | О Г | ieade | eriyp | e/Lat | ency | Ime | CON | ngura | ation | Regis | ster ( | спт | /CLA | 1)  |     |
|-------|-----|-------|-------|-------|------|-----|-----|-------|-------|-------|--------|-----|------|-----|-----|
| 31    | 30  | 29    | 28    | 27    | 26   | 25  | 24  | 23    | 22    | 21    | 20     | 19  | 18   | 17  | 16  |
|       |     |       |       |       |      |     |     | HT7   | HT6   | HT5   | HT4    | HT3 | HT2  | HT1 | нто |
| 15    | 14  | 13    | 12    | 11    | 10   | 9   | 8   | 7     | 6     | 5     | 4      | 3   | 2    | 1   | 0   |
| LT7   | LT6 | LT5   | LT4   | LT3   | LT2  | LT1 | LTO |       |       |       |        |     |      |     |     |

# 6.2.10 Header Type/Latency Timer Configuration Register (CHTY/CLAT)

Not implemented, read as zero and should be written zero

| Bi   | it    | Name            | Function                        |  |  |  |  |  |
|------|-------|-----------------|---------------------------------|--|--|--|--|--|
|      | 7-0   | not implemented |                                 |  |  |  |  |  |
| CLAT | 15-8  | LT7-LT0         | Latency Timer (High)            |  |  |  |  |  |
| CHTY | 23-16 | HT7-HT0         | Header Type (hardwired to \$00) |  |  |  |  |  |
|      | 31-24 | not implemented |                                 |  |  |  |  |  |

The CHTY/CLAT is a PCI standard 32-bit read/write register mapped into the PCI configuration space, when in the PCI mode or in mode 0 (HM=\$1 or \$0). The CHTY/CLAT is accessed if a configuration read/write command is in progress and the PCI address is \$0C. In the Self Configuration mode (HM=\$5): the DSP56300 Core can indirectly access the CLAT (See "SELF CONFIGURATION MODE" on page 73.).

The CHTY/CLAT is written in accordance with the byte enables. Byte lanes that are not enabled are not written and the corresponding bits remain unchanged.

The CHTY/CLAT cannot be accessed by the host when not in the PCI mode (HM≠\$1).

The CHTY/CLAT bits are described in the following paragraphs.

6.2.10.1 Header Type (HT7-HT0) Bits 23-16

The read-only bits HT7-HT0 identify the layout of bytes \$10-\$3F in the configuration space and also whether or not the device contains multiple functions. This byte is hardwired to the value \$00.

6.2.10.2 Latency Timer (LT7-LT0) Bits 15-8

The read/write bits LT7-LT0 have two functions:

In the PCI mode (HM=\$1): LT7-LT0 specify, in units of PCI bus clock cycles, the value of the latency timer for this PCI bus master.

In the Universal Bus modes (HM=\$2,\$3) with HIRH cleared: LT7-LT0 specify, in units of DSP56300 Core clock cycles, the duration of the  $\overline{HIRQ}$  pulse. The duration of the  $\overline{HIRQ}$ 

pulse is given by the following equation:

HIRQ\_PULSE\_WIDTH = (LT[7:0]\_Value + 1) • DSP56300\_Core\_clock\_cycle

This bits can be written by the DSP56300 Core in the Self Configuration mode (see Self Configuration Procedure for the Universal Bus Mode on page 73).

The personal hardware reset clears LT7-LT0.

6.2.10.3 CHTY/CLAT Not Implemented Bits 31-24,7-0

These not implemented bits are reserved for future expansion and should be written with zeros for upward compatibility. They are read by the host processor as zeros.

| 6.2.11 | Memory Space Base Address Configuration Register (CBMA) |  |
|--------|---------------------------------------------------------|--|
|--------|---------------------------------------------------------|--|

| 31   | 30   | 29   | 28   | 27   |              | 25   |      |               |              | 21            |                      | 19           | 18           | 17           | 16           |
|------|------|------|------|------|--------------|------|------|---------------|--------------|---------------|----------------------|--------------|--------------|--------------|--------------|
| PM31 | PM30 | PM29 | PM28 | PM27 | <i>PM</i> 26 | PM25 | PM24 | PM23/<br>GB10 | PM22/<br>GB9 | PM21/<br>GB98 | <i>РМ</i> 20/<br>GB7 | PM19/<br>GB6 | PM18/<br>GB5 | PM17/<br>GB4 | PM16/<br>GB3 |
| 15   | 14   | 13   | 12   | 11   | 10           | 9    | 8    | 7             | 6            | 5             | 4                    | 3            | 2            | 1            | 0            |
| PM15 | PM14 | PM13 | PM12 | PM11 | PM10         | PM9  | PM8  | PM7           | PM6          | PM5           | PM4                  | PF           | MS1          | MS0          | MSI          |

Hardwired to zero

| Bit   | Name      | Function                                     |
|-------|-----------|----------------------------------------------|
| 0     | MSI       | Memory Space Indicator (Hardwired to zero)   |
| 2-1   | MS1-MS0   | Memory Space (Hardwired to zeros)            |
| 3     | PF        | Pre-fetch (Hardwired to zero)                |
| 15-4  | PM15-PM4  | Memory Base Address Low (Hardwired to zeros) |
| 31-16 | PM31-PM16 | Memory Base Address High                     |
| 23-16 | GB10-GB3  | Universal Bus mode Base Address              |

The CBMA is a PCI standard 32-bit read/write register mapped into the PCI configuration space, when in the PCI mode or in mode 0 (HM=\$1 or \$0). The CBMA is accessed if a configuration read/write command is in progress and the PCI address is \$10. The CBMA controls the HI32 mapping into the PCI memory space and the Universal Bus mode space. In the Self Configuration mode (HM=\$5): the DSP56300 Core can indirectly access the CBMA (See "SELF CONFIGURATION MODE" on page 73.).

The CBMA is written in accordance with the byte enables. Byte lanes that are not enabled are not written and the corresponding bits remain unchanged.

The CBMA cannot be accessed by the host when not in the PCI mode ( $HM \neq$ \$1).

The CBMA bits are described in the following paragraphs.

### 6.2.11.1 Memory Space Indicator (MSI) Bit 0

The MSI determines that CBMA register maps the HI32 into the PCI memory space. The MSI bit is hardwired to zero and is not affected by any type of reset.

#### 6.2.11.2 Memory Space (MS1-MS0) Bits 2 and 1

The MS1 and MS0 bits encode that CBMA register is 32 bits wide and mapping can be done anywhere in the 32 bit memory space. The MS1 and MS0 are hardwired to zeros and is not affected by any type of reset.

### 6.2.11.3 Pre-fetch (PF) Bit 3

The PF bit indicates that the data is pre-fetchable or not. PF is hardwired to zero and is not affected by any type of reset.

#### 6.2.11.4 Memory Base Address (PM31-PM16) Bits 31-4

The PM31-PM4 bits define the HI32 base address when it is mapped into the PCI memory space. The PM15-PM4 are hardwired to zero, while PM31-PM16 can be written by the PCI master during system configuration.

The HI32 target occupies 16384 Dwords of the PCI memory space. The HI32 is selected by the 20 most significant PCI address pins HAD31-HAD12, and the twelve least significant address pins HAD11-HAD0 are used to select the HI32 registers on the host side (see Figure 6-3 on page 6-43).

The personal hardware reset clears PM31-PM16.

#### 6.2.11.5 Universal Bus Mode Base Address (GB10-GB3) Bits 23-16

The GB10-GB3 bits define the HI32 base address when it is mapped into the Universal Bus mode space. The remaining CBMA bits are ignored in Universal Bus modes.

The HI32 slave occupies eight locations in the Universal Bus mode space. The HI32 is selected by the eight most significant address pins HA10-HA3, and the three least significant address pins HA2-HA0 are used to select the HI32 registers on the host side.

All reserved register addresses are read as zeros and should be written with zeros for upward compatibility (see Figure 6-5 on page 6-43).

The personal hardware reset clears GB10-GB3.

| •   |     |       |          |      |     |     |     |       |         |     |     | (•  | ,   |     |     |
|-----|-----|-------|----------|------|-----|-----|-----|-------|---------|-----|-----|-----|-----|-----|-----|
| 31  | 30  | 29    | 28       | 27   | 26  | 25  | 24  | 23    | 22      | 21  | 20  | 19  | 18  | 17  | 16  |
| ML7 | ML6 | ML5   | ML4      | ML3  | ML2 | ML1 | MLO | MG7   | MG6     | MG5 | MG4 | MG3 | MG2 | MG1 | MG0 |
| 15  | 14  | 13    | 12       | 11   | 10  | 9   | 8   | 7     | 6       | 5   | 4   | 3   | 2   | 1   | 0   |
| IP7 | IP6 | IP5   | IP4      | IP3  | IP2 | IP1 | IP0 | IL7   | IL6     | IL5 | IL4 | IL3 | IL2 | IL1 | ILO |
|     | ]   | Hardw | vired to | zero |     |     |     | Hardw | ired to | one |     |     |     |     |     |

Interrupt Line - Interrupt Pin Configuration Register (CILP)

| Bit            |       | Name    | Value<br>(hardwired) |
|----------------|-------|---------|----------------------|
| Interrupt Line | 7-0   | IL7-IL0 |                      |
| Interrupt Pin  | 15-8  | IP7-IP0 | \$01                 |
| MIN_GNT        | 23-16 | MG7-MG0 | \$00                 |
| MAX_LAT        | 31-24 | ML7-ML0 | \$00                 |

The CILP is a PCI standard 32-bit read-only register mapped into the PCI configuration space, when in the PCI mode or in mode 0 (HM=\$1 or \$0). CILP is accessed if a configuration read command is in progress and the PCI address is \$FC. The CILP register cannot be accessed by the DSP56300 Core.

ML7-ML0: MAX\_LAT is used for specifying how often the device needs to gain access to the PCI bus. As the HI32 has no major requirements for the settings of Latency Timers, these bits are hardwired to zero.

MG7-MG0: MIN\_GNT is used for specifying how long a burst the device needs. As the HI32 has no major requirements for the settings of Latency Timers, these bits are hardwired to zero.

IP7-IP0: The Interrupt Pin bits specify which interrupt the device uses. A value of 1 corresponds to PCI INTA.

IL7-IL0: These read/write bits are used to communicate PCI interrupt line routing information. POST software will write the routing information into these bits as it initializes and configures the PCI system.

The CILP cannot be accessed by the host when not in the PCI mode ( $HM \neq$ \$1).

The 24 most significant bits of the CILP register are hardwired and are not affected by any type of reset. The personal hardware reset clears IL7-IL0.

6.2.12

## 6.3 SELF CONFIGURATION MODE

The Self Configuration mode is used to program the HI32 base address and HIRQ pulse width, for operation in the Universal Bus mode; and for programming the configuration registers for operation in a PCI environment without an external system configurator.

In the Self Configuration mode (HM=\$5), the DSP56300 Core can indirectly write to all the writable HI32 configuration registers. The DSP56300 Core writes the Dword data to the AR bits of the DPMC and DPAR registers (the remaining bits in these registers are ignored). The two most significant bytes of the Dword are written to the DPMC, the two least significant, to the DPAR. The data is transferred to the configuration register by the HI32 hardware. The registers are written sequentially beginning with the CSTR/CCMR register (location \$04). After each write to the DPAR, the data is transferred to the accessed register and an internal pointer is advanced to point to the next Dword location in the configuration space.

NOTE: At least one DSP instruction must appear between writing the Self Configuration mode (HM2-HM0 = \$5) and first write to the DPAR if the first write is a one DSP clock cycle instruction. (e.g. move immediate and move from external memory are more than one clock cycle)

| M_DCTR | equ DCTR_ADDR                       | ; HI32 via programmed address :\$5  |
|--------|-------------------------------------|-------------------------------------|
| M_DPMC | equ DPMC_ADDR                       | ; HI32 via programmed address :\$6  |
| M_DPAR | equ DPAR_ADDR                       | ; HI32 via programmed address :\$8  |
|        |                                     |                                     |
| movep  | #\$500000, x: M_DCTR                | ; enter self configuration mode     |
| movep  | <pre>#BASE_ADDRESS, x: M_DPMC</pre> | ; CBMA Data (location \$10)         |
| movep  | #CCMR_DATA, x: M_DPAR               | ; write CSTR & CCMR (location \$04) |
| movep  | #\$0, x: M_DPAR                     | ; dummy write to location \$08      |
| movep  | #CLAT_DATA, x: M_DPAR               | ; write CLAT (location \$0C)        |
| movep  | #\$0, x: M_DPAR                     | ; write CBMA (location \$10)        |
| movep  | #\$0, x: M_DCTR                     | ; return to personal software reset |
|        |                                     |                                     |

#### 6.3.1 Self Configuration Procedure for the PCI Mode

#### 6.3.2 Self Configuration Procedure for the Universal Bus Mode

| M_DCTR                                    | equ DCTR_ADDR                                                                                                                     | ; HI32 via programmed address :\$5                                                                                                                                                                                 |
|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| M_DPMC                                    | equ DPMC_ADDR                                                                                                                     | ; HI32 via programmed address :\$6                                                                                                                                                                                 |
| M_DPAR                                    | equ DPAR_ADDR                                                                                                                     | ; HI32 via programmed address :\$8                                                                                                                                                                                 |
| movep<br>movep<br>movep<br>movep<br>movep | <pre>#\$500000, x: M_DCTR #BASE_ADDRESS, x: M_DPMC #\$0, x: M_DPAR #\$0, x: M_DPAR #HIRQDURATION, x: M_DPAR #\$0, x: M_DPAR</pre> | <pre>; enter self configuration mode<br/>; CBMA Data (location \$10)<br/>; dummy write to location \$04<br/>; dummy write to location \$08<br/>; write CLAT (location \$0C)<br/>; write CBMA (location \$10)</pre> |

# 6.4 HOST PORT PINS

| HI32 Port Pin | PCI mode       | Enhanced General Bus Mode                                                                                        | General Bus Mode     | GPIO Mode    |
|---------------|----------------|------------------------------------------------------------------------------------------------------------------|----------------------|--------------|
| HP0           | HAD0           | НАЗ                                                                                                              |                      | HIO0         |
| HP1           | HAD1           | HA4                                                                                                              |                      | HIO1         |
| HP2           | HAD2           | HA5                                                                                                              |                      | HIO2         |
| HP3           | HAD3           | HA6                                                                                                              |                      | HIO3         |
| HP4           | HAD4           | HA7                                                                                                              |                      | HIO4         |
| HP5           | HAD5           | HA8                                                                                                              |                      | HIO5         |
| HP6           | HAD6           | HA9                                                                                                              |                      | HIO6         |
| HP7           | HAD7           | HA10                                                                                                             |                      | HIO7         |
| HP8           | HAD8           | HD0                                                                                                              |                      | HIO8         |
| HP9           | HAD9           | HD1                                                                                                              |                      | HIO9         |
| HP10          | HAD10          | HD2                                                                                                              |                      | HIO10        |
| HP11          | HAD11          | HD3                                                                                                              |                      | HIO11        |
| HP12          | HAD12          | HD4                                                                                                              |                      | HIO12        |
| HP13          | HAD13          | HD5                                                                                                              |                      | HIO13        |
| HP14          | HAD14          | HD6                                                                                                              |                      | HIO14        |
| HP15          | HAD15          | HD7                                                                                                              |                      | HIO15        |
| HP16          | HC0/HBE0       | НАО                                                                                                              |                      | HIO16        |
| HP17          | HC1/HBE1       | HA1                                                                                                              |                      | HIO17        |
| HP18          | HC2/HBE2       | HA2                                                                                                              |                      | HIO18        |
| HP19          | HC3/HBE3       | UNUSED (Must be forced or pulled to Vcc                                                                          | or GND.)             | HIO19        |
| HP20          | HTRDY          | HDBEN                                                                                                            | ,                    | 1020         |
| HP21          | HIRDY          | HDBDR                                                                                                            |                      | 11021        |
| HP22          | HDEVSEL        | HSAK                                                                                                             |                      | 11022        |
| HP23          | HLOCK          | HBS (Schmitt trigger buffer on input - should be for                                                             |                      | HIO23        |
| HP24          | HPAR           | HDAK (Schmitt trigger buffer on input - should be                                                                |                      | disconnecte  |
| HP25          | HPERR          | HDRQ                                                                                                             |                      | disconnected |
| HP26          | HGNT           | HAEN                                                                                                             |                      | disconnecte  |
| HP27          | HREQ           | НТА                                                                                                              |                      | disconnecte  |
| HP28          | HSERR          | HIRQ                                                                                                             |                      | disconnecte  |
| HP29          | HSTOP          | HWR/HRW (Schmitt trigger buffer on input                                                                         | <i>t</i> )           | disconnecte  |
| HP30          | HIDSEL         | HRD/HDS (Schmitt trigger buffer on input)                                                                        |                      | disconnecte  |
| HP31          | HFRAME         | UNUSED (Must be forced or pulled up to                                                                           |                      |              |
| HP32          | HCLK           | UNUSED (Must be forced or pulled up to V                                                                         | ,                    |              |
| HP33          | HAD16          | HD8 (should be pulled to Vcc or GND if no                                                                        |                      | disconnecte  |
| HP34          | HAD17          | HD9 (should be pulled to Vcc or GND if no                                                                        |                      | disconnecte  |
| HP35          | HAD18          | HD10 (should be pulled to Vcc or GND if r                                                                        |                      | disconnecte  |
| HP36          | HAD19          | HD11 (should be pulled to Vcc or GND if r                                                                        | ,                    | disconnecte  |
| HP37          | HAD20          | HD12 (should be pulled to Vcc or GND if r                                                                        | ,                    | disconnecte  |
| HP38          | HAD21          | HD13 (should be pulled to Vcc or GND if r                                                                        |                      | disconnecte  |
| HP39          | HAD22          | HD14 (should be pulled to Vcc or GND if r                                                                        | ,                    | disconnecte  |
| HP40          | HAD23          | HD15 (should be pulled to Vcc or GND if r                                                                        |                      | disconnecte  |
| HP41          | HAD23<br>HAD24 | HD16 <sup>(a)</sup> (should be forced or pulled to Vcc                                                           |                      | disconnecte  |
| HP42          | HAD24<br>HAD25 | $HD17^{(a)}$ (should be forced or pulled to Vcd                                                                  |                      | disconnecte  |
| HP43          | HAD25<br>HAD26 | HD18 <sup>(a)</sup> (should be forced or pulled to Vo                                                            |                      | disconnecte  |
| HP44          | HAD20<br>HAD27 | HD19 <sup>(a)</sup> (should be forced of pulled to Vcc                                                           |                      | disconnecte  |
| HP45          | HAD27<br>HAD28 | HD20 <sup>(a)</sup> (should be forced or pulled to Vcc                                                           |                      | disconnecte  |
| HP46          | HAD28<br>HAD29 | HD20 <sup>(a)</sup> (should be forced or pulled to Vcc<br>HD21 <sup>(a)</sup> (should be forced or pulled to Vcc |                      | disconnecte  |
| HP40<br>HP47  | HAD29<br>HAD30 | HD2 <sup>(a)</sup> (should be forced of pulled to Vcc<br>HD22 <sup>(a)</sup> (should be forced or pulled to Vcc  |                      | disconnecte  |
|               | HAD30<br>HAD31 | HD22 <sup>(a)</sup> (should be forced or pulled to Vcc<br>HD23 <sup>(a)</sup> (should be forced or pulled to Vcc | or GND if not used)  | disconnecte  |
| HP48<br>HP49  |                |                                                                                                                  | or GIND II Hot usea) | aisconnecte  |
| <u>nr49</u>   | HRST           | HRST (Schmitt trigger buffer on input)                                                                           |                      |              |

a. HD23-HD16 Output is high impedance if HRF≠\$0. Input is disconnected if HTF≠\$0.

# Table 6-10. Host Port Pins - Detailed Description (Sheet 1 of 8)

| HI32                       |                                                                                                                                                                                                                                                              | HI32 Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |                                    |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|
| Port<br>Pin <sup>(a)</sup> | PCI                                                                                                                                                                                                                                                          | Enhanced Universal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                    |
|                            | HAD15-HAD0<br>Address/Data Multiplexed Bus<br>Tri-state, bidirectional bus.<br>During the first clock cycle of a<br>transaction HAD31-HAD0<br>contain the physical byte address<br>(32 bits). During subsequent clock<br>cycles, HAD31-HAD0 contain<br>data. | HA10-HA3<br>Address Bus<br>Input pin.<br>This bus selects the HI32 register to be accesse<br>HA10-HA3 select the HI32 and HA2-HA0 select to<br>particular register of the HI32 to be accessed.<br>HD7-HD0<br>Data Bus<br>Tri-state, bidirectional bus.<br>Used to transfer data between the host process<br>and the HI32.<br>This bus is released (disconnected) when the HI<br>is not selected by HA10-HA0. The HD23-HD0 pi<br>are driven by the HI32 during a read access, and a<br>inputs to the HI32 during a write access.<br>HD23-HD16 outputs are high impedance if HRF≠\$ | or<br>32<br>re                     |
| HP18-HP16                  | HC3/HBE3-HC0/HBE0<br>Bus Command/Byte Enables                                                                                                                                                                                                                | HD23-HD16 inputs are disconnected if HTF≠\$0.<br>HA2-HA0<br>Address Bus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | HIO18-HIO16<br>GPIO <sup>(b)</sup> |
|                            | transaction, HC3/HBE3-                                                                                                                                                                                                                                       | Input pin.<br>This bus selects the HI32 register to be accesse<br>HA10-HA3 select the HI32 and HA2-HA0 select th<br>particular register of the HI32 to be accessed.                                                                                                                                                                                                                                                                                                                                                                                                               |                                    |
| HP19                       | command. During the data phase<br>HC3/HBE3-HC0/HBE0 are used<br>as byte enables. The byte<br>enables determine which byte<br>lanes carry meaningful data.                                                                                                    | Must be forced or pulled to Vcc or GND.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | HIO19<br>GPIO <sup>(b)</sup>       |

#### Table 6-10. Host Port Pins - Detailed Description (Sheet 2 of 8)

| HI32                       | HI32 Mode                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                          |                              |      |  |  |  |  |
|----------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|------|--|--|--|--|
| Port<br>Pin <sup>(a)</sup> | PCI                                                                                                                                                                                                                                                                                                                                                                                                                                   | Enhanced Universal                                                                                                                                                                       | Uni-<br>versal               | GPIO |  |  |  |  |
| HP20                       | HTRDY<br>Target Ready                                                                                                                                                                                                                                                                                                                                                                                                                 | HDBEN<br>Host Data Bus Enable                                                                                                                                                            | HIO20<br>GPIO <sup>(b)</sup> |      |  |  |  |  |
|                            | to complete the current data                                                                                                                                                                                                                                                                                                                                                                                                          | Asserted during HI32 accesses.<br>When asserted the external (optional) data<br>transceiver outputs are enabled. When<br>negated the external transceiver outputs are<br>high impedance. |                              |      |  |  |  |  |
| HP21                       | HIRDYInitiator ReadySustained tri-state bidirectionalpin. <sup>(d)</sup> Indicates the initiating agent'sability to complete the currentdata phase of the transaction.HIRDY is used in conjunction withHTRDY. A data phase iscompleted on any clock bothHIRDY and HTRDY are sampledasserted. Wait cycles are inserteduntil both HIRDY and HTRDY areasserted together. The HI32negates HIRDY if it cannotcomplete the next data phase. | HDBDR is driven high on write data transfers<br>and driven low on read data transfers. This pin<br>is normally high.                                                                     |                              |      |  |  |  |  |

#### Table 6-10. Host Port Pins - Detailed Description (Sheet 3 of 8)

| HI32                       | HI32 Mode                                                                                                                              |                                                                                                                                                                                                                                                                                                                                   |                                      |                              |  |  |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|------------------------------|--|--|
| Port<br>Pin <sup>(a)</sup> | PCI                                                                                                                                    | Enhanced Universal                                                                                                                                                                                                                                                                                                                | Uni-<br>versal                       | GPIO                         |  |  |
| HP22                       | HDEVSEL<br>Device Select                                                                                                               | HSAK<br>Host Select Acknowledge                                                                                                                                                                                                                                                                                                   | HIO22<br>GPIO                        |                              |  |  |
|                            | the driving device has decoded its                                                                                                     | Used to acknowledge the host processor that<br>the HI32 has identified its address as a slave.<br>HSAK is asserted when the HI32 is the<br>selected slave; otherwise HSAK is released.                                                                                                                                            |                                      |                              |  |  |
| HP23                       | HLOCK<br>Lock                                                                                                                          | HBS<br>(Bus Strobe)                                                                                                                                                                                                                                                                                                               |                                      | HIO23<br>GPIO <sup>(b)</sup> |  |  |
|                            | operation that may require multiple transactions to complete.                                                                          | Asserted at the start of a bus cycle (for half of a cycle) providing an "early bus start" signal.<br>enables the HI32 to respond (HTA valid) earlier<br>HBS should be forced or pulled up to Vcc if not<br>(e.g. ISA bus).                                                                                                        | . <i>Thi</i> s<br>:                  |                              |  |  |
| HP24                       | and HC3/HBE3-HC0/HBE0. The master drives HPAR during address and write data phases;                                                    | HDAK<br>Host DMA Acknowledge<br>Schmitt trigger input pin.<br>HDAK indicates that the external DMA chan<br>accessing the HI32. The HI32 is selected as a<br>device if HDAK and HWR or HRD (ir<br>double-strobe mode) or HDAK and HDS (i<br>single-strobe mode) are asserted. HDAK show<br>forced or pulled up to Vcc if not used. | DMA<br>the<br>n the                  | Disconnected                 |  |  |
| HP25                       | errors. HPERR must be driven<br>active (by the agent receiving<br>data) two clocks following the<br>data (i.e. one clock following the | Used to support ISA/EISA-type DMA data trans<br>HDRQ is asserted by the HI32 when a DMA re<br>(receive and/or transmit) is generated in the<br>HDRQ is negated when the DMA request sou<br>cleared (HDAK is asserted), masked (by RREC                                                                                            | equest<br>HI32.<br>vrce is<br>2=0 or | Disconnected                 |  |  |

#### Table 6-10. Host Port Pins - Detailed Description (Sheet 4 of 8)

| HI32                       | HI32 Mode                                                                                                 |                                                                                                                                                                                                                                                                                                                     |                                                                        |              |
|----------------------------|-----------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------|--------------|
| Port<br>Pin <sup>(a)</sup> | PCI                                                                                                       | Enhanced Universal Un                                                                                                                                                                                                                                                                                               |                                                                        | GPIO         |
| HP26                       |                                                                                                           | HAEN<br>Host Address Enable<br>Input pin.<br>Enables ISA/EISA DMA / I/O type accesses.<br>When high, the HI32 will respond to DMA cycle<br>(if DMAE=1 in the DCTR, if DMAE=0 the HI3<br>ignore the access).<br>When low, the HI32 responds when it identifi<br>address (i.e. ISA/EISA DMA / I/O type-<br>accesses). | 32 will<br>ies its                                                     | Disconnected |
| HP27                       | HI32 desires use of the bus.<br>HREQ is negated in the same PCI<br>clock that the HI32 asserts<br>HFRAME. |                                                                                                                                                                                                                                                                                                                     | ses a<br>If the<br>host<br>s long<br>pin is<br>nt on<br>ready<br>ready | Disconnected |

#### Table 6-10. Host Port Pins - Detailed Description (Sheet 5 of 8)

| HI32                       | HI32 Mode                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                       |              |  |  |
|----------------------------|-----------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|--------------|--|--|
| Port<br>Pin <sup>(a)</sup> | PCI                               | Enhanced Universal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Uni-<br>versal                                                                                                                        | GPIO         |  |  |
| HP28                       | errors and other errors where the | Used by the HI32 to request service from the processor. HIRQ may be connected to an int request pin of a host processor, a transfer requark DMA controller or a control input of example.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | errupt<br>lest of<br>ternal<br>en an<br>EQ=1)<br>a data<br>HIRQ<br>by the<br>g of a<br>te), or<br>sabled<br>ccess<br>nd the<br>nsfer. | Disconnected |  |  |
| HP29                       |                                   | HWR/HRW<br>Host Write/Read-Write<br>Schmitt trigger input pin.<br>When in the double-strobe mode of the<br>(HDSM=0), this pin functions as host write<br>strobe (HWR). The host processor initiates a<br>access by asserting HWR. Data input is latche<br>the rising edge of HWR.<br>When in the single-strobe mode of the<br>(HDSM=1), this pin functions as host read<br>(HRW) input. It selects the direction of data tra<br>for each host processor access: from the HI32<br>host processor when HRW is asserted and fro<br>host processor to the HI32 when HRW is neg<br>The polarity of the HRW pin is controlled by F<br>bit in the DCTR.<br><b>NOTE</b> : The simultaneous assertion of HRE<br>HWR is illegal. | input<br>write<br>d with<br>HI32<br>H-write<br>ansfer<br>to the<br>gated.<br>HRWP                                                     | Disconnected |  |  |

#### Table 6-10. Host Port Pins - Detailed Description (Sheet 6 of 8)

| HI32                       | HI32 Mode                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                             |      |  |
|----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------|------|--|
| Port<br>Pin <sup>(a)</sup> | PCI                                                                                                                                                                                                                                                                                                                              | Enhanced Universal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Uni-<br>versal                                                                              | GPIO |  |
| HP30                       | upper 21 address lines during                                                                                                                                                                                                                                                                                                    | HRD/HDS<br>Host Read/Data Strobe<br>Schmitt trigger input pin.<br>When in the double-strobe mode of the<br>(HDSM=0), this pin functions as the host read a<br>(HRD). The host processor initiates a read a<br>by asserting HRD. Data output may be latche<br>the rising edge of HRD.<br>When in the single-strobe mode of the<br>(HDSM=1), this pin functions as the host data a<br>(HDS). The host processor initiates a read acce<br>asserting HDS with HRW asserted. Data output<br>be latched with the rising edge of HDS. The<br>processor initiates a write access by asserting<br>with HRW negated. Data input is latched by the<br>with the rising edge of HDS.<br><b>NOTE</b> : The simultaneous assertion of HRE<br>HWR is illegal. | strobe<br>ccess<br>d with<br>HI32<br>strobe<br>ess by<br>t may<br>e host<br>g HDS<br>e HI32 |      |  |
| HP31<br>HP32               | HFRAMECycle FrameSustained tri-state bidirectionalpin. <sup>(d)</sup> Driven By the current master toindicate the beginning andduration of an access. HFRAMEis negated in the final data phaseof the transaction.HCLKBus ClockInput pin.Provides timing for alltransactions on PCI. All other PCIsignals are sampled on the HCLK | UNUSED<br>Must be forced or pulled up to Vcc.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                                                                             |      |  |

#### Table 6-10. Host Port Pins - Detailed Description (Sheet 7 of 8)

| HI32                       | HI32 Mode                                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                             |              |  |  |
|----------------------------|----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------|--------------|--|--|
| Port<br>Pin <sup>(a)</sup> | PCI                                                      | Enhanced Universal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | Uni-<br>versal                                                                                                              | GPIO         |  |  |
| HP40-HP33                  | transaction HAD31-HAD0 contain the physical byte address | HD15-HD8<br>Data Bus<br>Tri-state, bidirectional bus.<br>Used to transfer data between the host proc<br>and the HI32.<br>This bus is released (disconnected) when the<br>is not selected by HA10-HA0. The HD15-HD0<br>are driven by the HI32 during a read access, an<br>inputs to the HI32 during a write access.<br>When operating with a host bus less than 1<br>wide, the HD15-HD8 pins that are not use<br>transferring data must be pulled to Vcc or to<br>For example: when operating with a 8-bit<br>HP40-HP33 must be pulled up to Vcc or pulled<br>to GND.<br><b>NOTE</b> : It is recommended to pull these unused<br>lines to GND, as pulling these lines to Vcc will s<br>corresponding bits in the HCTR, when the ex-<br>host writes to this register.                                                                                                                                       | Disconnected                                                                                                                |              |  |  |
| HP48-HP41                  |                                                          | HD23-HD16<br>Data Bus<br>Tri-state, bidirectional bus.<br>Used to transfer data between the host proc<br>and the HI32.<br>This bus is released (disconnected) when the<br>is not selected by HA10-HA0. The HD23-HD1<br>are driven by the HI32 during a read access, an<br>inputs to the HI32 during a write access.<br>HD23-HD16 outputs are high impedance if HR<br>HD23-HD16 inputs are disconnected if HTF+\$0<br>When operating with a host bus less than 2<br>wide, the data pins that are not used for transf<br>data must be forced or pulled to Vcc or to GN<br>example: when operating with a 16-bit bus (e.,<br>bus), HP48-HP41 must be forced or pulled up<br>or pulled down to GND.<br><b>NOTE</b> : It is recommended to force or pull<br>unused data lines to GND, as forcing or pulling<br>lines to Vcc will set the corresponding bits<br>HCTR, when the external host writes to this res | e HI32<br>6 pins<br>nd are<br>2F≠\$0.<br>0.<br>24 bits<br>ferring<br>D. For<br>g. ISA<br>to Vcc<br>these<br>these<br>in the | Disconnected |  |  |

#### Table 6-10. Host Port Pins - Detailed Description (Sheet 8 of 8)

| HI32                       |                                                                                            | HI32 Mode                                                                                                                                                                                                                                                    |                  |               |
|----------------------------|--------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|---------------|
| Port<br>Pin <sup>(a)</sup> | PCI                                                                                        | Enhanced Universal                                                                                                                                                                                                                                           | Uni-<br>versal   | GPIO          |
| HP49                       | the initial state. All pins are forced to the disconnected state.                          | HRST<br>Hardware Reset<br>Schmitt trigger input pin.<br>Forces the HI32 to its initial state. All pins<br>disconnected state.<br>The polarity of the HRST pin is controlled b<br>DCTR.                                                                       |                  |               |
| HP50                       | request pin of a host processor, a open-drain output.<br>HINTA is asserted by the HI32 who | ).<br>The from the host processor. HINTA may be connected from the host processor. HINTA may be connected as control input of external circuitry, or be used as en HINT, in the DCTR, is set by the DSP56300 re) when HINT, in the DCTR, is cleared by the D | s a ger<br>Core. | neral purpose |

a. This list does not include Vcc and Ground supply pins.

b. The GPIO pin is controlled by the corresponding bits in the GPIO data (DATH) and GPIO direction (DIRH) registers.

c. Open Drain output pin is driven, when asserted, by the HI32. When negated the pin is released (high impedance). This enables using a multi-slave configuration. An external pull-up, must be connected externally for proper operation.

d. Sustained Tri-State is an active low tri-state signal owned and driven by one and only one agent at a time. The agent that drives this pin low must drive it high for at least one clock before letting it float. A new agent cannot start driving a sustained tri-state signal any sooner that one clock after the previous owner tri-states it. A pull-up resistor is required to sustain the inactive state until another agent drives it.

PCI UB Access

\$8 Ş \$10

| CORE<br>Acces<br>s |       | \$5                                                                                | \$6           | \$7                 | \$8                           | \$9                            | \$A                           | \$B                | \$C     | \$D     | \$E       | \$F       |                     |       |          |        |         | \$1           |       |                                   | (1)           | \$8                                             | (3)           | (4)                                                                  |
|--------------------|-------|------------------------------------------------------------------------------------|---------------|---------------------|-------------------------------|--------------------------------|-------------------------------|--------------------|---------|---------|-----------|-----------|---------------------|-------|----------|--------|---------|---------------|-------|-----------------------------------|---------------|-------------------------------------------------|---------------|----------------------------------------------------------------------|
| NAME A             |       | DCTR                                                                               | DPCR          | DPMC                | DPAR                          | DSR                            | DPSR                          | DTXM               | DTXS    | DRXR    | DIRH      | DATH      |                     |       | HCTR     | HSTR   | HCVR    | HTXR/<br>HRXS |       | CDID<br>CVID                      | CSTR/<br>CCMR | cccR<br>/<br>CRID                               | CHTY/<br>CLAT | CBMA                                                                 |
| <                  | 0     | HCIE [                                                                             | T             | AR16 D              | AR0 [                         | НСР                            | SMM                           | DO                 | DO      | DO      | DIO       | DA0       | ]                   | 0     | 4        | TRDY H | HC<br>H | 9<br>2 4      | 0     | 4                                 | 0             |                                                 | 0             | 0                                                                    |
|                    | 1     | STIE                                                                               | MTIE          | AR17 /              | AR1                           | STRQ                           | MTRQ                          | D1                 | D1      | D1      | DI1       | DA1       |                     | +     | TREQ     | нтка 1 | ОЛН     | D1            | 1     | 1                                 | MSE           | tion 6                                          | 0             | 0                                                                    |
|                    | 2     | SRIE                                                                               | MRIE          | AR18 /              | AR2                           | SRRQ S                         | MRR<br>Q                      | D2                 | D2      | D2      | DI2       | DA2       |                     | 2     | RREQ 1   | HRRQ H | HV1     | D3            | 2     | 1                                 | BM            | Sec                                             | 0             | 0                                                                    |
|                    | e     | HF3                                                                                | -             | AR19                | AR3                           | HF0 S                          | -                             | D3                 | D3      | D3      | DI3       | DA3       |                     | 3     | HF0 F    | HF3 H  | HV2     | D3            | ę     | 0                                 | 0             | (see                                            | 0             | 0                                                                    |
|                    | 4     | HF4                                                                                | MAIE          | AR20                | AR4                           | HF1                            | WARQ                          | D4                 | D4      | D4      | DI4       | DA4       | 1                   | 4     | HF1      | HF4    | HV3     | D4            | 4     | 1                                 | 0             | Via Programmable (see Section 6.8)              | 0             | 0                                                                    |
|                    | 5     | HF5                                                                                | PEIE          | AR21                | AR5                           | HF2                            | APER MARQ                     | D5                 | D5      | D5      | DI5       | DA5       |                     | 5     | HF2      | HF5    | HV4     | D5            | 5     | 0                                 | 0             | ramn                                            | 0             | 0                                                                    |
|                    | 9     | HINT                                                                               |               | AR22                | AR6                           |                                | DPER                          | D6                 | D6      | D6      | DIG       | DA6       |                     | 9     | DMAE     | INIH   | HV5     | D6            | 9     | 1                                 | PERR          | Prog                                            | 0             | 0                                                                    |
|                    | ~     |                                                                                    | TAIE          | AR23                | AR7                           |                                | MAB                           | D7                 | D7      | D7      | DI7       | DA7       |                     | ~     | SFT      | HREQ   | HV6     | D7            | 7     | 0                                 | 0             | Via                                             | 0             | 0                                                                    |
|                    | 8     |                                                                                    |               | AR24                | AR8                           |                                | TAB                           | D8                 | D8      | D8      | D18       | DA8       |                     | 8     | НТF0     |        |         | D8            | 8     | 0                                 | SERE          |                                                 | ΓΤΟ           | 0                                                                    |
|                    | 6     |                                                                                    | TTIE          | AR25                | AR9                           |                                | , TDIS                        | D9                 | D6      | D6      | D19       | DA9       |                     | 6     | НТF1     |        |         | 60            | 6     | 0                                 | 0             | -                                               | 111           | 0                                                                    |
|                    | 10    |                                                                                    |               | 7 AR26              | AR15 AR14 AR13 AR12 AR11 AR10 |                                | ΤRTY                          | D10                | D10     | D10     | D110      | I DA10    |                     | 10    | 0        |        |         | D10           | 10    | 0                                 |               |                                                 | Г12           | 0                                                                    |
|                    | 11    |                                                                                    | lu            | AR28 AR27           | 2 AR11                        |                                | с то                          | D11                | D11     | D11     | E DI11    | 2 DA11    |                     | 11    | 1 HRF0   |        |         | D11           | 11    | 0                                 |               | -                                               | 173           | 0                                                                    |
|                    | 12    | (0)                                                                                | TCIE          | 9 AR2               | 3 AR1:                        |                                | НДТС                          | 3 D12              | 3 D12   | 3 D12   | 3 DI12    | 3 DA12    |                     | 12    | HRF1     |        |         | 3 D12         | 12    | 1                                 |               |                                                 | 5 LT4         | 0                                                                    |
|                    | 1 13  | N HDS                                                                              | ۲             | AR30 AR29           | 14 AR1                        |                                |                               | 4 D13              | 4 D13   | 4 D13   | 4 DI13    | 14 DA 13  |                     | 1 13  | 0        |        |         | 4 D13         | 1 13  | 0                                 |               | -                                               | 5 LT5         | 0                                                                    |
|                    | 15 14 | <sub>4</sub> P P                                                                   | T CLRT        | 31 AR3              | 15 AR1                        |                                |                               | 5 D14              | 5 D14   | 5 D14   | 15 D114   | 15 DA14   |                     | 5 14  | HS0      |        | IW      | 5 D14         | 5 14  | 0                                 |               | -89)                                            | 7 176         | 0                                                                    |
|                    | 16 1  | RP HTAP                                                                            | SERF MTT      | BLO AR31            | CO AR                         |                                | S                             | D16 D15            | D16 D15 | D16 D15 | DI16 DI15 | DA16 DA15 | -                   | 16 15 | HS2 HS1  |        | IMNH    | D16 D15       | 16 15 | 0                                 |               | age 6                                           | 0 117         | 116 0<br>33 0                                                        |
|                    | 17 1  | HIRH HRSP HDRP                                                                     | SE            | BL1 BI              | C1 C                          |                                | C1 RD                         | D17 D              | D17 D   | D17 D   | DI17 DI   | DA17 DA   |                     | 17 1  | H        |        |         | D17 D         | 17 1  |                                   |               | on pi                                           | 0             | 117 PM16<br>B4 GB3                                                   |
|                    | 18 1  | RH HF                                                                              | MACE          | BL2 B               | 3                             |                                | DC2 RD                        | D18 D              | D18 D   | D18 D   | DI18 DI   | DA18 D/   |                     | 18    |          |        |         | D18 D         | 18    | -                                 |               | 0.8                                             | 0             | <i>A</i> 18 PN<br>B5 G                                               |
|                    | 19    | HIRD H                                                                             | MWS<br>D<br>D | BL3 E               | 3<br>3                        |                                | RDC5 RDC4 RDC3 RDC2 RDC1 RDC0 | D19 [              | D19 [   | D19 [   | DI19 D    | DA19 D.   |                     | 19    | TWS<br>D |        |         | D19 [         | 19    | on page 6-89)                     |               | Via Programmable (see Section 6.8 on page 6-89) | 0             | M19 PI<br>3B6 G                                                      |
|                    | 20    | HMO H                                                                              | RBLE N        | BL4 I               | BEO                           |                                | DC4 R                         | D20 I              | D20 I   | D20 I   | DI20 I    | DA20 D    |                     | 20    | 1        |        |         | D20 I         | 20    | oage                              |               | ee Se                                           | 0             | M20 P<br>GB7 (                                                       |
|                    | 21    | HM1                                                                                | IAE F         | BL5                 | BE1                           |                                | RDC5 F                        | D21                | D2 1    | D2 1    | DI21      | DA21      |                     | 21    |          |        |         | D2 1          | 21    |                                   |               | le (s                                           | 0             | PM21 F<br>GB8                                                        |
|                    | 22    | HM2                                                                                |               | FC0                 | <u>BE2</u>                    |                                | -                             | D22                | D22     | D22     | DI22      |           | 1                   | 22    |          |        |         | D22           | 52    | Via Programmable (see Section 6.8 |               | nmab                                            | 0             | PM22  <br>GB9                                                        |
|                    | 23    |                                                                                    |               | FC1                 | <u>BE3</u>                    | HACT                           |                               | D23                | D23     | D23     | DI23      | DA23 DA22 |                     | 23    |          |        |         | D23           | 23    | Sectic                            | <del>.</del>  | ogran                                           | 0             | PM23<br>GB10                                                         |
|                    | •     |                                                                                    |               |                     |                               |                                |                               |                    |         |         |           |           | -                   | 24    |          |        |         | D24           | 24    | see S                             | DPR           | a Pro                                           | 0             | PM24                                                                 |
|                    |       | DPAR                                                                               |               |                     |                               |                                |                               |                    |         |         |           |           |                     | 25    |          |        |         | D25           | 25    | ble (                             | <u> </u>      | 5                                               | 0             | PM25                                                                 |
|                    |       | ethen <sup>th</sup><br>register                                                    |               |                     |                               | 970                            |                               |                    |         |         |           |           |                     | 26    |          |        |         | D26           | 26    | mma                               | 0             | -                                               | 0             | 7 PM26                                                               |
| sters              |       | n mode<br>ses this                                                                 |               |                     |                               | ed to ze                       |                               |                    |         |         |           |           | sters               | 27    |          |        |         | D27           | 27    | rogra                             | STA           | -                                               | 0             | 3 PM27                                                               |
| Regi               |       | figuratic<br>e acces.                                                              |               | to zero             |                               | hardwii                        |                               | to one             |         |         |           |           | Regi                | 28    |          |        |         | ) D28         | 28    | lia Pl                            | A RTA         |                                                 | 0             | 9 PM2                                                                |
| ide l              |       | in Self Configuration mode then <sup>th</sup> DPAR<br>write accesses this register |               | = hardwired to zero |                               | = reserved - hardwired to zero |                               | = hardwired to one |         |         |           |           | ide F               | 29    |          |        |         | 0 D29         | 29    | ~                                 | E RMA         | -                                               | 0             | 30 PM2                                                               |
| DSP Side Registers |       |                                                                                    |               |                     |                               | = res                          |                               | = haı              |         |         |           |           | Host Side Registers | 30    |          |        |         | 1 D30         | 30    |                                   | E SSE         | -                                               | 0             | PM31 PM30 PM29 PM28 PM27 PM26 PM25 PM24 GB10 GB9 GB8 GB7 GB6 GB5 GB4 |
| D                  |       | (u)                                                                                |               | 0                   |                               |                                |                               | 1                  |         |         |           |           | Р                   | 31    |          |        |         | D31           | 31    |                                   | DPE           |                                                 | 0             | PMS                                                                  |

HI32 CONTROL, STATUS AND CONFIGURATION REGISTERS 6.5

# 6.6 HI32 PROGRAMMING MODEL - QUICK REFERENCE

|      |       |         | HI32 Registe                             | ers - (                         | Quick Reference (Sheet 1 of a                                                                                             | 5)                                                                           |     |        |    |
|------|-------|---------|------------------------------------------|---------------------------------|---------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------|-----|--------|----|
|      |       |         | Bit                                      |                                 |                                                                                                                           |                                                                              | Res | et Typ | е  |
| Reg  | Num   | Mnem.   | Name                                     | Val                             | Function                                                                                                                  | Comments                                                                     | HS  | PH     | PS |
|      |       |         |                                          |                                 | DSP SIDE                                                                                                                  |                                                                              |     |        |    |
|      | 0     | HCIE    | Host Command Interrupt Enable            | 0<br>1                          | HCP interrupt disabled<br>HCP interrupt enabled                                                                           |                                                                              | 0   | -      | -  |
|      | 1     | STIE    | Slave Transmit Interrupt Enable          | 0<br>1                          | STRQ interrupt disabled<br>STRQ interrupt enabled                                                                         |                                                                              | 0   | -      | -  |
|      | 2     | SRIE    | Slave Receive Interrupt Enable           | 0<br>1                          | SRRQ interrupt disabled<br>SRRQ interrupt enabled                                                                         |                                                                              | 0   | -      | -  |
|      | 5-3   | HF5-HF3 | Host Flags                               |                                 |                                                                                                                           |                                                                              | \$0 | -      | -  |
|      | 6     | HINT    | Host Interrupt A                         | 0<br>1                          | HINTA pin is high impedance<br>HINTA pin is driven low                                                                    |                                                                              | 0   |        |    |
|      | 13    | HDSM    | Host Data Strobe Mode                    | 0<br>1                          | $\overrightarrow{HWR}$ + $\overrightarrow{HRD}$ (double data strobe)<br>HRW + $\overrightarrow{HDS}$ (single data strobe) | may be changed only in PS reset                                              | 0   | -      | -  |
|      | 14    | HRWP    | Host RD/WR Polarity                      | 0<br>1                          | HRW (0=WRITE, 1=READ)<br>HRW(0=READ, 1=WRITE)                                                                             | may be changed only in PS reset                                              | 0   | -      | -  |
|      | 15    | НТАР    | Host Transfer Acknowledge<br>Polarity    | 0<br>1                          | HTA<br>HTA                                                                                                                | may be changed only in PS reset                                              | 0   | -      | -  |
| DCTR | 16    | HDRP    | Host DMA Request Polarity                | 0<br>1                          | HDRQ<br>HDRQ                                                                                                              | may be changed only in PS reset                                              | 0   | -      | -  |
|      | 17    | HRSP    | Host Reset Polarity                      | 0<br>1                          | HRST<br>HRST                                                                                                              | may be changed only in PS reset                                              | 0   | -      | -  |
|      | 18    | HIRH    | Host Interrupt Request<br>Handshake Mode | 0<br>1                          | HIRQ pulsed<br>HIRQ - full handshake                                                                                      | may be changed only in PS<br>reset<br>HIRQ pulse width is<br>defined by CLAT | 0   | -      | -  |
|      | 19    | HIRD    | Host Interrupt Request Drive<br>Control  | 0<br>1                          | HIRQ - open drain<br>HIRQ - driven                                                                                        | may be changed only in PS reset                                              | 0   | -      | -  |
|      | 22-20 | HM2-HM0 | HI32 Mode                                | 001<br>010<br>011<br>100<br>101 | Terminate and Reset<br>PCI<br>GenBus<br>Enhanced GenBus<br>GPIO<br>Self Configuration<br>Reserved                         | may be changed to<br>non-zero value only in PS<br>reset                      | \$0 | -      | -  |

|      |       |           | Bit                                   |          | Quick Reference (Sheet 2 of S                                                                                  | ,                                             | Poor   | et Typ |   |
|------|-------|-----------|---------------------------------------|----------|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------|--------|--------|---|
| Reg  | Num   | Mnem.     | Name                                  | Val      | Function                                                                                                       | Comments                                      | HS     | PH     | 1 |
|      |       | MTIE      | Master Transmit Interrupt Enable      | 0<br>1   | MTRQ interrupt disabled<br>MTRQ interrupt enabled                                                              |                                               | 0      | -      | - |
|      | 2     | MRIE      | Master Receive Interrupt Enable       | 0<br>1   | MRRQ interrupt disabled<br>MRRQ interrupt enabled                                                              |                                               | 0      | -      | - |
|      | 4     | MAIE      | Master Address Interrupt Enable       | 0<br>1   | A/DPER interrupt disabled<br>A/DPER interrupt enabled                                                          |                                               | 0      | -      | - |
|      | 5     | PEIE      | Parity Error Interrupt Enable         | 0<br>1   | MARQ interrupt disabled<br>MARQ interrupt enabled                                                              |                                               | 0      | -      | - |
|      | 7     | TAIE      | Transaction Abort Interrupt<br>Enable | 0<br>1   | M/TAB interrupt disabled<br>M/TAB interrupt enabled                                                            |                                               | 0      | -      | - |
|      | 9     | TTIE      | Transaction Termination Int. En.      | 0<br>1   | TO/DIS/RTY interrupt disabled<br>TO/DIS/RTY interrupt enabled                                                  |                                               | 0      | -      | - |
|      | 12    | TCIE      | Transfer Complete Interrupt<br>Enable | 0<br>1   | HDTC interrupt disabled<br>HDTC interrupt enabled                                                              |                                               | 0      | -      | - |
| DPCR | 14    | CLRT      | Clear Transmitter                     | 0<br>1   | inactive<br>empty master transmitter path                                                                      | may be set only if MARQ=1 cleared by hardware | 0      | -      | - |
|      | 15    | МТТ       | Master Transfer Terminate             | 0<br>1   | inactive<br>terminate current PCI transaction                                                                  | may be set only if MWS=1 cleared by hardware  | 0      | -      | - |
|      | 16    | SERF      | HSERR Force                           | 0<br>1   | inactive<br>generate a PCI system error                                                                        | cleared by hardware                           | 0      | -      | - |
|      | 18    | MACE      | Master Access Counter Enable          | 0<br>1   | unlimited burst lengh<br>burst length is limited by the BL<br>value                                            |                                               | 0      | -      | - |
|      | 19    | MWSD      | Master Wait State Disable             | 0<br>1   | HI32 master inserts wait states<br>HI32 master releases bus                                                    | may be set only if MARQ=1                     | 0      | -      | - |
|      | 20    | RBLE      | Receive Buffer Lock Enable            | 0<br>1   | HI32 responds to new accesses<br>HI32 retries accesses after write<br>accesses                                 | may be changed only in PS reset               | 0      | -      | - |
|      | 21    | IAE       | Insert Address Enable                 | 0<br>1   | HI32 does not insert address<br>HI32 inserts address in incoming<br>data                                       | may be changed only in PS reset               | 0      | -      | - |
|      | 15-0  | AR31-AR16 | DSP PCI Transaction Address<br>(High) |          |                                                                                                                | may be written only if<br>MARQ=1              | \$0000 | -      | - |
|      | 21-16 | BL5-BL0   | PCI Data Burst Length                 |          |                                                                                                                | may be written only if<br>MARQ=1              | \$0    | -      | - |
| DPMC | 23-22 | FC1-FC0   | Data Transfer Format Control          | 01<br>10 | TransmitReceive32 bit mode32 bit mode3 Right, zero ext.3 LSBs3 Right, sign ext.3 LSBs3 Left, zero filled3 MSBs | may be written only if<br>MARQ=1              | \$0    | -      | - |
|      | 15-0  | AR15-AR0  | DSP PCI Transaction<br>Address (Low)  |          |                                                                                                                | may be written only if<br>MARQ=1              | \$0000 | -      | - |
| DPAR | 19-16 | C3-C0     | PCI Bus Command                       |          |                                                                                                                | may be written only if<br>MARQ=1              | \$0    | -      | - |
|      | 23-20 | BE3-BE0   | PCI Byte Enables                      |          |                                                                                                                | may be written only if<br>MARQ=1              | \$0    | -      | - |

|      |       |                | Bit                             |            |                                                                                                                                               |                                                                                                             | Res              | et Typ | e |
|------|-------|----------------|---------------------------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|------------------|--------|---|
| Reg  | Num   | Mnem.          | Name                            | Val        | Function                                                                                                                                      | Comments                                                                                                    | HS               | PH     |   |
|      | 0     | HCP            | Host Command Pending            | 0<br>1     | no host command pending<br>host command pending                                                                                               | cleared when the HC<br>interrupt request is serviced                                                        | -                | -      |   |
|      | 1     | STRQ           | Slave Transmit Data Request     | 1<br>0     | slave transmit FIFO is not full<br>slave transmit FIFO is full                                                                                | cleared if the DTXS is filled<br>by Core writes                                                             | 1 <sup>(a)</sup> | -      | 1 |
| DSR  | 2     | SRRQ           | Slave Receive Data Request      | 0<br>1     | slave receive FIFO is empty<br>slave receive FIFO is not empty                                                                                | cleared if the DRXR is<br>emptied by Core reads; or<br>the data to be read from the<br>DRXR is master data. | 0                | -      |   |
|      | 5-3   | HF2-HF0        | Host Flags                      |            |                                                                                                                                               |                                                                                                             | -                | \$0    |   |
|      | 23    | HACT           | HI32 Active                     | 0<br>1     | HI32 is in persnal reset (PS)<br>HI32 is active                                                                                               |                                                                                                             | 0                | -      |   |
|      | 0     | MWS            | PCI Master Wait States          | 0<br>1     | HI32 is asserting HIRDY<br>HI32 is negating HIRDY                                                                                             |                                                                                                             | 0                | -      |   |
|      | 1     | MTRQ           | PCI Master Transmit Data Req.   | 1<br>0     | master transmit FIFO is not full<br>master transmit FIFO is full                                                                              | cleared if the DTXM is filled<br>by Core writes                                                             | 1 <sup>(a)</sup> | -      | 1 |
|      | 2     | MRRQ           | PCI Master<br>Receive Data Req. | 0<br>1     | master receive FIFO is empty<br>master receive FIFO is not empty                                                                              | cleared if the DRXR is<br>emptied by Core reads; or<br>the data to be read from the<br>DRXR is slave data.  | 0                | -      |   |
|      | 4     | MARQ           | PCI Master Address Request      | 1<br>0     | Core may initiate new transaction<br>Core may not initiate new<br>transaction                                                                 |                                                                                                             | 0                | 0      |   |
|      | 5     | APER           | PCI Address Parity Error        | 0<br>1     | HI32 target has not detected an<br>address parity error<br>HI32 target has detected an address<br>parity error                                | cleared by writing 1                                                                                        | 0                | -      |   |
| 0000 | 6     | DPER           | PCI Data Parity Error           | 0<br>1     | a data parity error has not occurred<br>a data parity error has occurred                                                                      | cleared by writing 1                                                                                        | 0                | -      |   |
| DPSR | 7     | MAB            | PCI Master Abort                | 0<br>1     | a master abort has not occurred<br>a master abort has occurred                                                                                | cleared by writing 1                                                                                        | 0                | -      |   |
|      | 8     | TAB            | PCI Target Abort                | 0<br>1     | a target abort has not occurred<br>a target abort has occurred                                                                                | cleared by writing 1                                                                                        | 0                | -      |   |
|      | 9     | TDIS           | PCI Target Disconnect           | 0<br>1     | a target disconnect has not occurred<br>a target disconnect has occurred                                                                      | cleared by writing 1                                                                                        | 0                | -      |   |
|      | 10    | TRTY           | PCI Target Retry                | 0<br>1     | a target retry has not occurred<br>a target retry has occurred                                                                                | cleared by writing 1                                                                                        | 0                | -      |   |
|      | 11    | то             | PCI Time Out Termination        | 0<br>1     | a time-out termination has not<br>occurred<br>a time-out termination has occurred                                                             | cleared by writing 1                                                                                        | 0                | -      |   |
|      | 12    | HDTC           | PCI Host Data Transfer Complete | 0<br>1     | HI32 is transfering data to the Core<br>HI32 has completed transfer of data<br>to the Core, and will disconnect<br>write accesses to the HTXR | cleared by writing 1<br>may be written 1 only if<br>HDTC=1                                                  | 0                | -      |   |
|      | 21-16 | RDC5-RDC<br>0  | Remaining Data Count            |            |                                                                                                                                               |                                                                                                             | -                | -      |   |
| DRXR | 23-0  |                | DSP Receive Data FIFO           |            |                                                                                                                                               |                                                                                                             | e                | mpty   |   |
| DTXM | 23-0  |                | DSP Master Transmit Data FIFO   |            |                                                                                                                                               |                                                                                                             | e                | mpty   | - |
| DTXS | 23-0  |                | DSP Slave<br>Transmit Data FIFO |            |                                                                                                                                               |                                                                                                             | ei               | mpty   |   |
| DATH | 23-0  | DAT23-DAT<br>0 | GPIO Pin Data                   |            |                                                                                                                                               |                                                                                                             | \$0000<br>00     | -      |   |
| DIRH | 23-0  | DIR23-DIR0     | GPIO Pin Direction              | [0]<br>[1] | Input<br>Output                                                                                                                               |                                                                                                             | \$0000<br>00     | -      |   |

|      |       |            | Bit                                   |                      |                                                                                                                                    |                                                                  | Res | et Typ               | e |
|------|-------|------------|---------------------------------------|----------------------|------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|-----|----------------------|---|
| Reg  | Num   | Mnem.      | Name                                  | Val                  | Function                                                                                                                           | Comments                                                         | HS  | PH                   | 1 |
|      |       |            |                                       |                      | Host Side                                                                                                                          |                                                                  |     |                      |   |
|      | 1     | TREQ       | Transmit Request<br>Enable            | 0<br>1               | HTRQ interrupt disabled<br>HTRQ interrupt enabled                                                                                  |                                                                  | -   | 0                    |   |
|      | 2     | RREQ       | Receive Request Enable                | 0<br>1               | HRRQ interrupt disabled<br>HRRQ interrupt enabled                                                                                  |                                                                  | -   | 0                    |   |
|      | 5-3   | HF2-HF0    | Host Flags                            |                      |                                                                                                                                    |                                                                  | -   | 0                    |   |
|      | 6     | DMAE       | DMA Enable (ISA/EISA)                 | 0<br>1               | HI32 does not support DMA<br>transfers<br>HI32 supports ISA-DMA type<br>transfers                                                  |                                                                  | -   | 0                    |   |
|      | 7     | SFT        | Slave Fetch Type                      | 0<br>1               | Pre-fetch<br>Fetch                                                                                                                 |                                                                  | -   | 0                    |   |
| HCTR | 9-8   | HTF1-HTF0  | Host Transmit Data Transfer<br>Format | 00<br>01<br>10<br>11 | PCI UB<br>32 bit mode 24 bit mode<br>3 LSBs 2 Right, zero<br>ext.<br>3 LSBs 2 Right, sign<br>ext.<br>3 MSbs 2 Left, zero<br>filled |                                                                  | -   | \$0                  |   |
|      | 12-11 | HRF1-HRF0  | Host Receive Data Transfer<br>Format  | 01                   | PCI UB<br>32 bit mode 24 bit mode<br>3 Right, zero ext. 2 LSBs<br>3 Right, sign ext. 2 LSBs<br>3 Left, zero filled 2 midlle bytes  |                                                                  | -   | \$0                  |   |
|      | 16-14 | HS2-HS0    | Host Semaphores                       |                      |                                                                                                                                    |                                                                  | -   | 0                    |   |
|      | 19    | TWSD       | Target Wait State Disable             | 0<br>1               | HI32 target will insert up to 8 w.s.<br>HI32 target will not insert wait states                                                    |                                                                  | -   | 0                    |   |
|      | 0     | TRDY       | Transmitter Ready                     | 1<br>0               | transmit FIF O (6 deep) is empty<br>transmit FIFO is not empty                                                                     |                                                                  | 1   | -                    |   |
|      | 1     | HTRQ       | Host Transmit Data Request            | 1<br>0               | host transmit FIFO is not full<br>host transmit FIFO is full                                                                       |                                                                  | 1   | -                    |   |
| HSTR | 2     | HRRQ       | Host Receive Data Request             | 0<br>1               | host receive FIFO is empty<br>host receive FIFO is not empty                                                                       |                                                                  | 0   | -                    |   |
|      | 5-3   | HF5-HF3    | Host Flags                            |                      |                                                                                                                                    |                                                                  | 0   | -                    |   |
|      | 6     | HINT       | Host Interrupt A                      | 0<br>1               | HINTA pin is high impedance<br>HINTA pin is driven low                                                                             |                                                                  | 0   | -                    |   |
|      | 7     | HREQ       | Host Request                          | 0<br>1               | HIRQ pin is negated<br>HIRQ pin is asserted (if enabled)                                                                           |                                                                  | -   | 0                    |   |
|      | 0     | НС         | Host Command                          | 0<br>1               | no host command pending<br>host command pending                                                                                    | cleared when the HC<br>interrupt request is serviced             | -   | -                    |   |
| HCVR | 7-1   | HV6-HV0    | Host Command Vector                   |                      |                                                                                                                                    | default vector via<br>programmable<br>(Section 6.8 on page 6-89) | -   | defau<br>t<br>vector |   |
|      | 15    | HNMI       | Host Non Maskable Int. Req.           |                      | a maskable interrupt request<br>a non-maskable interrupt request                                                                   |                                                                  | -   | 0                    |   |
| HRXM | 31-0  |            | Host Master Receive Data FIFO         |                      |                                                                                                                                    |                                                                  | е   | mpty                 |   |
| HRXS | 31-0  |            | Host Slave Receive Data FIFO          |                      |                                                                                                                                    |                                                                  | e   | mpty                 |   |
| HTXR | 31-0  |            | Host Transmit Data FIFO               |                      |                                                                                                                                    |                                                                  | е   | mpty                 |   |
| CVID | 15-0  | VID15-VID0 | Vendor ID                             | \$105<br>7           |                                                                                                                                    | hardwired \$1057                                                 | -   | -                    | Γ |
| CDID | 31-16 | DID15-DID0 | Device ID                             |                      |                                                                                                                                    | via programmable<br>(Section 6.8 on page 6-89)                   | -   | -                    | Ī |

|        |       |           | Bit                          |        |                                                                                                             |                            | Res | et Typ     | е |
|--------|-------|-----------|------------------------------|--------|-------------------------------------------------------------------------------------------------------------|----------------------------|-----|------------|---|
| Reg    | Num   | Mnem.     | Name                         | Val    | Function                                                                                                    | Comments                   | HS  | PH         | - |
|        | 1     | MSE       | Memory Space Enable          | 0<br>1 | memory space response is disabled<br>memory space response is enabled                                       |                            | -   | 0          |   |
|        | 2     | BM        | Bus Master Enable            | 0<br>1 | HI32 PCI bus master disabled<br>HI32 PCI bus master enabled                                                 |                            | -   | 0          |   |
|        | 6     | PERR      | Parity Error Response        | 0<br>1 | HI32 does not drive HPERR<br>HI32 drives HPERR if a parity error<br>is detected                             |                            | -   | 0          |   |
|        | 7     | WCC       | Wait Cycle Control           | 0      | HI32 never executes address stepping                                                                        | hardwired 0                | -   | -          |   |
|        | 8     | SERE      | System Error Enable          | 0<br>1 | HI32 does not drive HSERR<br>HI32 may drive HSERR                                                           |                            | -   | 0          |   |
|        | 23    | FBBC      | Fast Back-to-Back Capable    | 1      | HI32 supports fast back-to-back transactions as a target                                                    | hardwired 1                | -   | -          |   |
| CCMR   | 24    | DPR       | Data Parity Reported         | 0<br>1 | no parity error detected<br>HI32 master parity error detected or<br>HPERR asserted                          | cleared by writing 1       | -   | 0          |   |
|        | 26-25 | DST1-DST0 | DEVSEL Timing                | 01     | medium DEVSEL timing                                                                                        | hardwired 01               | -   | -          | 1 |
|        | 27    | STA       | Signaled Target Abort        | 0<br>1 | HI32 has not generated a<br>target-abort event<br>HI32 target, generated a<br>target-abort event            | cleared by writing 1       | -   | 0          | - |
|        | 28    | RTA       | Received Target Abort        | 0<br>1 | HI32 has not received a target-abort<br>event<br>HI32 master, received a target-abort<br>event              | cleared by writing 1       | -   | 0          |   |
|        | 29    | RMA       | Received Master Abort        | 0<br>1 | HI32 has not received a<br>master-abort event<br>HI32 master, terminates a<br>transaction with master-abort | cleared by writing 1       | -   | 0          | _ |
|        | 30    | SSE       | Signaled System Error        | 0<br>1 | HI32 not asserted HSERR<br>HI32 asserted HSERR                                                              | cleared by writing 1       | -   | 0          |   |
|        | 31    | DPE       | Detected Parity Error        | 0<br>1 | no parity error detected parity error detected                                                              | cleared by writing 1       | -   | 0          |   |
|        | 7-0   | RID7-RID0 | Revision ID                  |        |                                                                                                             |                            | -   | -          |   |
| CRID   | 15-8  | PI7-PI0   | PCI Device Program Interface |        |                                                                                                             | via programmable           | -   | -          |   |
| CCCR   | 23-16 | SC7-SC0   | PCI Device Sub-Class         |        |                                                                                                             | (Section 6.8 on page 6-89) | -   | -          | Ī |
|        | 31-24 | BC7-BC0   | PCI Device Base Class        |        |                                                                                                             |                            | -   | -          | Ī |
| CLAT   | 15-8  | LT7-LT0   | Latency Timer                |        |                                                                                                             |                            | -   | \$00       |   |
| CHTY   | 23-16 | HT7-HT0   | Header Type                  | \$0    |                                                                                                             | hardwired \$0              | -   | -          |   |
|        | 0     | MSI       | Memory Space Indicator       | 0      | HI32 is a memory mapped agent                                                                               | hardwired 0                | -   | -          |   |
|        | 2-1   | MS1-MS0   | Memory Space                 | \$0    | 32 bits wide and mapping can be done anywhere                                                               | hardwired \$0              | -   | -          |   |
| СВМА   | 3     | PF        | Prefetch                     | 0      | HI32 data is not pre-fetchable (in the PCI sense)                                                           | hardwired 0                | -   | -          |   |
| JUIVIA | 15-4  | PM15-PM4  | Memory Base Address Low      | \$00   | 64Kbytes occupancy of PCI memory space                                                                      | hardwired \$00             | -   | -          |   |
|        | 31-16 | PM31-PM16 | Memory Base Address High     |        |                                                                                                             |                            | -   | \$000<br>0 | 1 |
|        | 23-15 | GB10-GB3  | Genbus Base Address          |        |                                                                                                             |                            | -   | \$00       |   |
|        | 7-0   | IP-7-IP0  | Interrupt Pin                |        | PCI interrupt line routing information                                                                      |                            |     |            |   |
|        | 15-8  | IL7-IL0   | Interrupt Line               | \$01   | INTA is supported                                                                                           | hardwired \$01             |     |            |   |
| CILP   | 23-16 | MG7-MG0   | MAX_GNT                      | \$00   | Min Grant                                                                                                   | hardwired \$00             |     |            |   |
|        | 31-24 | ML7-ML0   | MAX_LAT                      | \$00   | Max Latency                                                                                                 | hardwired \$00             |     |            |   |

a. STRQ. MTRQ are zero in the personal software reset state.

# 6.7 INTERRUPT VECTORS

| Vector / 2                | Interrupt                   | Activated by          | Priority |
|---------------------------|-----------------------------|-----------------------|----------|
| Via Programmable          | Host Command (default)      | HC (HCVR)             | Highest  |
| Via Programmable Base     | PCI Transaction Termination | TO, TRTY, TDIS (DPSR) | ٨        |
| Via Programmable Base + 1 | PCI Transaction Abort       | TAB, MAB (DPSR)       | ΖΔ       |
| Via Programmable Base + 2 | PCI Parity Error            | DPER, APER (DPSR)     |          |
| Via Programmable Base + 3 | PCI Transfer Complete       | HDTC (DPSR)           |          |
| Via Programmable Base + 4 | PCI Master Receive          | MRRQ (DPSR)           |          |
| Via Programmable Base + 5 | Slave Receive               | SRRQ (DSR)            |          |
| Via Programmable Base + 6 | PCI Master Transmit         | MTRQ (DPSR)           |          |
| Via Programmable Base + 7 | Slave Transmit              | STRQ (DSR)            | L        |
| Via Programmable Base + 8 | PCI Master Address          | MARQ (DPSR)           | Lowest   |

#### Table 6-11. Interrupt Vectors

# 6.8 VIA PROGRAMMING

Below is a table of the DSP56301 via-programmable registers:

| Register | Bits         | Value    | Meaning                                                                                                                       |
|----------|--------------|----------|-------------------------------------------------------------------------------------------------------------------------------|
| CDID     | CDID15-CDID0 | \$1801   | DSP56301                                                                                                                      |
| CCCR     | CCCR23-CCCR0 | \$048000 | <ul><li>\$04: (Multimedia Device)</li><li>\$80: (Other Multimedia Device)</li><li>\$00: (Default Program Interface)</li></ul> |
| CRID     | CRID7-CRID0  | \$01     | Rev A                                                                                                                         |

# 6.9 EXAMPLES OF HOST TO HI32 CONNECTIONS

#### 6.9.1 Example of Connection to PCI Bus





6.9.2 Example of Connection to 16-bit Data Bus (ISA/EISA Bus)

NOTE HI32 may be externally buffered to drive the current required by the

ISA/EISA standard. HI32 inputs should be externally buffered if the other ISA/EISA agents are not "3 Volt friendly" as defined in the PCI specifications.



6.9.3 Example of Connection to DSP56300 Core Port A Bus

NOTE: If the HI32's DSP and the host DSP use the same EXTAL clock, the HI32 can operate synchronously at its maximum throughput of three clock cycles/word (e.g. for a 66MHz clock the HI32 throughput is 22 Mwords/sec = 66 Mbytes/sec)

# 7 TRIPLE TIMER MODULE

# 7.1 INTRODUCTION

This section describes a peripheral module for the DSP56300 core family, composed of a common 21-bit prescaler and three independent and identical general purpose 24-bit timer/event counters, each one having its own register set.

Each timer can use internal or external clocking and can interrupt the DSP56301 after a specified number of events (clocks) or can signal an external device after counting internal events. Each timer can also be used to trigger DMA transfers after a specified number of events (clocks) occurred. Each timer connects to the external world through one bidirectional pin TIO. When TIO is configured as input, the timer functions as an external event counter or can measure external pulse width/signal period. When TIO is used as output the timer is functioning as either a timer, a watchdog or a Pulse Width Modulator. When the TIO pin is not used by the timer it can be used as a General Purpose Input/ Output Pin.

# 7.2 TRIPLE TIMER MODULE - PROGRAMMING MODEL

The registers comprising the Triple Timer Module are shown in Figure 7-1 through Figure 7-4.

#### Table 7-1. Triple Timer Module Programming Model - Timer 0

TCR0 - Timer Count Register for timer 0

TLR0 - Timer Load Register for timer 0

TCPR0 - Timer Compare Register for timer 0

TCSR0 - Timer Control/Status Register for timer 0

#### Table 7-2. Triple Timer Module Programming Model - Timer 1

TCR1 - Timer Count Register for timer 1

TLR1 - Timer Load Register for timer 1

TCPR1 - Timer Compare Register for timer 1

TCSR1 - Timer Control/Status Register for timer 1

#### Table 7-3. Triple Timer Module Programming Model - Timer 2

| CR2 - Timer Count Register for timer 2 |
|----------------------------------------|
|----------------------------------------|

TLR2 - Timer Load Register for timer 2

TCPR2 - Timer Compare Register for timer 2

TCSR2 - Timer Control/Status Register for timer 2

#### Table 7-4. Common Prescaler Registers

TPLR - Timer Prescaler Load Register

**TPCR - Timer Prescaler Count Register** 

# 7.3 TRIPLE TIMER MODULE ARCHITECTURE

#### 7.3.1 Triple Timer Module Block Diagram

Figure 7-2 shows a block diagram of the triple timer module. It includes a 24-bit Timer Prescaler Load Register (TPLR), a 24-bit Timer Prescaler Count Register (TPCR), a 21-bit counter and three timers. (Each one of the three timers may use the Prescaled Clock as its clock source).

#### 7.3.2 Prescaler Counter

This is a 21-bit counter which is decremented on each rising edge of the prescaler input clock. The counter is enabled when at least one of the three timers is both enabled  $(TE_i = 1)$  and using the prescaler output as its source (PCE<sub>i</sub> = 1).

#### 7.3.3 Timer Prescaler Load Register (TPLR)

The Timer Prescaler Load Register is a 24-bit read/write register that controls the prescaler divide factor and the source for the prescaler input clock. The control bits are described in the following paragraphs (see Figure 7-1).



#### Figure 7-1. Timer Prescaler Load Register

#### 7.3.3.1 Prescaler Preload Value (PL0-PL20) Bits 0-20

These 21 bits contain the prescaler preload value. This preload value is loaded into the prescaler counter whenever either the counter reaches the value of zero or the counter switches state from disabled to enabled.

If PL0-PL20 = N then the prescaler will count N+1 source clock cycles before generating a prescaled clock pulse. Therefore the prescaler divide factor is preload value + 1.

PL0-PL20 bits are cleared by hardware RESET and software RESET (RESET instruction).





7.3.3.2 Prescaler Source (PS0-PS1) Bits 21-22

The two Prescaler Source bits control the source of the prescaler clock. Table 7-5 summarizes the functionality of the PS bits. The internal clock CLK/2 (the DSP56301 clock divided by two) is selected when bits PS0-PS1 are cleared. The other combinations select one of the TIO pins as the source clock for the prescaler, regardless of the operating mode of the appropriate timer.

PS0-PS1 bits are cleared by hardware RESET and software RESET (RESET instruction).

- **NOTE1:** If the prescaler source clock is external, the prescaler counter will be incremented by the transitions on the TIO pin. 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).
- **NOTE2**: The PS1-PS0 bits should be changed only when the prescaler counter is disabled to ensure proper functionality.

| PS1 | PS0 | PRESCALER CLOCK SOURCE |
|-----|-----|------------------------|
| 0   | 0   | Internal CLK/2         |
| 0   | 1   | TIO0                   |
| 1   | 0   | TIO1                   |
| 1   | 1   | TIO2                   |

Table 7-5. Prescaler Source Selection

7.3.3.3 TPLR Reserved bit (Bit 23)

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

#### 7.3.4 Timer Prescaler Count Register (TPCR)

The Timer Prescaler Count Register is a 24-bit read only register that reflects the current value in the prescaler counter. The register bits are described in the following paragraphs (see Figure 7-3).





7.3.4.1 Prescaler Counter Value (PC0-PC20) Bits 0-20

These 21 bits contain the current value in the prescaler counter.

7.3.4.2TPCR Reserved bits (Bits 21,22,23)

These reserved bit are read as zero.

# 7.4 TIMER ARCHITECTURE

#### 7.4.1 Timer Block Diagram

Figure 7-4 shows a block diagram of a timer. It includes a 24-bit counter, a 24-bit readwrite 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 DSP56301 views each timer as a memory mapped peripheral occupying four 24-bit words in the X data memory space. The user may use standard polled or interrupt programming techniques. The programming model is shown in Figure 7-5

## 7.4.2 Timer Count Register (TCR)

The Count Register is a 24-bit read-only Register (TCR). In Timer and Watchdog Modes the counter contents can be read at any time by reading the TCR register. In Measurement Modes the TCR will be 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 leading edge of the input signal (incoming on the TIO pin).

## 7.4.3 Timer Load Register (TLR)

The Load Register is a 24-bit write-only Register (TLR). In all modes the counter is preloaded with the TLR value after the Timer Enable bit is set (TE=1) and a first event occurs.

In Timer Modes, if timer reload mode is set (TRM=1), the counter is reloaded each time after it has reached the value contained by the Timer Compare Register and the new event occurs.

In Measurement Modes, if timer reload mode is set (TRM=1), the counter is reloaded with the TLR value on each appropriate edge of the input signal, after the Timer Enable bit is set (TE=1).

In PWM Modes, if timer reload mode is set (TRM=1), the counter is reloaded each time after it has overflowed and the new event occurs.

In Watchdog Modes, if timer reload mode is set (TRM=1), the counter is reloaded each time after it has reached the value contained by the Timer Compare Register and the new event occurs. In this mode, the counter is also reloaded whenever the TLR is written with a new value while the Timer Enable bit is set (TE = 1).

In all modes, if TRM is cleared (TRM=0), the counter operates as free running counter.

# 7.4.4 Timer Compare Register (TCPR)

The compare register is a 24-bit read-write register which contains the value to be compared to the counter value. The counter value is compared against the value contained by the TCPR on every timer clock after the Timer Enable bit is set (TE=1). When the compare matches, the TCF bit is set and, if interrupts are enabled (TCIE=1), an interrupt is generated. In Measurement Modes the TCPR is ignored.

#### 7.4.5 Timer Control/Status Register (TCSR)

The control/status register is a 24-bit read/write register that controls the timer and reflects its status. The control and status bits are described in the following paragraphs (see Figure 7-5).





#### 7.4.5.1 Timer Enable (TE) Bit 0

The Timer Enable is used to enable or disable the timer. Setting the TE bit (TE=1) will enable the timer and clear the timer counter. The counter will start counting according to the mode defined by TC3-TC0. Clearing the TE bit will disable the timer. TE is cleared by hardware **RESET** and software **RESET** (**RESET** instruction).

NOTE: When all the three timers are disabled and not in GPIO mode, all three TIO pins becomes tri-state. In order to prevent undesired spikes on the TIO pins (when switching from tri-state into active state) it is recommended to use external pull-ups or pull downs resistors tied to TIO pins.

#### 7.4.5.2 Timer Overflow Interrupt Enable (TOIE) Bit 1

The Timer Overflow Interrupt Enable bit is used to enable the timer overflow interrupts. The overflow interrupt will be generated after the counter wraparound occurred, i.e. the counter value has changed from \$FFFFFF to \$000000 when a new event occurred. Setting TOIE (TOIE=1) will enable the overflow interrupts. When the bit is cleared (TOIE=0) the overflow interrupts are disabled.

TOIE is cleared by hardware **RESET** and software **RESET** (**RESET** instruction).



Figure 7-5. Timer Module Programming Model

#### 7.4.5.3 Timer Compare Interrupt Enable (TCIE) Bit 2

The Timer Compare Interrupt Enable bit is used to enable the timer compare interrupts. The compare interrupt will be generated after the counter matches the compare register (in the Timer, PWM or Watchdog Modes). If TCPR is loaded with N, an interrupt will occur after (N-M+1) events, where M is TLR value. Setting TCIE (TCIE=1) will enable the compare interrupts. When the bit is cleared (TCIE=0) the compare interrupts are disabled. TCIE is cleared by hardware RESET and software RESET (RESET instruction).

#### 7.4.5.4 Timer Control (TC0-TC3) Bits 4-7

The four Timer Control bits control the source of the timer clock, the behavior of the TIO pin and the timer mode of operation. Table 7-6 summarizes the functionality of the TC bits. A detailed description of the timer operating modes is given in Section 7.5. TC0-TC3 bits are cleared by hardware RESET and software RESET (RESET instruction).

- **NOTE1**: If the clock is external, the counter will be incremented by the transitions on the TIO pin. 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).
- **NOTE2**: The TC3-TC0 bits should be changed only when TE=0 (i.e. timer disabled) to ensure proper functionality.

| TC3 | TC2 | TC1 | TC0 | TIO               | CLOCK    | MODE                         |
|-----|-----|-----|-----|-------------------|----------|------------------------------|
| 0   | 0   | 0   | 0   | GPIO <sup>*</sup> | Internal | Timer                        |
| 0   | 0   | 0   | 1   | Output            | Internal | Timer Pulse                  |
| 0   | 0   | 1   | 0   | Output            | Internal | Timer Toggle                 |
| 0   | 0   | 1   | 1   | Input             | External | Event Counter                |
| 0   | 1   | 0   | 0   | Input             | Internal | Input Width                  |
| 0   | 1   | 0   | 1   | Input             | Internal | Input Period                 |
| 0   | 1   | 1   | 0   | Input             | Internal | Capture                      |
| 0   | 1   | 1   | 1   | Output            | Internal | Pulse Width Modulation (PWM) |
| 1   | 0   | 0   | 0   | -                 | -        | Reserved                     |
| 1   | 0   | 0   | 1   | Output            | Internal | Watchdog Pulse               |
| 1   | 0   | 1   | 0   | Output            | Internal | Watchdog Toggle              |
| 1   | 0   | 1   | 1   | -                 | -        | Reserved                     |
| 1   | 1   | 0   | 0   | -                 | -        | Reserved                     |
| 1   | 1   | 0   | 1   | -                 | -        | Reserved                     |
| 1   | 1   | 1   | 0   | -                 | -        | Reserved                     |
| 1   | 1   | 1   | 1   | -                 | -        | Reserved                     |

#### Table 7-6. Timer Control Bits

\* - the GPIO function is enabled only if TC3-TC0 are all 0 (zero)

#### 7.4.5.5 Inverter (INV) Bit 8

The Inverter bit affects the polarity of the external incoming signal on the TIO pin (when TIO is programmed as input) and affects the polarity of the pulse generated on the TIO pin (when TIO is programmed as output). In the Timer Modes if TIO is programmed as input and INV=0, the 0 to 1 transitions on the TIO input pin will increment the counter; if INV=1, the 1 to 0 transitions on the TIO input pin will increment the counter. In the Input Width Mode the INV bit determines whether the high pulse or the low pulse is measured and in the Input Period Mode the INV bit determines whether the period is measured between rising or falling edges. If TIO is programmed as output and INV=0, the pulse generated by the timer will be of positive polarity; if INV=1, the pulse generated by the timer will be inverted.

INV is cleared by hardware **RESET** and software **RESET** (**RESET** instruction).

- **NOTE1**: The INV bit affects both the timer and the GPIO modes of operation.
- **NOTE2**: The INV bit should be changed only when TE=0 (i.e. timer disabled), or in GPIO mode of operation, to ensure proper functionality.
- **NOTE3**: The polarity of the prescaler source clock, when the TIO is used as input to the prescaler, is not affected by the corresponding INV bit.
- 7.4.5.6 Timer reload mode (TRM) Bit 9

The timer reload mode bit controls the counter preload operation.

In Timer and Watchdog Modes the counter is preloaded with the TLR value after the Timer Enable bit is set (TE=1) and a first event occurs. If timer reload mode is set (TRM=1), the counter is reloaded each time after it has reached the value contained by the Timer Compare Register and the new event occurs. In PWM Mode the counter is reloaded each time counter wraparound has occurred (overflow) and the new event occurs. In Measurement Modes the counter is preloaded with the TLR value (if TRM=1) on each appropriate edge of the input signal, after the Timer Enable bit is set (TE=1). If TRM is cleared (TRM=0), the counter operates as free running counter, incrementing on each incoming event.

TRM is cleared by hardware RESET and software RESET (RESET instruction).

#### 7.4.5.7 Direction (DIR) Bit 11

The direction bit determines the behavior of the TIO pin when used as general purpose Input/Output pin. When DIR=0 the TIO pin is an input and when DIR=1 the TIO pin is an output. The TIO pin can be used as a general purpose Input/Output (GPIO) pin only when TC3-TC0 are all zero. If one of TC3, TC2, TC1 or TC0 is not 0 the GPIO function is disabled and the DIR pin has no effect.

DIR is cleared by hardware RESET and software RESET (RESET instruction).

#### 7.4.5.8 Data Input (DI) Bit 12

The DI bit reflects the value of TIO pin according to the INV bit. Reading the DI bit will read the TIO pin if INV=0, or the inverted TIO pin if INV=1.

#### 7.4.5.9 Data Output (DO) Bit 13

When the GPIO mode is enabled (TC3-TC0 are all zero) and DIR=1 the TIO pin acts as data output. Writing the DO bit will write the data to the TIO pin. If the INV bit is set the data on the TIO pin will be inverted. When GPIO mode is disabled writing the DO bit will have no effect.

DO is cleared by hardware RESET and software RESET (RESET instruction).

#### 7.4.5.10 Prescaled Clock Enable (PCE) Bit 15

The prescaled clock enable bit is used to select the prescaled clock as the timer source clock. When PCE is cleared the timer uses either internal (CLK/2) or external (TIO) source clock as determined by the timer operating mode. When PCE is set the prescaler output is used as the timer source clock for the counter regardless of the timer operating mode. PCE is cleared by hardware RESET and software RESET (RESET instruction).

- **NOTE1**: The PCE bit should be changed only when TE=0 (i.e. timer disabled) to ensure proper functionality.
- **NOTE2**: The source clock for the prescaler is determined only by the Prescaler Source bits (PS0-PS1) of the Timer Prescaler Load Register (TPLR). Therefore a timer may be clocked by prescaled clock derived from the TIO of another timer.
- 7.4.5.11 Timer Overflow Flag (TOF) Bit 20

The Timer Overflow Flag bit when set indicates that counter wraparound has occurred. The Timer Overflow Flag bit is cleared when writing a one into the TOF bit. Writing a zero into the TOF bit has no effect. The bit is cleared also when the timer overflow interrupt is serviced (timer overflow interrupt acknowledge).

TOF is cleared by hardware RESET and software RESET (RESET instruction).

7.4.5.12 Timer Compare Flag (TCF) Bit 21

In the Timer, PWM and Watchdog Modes the Timer Compare Flag bit when set indicates that (N-M+1) events are counted, where N is the value in the compare register and M is TLR value. In the Measurement Modes the TCF bit when set indicates that the measurement has been completed.

The Timer Compare Flag bit is cleared when writing a one into the TCF bit. Writing a zero into the TCF bit has no effect. The bit is cleared also when the timer compare interrupt is serviced (timer compare interrupt acknowledge).

TCF is cleared by hardware RESET and software RESET (RESET instruction).

- **NOTE:** Writing a zero in the TOF or TCF bit can be done with the Bit Test and Clear (BCLR) instruction. The state of the tested bit will be stored in the carry bit of the status register (SR).
- 7.4.5.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.

# 7.5 TIMER FUNCTIONAL DESCRIPTION (MODES OF OPERATION)

This section describes the various modes of operation of the timer module.

#### 7.5.1 Timer Modes

7.5.1.1 Timer mode, internal clock, no output (mode 0)

This mode is defined by TC3-TC0 equal 0000. In this mode the counter is cleared after TE is set and loaded with the TLR value on the first timer clock derived either from the DSP56301 clock divided by two (CLK/2) or from the prescaled clock input. The following timer clocks will increment the counter. When the counter matches the value contained by the TCPR, the TCF bit in TCSR is set and, if the TCIE is set, a compare interrupt is generated. At the next timer clock the counter is loaded with TLR value (if TRM is set) and the count is resumed. If TRM is cleared, the counter continues to be incremented on each timer clock. If counter wraparound has occurred the TOF bit is set and, if the TOIE is set, an overflow interrupt is generated. This process is repeated until the timer is disabled (TE=0). The counter contents can be read at any time by reading the TCR register.

#### 7.5.1.2 Timer mode, internal clock, output pulse enable (mode 1)

This mode is defined by TC3-TC0 equal 0001. In this mode the counter is cleared after TE is set and loaded with the TLR value on the first timer clock derived either from the DSP56301 clock divided by two (CLK/2) or from the prescaled clock input. The following timer clocks will increment the counter. When the counter matches the value contained by the TCPR, the TCF bit in TCSR is set and, if the TCIE is set, a compare interrupt is generated. At the next timer clock the counter is loaded with TLR value (if TRM is set) and the count is resumed. If TRM is cleared, the counter continues to be incremented on each timer clock. This process is repeated until the timer is disabled (TE=0). Each time the counter matches the TCPR value a pulse will be output on the TIO pin with the width equal to timer clock period. The pulse polarity is determined by the INV bit. If counter wraparound has occurred the TOF bit is set and, if the TOIE is set, an overflow interrupt is generated. The counter contents can be read at any time by reading the TCR register.

**NOTE:** After TE=1 the TIO pin output value is set equal to INV bit, to guarantee the correct first pin transition.

#### 7.5.1.3 Timer mode, internal clock, output toggle enable (mode 2)

This mode is defined by TC3-TC0 equal 0010. In this mode the counter is cleared after TE is set and loaded with the TLR value on the first timer clock derived either from the DSP56301 clock divided by two (CLK/2) or from the prescaled clock input. The following timer clocks will increment the counter. When the counter matches the value of the TCPR, the TIO output pin will be toggled, the TCF bit in TCSR is set and, if the TCIE is set, a compare interrupt is generated. At the next timer clock the counter is loaded with TLR value (if TRM is set) and the count is resumed. If TRM is cleared, the counter continues to be incremented on each timer clock. This process is repeated until the timer is disabled (TE=0). The TIO polarity is determined by the INV bit. On the first match the TIO output will be set if INV=0 or cleared if INV=1. If counter wraparound has occurred the TOF bit is set and, if the TOIE is set, an overflow interrupt is generated. The counter contents can be read at any time by reading the TCR register.

- **NOTE:** After TE=1 the TIO pin output value is set equal to INV bit, to guarantee the correct first pin transition.
- 7.5.1.4 Timer mode, external clock, event counter (mode 3)

This mode is defined by TC3-TC0 equal 0011. In this mode the counter is cleared after TE is set and loaded with the TLR value on the first transitions on the source clock which can be either the TIO input pin or the prescaled clock input. The following transitions will increment the counter. When the counter matches the value contained by TCPR, the TCF bit in TCSR is set and, if the TCIE is set, a compare interrupt is generated. At the next transitions the counter is loaded with TLR value (if TRM is set) and the count is resumed. If TRM is cleared, the counter continues to be incremented with each transitions on the source clock. This process is repeated until the timer is disabled (TE=0). The INV bit determines whether 0 to 1 transitions (INV=0) or 1 to 0 transitions (INV=1) will increment the counter. If counter wraparound has occurred the TOF bit is set and, if the TOIE is set, an overflow interrupt is generated. The counter contents can be read at any time by reading the TCR register. 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).

#### 7.5.2 Measurement Modes

#### 7.5.2.1 Pulse width measurement mode (mode 4)

This mode is defined by TC3-TC0 equal 0100. In this mode the counter is cleared after TE is set and, after the first appropriate transition (as determined by the INV bit) occurring on TIO input pin, it is loaded with the TLR value on the first timer clock derived either from the DSP56301 clock divided by two (CLK/2) or from the prescaled clock input. The following timer clocks will increment the counter. When the first edge of opposite polarity occurs on TIO the counter stops, the TCF bit in TCSR is set and, if the TCIE is set, a compare interrupt is generated. The contents of the counter is loaded into the TCR and the user's program can read its value that represents the widths of the TIO pulse. On the first timer clock, following the next transition that occurs on TIO input pin, the counter is loaded with

TLR value (if TRM is set) and the count is resumed. If TRM is cleared, the counter continues to be incremented on each timer clock, accumulating measurements results. This process is repeated until the timer is disabled (TE=0). If counter wraparound has occurred the TOF bit is set and, if the TOIE is set, an overflow interrupt is generated. In this mode TIO acts as a gating signal for the internal timer clock. The INV bit determines whether the counting is enabled when TIO is high (INV=0) or when TIO is low (INV=1).

#### 7.5.2.2 Period measurement mode (mode 5)

This mode is defined by TC3-TC0 equal 0101. In this mode the counter is cleared after TE is set and, after the first appropriate transition (as determined by the INV bit) occurring on TIO input pin, it is loaded with the TLR value on the first timer clock derived either from the DSP56301 clock divided by two (CLK/2) or from the prescaled clock input. The following timer clocks will increment the counter. On each following transition of the same polarity that occurs on TIO the TCF bit in TCSR is set and, if the TCIE is set, a compare interrupt is generated. The contents of the counter is loaded in the TCR and the user's program can read its value and the user's program can read the TCR to determine the distance between TIO edges. On the next timer clock the counter is loaded with TLR value (if TRM is set) and the count is resumed. If TRM is cleared, the counter continues to be incremented on each timer clock, accumulating measurements results. This process is repeated until the timer is disabled (TE=0). If counter wraparound has occurred the TOF bit is set and, if the TOIE is set, an overflow interrupt is generated. The INV bit determines whether the period is measured between consecutive 0 to 1 transitions of TIO (INV=0) or between consecutive 1 to 0 transitions of TIO (INV=1).

#### 7.5.2.3 Capture mode (mode 6)

This mode is defined by TC3-TC0 equal 0110. In this mode the counter is cleared after TE is set and loaded with the TLR value on the first timer clock derived either from the DSP56301 clock divided by two (CLK/2) or from the prescaled clock input. The following timer clocks will increment the counter. If counter wraparound has occurred the TOF bit is set and, if the TOIE is set, an overflow interrupt is generated. At the first transition of external clock the TCF bit in TCSR is set and, if the TCIE is set, a compare interrupt is generated. The contents of the counter is loaded into the TCR and the user's program can read its value that represents the delay of the leading detected edge in relation to the setting of the TE bit. The counting is stopped. The INV bit determines whether the period is measured between the setting of TE bit and the transitions of TIO from 0 to 1 (INV=0) or from 1 to 0 (INV=1).

#### 7.5.2.4 Measurement modes exactness

Since the measurement modes use the internal clock to increment the counter, but use the external signal for gating the count, synchronization is needed. The synchronization process may effect the measurement exactness up to a single selected (internal or prescaled) clock cycle.

## 7.5.3 PWM Modes

7.5.3.1 Pulse Width Modulation mode, internal clock, output toggle enable (mode 7)

This mode is defined by TC3-TC0 equal 0111. In this mode the counter is cleared after TE is set and loaded with the TLR value on the first timer clock derived either from the DSP56301 clock divided by two (CLK/2) or from the prescaled clock input. The following timer clocks will increment the counter. When the counter matches the value of the TCPR, the TIO output pin will be toggled, the TCF bit in TCSR is set and, if the TCIE is set, a compare interrupt is generated and the count is continued. When counter wraparound has occurred the TIO output pin will be toggled, the TOF bit in TCSR is set and, if the TOIE is set, an overflow interrupt is generated. At the next timer clock the counter is loaded with TLR value (if TRM is set) and the count is resumed. If TRM is cleared, the counter continues to be incremented on each timer clock. This process is repeated until the timer is disabled (TE=0). The TIO polarity is determined by the INV bit. On the first transaction the TIO output will be set if INV=0 or cleared if INV=1. The counter contents can be read at any time by reading the TCR register.

The value in the TLR determines the output period (\$FFFFFF - TLR). The value in the TCPR determines the duty cycle of the output signal (TLR - TCPR vs. \$FFFFFF - TCPR). Therefore, the ensure correct functionality, the values in TLR and TCPR should not be the same.

**NOTE:** After TE=1 the TIO pin output value is set equal to INV bit, to guarantee the correct first pin transition.

## 7.5.4 Watchdog Modes

7.5.4.1 Watchdog mode, internal clock, output pulse enable (mode 9)

This mode is defined by TC3-TC0 equal 1001. In this mode the counter is cleared after TE is set and loaded with the TLR value on the first timer clock derived either from the DSP56301 clock divided by two (CLK/2) or from the prescaled clock input. The following timer clocks will increment the counter. When the counter matches the value of the TCPR, the TCF bit in TCSR is set and, if the TCIE is set, a compare interrupt is generated and the count is continued. At the next timer clock the counter is loaded with TLR value (if TRM is set) and the count is resumed. If TRM is cleared, the counter continues to be incremented on each timer clock. This process is repeated until the timer is disabled (TE=0). The counter will be reloaded whenever the TLR is written with a new value while the Timer Enable bit is set (TE = 1). When counter wraparound has occurred the TOF bit in TCSR is set and, if the TOIE is set, an overflow interrupt is generated. At the same time a pulse will be output on the TIO pin with the width equal to timer clock period. The pulse polarity is determined by the INV bit. The counter contents can be read at any time by reading the TCR register.

**NOTE:** In this mode, the internal hardware will preserve the TIO value and direction for additional 2.5 internal clock cycles after reset was activated. This will ensure a valid length reset when the TIO is used as input to the RESET pin.

#### 7.5.4.2 Watchdog mode, internal clock, output toggle enable (mode 10)

This mode is defined by TC3-TC0 equal 1010. In this mode the counter is cleared after TE is set and loaded with the TLR value on the first timer clock derived either from the DSP56301 clock divided by two (CLK/2) or from the prescaled clock input. The following timer clocks will increment the counter. When the counter matches the value of the TCPR, the TCF bit in TCSR is set and, if the TCIE is set, a compare interrupt is generated and the count is continued. At the next timer clock the counter is loaded with TLR value (if TRM is set) and the count is resumed. If TRM is cleared, the counter continues to be incremented on each timer clock. This process is repeated until the timer is disabled (TE=0). The counter will be reloaded whenever the TLR is written with a new value while the Timer Enable bit is set (TE = 1). When counter wraparound has occurred the TIO output pin will be toggled, the TOF bit in TCSR is set and, if the TOIE is set, an overflow interrupt is generated. The TIO polarity is determined by the INV bit. On the first transaction the TIO output will be set if INV=0 or cleared if INV=1. The counter contents can be read at any time by reading the TCR register.

- **NOTE1:** After TE=1 the TIO pin output value is set equal to INV bit, to guarantee the correct first pin transition.
- **NOTE2:** In this mode, the internal hardware will preserve the TIO value and direction for additional 2.5 internal clock cycles after reset was activated. This will ensure a valid length reset when the TIO is used as input to the RESET pin.

#### 7.5.5 Reserved Modes

Modes 8,11,12,13,14 and 15 are reserved.

#### 7.5.6 Special Cases

#### 7.5.6.1 Timer behavior during WAIT and STOP

During the execution of the WAIT instruction the timer clocks are active thus the timer activity will continue undisturbed. When reaching the final event, if the timer interrupt is enabled, an interrupt will be generated, the processor will leave the WAIT state and service the interrupt.

During the execution of the STOP instruction the timer clocks are disabled, the timer activity is stopped and the TIO pins are disconnected. If, for example, the TIO pin is used as input the changes that occur while in STOP will be ignored. In order to ensure correct behavior the timer should be disabled before executing the STOP instruction.

## 7.5.7 DMA trigger

Each timer can also be used to trigger DMA transfers. For that a DMA channel has to be programmed to be triggered by the specific timer. The timer will issue a DMA trigger on every compare event, in all modes of operation. It is the user's responsibility to guarantee

that a new trigger will not be generated before the DMA channel has completed the transfers associated with the previous trigger, otherwise the trigger will not be captured by the DMA channel.

# 8 ENHANCED SYNCHRONOUS SERIAL INTERFACE

# (ESSI)

# 8.1 INTRODUCTION

There are two independent and identical Synchronous Serial Interfaces in the DSP56301: ESSI0 and ESSI1. For simplicity a single generic ESSI will be described.

The enhanced synchronous serial interface (ESSI) provides a full-duplex serial port for serial communication with a variety of serial devices including one or more industry-standard codecs, other DSPs, microprocessors, and peripherals which implement the Motorola SPI. The ESSI consists of independent transmitter and receiver sections and a common ESSI clock generator.

ESSI Block Diagram is shown in Figure 8-1. This interface 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 will support 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. This mode can be used to transfer data serially at high speed when the data becomes available. This mode offers a subset of the SPI protocol.

# 8.2 ESSI DATA AND CONTROL PINS

Three to six pins are required for operation, depending on the operating mode selected. STD, SC0, SC1 pins are fully synchronized if they are programmed as transmit data pins.

#### 8.2.1 Serial Transmit Data Pin (STD)

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

STD may be programmed as a general-purpose pin (P5) when the ESSI STD function is not being used.

## 8.2.2 Serial Receive Data Pin (SRD)

SRD receives serial data and transfers the data to the ESSI receive shift register. SRD may be programmed as a general-purpose I/O pin (P4) when the ESSI SRD function is not being used.



Figure 8-1. ESSI Block Diagram

## 8.2.3 Serial Clock (SCK)

SCK is a bidirectional pin providing the serial bit rate clock for the ESSI interface. The SCK is a clock input or output used by all the enabled transmitters and receiver in synchronous modes or by all the enabled transmitters in asynchronous modes (see Table 8-1 on page 4).

SCK may be programmed as a general-purpose I/O pin (P3) when the ESSI SCK function is not being used.

- **NOTE 1** The ESSI can operate with more than one active transmitter only in synchronous mode.
- **NOTE** 2 Although an external serial clock can be independent of and asynchronous to the DSP system clock, it must exceed the minimum clock cycle time of three Clkout cycles time. (i.e., the DSP56301 clock frequency must be at least three times the external ESSI clock frequency and each ESSI phase must exceed the minimum of 1.5 Clkout cycles)

## 8.2.4 Serial Control Pin (SC0)

The function of this pin is determined by the selection of either synchronous or asynchronous mode (see Table 8-3 on page 13). For asynchronous mode, this pin will be used for the receive clock I/O. For synchronous mode, this pin is used for transmitter data out pin of transmit shift register number 1 or for serial flag I/O. A typical application of flag I/O would be multiple device selection for addressing in codec systems. If this pin is configured as serial flag pin its direction is determined by the SCD0 bit in the CRB. When configured as an output, this pin will be either serial output flag 0, based on control bit OF0 in CRB, or a receive shift register clock output. When configured as an input, this pin may be used either as serial input flag 0, which will control status bit IF0 in the SSISR, or as a receive shift register clock input.

When this pin is configured as a transmit data pin its direction is always output regardless of SCD0 bit value, and is fully synchronized with the other transmit data pins (STD and SC1).

SC0 may be programmed as a general-purpose I/O pin (P0) when the ESSI SC0 function is not being used.

## 8.2.5 Serial Control Pin (SC1)

The function of this pin is determined by the selection of either synchronous or asynchronous mode (see Table 8-3 on page 13). In asynchronous mode (such as a single codec with asynchronous transmit and receive), this pin is the receiver frame sync I/O. For synchronous mode, this pin is used for transmitter data out pin of transmit shift register number 2 or for drive enable transmitter#0 signal or for serial flag SC1 and operates like the previously described SC0. SC0 and SC1 are independent serial I/O flags but may be used together for multiple serial device selection. SC0 and SC1 can be used unencoded to select up to two codecs or may be decoded externally to select up to four codecs. If this pin is configured as an output, this pin will be either a serial output flag, based on control bit OF1, the transmitter#0 drive enable signal or it will make the receive frame sync signal available. When configured as an input, this pin may be used as a serial input flag, which will control status bit IF1 in the ESSI status register, or as a receive frame sync from an external source.

When this pin is configured as a transmit data pin its direction is always output regardless

of SCD1 bit value, and is fully synchronized with the other transmit data pins (STD and SC0).

SC1 may be programmed as a general-purpose I/O pin (P1) when the ESSI SC1 function is not being used.

| SYN | SCKD | SCD0 | R Clock<br>Source | RX<br>Clock<br>Out | T Clock<br>Source | TX Clock Out |
|-----|------|------|-------------------|--------------------|-------------------|--------------|
|     |      |      | Asynch            | nronous            |                   |              |
| 0   | 0    | 0    | EXT, SC0          | _                  | EXT, SCK          | _            |
| 0   | 0    | 1    | INT               | SC0                | EXT, SCK          | _            |
| 0   | 1    | 0    | EXT, SC0          | _                  | INT               | SCK          |
| 0   | 1    | 1    | INT               | SC0                | INT               | SCK          |
|     |      |      | Synch             | ronous             |                   |              |
| 1   | 0    | 0/1  | EXT, SCK          | _                  | EXT, SCK          | -            |
| 1   | 1    | 0/1  | INT               | SCK                | INT               | SCK          |

 Table 8-1. ESSI Clock Sources

## 8.2.6 Serial Control Pin (SC2)

This pin is used for frame sync I/O. SC2 is the frame sync for both the transmitter and receiver in synchronous mode and for the transmitter only in asynchronous mode (see Table 8-3 on page 13). The direction of this pin is determined by the SCD2 bit in CRB. 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 transmitter (and the receiver in synchronous operation).

SC2 may be programmed as a general-purpose I/O pin (P2) when the ESSI SC2 function is not being used.

# 8.3 ESSI PROGRAMMING MODEL

The ESSI can be viewed as two control registers, one status register, three transmit data registers, a receive data register, two transmit slot mask registers, two receive slot mask registers and special-purpose time slot register. The following paragraphs give detailed

descriptions and operations of each of the bits in the ESSI registers. The ESSI contains also the GPIO functionality, described at Chapter 8.5.

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

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

Figure 8-3. ESSI Control Register B (CRB)

| 11   | 10   | 9    | 8    | 7    | 6    | 5    | 4    | 3    | 2    | 1   | 0   |
|------|------|------|------|------|------|------|------|------|------|-----|-----|
| CKP  | FSP  | FSR  | FSL1 | FSL0 | SHFD | SCKD | SCD2 | SCD1 | SCD0 | OF1 | OF0 |
| 23   | 22   | 21   | 20   | 19   | 18   | 17   | 16   | 15   | 14   | 13  | 12  |
| REIE | TEIE | RLIE | TLIE | RIE  | TIE  | RE   | TE0  | TE1  | TE2  | MOD | SYN |

Figure 8-4. ESSI Status Register (SSISR)

| 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|-----|-----|-----|-----|-----|-----|-----|-----|
| RDF | TDE | ROE | TUE | RFS | TFS | IF1 | IF0 |

Figure 8-5. ESSI Transmit Slot Mask Register A (TSMA)

| 11   | 10   | 9   | 8   | 7   | 6   | 5   | 4   | 3    | 2    | 1    | 0    |
|------|------|-----|-----|-----|-----|-----|-----|------|------|------|------|
| TS11 | TS10 | TS9 | TS8 | TS7 | TS6 | TS5 | TS4 | TS3  | TS2  | TS1  | TS0  |
| 23   | 22   | 21  | 20  | 19  | 18  | 17  | 16  | 15   | 14   | 13   | 12   |
|      |      |     |     |     |     |     |     | TS15 | TS14 | TS13 | TS12 |

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

Figure 8-6. ESSI Transmit Slot Mask Register B (TSMB)

Figure 8-7. ESSI Receive Slot Mask Register A (RSMA)

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

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

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

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

## 8.3.1 ESSI Control Register A (CRA)

CRA is one of two 24-bit read/write control registers used to direct the operation of the ESSI. The CRA controls the ESSI clock generator bit and frame sync rates, word length, and number of words per frame for the serial data. The CRA control bits are described in the following paragraphs (see Figure 8-2).

## 8.3.1.1 CRA Prescale Modulus Select (PM7–PM0) Bits 7–0

The PM7–PM0 bits specify the divide ratio of the prescale divider in the ESSI clock generator. A divide ratio from 1 to 256 (PM=0 to \$FF) may be selected. The bit clock output is available at the transmit clock (SCK) and/or the receive clock (SC0) pins 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. Careful choice of the crystal oscillator frequency and the prescaler modulus will allow the industry-standard codec master clock frequencies of 2.048 MHz, 1.544 MHz, and 1.536 MHz to be generated. Hardware and software reset clear PM0–PM7.

## 8.3.1.2 CRA Prescaler Range (PSR) Bit 11

The PSR 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 PSR is set, the fixed prescaler is bypassed. When PSR is cleared, the fixed divide-by-eight prescaler is operational. The maximum internally generated bit clock frequency is fosc/4, the minimum internally generated bit clock frequency is fosc/4, the minimum internally generated bit clock frequency is fosc/2/ 8/256=fosc/4096. Hardware and software reset clear PSR.

- **NOTE** The combination PSR = 1 and PM7-PM0 = \$00 is forbidden and may cause synchronization problems if used.
- 8.3.1.3 CRA Frame Rate Divider Control (DC4–DC0) Bits 16–12

The DC4–DC0 bits control the divide ratio for the programmable frame rate dividers used to generate the frame clocks. In network mode, this ratio may be interpreted as the number of words per frame minus one. In normal mode, this ratio determines the word transfer rate. The divide ratio may range from 1 to 32 (DC=00000 to 11111) for normal mode and 2 to 32 (DC=00001 to 11111) for network mode.

A divide ratio of one (DC=00000) in network mode is a special case (on demand mode). In normal mode, a divide ratio of one (DC=00000) provides continuous periodic data word transfers. A bit-length sync (FSL1=1, FSL0=0) must be used in this case. Hardware and software reset clear DC4–DC0.

8.3.1.4 CRA Alignment Control (ALC) Bit 18

The ESSI is designed for 24 bit fractional data, thus shorter data words are left aligned to the MSB (bit 23). Several applications use 16 bit fractional data, thus shorter data words are left aligned to bit 15. Alignment Control (ALC) support this applications.

If ALC is set, received words are left aligned to bit 15 in the receive shift register and transmitted words are supposed to reside left aligned to bit 15 in the transmit/s shift register.

If ALC is cleared, received words are left aligned to bit 23 in the receive shift register and transmitted word are supposed to reside left align to bit 23 in the transmit/s shift register. Hardware and software reset clear ALC.

- **NOTE** While in ALC is set, 24 and 32 bits words use are forbidden, and word length control should be 8, 12 or 16, otherwise results are unpredictable.
- 8.3.1.5 CRA Word Length Control (WL2- WL0) Bits 21-19

The WL2, WL1 and WL0 bits are used to select the length of the data words being

transferred via the ESSI. Word lengths of 8, 12, 16, 24 or 32 bits may be selected according to the assignment described in Table 8-2. - ESSI word length selection The data register of the ESSI are of 24 bit length and therefore the ESSI transmits 32 bit words by either duplicating the last bit 8 more times (WL2-WL0 = 100), or duplicating the first bit 8 more times (WL2-WL0 = 101).

Hardware and software reset clear WL2, WL1 and WL0.

| WL2 | WL1 | WL0 | Number of Bits/Word                     |
|-----|-----|-----|-----------------------------------------|
| 0   | 0   | 0   | 8                                       |
| 0   | 0   | 1   | 12                                      |
| 0   | 1   | 0   | 16                                      |
| 0   | 1   | 1   | 24                                      |
| 1   | 0   | 0   | 32<br>(valid data in the first 24 bits) |
| 1   | 0   | 1   | 32<br>(valid data in the last 24 bits)  |
| 1   | 1   | 0   | Reserved                                |
| 1   | 1   | 1   | Reserved                                |

 Table 8-2.
 ESSI word length selection

## 8.3.1.6 CRA Reserved Bits 8-10,17,18,22,23

Bits 8-10,17, 22, 23 in the CRA are reserved bits they read as zeros and must be written with zero for future compatibility.

8.3.1.7 CRA Select SC1 as Transmitter#0 drive enable (SSC1) Bit 22

The SSC1 controls the functionality of SC1 pin. If the ESSI is configured as synchronous mode (SYN=1), and transmitter#2 is disable (TE2=0), and SSC1 is set while SC1 pin is configured as output (SCD1=1), the SC1 pin will function as the driver enable of transmitter#0 to enable the use of an external buffer on transmitter#0 output (STD). If on same conditions SSC1 is clear then the pin will function as the serial I/O flag.

# 8.3.2 ESSI Control Register B (CRB)

The CRB is one of two 24-bit read/write control registers used to direct the operation of the ESSI (see Figure 8-3). CRB controls the ESSI multifunction pins, SC2, SC1, and SC0, which can be used as clock inputs or outputs, frame synchronization pins, transmit data pins or serial I/O flag pins. The serial output flag control bits and the direction control bits for the serial control pins are in the ESSI CRB. Interrupt enable bits for the receiver and

the transmitter are provided in this control register. The number of enabled transmitters are enabled in this register (0,1,2 or 3 transmitters can be enabled). Operating modes are also selected in this register. Hardware and software reset clear all the bits in the CRB. The relationships between the ESSI pins (SC0, SC1, SC2, and SCK) and some of the CRB bits are summarized in Table 8-3 on page 13. The ESSI CRB bits are described in the following paragraphs.

## 8.3.2.1 CRB Serial Output Flag 0 (OF0) Bit 0

When the ESSI is in the synchronous clock mode and transmitter #1 is disabled (TE1 = 0) SC0 pin is configured as ESSI flag 0. The serial control direction zero bit (SCD0) when set, indicates that the SC0 pin is an output, then data present in OF0 will be written to SC0 at the beginning of the frame in normal mode or at the beginning of the next time slot in network mode. Hardware and software reset clear OF0.

## 8.3.2.2 CRB Serial Output Flag 1 (OF1) Bit 1

When the ESSI is in the synchronous clock mode and transmitter #2 is disabled (TE2 = 0) SC1 pin is configured as ESSI flag 1. The serial control direction one bit (SCD1) when set, indicates that the SC1 pin is an output, then data present in OF1 will be written to SC1 at the beginning of the frame in normal mode or at the beginning of the next time slot in network mode. Hardware and software reset clear OF1.

The normal sequence for setting output flags when transmitting data (by transmitter #0 through STD pin only) is: wait for TDE (TX0 empty) to be set, first write the flags, and then write the transmit data to the TX register. OF0 and OF1 are double buffered so that the flag states appear on the pins when the TX data is transferred to the transmit shift register (i.e., the flags are synchronous with the data). Hardware and software reset clear OF1.

**NOTE** The optional serial output pins timing (SC0, SC1, and SC2) are controlled by the frame timing and are not affected by TE2, TE1, TE0 or RE.

## 8.3.2.3 CRB Serial Control 0 Direction (SCD0) Bit 2

In synchronous mode (SYN=1), when transmitter #1 is disabled (TE1=0), or in asynchronous mode (SYN=0), SCD0 controls the direction of the SC0 I/O pin. When SCD0 is cleared, SC0 is an input; when SCD0 is set, SC0 is an output. Hardware and software reset clear SCD0. When TE1 is set SCD0 is ignored and the SC0 pin is always an output.

## 8.3.2.4 CRB Serial Control 1 Direction (SCD1) Bit 3

In synchronous mode (SYN=1), when transmitter #2 is disabled (TE2=0), or in asynchronous mode (SYN=0) SCD1 controls the direction of the SC1 I/O pin. When SCD1 is cleared, SC1 is an input; when SCD1 is set, SC1 is an output. Hardware and software reset clear SCD1. When TE2 is set SCD1 is ignored and the SC1 pin is always an output.

#### 8.3.2.5 CRB Serial Control 2 Direction (SCD2) Bit 4

SCD2 controls the direction of the SC2 I/O pin. When SCD2 is cleared, SC2 is an input; when SCD2 is set, SC2 is an output. Hardware and software reset clear SCD2.

#### 8.3.2.6 CRB Clock Source Direction (SCKD) Bit 5

SCKD selects the source of the clock signal used to clock the transmit shift register in the asynchronous mode and all the transmit shift register/s and the receive shift register in the synchronous mode. In asynchronous mode when SCKD is set, the internal clock source becomes the bit clock for the transmit shift register and word length divider and is the output on the SCK pin. When SCKD is cleared, the clock source is external; the internal clock generator is disconnected from the SCK pin, and an external clock source may drive this pin. Hardware and software reset clear SCKD.

#### 8.3.2.7 CRB Shift Direction (SHFD) Bit 6

This bit causes the transmit shift register/s to shift data out MSB first when SHFD equals zero or LSB first when SHFD equals one. Received data is shifted in MSB first when SHFD equals zero or LSB first when SHFD equals zero. Hardware reset and software reset clear SHFD.

#### 8.3.2.8 CRB Frame Sync Length (FSL0 and FSL1) Bits 7 and 8

These bits select the length of frame sync to be generated or recognized. If FSL1 equals to zero and FSL0 equals to zero, a word-length frame sync is selected for both TX and RX that is the length of the data word defined by bits WL2, WL1 and WL0. If FSL1 equals to one and FSL0 equals to zero, a 1-bit clock period frame sync is selected for both TX and RX. When FSL0 equals to one, the TX and RX frame syncs are different lengths. The encoding of FSL1 and FSL0 is described in the following table. Hardware reset and software reset clear FSL0 and FSL1.

| FSL1 | FSL0 | Frame Sync Length                            |
|------|------|----------------------------------------------|
| 0    | 0    | WL bit clock for both TX/RX                  |
| 0    | 1    | One-bit clock for TX and WL bit clock for RX |
| 1    | 0    | One-bit clock for both TX/RX                 |
| 1    | 1    | One-bit clock for RX and WL bit clock for TX |

#### 8.3.2.9 CRB Frame Sync Relative Timing (FSR) Bit 9

FSR determines the relative timing of the receive and transmit frame sync signal as referred to the serial data lines, for a word length frame sync only. When FSR is cleared the word length frame sync occurs together with the first bit of the data word of the first slot. When FSR is set the word length frame sync occurs one serial clock cycle earlier (i.e together with the last bit of the previous data word). Hardware reset and software reset

#### clear FSR.

## 8.3.2.10 CRB Frame Sync Polarity (FSP) Bit 10

FSP determines the polarity of the receive and transmit frame sync signals. When FSP is cleared the frame sync signal polarity is positive (i.e the frame start is signed by the high level of the frame sync pin). When FSP is set the frame sync signal polarity is negative (i.e the frame start is signed by the low level of the frame sync pin). Hardware reset and software reset clear FSP.

## 8.3.2.11 CRB Clock Polarity (CKP) Bit 11

The clock polarity bit controls on which bit clock edge data and frame sync are clocked out and latched in. If CKP 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 receive bit clock. If CKP 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 receive clock is used to latch the data and frame sync in. Hardware reset and software reset clear CKP.

## 8.3.2.12 CRB Synchronous /Asynchronous (SYN) Bit 12

SYN controls whether the receive and transmit functions of the ESSI occur synchronously or asynchronously with respect to each other. When SYN is cleared, asynchronous mode is chosen and separate clock and frame sync signals are used for the transmit and receive sections. When SYN is set, synchronous mode is chosen and the transmit and receive sections use common clock and frame sync signals. Only in the synchronous mode more than one transmitter can be enabled. Hardware reset and software reset clear SYN.

## 8.3.2.13 CRB ESSI Mode Select (MOD) Bit 13

MOD selects the operational mode of the ESSI. When MOD is cleared, the normal mode is selected; when MOD is set, the network mode is selected. 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. In network mode, a word is (possibly) transferred every time slot. For more details, see Section 8.4. Hardware and software reset clear MOD.

## 8.3.2.14 CRB ESSI Transmit #2 Enable (TE2) Bit 14

TE2 enables the transfer of data from TX2 to the transmit shift register #2. TE2 is functional only in synchronous mode (SYN =1) and ignored in asynchronous mode (SYN = 0). When TE2 is set (in synchronous mode) and a frame sync is detected, the transmit #2 portion of the ESSI is enabled for that frame. When TE2 is cleared (in synchronous mode), transmitter #2 will be disabled after completing transmission of data currently in the ESSI transmit shift register. Any data present in TX2 will not be transmitted (i.e., data can be written to TX2 with TE2 cleared; TDE will be cleared, but data will not be transferred to the transmit shift register #2).

The normal transmit enable sequence is to write data to one or more transmit data

registers (or TSR) 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 will disable the transmitter #2 after completing transmission of the current data word until the beginning of the next frame. During that time period, the SC1 pin will remain in the high-impedance state. Keeping TE2 cleared until the start of the next frame will cause SC1 pin to act as serial I/O flag, (from the start of the frame) - in both normal and network mode.Hardware reset and software reset clear TE2.

The on-demand mode transmit enable sequence can be the same as the normal mode, or TE2 can be left enabled.

**NOTE** TE2 does not affect the generation of frame sync or output flags.

8.3.2.15 CRB ESSI Transmit #1 Enable (TE1) Bit 15

TE1 enables the transfer of data from TX1 to the transmit shift register #1. TE1 is functional only in synchronous mode (SYN =1) and ignored in asynchronous mode (SYN = 0). When TE1 is set (in synchronous mode) and a frame sync is detected, the transmit #1 portion of the ESSI is enabled for that frame. When TE1 is cleared (in synchronous mode), the transmitter #1 will be disabled after completing transmission of data currently in the ESSI transmit shift register. Any data present in TX1 will not be transmitted (i.e., data can be written to TX1 with TE1 cleared; TDE will be cleared, but data will not be transferred to the transmit shift register #1).

The normal mode transmit enable sequence is to write data to one or more transmit data registers (or TSR) 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 will disable the transmitter #1 after completing transmission of the current data word until the beginning of the next frame. During that time period, the SC0 pin will remain in the high-impedance state. Keeping TE1 cleared until the start of the next frame will cause SC0 pin to act as serial I/O flag, (from the start of the frame) - in both normal and network mode.Hardware reset and software reset clear TE1.

The on-demand mode transmit enable sequence can be the same as the normal mode, or TE1 can be left enabled.

**NOTE** TE1 does not affect the generation of frame sync or output flags.

8.3.2.16 CRB ESSI Transmit #0 Enable (TE0) Bit 16

TEO enables the transfer of data from TX0 to the transmit shift register #0. When TEO is set and a frame sync is detected, the transmit #0 portion of the ESSI is enabled for that frame. When TEO is cleared, the transmitter #0 will be disabled after completing transmission of data currently in the ESSI transmit shift register. The STD output is three-stated, and any data present in TX0 will not be transmitted (i.e., data can be written to TX0 with TE0 cleared; but data will not be transferred to the transmit shift register #0).

The normal mode transmit enable sequence is to write data to one or more transmit data registers (or TSR) 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 will disable the transmitter #0 after completing transmission of the current data word until the beginning of the next frame. During that time period, the STD pin will remain in the high-impedance state. Hardware reset and software reset clear TE0.

The on-demand mode transmit enable sequence can be the same as the normal mode, or TE0 can be left enabled.

- **NOTE** Transmitter #0 is the only transmitter that can operate in asynchronous mode (SYN=0).
- **NOTE** TE0 does not affect the generation of frame sync or output flags.

|     | Со  | ntrol E | Bits |     |     |        | ESSI I | PINS |     |      |
|-----|-----|---------|------|-----|-----|--------|--------|------|-----|------|
| SYN | TE0 | TE1     | TE2  | RE  | SC0 | SC1    | SC2    | SCK  | STD | SRD  |
| 0   | 0   | Х       | Х    | 0   | U   | U      | U      | U    | U   | U    |
| 0   | 0   | Х       | Х    | 1   | RXC | FSR    | U      | U    | U   | RD   |
| 0   | 1   | Х       | Х    | 0   | U   | U      | FST    | ТХС  | TD0 | U    |
| 0   | 1   | Х       | Х    | 1   | RXC | FSR    | FST    | ТХС  | TD0 | RD   |
| 1   | 0   | 0       | 0    | 1/0 | F0  | F1/T0D | FS     | XC   | U   | RD/U |
| 1   | 0   | 0       | 1    | 1/0 | F0  | TD2    | FS     | XC   | U   | RD/U |
| 1   | 0   | 1       | 0    | 1/0 | TD1 | F1/T0D | FS     | XC   | U   | RD/U |
| 1   | 0   | 1       | 1    | 1/0 | TD1 | TD2    | FS     | XC   | U   | RD/U |
| 1   | 1   | 0       | 0    | 1/0 | F0  | F1/T0D | FS     | XC   | TD0 | RD/U |
| 1   | 1   | 0       | 1    | 1/0 | F0  | TD2    | FS     | XC   | TD0 | RD/U |
| 1   | 1   | 1       | 0    | 1/0 | TD1 | F1/T0D | FS     | XC   | TD0 | RD/U |
| 1   | 1   | 1       | 1    | 1/0 | TD1 | TD2    | FS     | XC   | TD0 | RD/U |

#### Table 8-3. Mode and Pin Definition Table

• TXC - Transmitter Clock

- RXC Receiver Clock
- XC Transmitter/Receiver Clock (Synchronous Operation)
- FST Transmitter Frame Sync
- FSR Receiver Frame Sync
- FS Transmitter/Receiver Frame Sync (Synchronous Operation)
- TD0 Transmit Data pin #0
- TD1 Transmit Data pin #1
- TD2 Transmit Data pin #2

- T0D Transmitter#0 drive enable if SSC1=1 & SCD1=1
- RD Receive Data
- F0 Flag 0
- F1 Flag 1 if SSC1=0
- U Unused (may be used as GPIO pin)
- X Don't Care

## 8.3.2.17 CRB ESSI Receive Enable (RE) Bit 17

When RE is set, the receive portion of the ESSI is enabled. When this bit is cleared, the receiver will be disabled by inhibiting data transfer into RX. If data is being received while this bit is cleared, the remainder of the word will be shifted in and transferred to the ESSI receive data register.

RE must be set in the normal mode and on-demand mode to receive data. In network mode, the operation of clearing RE and setting it again will disable the receiver after reception of the current data word until the beginning of the next data frame. Hardware and software reset clear RE.

**NOTE** RE does not affect the generation of a frame sync.

## 8.3.2.18 CRB ESSI Transmit Interrupt Enable (TIE) Bit 18

The DSP will be interrupted when TIE and the TDE flag in the ESSI status register are set. When TIE is cleared, this interrupt is disabled. Writing data to all the data register of the enabled transmitters or to TSR will clear 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 ESSI will request an SSI transmit data with exception interrupt from the interrupt controller. Hardware and software reset clear TIE.

## 8.3.2.19 CRB ESSI Receive Interrupt Enable (RIE) Bit 19

When RIE is set, the DSP will be interrupted when RDF in the ESSI status register is set. When RIE is cleared, this interrupt is disabled. Reading the receive data register will clear RDF, thus clearing the pending 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 ESSI will request an SSI receive data with exception interrupt from the interrupt controller. Hardware and software reset clear RIE.

8.3.2.20 CRB ESSI Transmit Last slot Interrupt Enable (TLIE) Bit 20

TLIE enables an interrupt at the beginning of last slot of a frame in network mode. When TLIE is set the DSP will be 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. Hardware and software reset clear TLIE. TLIE is disabled when DC= \$0 (on demand mode).

The use of the transmit last slot interrupt is described in paragraph 8.4.3 - ESSI

Exceptions.

# 8.3.2.21 CRB ESSI Receive Last slot Interrupt Enable (RLIE) Bit 21

RLIE enables an interrupt after the last slot of a frame ended in network mode only. When RLIE is set the DSP will be 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 DC = \$0 (on demand mode). The use of the Receive last slot interrupt is described in paragraph 8.4.3 - ESSI Exceptions.

# 8.3.2.22 CRB ESSI Transmit Exception Interrupt Enable (TEIE) Bit 22

When TEIE is set, the DSP will be interrupted when both TDE and TUE in the ESSI status register are set. When TEIE is cleared, this interrupt is disabled. Reading the status register followed by writing to all the data registers of the enabled transmitters will clear TUE, thus clearing the pending interrupt. Hardware and software reset clear TEIE

# 8.3.2.23 CRB ESSI Receive Exception Interrupt Enable (REIE) Bit 23

When REIE is set, the DSP will be interrupted when both RDF and ROE in the ESSI status register are set. When REIE is cleared, this interrupt is disabled. Reading the status register followed by reading the receive data register will clear ROE, thus clearing the pending interrupt. Hardware and software reset clear REIE

# 8.3.3 ESSI Status Register (SSISR)

The SSISR (see Figure 8-4) is an 8-bit read-only status register used by the DSP to read the status and serial input flags of the ESSI. When the SSISR is read to the internal data bus, the register contents occupy the low-order byte of the data bus, and the remaining bits are read as zeros. The status bits are described in the following paragraphs.

## 8.3.3.1 SSISR Serial Input Flag 0 (IF0) Bit 0

The ESSI latches data present on the SC0 pin during reception of the first received bit after frame sync is detected. IF0 bit is updated with this data when the receive shift register is transferred into the receive data register. The IF0 bit is enabled only when SC0 is programmed as ESSI in the Port Control Register and SYN is set, TE1 is cleared and SCD0 is cleared, indicating that SC0 is an input flag and the synchronous mode is selected; otherwise, IF0 reads as a zero when it is not enabled. Hardware, software, ESSI individual, and STOP reset clear IF0.

# 8.3.3.2 SSISR Serial Input Flag 1 (IF1) Bit 1

The ESSI latches data present on the SC1 pin during reception of the first received bit after frame sync is detected. IF1 bit is updated with this data when the receiver shift register is transferred into the receive data register. The IF1 bit is enabled only when SC1 is programmed as ESSI in the Port Control Register and SYN is set, TE2 is cleared and SCD1 is cleared, indicating that SC1 is an input flag and the synchronous mode is

selected; otherwise, IF1 reads as a zero when it is not enabled. Hardware, software, ESSI individual, and STOP reset clear IF1.

#### 8.3.3.3 SSISR Transmit Frame Sync Flag (TFS) Bit 2

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 will be 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, ESSI individual, or STOP reset. TFS is valid only if at least one transmitter is enabled (TE0, TE1 or TE2 equal 1).

**NOTE** In normal mode, TFS will always be read as a one when transmitting data because there is only one time slot per frame – the "frame sync" time slot.

#### 8.3.3.4 SSISR Receive Frame Sync Flag (RFS) Bit 3

When set, RFS indicates that a receive frame sync occurred during reception of the word in the serial receive data register. This indicates that the data word is from the first time 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, ESSI individual, or STOP reset. RFS is valid only if the receiver is enabled (RE=1).

**NOTE** In normal mode, RFS will always read as a one when reading data because there is only one time slot per frame – the "frame sync" time slot.

#### 8.3.3.5 SSISR Transmitter Underrun Error Flag (TUE) Bit 4

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) will be retransmitted.

In the normal mode, there is only one transmit time slot per frame. In the network mode, there can be up to 32 transmit time slots per frame.

If TEIE is set, a DSP transmit underrun error interrupt request will be issued when TUE is set. Hardware, software, ESSI individual, and STOP reset clear TUE. TUE is also cleared by reading the SSISR with TUE set, followed by writing to all the enabled transmit data registers or to TSR.

#### 8.3.3.6 SSISR Receiver Overrun Error Flag (ROE) Bit 5

This flag is set when the serial receive shift register is filled and ready to transfer to the receiver data register (RX) and RX is already full (i.e., RDF=1). If REIE is set, a DSP receiver overrun error interrupt request will be issued when ROE is set. Hardware,

software, ESSI individual, and STOP reset clear ROE. ROE is also cleared by reading the SSISR with ROE set, followed by reading the RX.

## 8.3.3.7 SSISR ESSI Transmit Data Register Empty (TDE) Bit 6

This flag is set when the contents of the transmit data register of all the enabled transmitters are transferred to the transmit shift register/s; 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, a DSP transmit data interrupt request will be issued when TDE is set. Hardware, software, ESSI individual, and STOP reset clear TDE.

## 8.3.3.8 SSISR ESSI Receive Data Register Full (RDF) Bit 7

RDF is set when the contents of the receive shift register are transferred to the receive data register. RDF is cleared when the DSP reads the receive data register or cleared by hardware, software, ESSI individual, or STOP reset. If RIE is set, a DSP receive data interrupt request will be issued when RDF is set.

## 8.3.4 ESSI Receive Shift Register

This 24-bit shift register receives the incoming data from the serial receive data pin. 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 SHFD equals zero and LSB first if SHFD equals one. Data is transferred to the ESSI receive data register after 8, 12, 16, 24, or 32 serial clock cycles were counted, depending on the word-length control bits in the CRA.

## 8.3.5 ESSI Receive Data Register (RX)

RX is a 24-bit read-only register that accepts data from the receive shift register as it becomes full. The data read will occupy the most significant portion of the receive data register according to ALC setting (When ALC=0, the m.s.b is bit 23, or bit 15 when ALC=1). The unused bits (least significant portion, and 8 most significant bits when ALC=1) will read as zeros. The DSP is interrupted whenever RX becomes full if the associated interrupt is enabled.

## 8.3.6 ESSI Transmit Shift Registers

These three 24-bit shift registers contain the data being transmitted. 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, 24 or 32 bits (determined by the word-length control bits in CRA). The data to be transmitted occupies the most significant portion of the shift registers according to ALC setting (When ALC=0,

the m.s.b is bit 23, or bit 15 when ALC=1). The unused portion of the registers is ignored. Data is shifted out of these registers MSB first if SHFD equals zero and LSB first if SHFD equals one.

## 8.3.7 ESSI Transmit Data Registers (TX2,TX1,TX0)

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. The data written (8, 12, 16, or 24 bits) should occupy the most significant portion of the TXx according to ALC setting (When ALC=0, the m.s.b is bit 23, or bit 15 when ALC=1). The unused bits (least significant portion, and 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.8 ESSI Time Slot Register (TSR)

TSR is effectively a null data register that is used when the data is not to be transmitted in the available transmit time slot. For the purposes of timing, TSR is a write-only register that behaves like an alternative transmit data register, except that, rather than transmitting data, the transmit data pins of all the enabled transmitters are in the high-impedance state for that time slot.

# 8.3.9 Transmit Slot Mask Registers (TSMA, TSMB)

The Transmit Slot Mask Registers are two 16-bit read/write registers. When the TSMA or TSMB is read to the internal data bus, the register contents occupy the two low-order bytes of the data bus, and the high-order byte is zero filled. They are used by the transmitter/s in network mode to determine for each slot whether to transmit a data word and generate a transmitter empty condition (TDE=1), or to three-state the transmitter/s data pin/s. TSMA and TSMB (see Figure 8-5 and Figure 8-6) should be seen as only one 32-bit register, TSM. Bit number N in TSM (TS\*\*) is an enable/disable control bit for transmission in slot number N.

When bit number N in TSM is cleared, all the transmit data pins of the enabled transmitters are three-stated during transmit time slot number N. The data is still transferred from the Transmit Data Register/s to the transmit shift register/s and the Transmit Data Empty flag (TDE) is not set. Also the Transmitter Underrun Error flag is not 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 Register/s 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 TX register/s to the shift register/s, it is transmitted during slot number N, and 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 will cause all the transmit data pins of the enabled transmitters to be three-stated during the next slot.

Data written to the TSM will affect next frame transmission. The frame being transmitted

is not affected by this data and would comply to last TSM setting. Data read from TSM will return 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.

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

The Receive Slot Mask Registers are two 16-bit read/write registers. When the RSMA or RSMB is read to the internal data bus, the register contents occupy the two low-order bytes of the data bus, and the high-order byte is zero filled. They are 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 (see Figure 8-7 and Figure 8-8) should be seen as only one 32-bit register, RSM. Bit number N in RSM (RS\*\*) is an enable/disable control bit for receiving data in slot number N.

When bit number N in RSM register is cleared, the data from receive data pin SRD is shifted into the Receive Shift Register during slot number N. The data is not transferred from the Receive Shift Register to the Receive Data Register and the Receiver Data Full flag (RDF) is not set. Also the Receiver Overrun Error flag is not 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 RSM is set, the receive sequence is as usual: data which is shifted into the receive shift register is transferred to the Receive Data register and RDF flag is set.

Data written to the RSM will affect next received frame. The frame being received is not affected by this data and would comply to last RSM setting. Data read from RSM will return last written data.

After hardware or software reset, the RSM register is preset to \$FFFFFFF, which means that all 32 possible slots are enabled for data reception.

# 8.4 **OPERATING MODES**

ESSI operating mode are selected by the ESSI control registers (CRA and CRB). The main operating mode are described in the following paragraphs.

## 8.4.1 ESSI After Reset

Hardware or software reset clears the port control register bits and the port direction control register bits, which configure all I/O as general-purpose input. The ESSI is reset while all ESSI pins are programmed as general-purpose I/O and is active only if at least one of the ESSI I/O pins is programmed as ESSI pin.

#### 8.4.2 ESSI Initialization

The correct way to initialize the ESSI is as follows:

- 1. Hardware, software, ESSI individual, or STOP reset
- 2. Program ESSI control and time slot registers
- 3. Write data to all the enabled transmitters.
- 4. Configure at least one pin as ESSI pin

During program execution, PC6-PC0 bits in the GPIO port control register (PCR) may be cleared causing the ESSI to stop serial activity and enter the individual reset state. All status bits of the interface will be set to their reset state; however, the contents of CRA and CRB are not affected. This procedure allows the DSP program to reset each interface separately from the other internal peripherals. During individual reset internal DMA accesses to the data registers of the ESSI are not valid and data read will be unexpected.

The DSP program must use an ESSI reset when changing the ESSI control registers (except for TEIE, REIE, TLIE, RLIE, TIE, RIE, TE2, TE1, TE0, or RE) to ensure proper operation of the interface.

#### 8.4.3 ESSI Exceptions

The ESSI can generate six different exceptions (ordered from the highest to the lowest priority):

- 1. ESSI Receive Data with Exception Status occurs when the receive exception interrupt is enabled, the receive data register is full, and a receiver overrun error has occurred. ROE is cleared by first reading the SSISR and then reading RX.
- 2. ESSI Receive Data occurs when the receive interrupt is enabled, the receive data register is full, and no receive error conditions exist. Reading RX clears the pending interrupt. This error-free interrupt can use a fast interrupt service routine for minimum overhead.
- 3. ESSI Receive Last slot interrupt occurs 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, reconfigure the DMA channels and reassignment of data memory pointers. Using the Receive last slot interrupt guarantees that the previous frame was serviced with the previous setting and the new frame will be serviced with the new setting without synchronization problems. Note that the maximum Receive last slot interrupt service time, should not exceed N-1 ESSI bits service time (Where N is the number of bits in a slot).
- 4. ESSI Transmit Data with Exception Status occurs when the transmit exception interrupt is enabled, at least one transmit data register of the enabled transmitters is empty, and a transmitter underrun error has occurred. TUE is cleared by first reading the SSISR and then writing to all the transmit data registers of the enabled transmitters, or to the TSR to clear the pending interrupt.
- 5. ESSI Transmit Last slot interrupt occurs 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, reconfigure the DMA channels and reassignment of data memory pointers. Using the Transmit last slot interrupt guarantees that the previous frame was serviced with the previous setting and the new frame will be serviced with the new setting without synchronization problems.Note that the maximum Transmit last slot interrupt service time, should not exceed N-1 ESSI bits service time (Where N is the number of bits in a slot).

6. ESSI Transmit Data – occurs when the transmit interrupt is enabled, and at least one of the enabled transmit data registers is empty, and no transmitter error conditions exist. Writing to all the TX registers of the enabled transmitters, or to the TSR will clear this interrupt. This error-free interrupt may use a fast interrupt service routine for minimum overhead (if no more than two transmitters are used).

#### 8.4.4 Operating Modes – Normal, Network, and On-Demand

The ESSI has three basic operating modes and many data/operation formats. These modes can be programmed by several bits in the ESSI control registers.

The data/operation formats available to the ESSI are selected by setting or clearing control bits in the CRA and CRB. These control bits are WL2, WL1, WL0, MOD, SYN, FSL1, FSL0, FSR, FSP, CKP and SHFD.

#### 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 MOD bit in the CRB. For normal mode, the ESSI functions with one data word of I/O per frame (per enabled transmitter). 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 (from each enabled transmitter). In either case, the transfers are periodic. The normal mode is typically used to transfer data to/from a single device. Network mode is typically used in time division multiplexed (TDM) networks of codecs or DSPs with multiple words per frame.

Setting the MOD bit in the CRB, as for network mode, and setting the frame rate divider to zero (DC=00000) selects the on demand mode. This special case will not generate a periodic frame sync. A frame sync pulse will be generated only when data is available to transmit. The frame sync signal indicates the first time slot in the frame. 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 ESSI is double buffered, only one word can be written to each TX, even if the transmit shift register is empty. The receive and transmit interrupts, function as usual using TDE and RDF; however, transmit underruns are impossible for on-demand transmission and are disabled. This mode is useful for interfacing to codecs requiring a continuous clock.

## 8.4.4.2 Synchronous/Asynchronous Operating Modes

The transmit and receive sections of this interface may be synchronous or asynchronous – i.e., the transmitter and receiver may use common clock and synchronization signals or they may have their own separate clock and sync signals (asynchronous operating mode). The SYN bit in CRB selects synchronous or asynchronous operation. Since the ESSI is designed to operate either synchronously or asynchronously, separate receive and transmit interrupts are provided.

When SYN equals zero, the ESSI TX and RX clocks and frame sync sources are independent. If SYN equals one, the ESSI TX and RX clocks and frame sync come from the same source (either external or internal).

Transmitter #1 and transmitter #2 can operate only in synchronous mode.

Data clock and frame sync signals can be generated internally by the DSP or may be obtained from external sources. If internally generated, the ESSI clock generator is used to derive bit clock and frame sync signals from the DSP internal system clock. The ESSI clock generator consists of a selectable fixed prescaler and a programmable prescaler for bit rate clock generation and also a programmable frame-rate divider and a word-length divider for frame-rate sync-signal generation.

#### 8.4.4.3 Frame Sync Selection

The transmitter and receiver can operate totally independent of each other. The transmitter can have either a bit-long or word-long frame-sync signal format, and the receiver can have the same or opposite format. The selection is made by programming FSL0 and FSL1 in the CRB.

- 1. If FSL1 equals zero, the RX frame sync is asserted during the entire 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. If FSL1 equals one, the RX frame sync pulses active 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.

The ability to mix frame sync lengths is useful in configuring systems in which data is received from one type device (e.g., codec) and transmitted to a different type device. FSL0 controls whether RX and TX have the same frame sync length. If FSL0 equals zero, RX and TX have the same frame sync length, which is selected by FSL1. If FSL0 equals one, RX and TX have different frame sync lengths, which are selected by FSL1. FSL0 is ignored when the SYN bit is set.

FSR controls the relative timing of the word length frame sync as referred to the data word. When FSR is cleared the word length frame sync is generated (or expected) with the first bit of the data word. When FSR is set the word length frame sync is generated (or expected) with the last bit of the previous word. FSR is ignored when a bit length frame sync is selected.

FSP controls the polarity of the frame sync. When FSP is cleared the polarity of the frame

sync is positive i.e. the frame sync signal is asserted high. When FSP is set the polarity of the frame sync is negative i.e. the frame sync is asserted low.

The ESSI receiver looks for a receive frame sync leading edge (trailing edge if FSP 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 FSR set), the current frame sync will not be recognized, and the receiver will be 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. All the enabled transmitters will be three-stated during these gaps.

#### 8.4.4.4 Shift Direction Selection

Some data formats, such as those used by codecs, specify MSB first other data formats, such as the AES-EBU digital audio, specify LSB first. To interface with devices from both systems, the shift registers in the ESSI are bidirectional. The MSB/LSB selection is made by programming SHFD in the CRB.

If SHFD equals zero, data is shifted into the receive shift register MSB first and shifted out of the transmit shift register MSB first. If SHFD equals one, data is shifted into the receive shift register LSB first and shifted out of the transmit shift register LSB first.

## 8.4.5 Flags

Two ESSI pins (SC1 and SC0) are available as serial I/O flags. Their operation can be controlled by SYN, SCD0, SCD1, SSC1, TE1 and TE2 bits in the CRB/CRA.The control bits (OF1 and OF0) and status bits (IF1 and IF0) are double buffered to/from SC1 and SC0. Double buffering the flags keeps them in sync with TX and RX.

The flags are available in the synchronous mode only (SYN=1). Each flag can be separately programmed. Flag 0 is enabled when transmitter #1 is disabled (TE1=0), its direction is selected by SCD0, SCD0=1 as output and SCD0=0 as input. In the same way flag1 is enabled when transmitter #2 is disabled (TE2=0), the pin is not configured as transmitter drive enable (SSC1=0) and its direction is selected by SCD1, SCD1=1 as output and SCD1=0 as input.

When programmed as input, SC0 and SC1 value, respectively, are latched at the same time as the first bit is sampled of the receive data word. Since the input was latched, the signal on the input flag pin (SC0 and SC1), can change without affecting the input flag until the first bit of the next receive data word. When received data word is latched by RX, the latched values are then latched by the SSISR IF0 and IF1 bits respectively and can be read by software.

When programed as output, SC0 and SC1 value, is driven by the value, from the CRB OF0 and OF1 bits respectively, latched when the TX is transferred to the transmit shift register. The value on SC0 or SC1, will be stable from the same time the first bit of the transmit data word is transmitted until the first bit of the next transmit data word is transmitted. Software can change the CRB OF0 and OF1 values and thus controlling the SC0 and SC1 pin values for each transmitted word.

# 8.5 GPIO - pins and registers

The GPIO functionality of port ESSI is controlled by three registers: Port Control register (PCR), Port Direction register (PRR) and Port Data register (PDR).

#### 8.5.1 Port Control Register (PCR)

The read/write 16 bit Port Control Register controls the functionality of ESSI GPIO pins. When the PCR is read to the internal data bus, the register contents occupy the two low-order bytes of the data bus, and the remaining bits are read as zeros. When written the most significant byte should be written zero for future compatibility.



#### Figure 8-9. Port Control Register (PCR)

Each of PC(5: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 ESSI pin. When a PC[i] bit is cleared, the corresponding port pin is configured as GPIO pin.

Hardware and software reset clear all PCR bits.

#### 8.5.2 Port Direction Register (PRR)

The read/write 16 bit Port Direction Register controls the direction of ESSI GPIO pins. When the PRR is read to the internal data bus, the register contents occupy the two low-order bytes of the data bus, and the remaining bits are read as zeros. When written the most significant byte should be written zero for future compatibility.



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

The following table describe the port pin configurations.

| PC[i] | PDC[i] | Port Pin[i] Function |
|-------|--------|----------------------|
| 1     | Х      | ESSI                 |
| 0     | 0      | GPIO input           |
| 0     | 1      | GPIO output          |

#### 8.5.3 Port Data register (PDR)

The read/write 16 bit Port Data Register is used to read or write data to/from ESSI GPIO pins.Bits PD(5:0) are used to read or write data from/to the corresponding port pins if they are configured as GPIO (by PC(5:0) bits in PCR). 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.When the PDR is read to the internal data bus, the register contents occupy the two low-order bytes of the data bus, and the remaining bits are read as zeros. When written the most significant byte should be written zero for future compatibility.



READ AS ZERO, SHOULD BE WRITTEN WITH ZERO FOR FUTURE COMPATIBILITY

Hardware and software reset clear all PDR bits.

# 9 SERIAL COMMUNICATION INTERFACE (SCI)

## 9.1 INTRODUCTION

The SCI provides a full-duplex port for serial communication to other DSPs, microprocessors, or peripherals such as modems. The communication can be TTL-level signals or, with additional external logic, RS232C, RS422, etc.

This interface uses three dedicated pins: transmit data (TXD), receive data (RXD), and SCI serial clock (SCLK). It supports industry-standard asynchronous bit rates and protocols as well as high-speed synchronous data transmission (up to 8.25 Mbps for a 66-MHz clock). The asynchronous protocols include a multidrop mode for master/slave operation with Wakeup On Idle Line and Wakeup On Address Bit capability.

The SCI consists of separate transmit and receive sections whose operation can be asynchronous with respect to one another. A programmable baud-rate generator provides the transmit and receive clocks. An enable vector and an interrupt vector have been included so that the baud-rate generator can function as a general-purpose timer when it is not being used by the SCI or when the interrupt timing is the same as that used by the SCI.

## 9.2 SCI I/O Pins

Each of the three SCI pins can be configured as either a general-purpose I/O or as a specific SCI pin. Each pin is independent of the others (e.g. if only TXD is needed, RXD and SCLK can be programmed for general-purpose I/O). However, at least one of the three pins must be selected as an SCI pin to release the SCI from reset.

SCI interrupts may be enabled by programming the SCI control registers before any of the SCI pins are programmed as SCI functions. In this case, only one transmit interrupt can be generated because the transmit data register is empty. The timer and timer interrupt will operate when one or more of the SCI pins is programmed as an SCI pin.

#### 9.2.1 Receive Data (RXD)

This input receives byte-oriented serial data and transfers the data to the SCI receive shift register. Asynchronous input data is sampled on the positive edge of the receive clock (1X SCLK) if SCKP equals zero. RXD may be programmed as a general-purpose I/O pin (PE0) when the SCI RXD function is not being used.

## 9.2.2 Transmit Data (TXD)

This output transmits serial data from the SCI transmit shift register. Data changes on the negative edge of the asynchronous transmit clock (SCLK) if SCKP equals zero. This output is stable on the positive edge of the transmit clock. TXD may be programmed as a general-purpose I/O pin (PE1) when the SCI TXD function is not being used.

## 9.2.3 SCI Serial Clock (SCLK)

This bidirectional pin provides an input or output clock from which the transmit and/or receive baud rate is derived in the asynchronous mode and from which data is transferred in the synchronous mode. SCLK may be programmed as a general-purpose I/O pin (PE2) when the SCI SCLK function is not being used. This pin may be programmed as PE2 when data is being transmitted on TXD since, in the asynchronous mode, the clock need not be transmitted. There is no connection between programming the PE2 pin as SCLK and data coming out the TXD pin because SCLK is independent of SCI data I/O.

# 9.3 SCI PROGRAMMING MODEL

The registers comprising the SCI are shown in Figure 9-1 and Figure 9-2. These registers are the SCI control register (SCR), SCI status register (SSR), SCI clock control register (SCCR), SCI receive data registers (SRX), SCI transmit data registers (STX), and the SCI transmit data address register (STXA). The SCI programming model can be viewed as three types of registers:

- 1. control SCR and SCCR in Figure 9-1;
- 2. status SSR in Figure 9-1; and
- 3. data transfer SRX, STX, and STXA in Figure 9-2.

The SCI contains also the GPIO functionality, described at Chapter 9.5. The following paragraphs describe each bit in the programming model.

## 9.3.1 SCI Control Register (SCR)

The SCR is a 24 -bit read/write register that controls the serial interface operation. seventeen of the 24 bits are currently defined. Each bit is described in the following paragraphs.

9.3.1.1 SCR Word Select (WDS0, WDS1, WDS2) Bits 0, 1, and 2

The three word-select bits (WDS0, WDS1, WDS2) select the format of the transmit and receive data. The formats include three asynchronous and one multidrop asynchronous mode, as well as an 8-bit synchronous (shift register) mode. The asynchronous modes are compatible with most UART-type serial devices. Standard RS232C communication links are supported by these modes.

Figure 9-1. SCI Programming Model – Control and Status Registers



|  | egister ( | JUUR) |
|--|-----------|-------|
|  |           |       |

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

The multidrop asynchronous modes are compatible with the MC68681 DUART, the M68HC11 SCI interface, and the Intel 8051 serial interface.

The synchronous data mode is essentially a high-speed shift register used for I/O expansion and stream-mode channel interfaces. Data synchronization is accomplished by the use of a gated transmit and receive clock that is compatible with the Intel 8051 serial interface mode 0. These formats are indicated in Table 9-1. The word-select bits are cleared by hardware reset.

When odd parity is selected, the transmitter will count the number of ones in the data word; if the total is not an odd number, the parity bit is made equal to one and thus

produces an odd number. If the receiver counts an even number of ones, an error in transmission has occurred. When even parity is selected, an even number must result from the calculation performed at both ends of the line or an error in transmission has occurred. The three word-select bits are cleared by hardware and software reset.

| WDS<br>2 | WDS<br>1 | WDS<br>0 | Word Formats                                                 |
|----------|----------|----------|--------------------------------------------------------------|
| 0        | 0        | 0        | 8-Bit Synchronous Data (shift register mode)                 |
| 0        | 0        | 1        | Reserved                                                     |
| 0        | 1        | 0        | 10-Bit Asynchronous (1 start, 8 data, 1 stop)                |
| 0        | 1        | 1        | Reserved                                                     |
| 1        | 0        | 0        | 11-Bit Asynchronous (1 start, 8 data, 1 even parity, 1 stop) |
| 1        | 0        | 1        | 11-Bit Asynchronous (1 start, 8 data, 1 odd parity, 1 stop)  |
| 1        | 1        | 0        | 11-Bit Multidrop (1 start, 8 data, 1 data type, 1 stop)      |
| 1        | 1        | 1        | Reserved                                                     |

#### Table 9-1. Word Formats

## 9.3.1.2 SCR SCI Shift Direction (SSFTD) Bit 3

The SCI data shift registers can be programmed to shift data in/out either LSB first - if SSFTD equals zero; or MSB first - if SSFTD equals one. The parity and data type bits do not change their position in the frame, and remain adjacent to the stop bit. SSFTD is cleared by hardware and software reset

## 9.3.1.3 SCR Send Break (SBK) Bit 4

A break is an all-zero word frame – a start bit zero and a character of all zeros (including any parity), and a stop bit zero: i.e., 10 or 11 zeros depending on the WDS mode selected. If SBK is set and then cleared, the transmitter completes transmission of the current frame, sends 10 or 11 zeros, and reverts to idle or sending data. If SBK remains set, the transmitter will continually send whole frames of zeros (10 or 11 bits with no stop bit). At the completion of the break code, the transmitter sends at least one high bit before transmitting any data to guarantee recognition of a valid start bit. Break can be used to signal an unusual condition, message, etc. by forcing a frame error, which is caused by a missing stop bit. Hardware and software reset clear SBK.

## 9.3.1.4 SCR Wakeup Mode Select (WAKE) Bit 5

When WAKE equals zero, the Wakeup On Idle Line mode is selected. In the Wakeup On Idle Line mode, the SCI receiver is re-enabled by an idle string of at least 10 or 11

(depending on WDS mode) consecutive ones. The transmitter's software must provide this idle string between consecutive messages. The idle string cannot occur within a valid message because each word frame contains a start bit that is a zero.

When WAKE equals one, the wakeup on address bit mode is selected. In the Wakeup On Address Bit mode, the SCI receiver is re-enabled when the last (eighth or ninth) data bit received in a character (frame) is one. The ninth data bit is the address bit (R8) in the 11-bit multidrop mode; the eighth data bit is the address bit in the 10-bit asynchronous and 11-bit asynchronous with parity modes. Thus, the received character is an address that has to be processed by all sleeping processors – i.e., each processor has to compare the received character with its own address and decide whether to receive or ignore all following characters. WAKE is cleared by hardware and software reset.

#### 9.3.1.5 SCR Receiver Wakeup Enable (RWU) Bit 6

When RWU equals one and the SCI is in an asynchronous mode, the wakeup function is enabled – i.e., the SCI is put to sleep, and will be woken by the event defined by the WAKE bit. In the Sleep state, all receive flags, except IDLE, and interrupts are disabled. When the receiver wakes up, RWU is cleared by the wakeup hardware. The programmer may also clear the RWU bit to wake up the receiver.

RWU can be used by the programmer to ignore messages that are for other devices on a multidrop serial network. Wakeup On Idle Line (WAKE=0) or Wakeup On Address Bit (WAKE=1) must be chosen.

- 1. When WAKE equals zero and RWU equals one, the receiver will not respond to data on the data line until an idle line is detected.
- 2. When WAKE equals one and RWU equals one, the receiver will not respond to data on the data line until a data byte with bit 9 equal to one is detected.

When the receiver wakes up, the RWU bit is cleared, and the first byte of data is received. If interrupts are enabled, the CPU will be interrupted, and the interrupt routine will read the message header to determine if the message is intended for this DSP.

- 1. If the message is for this DSP, the message will be received, and RWU will again be set to one to wait for the next message.
- 2. If the message is not for this DSP, the DSP will immediately set RWU to one. Setting RWU to one causes the DSP to ignore the remainder of the message and wait for the next message.

RWU is cleared by hardware and software reset. RWU is ignored in the synchronous mode.

#### 9.3.1.6 SCR Wired-OR Mode Select (WOMS) Bit 7

When the WOMS bit is set, the SCI TXD driver is programmed to function as an opendrain output and may be wired together with other TXD pins in an appropriate bus configuration such as a master-slave multidrop configuration. An external pullup resistor is required on the bus. When the WOMS is cleared, the TXD pin uses an active internal pullup. This bit is cleared by hardware and software reset.

#### 9.3.1.7 SCR Receiver Enable (RE) Bit 8

When RE is set, the receiver is enabled. When RE is cleared, the receiver is disabled, and data transfer is inhibited to the receive data register (SRX) from the receive shift register. If RE is cleared while a character is being received, the reception of the character will be completed before the receiver is disabled. RE does not inhibit RDRF or receive interrupts. RE is cleared by a hardware and software reset.

#### 9.3.1.8 SCR Transmitter Enable (TE) Bit 9

When TE is set, the transmitter is enabled. When TE is cleared, the transmitter will complete transmission of data in the SCI transmit data shift register; then the serial output is forced high (idle). Data present in the SCI transmit data register (STX) will not be transmitted. STX may be written and TDRE will be cleared, but the data will not be transferred into the shift register. TE does not inhibit TDRE or transmit interrupts. TE is cleared by a hardware and software reset.

Setting TE will cause the transmitter to send a preamble of 10 or 11 consecutive ones (depending on WDS). This procedure gives the programmer a convenient way to ensure that the line goes idle before starting a new message. To force this separation of messages by the minimum idle line time, the following sequence is recommended:

- 1. Write the last byte of the first message to STX.
- 2. Wait for TDRE to go high, indicating the last byte has been transferred to the transmit shift register.
- 3. Clear TE and set TE back to one. This queues an idle line preamble to immediately follow the transmission of the last character of the message (including the stop bit).
- 4. Write the first byte of the second message to STX.

In this sequence, if the first byte of the second message is not transferred to the STX prior to the finish of the preamble transmission, then the transmit data line will simply mark idle until STX is finally written.

#### 9.3.1.9 SCR Idle Line Interrupt Enable (ILIE) Bit 10

When ILIE is set, the SCI interrupt occurs when IDLE is set. When ILIE is cleared, the IDLE interrupt is disabled. ILIE is cleared by hardware and software reset.

An internal flag, the shift register idle interrupt (SRIINT) flag, is the interrupt request to the interrupt controller. SRIINT is not directly accessible to the user.

When a valid start bit has been received, an idle interrupt will be generated if both IDLE (SCI Status Register bit 3) and ILIE equals one. The idle interrupt acknowledge from the interrupt controller clears this interrupt request. The idle interrupt will not be asserted again until at least one character has been received. The result is as follows:

- 1. The IDLE bit shows the real status of the receive line at all times.
- 2. Idle interrupt is generated once for each idle state, no matter how long the idle state lasts.

#### 9.3.1.10 SCR SCI Receive Interrupt Enable (RIE) Bit 11

The RIE bit is used to enable the SCI receive data interrupt. If RIE is cleared, receive data interrupts are disabled, and the RDRF bit in the SCI status register must be polled to determine if the receive data register is full. If both RIE and RDRF are set, the SCI will request an SCI receive data interrupt from the interrupt controller.

Receive interrupts with exception have higher priority than normal receive data interrupts, therefore if exception occurs (PE, FE or OR are set) and REIE is set the SCI will request an SCI receive data with exception interrupt from the interrupt controller. RIE is cleared by hardware and software reset.

#### 9.3.1.11 SCR SCI Transmit Interrupt Enable (TIE) Bit 12

The TIE bit is used to enable the SCI transmit data interrupt. If TIE is cleared, transmit data interrupts are disabled, and the transmit data register empty (TDRE) bit in the SCI status register must be polled to determine if the transmit data register is empty. If both TIE and TDRE are set, the SCI will request an SCI transmit data interrupt from the interrupt controller. TIE is cleared by hardware and software reset.

#### 9.3.1.12 SCR Timer Interrupt Enable (TMIE) Bit 13

The TMIE bit is used to enable the SCI timer interrupt. If TMIE is set (enabled), the timer interrupt requests will be made to the interrupt controller at the rate set by the SCI clock register. The timer interrupt is automatically cleared by the interrupt acknowledge from the interrupt controller. This feature allows DSP programmers to use the SCI baud rate generator as a simple periodic interrupt generator if the SCI is not in use, if external clocks are used for the SCI, or if periodic interrupts are needed at the SCI baud rate. The SCI internal clock is divided by 16 (to match the  $1 \times$  SCI baud rate) for timer interrupt generation. This timer does not require that any SCI pins be configured for SCI use to operate. TMIE is cleared by hardware and software reset.

## 9.3.1.13 SCI Timer Interrupt Rate (STIR) Bit 14

This bit controls a divide by 32 in the SCI Timer interrupt generator. When this bit is cleared, the divide by 32 is inserted in the chain. When the bit is set, the divide by 32 is bypassed. This bit is cleared by hardware and software reset. To ensure proper operation of the timer, STIR may not be change during timer operation (TMIE=1).

## 9.3.1.14 SCR SCI Clock Polarity (SCKP) Bit 15

The clock polarity, sourced or received on the clock pin (SCLK), can be inverted using this bit, eliminating the need for an external inverter. When SCKP equals zero, the clock polarity is positive; when SCKP equals one, the clock polarity is negative. In the synchronous mode, positive polarity means that the clock is normally positive and

transitions negative during data valid; whereas, negative polarity means that the clock is normally negative and transitions positive during valid data. In the asynchronous mode, positive polarity means that the rising edge of the clock occurs in the center of the period that data is valid; negative polarity means that the falling edge of the clock occurs during the center of the period that data is valid. SCKP is cleared on hardware and software reset.

# 9.3.1.15 SCR SCI Receive with Exception Interrupt Enable (REIE) Bit 16

The REIE bit is used to enable the SCI receive data with exception interrupt. If REIE is cleared, receive data with exception interrupt is disabled. If both REIE and RDRF are set, and PE, FE, OR are not all zero the SCI will request an SCI receive data with exception interrupt from the interrupt controller. REIE is cleared by hardware and software reset.

# 9.3.2 SCI Status Register (SSR)

The SSR is an 8-bit read-only register used by the DSP CPU to determine the status of the SCI. When the SSR is read onto the internal data bus, the register contents occupy the low-order byte of the data bus and all high-order portions are zero filled. The status bits are described in the following paragraphs.

# 9.3.2.1 SSR Transmitter Empty (TRNE) Bit 0

The TRNE flag is set when both the transmit shift register and data register are empty to indicate that there is no data in the transmitter. When TRNE is set, data written to one of the three STX locations or to the STXA will be transferred to the transmit shift register and be the first data transmitted. TRNE is cleared when TDRE is cleared by writing data into the transmit data register (STX) or the transmit data address register (STXA), or when an idle, preamble, or break is transmitted. The purpose of this bit is to indicate that the transmitter is empty; therefore, the data written to STX or STXA will be transmitted next – i.e., there is no word in the transmit shift register presently being transmitted. This procedure is useful when initiating the transfer of a message (i.e., a string of characters). TRNE is set by the hardware, software, SCI individual, and stop reset.

# 9.3.2.2 SSR Transmit Data Register Empty (TDRE) Bit 1

The TDRE bit is set when the SCI transmit data register is empty. When TDRE is set, new data may be written to one of the SCI transmit data registers (STX) or transmit data address register (STXA). TDRE is cleared when the SCI transmit data register is written. TDRE is set by the hardware, software, SCI individual, and stop reset.

In the SCI synchronous mode, when using the internal SCI clock, there is a delay of up to 5.5 serial clock cycles between the time that STX is written until TDRE is set, indicating the data has been transferred from the STX to the transmit shift register. There is a two to four serial clock cycle delay between writing STX and loading the transmit shift register; in addition, TDRE is set in the middle of transmitting the second bit. When using an external serial transmit clock, if the clock stops, the SCI transmitter stops. TDRE will not be set until the middle of the second bit transmitted after the external clock starts. Gating the external clock off after the first bit has been transmitted will delay TDRE indefinitely.

In the SCI asynchronous mode, the TDRE flag is not set immediately after a word is transferred from the STX or STXA to the transmit shift register nor when the word first begins to be shifted out. TDRE is set two cycles of the  $16 \times \text{clock}$  after the start bit – i.e., two  $16 \times \text{clock}$  cycles into to transmission time of the first data bit.

# 9.3.2.3 SSR Receive Data Register Full (RDRF) Bit 2

The RDRF bit is set when a character is transferred to the SCI receive data register from the SCI receive shift register (regardless of the error bits condition). RDRF is cleared when the SCI receive data register is read or by the hardware, software, SCI individual, and stop reset.

# 9.3.2.4 SSR Idle Line Flag (IDLE) Bit 3

IDLE is set when 10 (or 11) consecutive ones are received. IDLE is cleared by a start-bit detection. The IDLE status bit represents the status of the receive line. The transition of IDLE from zero to one can cause an IDLE interrupt (ILIE). IDLE is cleared by the hardware, software, SCI individual, and stop reset.

# 9.3.2.5 SSR Overrun Error Flag (OR) Bit 4

The OR flag is set when a byte is ready to be transferred from the receive shift register to the receive data register (SRX) that is already full (RDRF=1). The receive shift register data is not transferred to the SRX. The OR flag indicates that character(s) in the receive data stream may have been lost. The only valid data is located in the SRX. OR is cleared when the SCI status register is read, followed by a read of SRX. The OR bit clears the FE and PE bits – i.e., overrun error has higher priority than FE or PE. OR is cleared by the hardware, software, SCI individual, and stop reset.

# 9.3.2.6 SSR Parity Error (PE) Bit 5

In the 11-bit asynchronous modes, the PE bit is set when an incorrect parity bit has been detected in the received character. It is set simultaneously with RDRF for the byte which contains the parity error – i.e., when the received word is transferred to the SRX. If PE is set, it does not inhibit further data transfer into the SRX. PE is cleared when the SCI status register is read, followed by a read of SRX. PE is also cleared by the hardware, software, SCI individual, or stop reset. In the 10-bit asynchronous mode, the 11-bit multidrop mode, and the 8-bit synchronous mode, the PE bit is always cleared since there is no parity bit in these modes. If the byte received causes both parity and overrun errors, the SCI receiver will only recognize the overrun error.

# 9.3.2.7 SSR Framing Error Flag (FE) Bit 6

The FE bit is set in the asynchronous modes when no stop bit is detected in the data string received. FE and RDRE are set simultaneously – i.e., when the received word is transferred to the SRX. However, the FE flag inhibits further transfer of data into the SRX until it is cleared. FE is cleared when the SCI status register is read followed by reading the SRX. The hardware, software, SCI individual, and stop reset also clear FE. In the 8-bit

synchronous mode, FE is always cleared. If the byte received causes both framing and overrun errors, the SCI receiver will only recognize the overrun error.

9.3.2.8 SSR Received Bit 8 (R8) Address Bit 7

In the 11-bit asynchronous multidrop mode, the R8 bit is used to indicate whether the received byte is an address or data. R8 is not affected by reading the SRX or status register. The hardware, software, SCI individual, and stop reset clear R8.

### 9.3.3 SCI Clock Control Register (SCCR)

The SCCR is a 16-bit read/write register, which controls the selection of the clock modes and baud rates for the transmit and receive sections of the SCI interface. The control bits are described in the following paragraphs. The SCCR is cleared by hardware reset. The basic points of the clock generator are as follows:

- 1. The SCI logic always uses a  $16 \times$  internal clock in the asynchronous modes and always uses a  $2 \times$  internal clock in the synchronous mode. The maximum internal clock available to the SCI peripheral block is the oscillator frequency divided by 4. With a 66-MHz DSP56301 processor, this gives a maximum data rate of 1031.25 Kbps for asynchronous data and 8.25 Mbps for synchronous data. These maximum rates are the same for internally or externally supplied clocks.
- 2. The  $16 \times$  clock is necessary for the asynchronous modes to synchronize the SCI to the incoming data.
- 3. For the asynchronous modes, the user must provide a  $16 \times \text{clock}$  if he wishes to use an external baud rate generator (i.e., SCLK input).
- 4. For the asynchronous modes, the user may select either  $1 \times \text{ or } 16 \times \text{ for}$  the output clock when using internal TX and RX clocks (TCM=0 and RCM=0).
- 5. The transmit data on the TXD pin changes on the negative edge of the  $1 \times$  serial clock and is stable on the positive edge (SCKP=0). For SCKP equals one, the data changes on the positive edge and is stable on the negative edge.
- 6. The receive data on the RXD pin is sampled on the positive edge (if SCKP=0) or on the negative edge (if SCKP=1) of the 1 × serial clock.
- 7. For the asynchronous mode, the output clock is continuous.
- 8. For the synchronous mode, a  $1 \times \text{clock}$  is used for the output or input baud rate. The maximum  $1 \times \text{clock}$  is the crystal frequency divided by 8.
- 9. For the synchronous mode, the clock is gated.
- 10. For the synchronous mode, the transmitter and receiver are synchronous with each other.
- 9.3.3.1 SCCR Clock Divider (CD11–CD0) Bits 11–0

The CD11–CD0 bits specify the divide ratio of the prescale divider in the SCI clock generator. A divide ratio from 1 to 4096 (CD11–CD0=\$000 0 to \$FFF) may be selected.

Hardware and software reset clear CD11–CD0.

9.3.3.2 SCCR Clock Out Divider (COD) Bit 12

The clock output divider is controlled by COD and the SCI mode. If the SCI mode is synchronous, the output divider is fixed at divide by 2; if the SCI mode is asynchronous, and

- 1. If COD equals zero and SCLK is an output (i.e., TCM and RCM=0), the SCI clock is divided by 16 before being output to the SCLK pin; thus, the SCLK output is a 1 × clock.
- 2. If COD equals one and SCLK is an output, the SCI clock is fed directly out to the SCLK pin; thus, the SCLK output is a 16 × baud clock.

The COD bit is cleared by hardware and software reset.

9.3.3.3 SCCR SCI Clock Prescaler (SCP) Bit 13

The SCI SCP bit selects a divide by 1 (SCP=0) or divide by 8 (SCP=1) prescaler for the clock divider. The output of the prescaler is further divided by 2 to form the SCI clock. Hardware and software reset clear SCP.

9.3.3.4 SCCR Receive Clock Mode Source Bit (RCM) Bit 14

RCM selects internal or external clock for the receive. RCM when equals zero selects the internal clock; RCM when equals one selects the external clock from the SCLK pin. Hardware and software reset clear RCM.

### 9.3.3.5 SCCR Transmit Clock Source Bit (TCM) Bit 15

The TCM bit selects internal or external clock for the transmitter. TCM equals zero selects the internal clock; TCM equals one selects the external clock from the SCLK pin. Hardware and software reset clear TCM.

# 9.3.4 SCI Data Registers

The SCI data registers are divided into two groups: receive and transmit. There are two receive registers – a receive data register (SRX) and a serial-to-parallel receive shift register. There are also two transmit registers – a transmit data register (called either STX or STXA) and a parallel-to-serial transmit shift register.

# 9.3.4.1 SCI Receive Registers

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



Figure 9-2. SCI Programming Model - Data Registers

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

The length and format of the serial word is defined by the WDS0, WDS1, and WDS2 control bits in the SCI control register. In the synchronous modes, the start bit, the eight data bits with LSB first, the address/data indicator bit and/or the parity bit, and the stop bit are received in that order if SSFTD equals zero. If SSFTD equals one, the data bits are transmitted MSB first. The clock source is defined by the receive clock mode (RCM) select bit in the SCR. In the synchronous mode, the synchronization is provided by gating the clock. In either mode, when a complete word has been clocked in, the contents of the shift register can be transferred to the SRX and the flags; RDRF, FE, PE, and OR are changed appropriately. Because the operation of the SCI receive shift register is transparent to the DSP, the contents of this register are not directly accessible to the programmer.

### 9.3.4.2 SCI Transmit Registers

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

The transfer from either STX or STXA to the transmit shift register occurs automatically, but not immediately, when the last bit from the previous word has been shifted out – i.e., the transmit shift register is empty. Like the receiver, the transmitter is double buffered. However, there will be a two to four serial clock cycle delay between when the data is transferred from either STX or STXA to the transmit shift register and when the first bit appears on the TXD pin. (A serial clock cycle is the time required to transmit one data bit). The transmit shift register is not directly addressable, and a dedicated flag for this register does not exist. Because of this fact and the two to four cycle delay, two bytes cannot be written consecutively to STX or STXA without polling, as the second byte might overwrite the first byte. The TDRE flag should always be polled prior to writing STX or STXA to prevent overruns unless transmit interrupts have been enabled. Either STX or STXA is usually written as part of the interrupt service routine. Of course, the interrupt will only be generated if TDRE equals one. The transmit shift register is indirectly visible via the TRNE bit in the SSR.

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

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

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

It is possible that two or three transmission commands are set simultaneously:

- 1. A preamble (TE was toggled).
- 2. A break (SBK was set or was toggled).
- 3. There is data for transmission (TDRE=0).

After the current character transmission, if two or more of these commands are set, the transmitter will execute them in the following order:

- 1. Preamble
- 2. Break
- 3. Data

# 9.4 **OPERATING MODES**

#### 9.4.1 Register Contents After Reset

There are four different methods of resetting the SCI.

1) Hardware and 2) software resets clear the port control register bits, which configure all I/O as general-purpose input. The SCI will remain in the reset state while all SCI pins are programmed as general-purpose I/O (CC2, CC1, and CC0=0); the SCI will become active only when at least one of the SCI I/O pins is programmed as not general-purpose I/O.

3) During program execution, the CC2, CC1, and CC0 bits may be cleared (individual reset), which will cause the SCI to stop serial activity and enter the reset state. All SCI status bits will be set to their reset state; however, the contents of the interface control register are not affected, allowing the DSP program to reset the SCI separately from the other internal peripherals. During individual reset internal DMA accesses to the data registers of the SCI are not valid and data read will be unexpected.

4) Executing the STOP instruction halts operation of the SCI until the DSP is restarted, causing the SSR to be reset. No other SCI registers are affected by the STOP instruction. Table 9-2. illustrates how each type of reset affects each register in the SCI.

| Register | Bit Bit Number |                  | Reset Type |          |          |          |  |
|----------|----------------|------------------|------------|----------|----------|----------|--|
| Bit      | Mnemonic       | Dit Number       | HW Reset   | SW Reset | IR Reset | ST Reset |  |
|          | REIE           | 16               | 0          | 0        | _        | _        |  |
|          | SCKP           | 15               | 0          | 0        | —        | _        |  |
|          | TMIE           | 14               | 0          | 0        | -        | _        |  |
|          | TMIE           | 13               | 0          | 0        | -        | _        |  |
|          | TIE            | 12               | 0          | 0        | -        | —        |  |
|          | RIE            | 11               | 0          | 0        | -        | _        |  |
|          | ILIE           | 10               | 0          | 0        | -        | —        |  |
|          | TE             | 9                | 0          | 0        | -        | _        |  |
| SCR      | RE             | 8                | 0          | 0        | -        | _        |  |
|          | WOMS           | 7                | 0          | 0        | _        | _        |  |
|          | RWU            | 6                | 0          | 0        | -        | _        |  |
|          | WAKE           | 5                | 0          | 0        | -        | _        |  |
|          | SBK            | 4                | 0          | 0        | _        | _        |  |
|          | SSFTD          | 3                | 0          | 0        | -        | _        |  |
|          | WDS (2–0)      | 2–0              | 0          | 0        | -        | _        |  |
|          | R8             | 7                | 0          | 0        | 0        | 0        |  |
|          | FE             | 6                | 0          | 0        | 0        | 0        |  |
|          | PE             | 5                | 0          | 0        | 0        | 0        |  |
| SSR      | OR             | 4                | 0          | 0        | 0        | 0        |  |
|          | IDLE           | 3                | 0          | 0        | 0        | 0        |  |
|          | RDRF           | 2                | 0          | 0        | 0        | 0        |  |
|          | TDRE           | 1                | 1          | 1        | 1        | 1        |  |
|          | TRNE           | 0                | 1          | 1        | 1        | 1        |  |
|          | ТСМ            | 15               | 0          | 0        | _        | —        |  |
|          | RCM            | 14               | 0          | 0        | _        | —        |  |
| SCCR     | SCP            | 13               | 0          | 0        | _        | —        |  |
|          | COD            | 12               | 0          | 0        | _        | _        |  |
|          | CD (11–0)      | 11–0             | 0          | 0        | _        | —        |  |
| SRX      | SRX (23–0)     | 23–16, 15–8, 7–0 | _          | _        | -        | —        |  |
| STX      | STX (23–0)     | 23–0             | —          | _        | -        | —        |  |
| SRSH     | SRS (8–0)      | 8–0              | _          | _        | -        | _        |  |
| STSH     | STS (8–0)      | 8–0              | -          | _        | -        | —        |  |

#### Table 9-2. SCI Registers after Reset

NOTES:

SRSH – SCI receive shift register, STSH – SCI transmit shift register

HW – Hardware reset is caused by asserting the external RESET pin.

SW – Software reset is caused by executing the RESET instruction.

IR – Individual reset is caused by clearing PCRE (bits 0–2) (configured for general-purpose I/O).

ST – Stop reset is caused by executing the STOP instruction.

1 - The bit is set during the xx reset.

0 – The bit is cleared during the xx reset.

-- The bit is not changed during the xx reset

### 9.4.2 SCI Initialization

The correct way to initialize the SCI is as follows:

- 1. Hardware or software reset.
- 2. Program SCI control registers.
- 3. Configure SCI pins (at least one) as not general-purpose I/O.

If interrupts are to be used, the pins must be selected, and interrupts must be enabled and unmasked before the SCI will operate. The order does not matter; any one of these three requirements for interrupts can be used to finally enable the SCI. Figure 9-1 shows the meaning of the individual bits in the SCR and SCCR. Synchronous applications usually require exact frequencies, which require that the crystal frequency be chosen carefully. An alternative to selecting the system clock to accommodate the SCI requirements is to provide an external clock to the SCI.

#### 9.4.3 SCI Exceptions

The SCI can cause five different exceptions in the DSP. These exceptions are as follows (ordered from the highest to the lowest priority):

- 1. SCI Receive Data with Exception Status caused by receive data register full with a receiver error (parity, framing, or overrun error). Clearing the pending interrupt is done by reading the SCI status register, followed by a read of SRX. A long interrupt service routine should be used to handle the error condition. This interrupt is enabled by SCR bit 16 (REIE).
- 2. SCI Receive Data caused by receive data register full. Reading SRX clears the pending interrupt. This error-free interrupt may use a fast interrupt service routine for minimum overhead. This interrupt is enabled by SCR bit 11 (RIE).
- 3. SCI Transmit Data caused by transmit data register empty. Writing STX clears the pending interrupt. This error-free interrupt may use a fast interrupt service routine for minimum overhead. This interrupt is enabled by SCR bit 12 (TIE).
- 4. SCI Idle Line caused by the receive line entering the idle state (10 or 11 bits of ones). This interrupt is latched and then automatically reset when the interrupt is accepted. This interrupt is enabled by SCR bit 10 (ILIE).
- 5. SCI Timer caused by the baud rate counter reaching zero. This interrupt is automatically reset when the interrupt is accepted. This interrupt is enabled by SCR bit 13 (TMIE).

# 9.5 GPIO - pins and registers

The GPIO functionality of port SCI is controlled by three registers: Port Control register (PCR), Port Direction Register (PRR) and Port Data register (PDR).

### 9.5.1 Port Control Register (PCR)

The read/write 16 bit Port Control Register controls the functionality of SCI GPIO pins. When the PCR is read to the internal data bus, the register contents occupy the two low-order bytes of the data bus, and the remaining bits are read as zeros. When written the most significant byte should be written zero for future compatibility.



Figure 9-3. Port Control Register (PCR)

Each of PC(2: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 SCI pin. When a PC[i] bit is cleared, the corresponding port pin is configured as GPIO pin.

Hardware and software reset clear all PCR bits.

#### 9.5.2 Port Direction Register (PRR)

The read/write 16 bit Port Direction Register controls the direction of SCI GPIO pins. When the PRR is read to the internal data bus, the register contents occupy the two low-order bytes of the data bus, and the remaining bits are read as zeros. When written the most significant byte should be written zero for future compatibility.



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

The following table describe the port pin configurations.

| PC[i] | PDC[i] | Port Pin[i] Function |
|-------|--------|----------------------|
| 1     | Х      | SCI                  |
| 0     | 0      | GPIO input           |
| 0     | 1      | GPIO output          |

### 9.5.3 Port Data register (PDR)

The read/write 16 bit Port Data Register is used to read or write data to/from SCI GPIO pins.Bits PD(2:0) are used to read or write data from/to the corresponding port pins if they are configured as GPIO (by PC(2:0) bits in PCR). 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.When the PDR is read to the internal data bus, the register contents occupy the two low-order bytes of the data bus, and the remaining bits are read as zeros. When written the most significant byte should be written zero for future compatibility.



READ AS ZERO, SHOULD BE WRITTEN WITH ZERO FOR FUTURE COMPATIBILITY

Hardware and software reset clear all PDR bits.

# Appendix A PROGRAMS

### A-1 BOOTSTRAP PROGRAM

```
; BOOTSTRAP CODE FOR DSP56301 - (C) Copyright 1994 Motorola Inc.
; Revised April, 17 1995.
; Bootstrap through the Host Interface, External EPROM or SCI.
; This is the Bootstrap program contained in the DSP56301 192-word Boot
; ROM. This program can load any program RAM segment from an external
; EPROM, from the Host Interface or from the SCI serial interface.
; If MC:MB:MA=000, then the Boot ROM is bypassed and the DSP56301 will start
; fetching instructions beginning with the address $C00000 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 MC:MB:MA=001, 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 MC:MB:MA=010, then it loads the program RAM from the SCI interface.
; The number of program words to be loaded and the starting address must
; be specified. The SCI bootstrap code expects to receive 3 bytes
; specifying the number of program words, 3 bytes specifying the address
; to start loading the program words and then 3 bytes for each program
; word to be loaded. The number of words, the starting address and the
; program words are received least significant byte first followed by the
; mid and then by the most significant byte. After receiving the
```

; program words, program execution starts in the same address where ; loading started. The SCI is programmed to work in asynchronous mode ; with 8 data bits, 1 stop bit and no parity. The clock source is ; external and the clock frequency must be 16x the baud rate. ; After each byte is received, it is echoed back through the SCI ; transmitter. ; If MC:MB:MA=100, then it loads the program RAM from the Host ; Interface programmed to operate in the PCI target (slave) mode. ; The HOST PCI bootstrap code expects to read a 32-bit word ; specifying the number of program words, a 32-bit word specifying the address ; to start loading the program words and then a 32-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. ; The HOST Processor must first configure the Host Interface as PCI slave ; and then start writing data to the Host Interface. The HOST Processor must ; program the HCTR HTF1-HTF0 bits with one of the combinations: 01, 10, 11. ; If MC:MB:MA=101, then it loads the program RAM from the Host ; Interface programmed to operate in the ISA (slave) mode. ; Using self configuration mode, the base address in CBMA is initially written ; with \$2f which corresponds to an ISA HTXR address of \$2fe (Serial Port 2 Modem ; Status read only register). ; The HOST ISA bootstrap code expects to read 32 consecutive times the "magic ; number" \$0037. Subsequently the bootstrap code expects to read a 16-bit word ; which is the designated ISA Port Address; this address is written into the ; CBMA. The HOST Processor must poll for the Host Interface to be reconfigured. ; This must be done by reading the HSTR and verifying that the value \$0013 is ; read. From this moment the HOST Processor may start writing data to the ; Host Interface. ; 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.

; Note that this ISA connection implies 16 bit data width access only and ; that the number of 16-bit wide words that are transferred must be even. ; The code to be loaded into 56301 is stored in the HOST Processor 16-bit ; wide memory in the following format: М0 L0 ; Н0 ; L1Н1 M1 ; L2 ; М2 ; The boot program will convert every three 16-bit wide host words to two 24-bit ; wide 56301 opcodes in the following format: н0 M0 | L0 ; H1 M1 L1; ; Required 56301 to ISA connection: ; HA[10] <- SBHE ; selects HI32 (base address 10011111) ; <- SA[0] ; selects HI32 (base address 10011111) HA[9] ; HA[8:3] <- SA[9:4] ; selects HI32 (base address 10011111) ; HA[2:0] <- SA[3:1] ; selects HTXR registers ; ; HD[15:0] - SD[15:0] ; Data bus HD[23:16] - Not connected ; High Data Bus - Should be pulled up or down ; HDBEN\_ -> OE\_ ; Output enable of transcievers ; HDBDR -> DIR ; Direction of transcievers ; HSAK\_ -> IO16\_ ; 16 bit data word ; ; HBS <- Vcc ; Bus Strobe disabled HAEN <- AEN ; DMA cycle enable ; -> CHRDY ; Channel ready ; HTA HWR <- IOWC ; IO/DMA write strobe ; HRD ; IO/DMA read strobe ; <- IORC ; HRST <- inverted RSTDRV ; invert ISA reset ; ; NOTE: the Host Processor must program the Host Interface to operate in the zero ; fill mode (HTF1-HTF0 = 01 in HCTR). ; ; If MC:MB:MA=110, then it loads the program RAM from the Host ; Interface programmed to operate in the Universal Bus (UB) mode, ; in double-strob pin configuration. ; The HOST UB bootstrap code expects accesses that are byte wide. ; The HOST UB 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 user must externally decode the port address with active low logic and ; connect the select line to HAEN; all the address lines shall be pulled down ; except for A3, A2 and A1 that select the HOST Interface registers. ; ; When booting through the Host Interface it is recommended that the Host ; boot program will verify that the Host Interface is operational, by ; reading the status register (HSTR) and confirm that TRDY=1. ; ; If MC:MB:MA=111, then it loads the program RAM from the Host ; Interface programmed to operate in the Universal Bus (UB) mode, ; in single-strob pin configuration.

; Other than the single-strob pin configuration, this mode is identical to ; the double-strob pin configuration UB mode (MC:MB:MA=110).

| BOOT<br>AARV | equ<br>equ | \$D00000<br>\$D00409 | ;;;;; | this is the location in P memory<br>on the external memory bus<br>where the external byte-wide<br>EPROM would be located<br>AAR1 selects the EPROM as CE~<br>mapped as P from \$D00000 to<br>\$DFFFFF, active low |
|--------------|------------|----------------------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| M_SSR        | EQU        | \$FFFF93             | ;     | SCI Status Register                                                                                                                                                                                               |
| M_STXL       | EQU        | \$FFFF95             |       | SCI Transmit Data Register (low)                                                                                                                                                                                  |
| M_SRXL       | EQU        | \$FFFF98             | ;     | SCI Receive Data Register (low)                                                                                                                                                                                   |
| M_SCCR       | EQU        | \$FFFF9B             | ;     | SCI Clock Control Register                                                                                                                                                                                        |
| M_SCR        | EQU        | \$FFFF9C             | ;     | SCI Control Register                                                                                                                                                                                              |
| M_PCRE       | EQU        | \$FFFF9F             | ;     | Port E Control register                                                                                                                                                                                           |
| M_DCTR       | EQU        | \$FFFFC5             | ;     | DSP CONTROL REGISTER (DCTR)                                                                                                                                                                                       |
| M_DPMC       | EQU        | \$FFFFC7             | ;     | DSP PCI MASTER CONTROL REGISTER (DPMC)                                                                                                                                                                            |
| M_DPAR       | EQU        | \$FFFFC8             | ;     | DSP PCI ADDRESS REGISTER (DPAR)                                                                                                                                                                                   |
| M_DSR        | EQU        | \$FFFFC9             | ;     | DSP STATUS REGISTER (DSR)                                                                                                                                                                                         |
| M_DRXR       | EQU        | \$FFFFCB             | ;     | DSP RECEIVE DATA FIFO (DRXR)                                                                                                                                                                                      |
| M_AAR1       | EQU        | \$FFFF8              | ;     | Address Attribute Register 1                                                                                                                                                                                      |
|              |            |                      |       |                                                                                                                                                                                                                   |

ORG PL:\$ff0000,PL:\$ff0000 ; bootstrap code starts at \$ff0000

START

| 0    |                       |                                                 |
|------|-----------------------|-------------------------------------------------|
|      | clr a #\$0a,X0        | ; clear a and load X0 with constant 0a0000      |
|      | jclr #2,omr,EPRSCILD  | ; If MC:MB:MA=0xx, go load from EPROM/SCI       |
|      | jclr #1,omr,IHOSTLD   | ; If MC:MB:MA=10x, go load from PCI/ISA HOST    |
|      | jclr #0,omr,UB2HOSTLD | ; If MC:MB:MA=110, go load from double-strob UB |
| Host |                       |                                                 |
|      |                       |                                                 |

; If MC:MB:MA=111, go load from single-strob UB Host

; This is the routine that loads from the Host Interface in UB (UNIVERSAL) mode, ; with single-strob pin configuration (RD/WR,DS). ; MC:MB:MA=111 - Host UB UB1HOSTLD ; Activate the UB mode movep #\$3e2000,X:M\_DCTR ; HM=\$3 (UB) ; HIRD=1 (HIRQ pin - drive high enabled) ; HIRH=1 (HIRQ\_ pin - handshake enabled) ; HRSP=1 (HRST pin - active low) ; HTAP=0 (HTA pin - active high) ; HDSM=1 (Double-strob pin mode disabled) bra <UB CONT ; Continue as in double-strob mode ; This is the routine that loads from the Host Interface in UB (UNIVERSAL) mode, ; with double-strob pin configuration (RD,WR). ; MC:MB:MA=110 - Host UB UB2HOSTLD ; Activate the UB mode movep #\$3e0000,X:M\_DCTR ; HM=\$3 (UB) ; HIRD=1 (HIRQ\_ pin - drive high enabled) ; HIRH=1 (HIRQ\_ pin - handshake enabled) ; HRSP=1 (HRST pin - active low) ; HTAP=0 (HTA pin - active high) ; HDSM=0 (Double-strob pin mode enabled) UB CONT do #6, LOOP0 ; read # of words and start address jclr #2,X:M\_DSR,\* ; Wait for SRRQ to go high (i.e. data ready) movep X:M DRXR,a2 asr #8,a,a ; Shift 8 bit data into A1 LOOPO ; starting address for load move al,r0 move al,r1 ; save it in r1 ; a0 holds the number of words ; Download P memory through UB do a0,\_LOOP1 ; Load instruction words do #3, LOOP2 ; for each byte LBLA jset #2,X:M\_DSR,\_LBLB ; Wait for SRRQ to go high (i.e. data ready) jclr #3,X:M\_DSR,\_LBLA ; If HF0=1, stop loading new data. enddo ; Must terminate the do loop enddo ; Must terminate the do loop bra <\_LOOP1 LBLB ; Store 16-bit data in accumulator movep X:M\_DRXR,a2 asr #8,a,a ; Shift 8 bit data into A1 ; and go get another 24-bit word. LOOP2

; Store 24-bit data in P mem. move a1,p:(r0)+ LOOP1 ; and go get another 24-bit word. ; finish bootstrap bra <FINISH IHOSTLD jclr #0,omr,PCIHOSTLD ; If MC:MB:MA=100, go load from PCI HOST ; This routine loads from the Host Interface in ISA (UNIVERSAL) mode. ; MC:MB:MA=101 - Host ISA ; Using self configuration mode, the base address in CBMA is written with ; \$2f which corresponds to an ISA HTXR address of \$2fe (Serial Port 2 Modem ; Status read only register). ISAHOSTLD movep #\$5a0000,X:M\_DCTR ; Configure HI32 as Self-Config movep #\$00002f,X:M DPMC ; write to DPMC rep #4 movep X0,X:M DPAR ; write to DPAR (CSTR+CCMR,CCCR+CRID,CLAT,CBMA) ; completing 32 bit write ; Switch to ISA mode movep X0,X:M DCTR ; Software personal reset move #\$010020,y1 ; width 16, offset 32 ; (also used as replacment to needed NOP after sw reset!) movep #\$3a0000,X:M\_DCTR ; HM=\$3 (UB) ; HIRD=1 (HIRQ\_ pin - drive high enabled) ; HIRH=0 (HIRQ\_ pin - handshake disabled) ; HRSP=1 (HRST pin - active low) ; HDRP=0 (HDRQ pin - active high) ; HTAP=0 (HTA pin - active high) ; HDSM=0 (Data-strob pin mode enabled) ; read the "magic sequence" 32 consecutive words with value \$37 LBLC do #32,\_LOOP3 jclr #2,X:M\_DSR,\* ; Wait for SRRQ to go high (i.e. data ready) movep X:M\_DRXR,A1 ; Store 24-bit data into A1 and #\$00ffff,A ; Mask upper byte cmp #\$37,A ; Compare the 24-bit dat to \$000037 ; If dat = \$37 then go back to loop jeq \_LBLD enddo ; else break the loop and retry bra <\_LBLC LBLD nop LOOP3 ; read new CBMA value ("ISA base address") jclr #2,X:M\_DSR,\* ; Wait for SRRQ to go high (i.e. data ready)

; Store 24-bit data into A1 movep X:M\_DRXR,A1 ; Switch to Self Configuration mode movep X0,X:M DCTR ; Software personal reset movep A1,X:M DPMC ; write to DPMC ; (also used as replacment to needed NOP after sw reset!) movep #\$5a0000,X:M\_DCTR ; Configure HI32 as Self-Config rep #4 movep X0,X:M DPAR ; write to DPAR (CSTR+CCMR,CCCR+CRID,CLAT,CBMA) ; Switch to ISA mode movep X0,X:M DCTR ; Software personal reset move #\$010010,x1 ; width 16, offset 16 ; (also used as replacment to needed NOP after sw reset!) movep #\$3a0010,x:M\_DCTR ; HM=\$3 (UB) ; HIRD=1 (HIRQ\_ pin - drive high enabled) ; HIRH=0 (HIRQ\_ pin - handshake disabled) ; HRSP=1 (HRST pin - active low) ; HDRP=0 (HDRQ pin - active high) ; HTAP=0 (HTA pin - active high) ; HDSM=0 (Double-strob pin mode enabled) ; HF4 =1 (turn on flag 4 for handshake) jclr #2,X:M\_DSR,\* ; Wait for SRRQ to go high (i.e. data ready) movep X:M DRXR,a0 ; Store number of words ; Wait for SRRQ to go high (i.e. data ready) jclr #2,X:M\_DSR,\* movep X:M\_DRXR,x0 ; Store starting address jclr #2,X:M\_DSR,\* ; Wait for SRRQ to go high (i.e. data ready) movep X:M\_DRXR,y0 ; Store starting address insert x1,x0,a ; concatenate next 16-bit word insert y1,y0,a ; concatenate next 16-bit word move al,r0 ; start to p-mem move a0,a1 ; number of words to transfer ; Download P memory through UB lsr a r0,r1 ; divide loop count by 2 and save r0 do al, LOOP4 ; Load instruction words LBLE jset #2,X:M DSR, LBLF ; Wait for SRRQ to go high (i.e. data ready) jclr #3,X:M DSR, LBLE ; If HF0=1, stop loading new data. enddo ; Must terminate the do loop bra <\_LOOP4 LBLF movep X:M\_DRXR,a0 ; Store 16-bit data in accumulator LBLG jset #2,X:M DSR, LBLH ; Wait for SRRQ to go high (i.e. data ready) jclr #3,X:M\_DSR,\_LBLG ; If HF0=1, stop loading new data. enddo ; Must terminate the do loop bra <\_LOOP4 LBLHmovep X:M DRXR,x0 ; Store 16-bit data in register

| LBLI               |                                                          |                                                                                                                                                                                                                            |
|--------------------|----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| LBLJ               |                                                          | ; Wait for SRRQ to go high (i.e. data ready)<br>; If HF0=1, stop loading new data.<br>; Must terminate the do loop                                                                                                         |
| LOOP4              | insert x1,x0,a<br>insert y1,y0,a                         | <pre>; Store 16-bit data in register<br/>; concatenate next 16-bit word<br/>; concatenate next 16-bit word<br/>; Store 24-bit data in P mem.<br/>; Store 24-bit data in P mem.<br/>; and go get another 24-bit word.</pre> |
| —                  | bra <finish< td=""><td>; finish bootstrap</td></finish<> | ; finish bootstrap                                                                                                                                                                                                         |
| ; This             |                                                          | s from the Host Interface in PCI mode.                                                                                                                                                                                     |
| PCIHOST            | LD                                                       |                                                                                                                                                                                                                            |
|                    |                                                          | <pre>; Configure HI32 as PCI<br/>; Wait for SRRQ to go high (i.e. data ready)<br/>; Store number of words<br/>; Wait for SRRQ to go high (i.e. data ready)<br/>; Store starting address<br/>; save r0</pre>                |
|                    | do a0,_LOOP5                                             | ; Load instruction words                                                                                                                                                                                                   |
| _LBLK              |                                                          | <pre>; Wait for SRRQ to go high (i.e. data ready) ; If HF0=1, stop loading data. Else check SRRQ. ; Must terminate the do loop</pre>                                                                                       |
| _LBLL<br>_LOOP5    | <pre>movep X:M_DRXR,P:(R0)+</pre>                        | ; Store 24-bit data in P mem.<br>; and go get another 24-bit word.<br>; finish bootstrap                                                                                                                                   |
|                    | bra <finish< td=""><td>;</td></finish<>                  | ;                                                                                                                                                                                                                          |
| ;======<br>EPRSCIL |                                                          |                                                                                                                                                                                                                            |
|                    | jclr #1,omr,EPROMLD                                      | ; If MC:MB:MA=001, go load from EPROM                                                                                                                                                                                      |
| ; This             | is the routine that load<br>:MA=010 - external SCI c     |                                                                                                                                                                                                                            |
| SCILD              |                                                          | ; Configure SCI Control Reg<br>; Configure SCI Clock Control Reg<br>; Configure SCLK, TXD and RXD                                                                                                                          |

do #6,\_LOOP6 ; get 3 bytes for number of ; program words and 3 bytes ; for the starting address ; Wait for RDRF to go high jclr #2,X:M SSR,\* movep X:M SRXL,A2 ; Put 8 bits in A2 jclr #1,X:M\_SSR,\* ; Wait for TDRE to go high movep A2,X:M\_STXL ; echo the received byte asr #8,a,a LOOP6 move al,r0 ; starting address for load move al.rl ; save starting address do a0,\_LOOP7 ; Receive program words do #3,\_LOOP8 jclr #2,X:M SSR,\* ; Wait for RDRF to go high jclr #2,X:M\_SSR,\* movep X:M\_SRXL,A2 ; Put 8 bits in A2 jclr #1,X:M\_SSR,\* ; Wait for TDRE to go high movep a2,X:M\_STXL ; echo the received byte asr #8,a,a LOOP8 movem a1,p:(r0)+ ; Store 24-bit result in P mem. LOOP7 bra <FINISH ; Boot from SCI done ; This is the routine that loads from external EPROM. ; MC:MB:MA=001 EPROMLD ; r2 = address of external EPROM move #BOOT,r2 movep #AARV,X:M AAR1 ; aarl configured for SRAM types of access do #6,\_LOOP9 ; read number of words and starting address movem p:(r2)+,a2 ; Get the 8 LSB from ext. P mem. ; Shift 8 bit data into A1 asr #8,a,a LOOP9 ; move al,r0 ; starting address for load ; save it in r1 move al,rl ; a0 holds the number of words do a0, LOOP10 ; read program words do #3,\_LOOP11 ; Each instruction has 3 bytes ; Get the 8 LSB from ext. P mem. movem p:(r2)+,a2 asr #8,a,a ; Shift 8 bit data into A1 ; Go get another byte. LOOP11 movem a1,p:(r0)+ ; Store 24-bit result in P mem. ; and go get another 24-bit word. LOOP10 ; Boot from EPROM done ;\_\_\_\_\_\_ FINISH

; This is the exit handler that returns execution to normal

; expanded mode and jumps to the RESET vector.

andi #\$0,ccr ; Clear CCR as if RESET to 0. jmp (r1) ; Then go to starting Prog addr.

; End of bootstrap code. Number of program words: 186

### A-2 XI/O EQUATES

```
EQUATES for DSP56301 I/O registers and ports
;
page 132,55,0,0,0
      opt mex
ioequ ident 1,0
;
     EQUATES for I/O Port Programming
;
;
;------
;
    Register Addresses
M_DATHEQU$FFFFCF; Host port GPIO data RegisterM_DIRHEQU$FFFFCE; Host port GPIO direction RegisterM_PCRCEQU$FFFFBF; Port C Control RegisterM_PCRCEQU$FFFFBF; Port C Control Register
M_PRRC EQU $FFFFBE
M_PDRC EQU $FFFFBD
M_PCRD EQU $FFFFAF
                      ; Port C Direction Register
                     ; Port C GPIO Data Register
                      ; Port D Control register
M PRRD EQU
           $FFFFAE
                      ; Port D Direction Data Register
                     ; Port D GPIO Data Register
; Port E Control register
; Port E Direction Register
M_PDRD EQU
           $FFFFAD
M_PCRE EQU
           $FFFF9F
M_PRRE EQU
           $FFFF9E
M PDRE EQU
                      ; Port E Data Register
           $FFFF9D
M_OGDB EQU $FFFFFC
                  ; OnCE GDB Register
;
    EQUATES for Host Interface
;
;
;------
; Register Addresses
```

| M DTXS           | EQU      | \$FFFCD         | ; DSP SLAVE TRANSMIT DATA FIFO (DTXS)          |
|------------------|----------|-----------------|------------------------------------------------|
| M DTXM           | EQU      | \$FFFFCC        | ; DSP MASTER TRANSMIT DATA FIFO (DTXM)         |
| M DRXR           | ΞQU      | ,<br>\$FFFFCB   | ; DSP RECEIVE DATA FIFO (DRXR)                 |
| M_DPSR           | EQU      | \$FFFFCA        | ; DSP PCI STATUS REGISTER (DPSR)               |
| M_DSR            | EQU      | \$FFFFC9        | ; DSP STATUS REGISTER (DSR)                    |
| M DPAR           | EQU      | \$FFFFC8        | ; DSP PCI ADDRESS REGISTER (DPAR)              |
| M_DPMC           | EQU      | \$FFFFC7        | ; DSP PCI MASTER CONTROL REGISTER (DPMC)       |
| M_DPCR           | EQU      | \$FFFFC6        | ; DSP PCI CONTROL REGISTER (DPCR)              |
| M_DCTR           | EQU      | \$FFFFC5        | ; DSP CONTROL REGISTER (DCTR)                  |
|                  |          |                 |                                                |
| ;                | Host Cor | trol Register B | it Flags                                       |
| M_HCIE           | EQU      | 0               | ; Host Command Interrupt Enable                |
| M_STIE           | EQU      | 1               | ; Slave Transmit Interrupt Enable              |
| M_SRIE           | EQU      | 2               | ; Slave Receive Interrupt Enable               |
| $M_{HF35}$       | EQU      | \$38            | ; Host Flags 5-3 Mask                          |
| M_HF3            | EQU      | 3               | ; Host Flag 3                                  |
| M_HF4            | EQU      | 4               | ; Host Flag 4                                  |
| M_HF5            | EQU      | 5               | ; Host Flag 5                                  |
| M_HINT           | EQU      | 6               | ; Host Interrupt A                             |
| M_HDSM           | EQU      | 13              | ; Host Data Strobe Mode                        |
| M_HRWP           | EQU      | 14              | ; Host RD/WR Polarity                          |
| M_HTAP           | EQU      | 15              | ; Host Transfer Acknowledge Polarity           |
| M_HDRP           | EQU      | 16              | ; Host Dma Request Polarity                    |
| M_HRSP           | EQU      | 17              | ; Host Reset Polarity                          |
| M_HIRP           | EQU      | 18              | ; Host Interrupt Request Polarity              |
| M_HIRC           | EQU      | 19              | ; Host Interupt Request Control                |
| M HMO            | EQU      | 20              | ; Host Interface Mode                          |
| M_HM1            | EQU      | 21              | ; Host Interface Mode                          |
| M_HM2            | EQU      | 22              | ; Host Interface Mode                          |
| M_HM             | EQU      | \$700000        | ; Host Interface Mode Mask                     |
|                  |          |                 |                                                |
| ;                | Host PCI | Control Registe | er Bit Flags                                   |
| M PMTIE          | EQU      | 1               | ; PCI Master Transmit Interrupt Enable         |
| M_PMRIE          | ~        | 2               | ; PCI Master Receive Interrupt Enable          |
| M_PMAIE          |          | 4               | ; PCI Master Address Interrupt Enable          |
| M PPEIE          |          | 5               | ; PCI Parity Error Interrupt Enable            |
| M PTAIE          |          | 7               | ; PCI Transaction Abort Interrupt Enable       |
| M PTTIE          |          | 9               | ; PCI Transaction Termination Interrupt Enable |
| M PTCIE          | ~        | 12              | ; PCI Transfer Complete Interrupt Enable       |
| M_CLRT           | ΞQU      | 14              | ; Clear Transmitter                            |
| M MTT            | EQU      | 15              | ; Master Transfer Terminate                    |
| M_SERF           | EQU      | 16              | ; HSERR~ Force                                 |
| M MACE           | EQU      | 18              | ; Master Access Counter Enable                 |
| M MWSD           | EQU      | 19              | ; Master Wait States Disable                   |
| M_NWSD<br>M RBLE | EQU      | 20              | ; Receive Buffer Lock Enable                   |
| M_RE             | EQU      | 21              | ; Insert Address Enable                        |
|                  | 200      |                 |                                                |
| i                | Host PCI | Master Control  | Register Bit Flags                             |
| M_ARH            | EQU      | \$00FFFF        | ; DSP PCI Transaction Address (High)           |
| M_BL             | EQU      | \$3F0000        | ; PCI Data Burst Length                        |
|                  | ΞQU      | \$C00000        | ; Data Transfer Format Control                 |
|                  | -        |                 |                                                |

Host PCI Address Register Bit Flags ; ; DSP PCI Transaction Address (Low) M\_ARL EQU \$00FFFF EQU \$0F0000 МС ; PCI Bus Command \$F000000 ; PCI Byte Enables M\_BE EQU ; DSP Status Register Bit Flags EQU 0 M HCP ; Host Command pending M STRO EOU 1 ; Slave Transmit Data Request 2 M\_SRRQ EQU ; Slave Receive Data Request M\_HF02 EQU \$38 M\_HF0 EQU 3 ; Host Flag 0-2 Mask ; Host Flag 0 M HF1 EQU 4 ; Host Flag 1 M\_HF2 EQU 5 ; Host Flag 2 ; DSP PCI Status Register Bit Flags M MWS EQU 0 ; PCI Master Wait States M\_MTRQ EQU 1 ; PCI Master Transmit Data Request M MRRO EQU 2 ; PCI Master Receive Data Request M\_MARQ EQU 4 M\_APER EQU 5 M\_DPER EQU 6 ; PCI Master Address Request ; PCI Address Parity Error ; PCI Data Parity Error M\_MAB EQU 7 ; PCI Master Abort M\_TAB EQU 8 M\_TDIS EQU 9 M\_TRTY EQU 10 ; PCI Target Abort ; PCI Target Disconnect 10 ; PCI Target Retry м то EQU 11 ; PCI Time Out Termination M\_RDC EQU \$3F0000 M\_RDC0 EQU 16 ; Remaining Data Count Mask (RDC5-RDC0) ; Remaining Data Count 0 M RDC1 EQU 17 ; Remaining Data Count 1 M\_RDC2 EQU 18 M\_RDC3 EQU 19 ; Remaining Data Count 2 ; Remaining Data Count 3 M\_RDC4 EQU 20 ; Remaining Data Count 4 M RDC5 EQU 21 ; Remaining Data Count 5 M\_HACT EQU 23 ; Hi32 Active ;-----; ; EQUATES for Serial Communications Interface (SCI) ; Register Addresses M\_STXH EQU \$FFFF97 M\_STXM EQU \$FFFF96 ; SCI Transmit Data Register (high) ; SCI Transmit Data Register (middle) M\_STXL EQU \$FFFF95 ; SCI Transmit Data Register (low)

|                 |         |                   |                                      | _ |
|-----------------|---------|-------------------|--------------------------------------|---|
| M_SRXH          | EQU     | \$FFFF9A          | ; SCI Receive Data Register (high)   |   |
|                 | ĒQU     | \$FFFF99          | ; SCI Receive Data Register (middle) |   |
| _<br>M_SRXL     | EQU     | \$FFFF98          | ; SCI Receive Data Register (low)    |   |
| M_STXA          | EQU     | \$FFFF94          | ; SCI Transmit Address Register      |   |
| M_SCR           | ĒQU     | \$FFFF9C          | ; SCI Control Register               |   |
| M_SSR           | EQU     | \$FFFF93          | ; SCI Status Register                |   |
| M_SCCR          | EQU     | \$FFFF9B          | ; SCI Clock Control Register         |   |
| _               | ~       |                   | 5                                    |   |
| ;               | SCI Con | trol Register Bit | Flags                                |   |
| M_WDS           | EQU     | \$7               | ; Word Select Mask (WDS0-WDS3)       |   |
| M_WDS0          | EQU     | 0                 | ; Word Select 0                      |   |
| M_WDS1          | EQU     | 1                 | ; Word Select 1                      |   |
| M_WDS2          | EQU     | 2                 | ; Word Select 2                      |   |
| M_SSFTD         | EQU     | 3                 | ; SCI Shift Direction                |   |
| M_SBK           | EQU     | 4                 | ; Send Break                         |   |
| M_WAKE          | EQU     | 5                 | ; Wakeup Mode Select                 |   |
| M_RWU           | EQU     | б                 | ; Receiver Wakeup Enable             |   |
| M_WOMS          | ĒQU     | 7                 | ; Wired-OR Mode Select               |   |
| M_SCRE          | EQU     | 8                 | ; SCI Receiver Enable                |   |
| M_SCTE          | EQU     | 9                 | ; SCI Transmitter Enable             |   |
| M_ILIE          | EQU     | 10                | ; Idle Line Interrupt Enable         |   |
| M_SCRIE         |         | 11                | ; SCI Receive Interrupt Enable       |   |
| M_SCTIE         |         | 12                | ; SCI Transmit Interrupt Enable      |   |
| M_TMIE          | EQU     | 13                | ; Timer Interrupt Enable             |   |
| M_TMIL<br>M_TIR | EQU     | 14                | ; Timer Interrupt Rate               |   |
|                 |         | 15                | ; SCI Clock Polarity                 |   |
| M_SCKP          | EQU     | 16                |                                      |   |
| M_REIE          | EQU     | TO                | ; SCI Error Interrupt Enable (REIE)  |   |
| ;               | SCI Sta | tus Register Bit  | ?lags                                |   |
| M_TRNE          | EQU     | 0                 | ; Transmitter Empty                  |   |
| M_TDRE          | EQU     | 1                 | ; Transmit Data Register Empty       |   |
| M_RDRF          | EQU     | 2                 | ; Receive Data Register Full         |   |
| M_IDLE          | EQU     | 3                 | ; Idle Line Flag                     |   |
| M_OR            | EQU     | 4                 | ; Overrun Error Flag                 |   |
|                 | EQU     | 5                 | ; Parity Error                       |   |
| M_FE            | EQU     | 6                 | ; Framing Error Flag                 |   |
| M_R8            |         | 7                 | ; Received Bit 8 (R8) Address        |   |
| 11_10           | ЦÕО     | ,                 | , Received bie o (Ro) hadrebb        |   |
| ;               | SCI Clo | ck Control Regist | er                                   |   |
| M_CD            | EQU     | \$FFF             | ; Clock Divider Mask (CD0-CD11)      |   |
| M_COD           |         | 12                | ; Clock Out Divider                  |   |
|                 | EQU     |                   | ; Clock Prescaler                    |   |
|                 | EQU     |                   | ; Receive Clock Mode Source Bit      |   |
|                 | EQU     |                   | ; Transmit Clock Source Bit          |   |
|                 |         |                   |                                      |   |
| ;               |         |                   |                                      | - |
| ;               |         |                   |                                      |   |
| ;               | EQUATES | for Synchronous   | Serial Interface (SSI)               |   |
| ;               |         |                   |                                      |   |
| ;               |         |                   |                                      | - |

; Register Addresses Of SSI0 ; M TX00 EQU \$FFFFBC ; SSI0 Transmit Data Register 0 \$FFFFBB \$FFFFBA M TX01 EOU ; SSIO Transmit Data Register 1 M TX02 EQU ; SSIO Transmit Data Register 2 ; SSIO Time Slot Register M\_TSR0 EQU \$FFFFB9 M RXO EQU \$FFFFB8 ; SSIO Receive Data Register M SSISRO EQU \$FFFFB7 ; SSIO Status Register \$FFFFB6 \$FFFFB5 ; SSIO Control Register B ; SSIO Control Register A ; SSIO Transmit Slot Mask Register A M CRBO EQU M\_CRAO EQU M TSMAO EQU \$FFFFB4 M\_TSMB0 EQU ; SSIO Transmit Slot Mask Register B \$FFFFB3 M RSMAO EQU ; SSIO Receive Slot Mask Register A \$FFFFB2 M RSMBO EQU \$FFFFB1 ; SSIO Receive Slot Mask Register B Register Addresses Of SSI1 ; M\_TX10 EQU \$FFFFAC ; SSI1 Transmit Data Register 0 M TX11 EQU \$FFFFAB ; SSI1 Transmit Data Register 1 M TX12 EQU \$FFFFAA ; SSI1 Transmit Data Register 2 \$FFFFA9 M\_TSR1 EQU ; SSI1 Time Slot Register M RX1 EQU \$FFFFA8 ; SSI1 Receive Data Register M SSISR1 EQU \$ffffa7 ; SSI1 Status Register ; SSI1 Control Register B M\_CRB1 EQU \$FFFFA6 ; SSII Control Register B ; SSII Control Register A ; SSII Transmit Slot Mask Register A \$FFFFA5 \$FFFFA4 M CRA1 EQU M TSMA1 EQU M TSMB1 EQU \$FFFFA3 ; SSI1 Transmit Slot Mask Register B M RSMA1 EQU \$FFFFA2 ; SSI1 Receive Slot Mask Register A M\_RSMB1 EQU \$FFFFA1 ; SSI1 Receive Slot Mask Register B ; SSI Control Register A Bit Flags EQU ŚFF ; Prescale Modulus Select Mask (PM0-PM7) M PM M PSR EQU 11 ; Prescaler Range M\_DC EQU \$1F000 ; Frame Rate Divider Control Mask (DC0-DC7) M ALC EQU 18 ; Alignment Control (ALC) EQU \$380000 ; Word Length Control Mask (WL0-WL7) M WL M\_SSC1 EQU ; Select SC1 as TR #0 drive enable (SSC1) 22 SSI Control Register B Bit Flags ; M OF EQU \$3 ; Serial Output Flag Mask EQU M OFO 0 ; Serial Output Flag 0 EQU ; Serial Output Flag 1 M OF1 1 M SCD EQU \$1C ; Serial Control Direction Mask M\_SCD0 EQU ; Serial Control 0 Direction 2 ; Serial Control 1 Direction M SCD1 EQU 3 M SCD2 EQU ; Serial Control 2 Direction 4 5 ; Clock Source Direction M SCKD EQU M SHFD EQU б ; Shift Direction EQU M FSL \$180 ; Frame Sync Length Mask (FSL0-FSL1) M\_FSLO EQU ; Frame Sync Length 0 7

| M FSL1             | EQU        | 8                | ; Frame Sync Length 1                       |
|--------------------|------------|------------------|---------------------------------------------|
| M_FSR              | EQU        | 9                | ; Frame Sync Relative Timing                |
| M_FSP              | EQU        | 10               | ; Frame Sync Polarity                       |
| M_CKP              | EQU        | 11               | ; Clock Polarity                            |
| M_SYN              | EQU        | 12               | ; Sync/Async Control                        |
| M_MOD              | EQU        | 13               | ; SSI Mode Select                           |
| M_NOD<br>M_SSTE    | EQU        | \$1C000          | ; SSI Transmit enable Mask                  |
| M_SSTE<br>M_SSTE2  |            | 14               | ; SSI Transmit #2 Enable                    |
| M_SSIE2<br>M_SSTE1 |            | 15               | ; SSI Transmit #1 Enable                    |
| M_SSIEI<br>M_SSTE0 |            | 16               | ; SSI Transmit #0 Enable                    |
| M_SSIEU<br>M_SSRE  | EQU<br>EQU | 17               | ; SSI Receive Enable                        |
|                    |            | 18               | ; SSI Transmit Interrupt Enable             |
| M_SSTIE            |            |                  | -                                           |
| M_SSRIE            |            | 19               | ; SSI Receive Interrupt Enable              |
| M_STLIE            |            | 20               | ; SSI Transmit Last Slot Interrupt Enable   |
| M_SRLIE            |            | 21               | ; SSI Receive Last Slot Interrupt Enable    |
| M_STEIE            |            | 22               | ; SSI Transmit Error Interrupt Enable       |
| M_SREIE            | EQU        | 23               | ; SSI Receive Error Interrupt Enable        |
| ;                  | SSI Stat   | tus Register Bit | t Flags                                     |
| N 75               | DOIL       | 4 <b>2</b>       | · Courtell Townsh Tiles Marsh               |
| M_IF               | EQU        | \$3              | ; Serial Input Flag Mask                    |
| M_IFO              | EQU        | 0                | ; Serial Input Flag 0                       |
| M_IF1              | EQU        | 1                | ; Serial Input Flag 1                       |
| M_TFS              | EQU        | 2                | ; Transmit Frame Sync Flag                  |
| M_RFS              | EQU        | 3                | ; Receive Frame Sync Flag                   |
| M_TUE              | EQU        | 4                | ; Transmitter Underrun Error FLag           |
| M_ROE              | EQU        | 5                | ; Receiver Overrun Error Flag               |
| M_TDE              | EQU        | 6                | ; Transmit Data Register Empty              |
| M_RDF              | EQU        | 7                | ; Receive Data Register Full                |
| ;                  | SSI Trar   | nsmit Slot Mask  | Register A                                  |
| M_SSTSA            | EQU        | \$FFFF           | ; SSI Transmit Slot Bits Mask A (TS0-TS15)  |
| ;                  | SSI Trar   | nsmit Slot Mask  | Register B                                  |
| M_SSTSB            | EQU        | ŞFFFF            | ; SSI Transmit Slot Bits Mask B (TS16-TS31) |
| ;                  | SSI Rece   | eive Slot Mask H | Register A                                  |
| M_SSRSA            | EQU        | \$FFFF           | ; SSI Receive Slot Bits Mask A (RSO-RS15)   |
| ;                  | SSI Rece   | eive Slot Mask H | Register B                                  |
| M_SSRSB            | EQU        | \$FFFF           | ; SSI Receive Slot Bits Mask B (RS16-RS31)  |
| ;                  |            |                  |                                             |
| ;                  |            | for Exception I  |                                             |
| ;                  |            |                  |                                             |
|                    |            |                  |                                             |

; Register Addresses

| M_IPRC           | EQU        | \$FFFFFF      | ; Interrupt Priority Register Core                                              |
|------------------|------------|---------------|---------------------------------------------------------------------------------|
| M_IPRC<br>M IPRP | EQU        | \$FFFFFE      | ; Interrupt Priority Register Peripheral                                        |
|                  | -20        | +             |                                                                                 |
| ;                | Interru    | pt Priority H | Register Core (IPRC)                                                            |
| M_IAL            | EQU        | \$7           | ; IRQA Mode Mask                                                                |
| M_IALO           | EQU        | 0             | ; IRQA Mode Interrupt Priority Level (low)                                      |
| M_IAL1           | EQU        | 1             | ; IRQA Mode Interrupt Priority Level (high)                                     |
| M_IAL2           | EQU        | 2             | ; IRQA Mode Trigger Mode                                                        |
| M_IBL            | EQU        | \$38          | ; IRQB Mode Mask                                                                |
| M_IBLO           | EQU        | 3             | ; IRQB Mode Interrupt Priority Level (low)                                      |
| M_IBL1           | EQU        | 4             | ; IRQB Mode Interrupt Priority Level (high)                                     |
| M_IBL2           | EQU        | 5             | ; IRQB Mode Trigger Mode                                                        |
| M_ICL            | EQU        | \$1C0         | ; IRQC Mode Mask                                                                |
| M_ICLO           | EQU        | 6             | ; 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_IDLO           | 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        | ; DMAO Interrupt priority Level Mask                                            |
| M_DOLO           | EQU        | 12            | ; DMAO 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<br>M D2L  | EQU        | 15<br>\$30000 | ; DMA1 Interrupt Priority Level (high)<br>; DMA2 Interrupt priority Level Mask  |
| M_D2L0<br>M_D2L0 | EQU<br>EQU | 330000<br>16  | ; DMA2 Interrupt Priority Level (low)                                           |
| M_D2L0<br>M D2L1 | EQU<br>EQU | 17            | ; DMA2 Interrupt Priority Level (10w)<br>; DMA2 Interrupt Priority Level (high) |
| M_DZHI<br>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                                            |
|                  | EQU        | 22            | ; DMA5 Interrupt Priority Level (low)                                           |
|                  | EQU        | 23            | ; DMA5 Interrupt Priority Level (high)                                          |
|                  |            |               |                                                                                 |
| ;                | Interru    | pt Priority B | Register Peripheral (IPRP)                                                      |
| M HPL            | EQU        | \$3           | ; Host Interrupt Priority Level Mask                                            |
| M_HPLO           | EQU        | 0             | ; Host Interrupt Priority Level (low)                                           |
| M_HPL1           | EQU        | 1             | ; Host Interrupt Priority Level (high)                                          |
| M_SOL            | EQU        | \$C           | ; SSIO Interrupt Priority Level Mask                                            |
| <br>M            | ~ -        |               |                                                                                 |

| M_S0L1<br>M_S1L0<br>M_S1L1<br>M_SCL<br>M_SCL0<br>M_SCL1<br>M_T0L<br>M_T0L0<br>M_T0L1 | EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU | 3<br>\$30<br>4<br>5<br>\$C0<br>6<br>7<br>\$300<br>8<br>9             | <pre>; SSI0 Interrupt Priority Level (high)<br/>; SSI1 Interrupt Priority Level Mask<br/>; SSI1 Interrupt Priority Level (low)<br/>; SSI1 Interrupt Priority Level (high)<br/>; SCI Interrupt Priority Level Mask<br/>; SCI Interrupt Priority Level (low)<br/>; SCI Interrupt Priority Level (high)<br/>; TIMER Interrupt Priority Level Mask<br/>; TIMER Interrupt Priority Level (low)<br/>; TIMER Interrupt Priority Level (low)</pre> |
|--------------------------------------------------------------------------------------|-------------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| ;                                                                                    | EQUATES                                                     | for TIMER                                                            |                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| ;                                                                                    | Register                                                    | Addresses                                                            | Of TIMER0                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| M_TCSR0<br>M_TLR0<br>M_TCPR0<br>M_TCR0                                               | EQU<br>EQU                                                  | \$FFFF8F<br>\$FFFF8E<br>\$FFFF8D<br>\$FFFF8C                         | ; TIMER0 Control/Status Register<br>; TIMER0 Load Reg<br>; TIMER0 Compare Register<br>; TIMER0 Count Register                                                                                                                                                                                                                                                                                                                              |
| ;                                                                                    | Register                                                    | Addresses                                                            | Of TIMER1                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| M_TCSR1<br>M_TLR1<br>M_TCPR1<br>M_TCR1                                               | EQU<br>EQU                                                  | \$FFFF8B<br>\$FFFF8A<br>\$FFFF89<br>\$FFFF88                         | ; TIMER1 Control/Status Register<br>; TIMER1 Load Reg<br>; TIMER1 Compare Register<br>; TIMER1 Count Register                                                                                                                                                                                                                                                                                                                              |
| ;                                                                                    | Register                                                    | Addresses                                                            | Of TIMER2                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| M_TCSR2<br>M_TLR2<br>M_TCPR2<br>M_TCR2<br>M_TPLR<br>M_TPCR                           | EQU<br>EQU<br>EQU<br>EQU<br>EQU                             | \$FFFF87<br>\$FFFF86<br>\$FFFF85<br>\$FFFF84<br>\$FFFF83<br>\$FFFF82 | ; TIMER2 Control/Status Register<br>; TIMER2 Load Reg<br>; TIMER2 Compare Register<br>; TIMER2 Count Register<br>; TIMER Prescaler Load Register<br>; TIMER Prescalar Count Register                                                                                                                                                                                                                                                       |
| ; 1                                                                                  | Fimer Cont                                                  | rol/Status                                                           | Register Bit Flags                                                                                                                                                                                                                                                                                                                                                                                                                         |
| M_TE<br>M_TOIE<br>M_TCIE<br>M_TC<br>M_INV<br>M_TRM<br>M_DIR<br>M_DI<br>M_DI<br>M_DO  | EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU<br>EQU        | 0<br>1<br>2<br>\$F0<br>8<br>9<br>11<br>12<br>13                      | <pre>; Timer Enable ; Timer Overflow Interrupt Enable ; Timer Compare Interrupt Enable ; Timer Control Mask (TCO-TC3) ; Inverter Bit ; Timer Restart Mode ; Direction Bit ; Data Input ; Data Output</pre>                                                                                                                                                                                                                                 |

 
 M\_PCE
 EQU
 15

 M\_TOF
 EQU
 20

 M\_TCF
 EQU
 21
 ; Prescaled Clock Enable ; Timer Overflow Flag ; Timer Compare Flag ; Timer Prescaler Register Bit Flags \$600000 ; Prescaler Source Mask M PS EQU M PSO EQU 21 M PS1 EQU 22 Timer Control Bits ; M\_TC0 EQU 4 M\_TC1 EQU 5 M\_TC2 EQU 6 ; Timer Control 0 ; Timer Control 1 ; Timer Control 2 M TC3 EQU 7 ; Timer Control 3 ;-----; ; EQUATES for Direct Memory Access (DMA) Register Addresses Of DMA ; M\_DSTR EQU \$FFFFF4 ; DMA Status Register M\_DOR0EQU\$FFFFF3; DMA Offset Register 0M\_DOR1EQU\$FFFFF2; DMA Offset Register 1M\_DOR2EQU\$FFFFF1; DMA Offset Register 2M\_DOR3EQU\$FFFFF0; DMA Offset Register 3 ; Register Addresses Of DMA0 M\_DSR0EQU\$FFFFEF; DMA0 Source Address RegisterM\_DDR0EQU\$FFFFEE; DMA0 Destination Address RegisterM\_DC00EQU\$FFFFED; DMA0 Counter M DCR0 EQU \$FFFFEC ; DMA0 Control Register ; Register Addresses Of DMA1 M\_DSR1EQU\$FFFFEB; DMA1 Source Address RegisterM\_DDR1EQU\$FFFFEA; DMA1 Destination Address RegisterM\_DC01EQU\$FFFFE9; DMA1 Counter M DCR1 EQU \$FFFFE8 ; DMA1 Control Register ; Register Addresses Of DMA2 ; DMA2 Source Address Register ; DMA2 Destination Address Register M DSR2 EQU SFFFFE7 M\_DDR2 EQU \$FFFFE6 M\_DCO2 EQU \$FFFFE5 ; DMA2 Counter M\_DCR2 EQU ; DMA2 Control Register \$FFFFE4

Register Addresses Of DMA4 ; M DSR3 EQU \$FFFFE3 ; DMA3 Source Address Register M DDR3 EQU SFFFFE2 ; DMA3 Destination Address Register M DCO3 EQU \$FFFFE1 ; DMA3 Counter M DCR3 EQU \$FFFFE0 ; DMA3 Control Register ; Register Addresses Of DMA4 M DSR4 EQU \$FFFFDF ; DMA4 Source Address Register M DDR4 EQU \$FFFFDE ; DMA4 Destination Address Register M DCO4 EQU \$FFFFDD ; DMA4 Counter M DCR4 EQU SFFFFDC ; 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 SFFFFD8 M DCR5 EOU ; DMA5 Control Register ; DMA Control Register M DSS EQU \$3 ; DMA Source Space Mask (DSS0-Dss1) M DSSO EQU 0 ; DMA Source Memory space 0 ; DMA Source Memory space 1 M DSS1 EQU 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 EQU M DAM \$3F0 ; DMA Address Mode Mask (DAM5-DAM0) M\_DAMO EQU ; DMA Address Mode 0 4 M DAM1 EQU 5 ; DMA Address Mode 1 M DAM2 EQU 6 ; DMA Address Mode 2 M\_DAM3 EQU 7 ; DMA Address Mode 3 ; DMA Address Mode 4 M\_DAM4 EQU 8 M DAM5 EQU 9 ; DMA Address Mode 5 M\_D3D EQU 10 ; DMA Three Dimensional Mode EQU M DRS \$F800 ; DMA Request Source Mask (DRS0-DRS4) M\_DCON EQU 16 ; DMA Continuous Mode EQU \$60000 ; DMA Channel Priority M DPR M DPRO EQU ; DMA Channel Priority Level (low) 17 M\_DPR1 EQU 18 ; DMA Channel Priority Level (high) M DTM EQU \$380000 ; DMA Transfer Mode Mask (DTM2-DTM0) ; DMA Transfer Mode 0 M DTMO EQU 19 M\_DTM1 EQU 20 ; DMA Transfer Mode 1 M DTM2 EQU 21 ; DMA Transfer Mode 2 M DIE EQU 22 ; DMA Interrupt Enable bit ; DMA Channel Enable bit M\_DE EQU 23 DMA Status Register ; M DTD EQU \$3F ; Channel Transfer Done Status MASK (DTD0-DTD5)

M\_DTDO EQU O ; DMA Channel Transfer Done Status 0 M\_DTD1 EQU 1 M\_DTD2 EQU 2 ; DMA Channel Transfer Done Status 1 ; DMA Channel Transfer Done Status 2 M\_DTD3 EQU 3 ; DMA Channel Transfer Done Status 3 M\_DTD4 EQU 4 M\_DTD5 EQU 5 ; DMA Channel Transfer Done Status 4 ; DMA Channel Transfer Done Status 5 M\_DACT EQU 8 ; DMA Active State M DCH EQU \$E00 ; DMA Active Channel Mask (DCH0-DCH2) 
 M\_DCH0
 EQU
 9

 M\_DCH1
 EQU
 10

 M\_DCH2
 EQU
 11
 ; DMA Active Channel 0 ; DMA Active Channel 1 ; DMA Active Channel 2 ; EQUATES for Phase Locked Loop (PLL) ; ; ; Register Addresses Of PLL M PCTL EQU \$FFFFFD ; PLL Control Register ; PLL Control Register M\_MF EQU \$FFF M\_DF EQU \$7000 M\_XTLR EQU 15 ; Multiplication Factor Bits Mask (MF0-MF11) ; Division Factor Bits Mask (DF0-DF2) ; XTAL Range select bit ; XTAL Disable Bit M XTLD EQU 16 M PSTP EQU 17 ; STOP Processing State Bit M\_PEN EQU 18 M\_PCOD EQU 19 ; PLL Enable Bit ; PLL Clock Output Disable Bit M\_PD EQU \$F00000 ; PreDivider Factor Bits Mask (PD0-PD3) ;\_\_\_\_\_\_ ; EQUATES for BIU ; ; ; Register Addresses Of BIU \$FFFFFB M\_BCR EQU ; Bus Control Register M\_DCR EQU \$FFFFFA ; DRAM Control Register ; Address Attribute Register 0 ; Address Attribute Register 1 ; Address Attribute Register 2 m\_aar0 equ \$FFFFF9 M AAR1 EQU SFFFFF8 M\_AAR2 EQU \$FFFFF7 M\_AAR3 EQU \$FFFFF6 ; Address Attribute Register 3 M\_IDR EQU \$FFFFF5 ; ID Register

| ;      | Bus Cor | ntrol Register  |                                                                      |
|--------|---------|-----------------|----------------------------------------------------------------------|
| M BAOW | EQU     | \$1F            | ; Area 0 Wait Control Mask (BA0W0-BA0W4)                             |
| M BA1W | ΞQU     | ;<br>\$3E0      | ; Area 1 Wait Control Mask (BA1W0-BA14)                              |
| M BA2W | EQU     | \$1C00          | ; Area 2 Wait Control Mask (BA2W0-BA2W2)                             |
| M_BA3W | EQU     | \$E000          | ; Area 3 Wait Control Mask (BA3W0-BA3W3)                             |
| M_BDFW | EQU     | \$1F0000        | ; Default Area Wait Control Mask (BDFW0-BDFW4)                       |
| M_BBS  | EQU     | 21              | ; Bus State                                                          |
| M_BLH  | EQU     | 22              | ; Bus Lock Hold                                                      |
| M_BRH  | EQU     | 23              | ; Bus Request Hold                                                   |
| ;      | DRAM Co | ontrol Register |                                                                      |
| M_BCW  | EQU     | \$3             | ; In Page Wait States Bits Mask (BCW0-BCW1)                          |
| M_BRW  | EQU     | \$C             | ; Out Of Page Wait States Bits Mask (BRW0-BRW1)                      |
| M_BPS  | EQU     | \$300           | ; DRAM Page Size Bits Mask (BPS0-BPS1)                               |
| M_BPLE | EQU     | 11              | ; Page Logic Enable                                                  |
| M_BME  | EQU     | 12              | ; Mastership Enable                                                  |
| M_BRE  | EQU     | 13              | ; Refresh Enable                                                     |
| M_BSTR | EQU     | 14              | ; Software Triggered Refresh                                         |
| M_BRF  | EQU     | \$7F8000        | ; Refresh Rate Bits Mask (BRF0-BRF7)                                 |
| M_BRP  | EQU     | 23              | ; Refresh prescaler                                                  |
| ;      | Address | Attribute Reg   | isters                                                               |
| M_BAT  | EQU     | \$3             | ; External Access Type and Pin Definition<br>; Bits Mask (BAT0-BAT1) |
| M_BAAP | EQU     | 2               | ; Address Attribute Pin Polarity                                     |
| M_BPEN | EQU     | 3               | ; Program Space Enable                                               |
| M_BXEN | EQU     | 4               | ; X Data Space Enable                                                |
| M_BYEN | EQU     | 5               | ; Y Data Space Enable                                                |
| M_BAM  | EQU     | 6               | ; Address Muxing                                                     |
| M_BPAC | EQU     | 7               | ; Packing Enable                                                     |
| M_BNC  | EQU     | \$F00           | ; No. of Addr Bits to Compare Mask (BNC0-BNC3)                       |
| M_BAC  | EQU     | \$FFF000        | ; Address to Compare Bits Mask (BAC0-BAC11)                          |
| ;      | control | and status bi   | ts in SR                                                             |
| M_CP   | EQU     | \$C00000        | ; mask for CORE-DMA priority bits in SR                              |
| M_CA   | EQU     | 0               | ; Carry                                                              |
| M_V    | EQU     | 1               | ; Overflow                                                           |
| M_Z    | EQU     | 2               | ; Zero                                                               |
| M_N    | EQU     | 3               | ; Negative                                                           |
| M_U    | EQU     | 4               | ; Unnormalized                                                       |
| M_E    | EQU     | 5               | ; Extension                                                          |
| M_L    | EQU     | 6               | ; Limit                                                              |
| M_S    | EQU     | 7               | ; Scaling Bit                                                        |
| M_IO   | EQU     | 8               | ; Interupt Mask Bit 0                                                |
| M_I1   | EQU     | 9               | ; Interupt Mask Bit 1                                                |
| M_SO   | 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 17 ; Sixteen-Bit Arithmetic M SA EQU ; Instruction Cache Enable M CE EOU 19 M\_SM EQU 20 ; Arithmetic Saturation EQU M RM 21 ; Rounding Mode 22 ; bit 0 of priority bits in SR M\_CPO EQU M CP1 EQU 23 ; bit 1 of priority bits in SR control and status bits in OMR ; M CDP EQU \$300 ; mask for CORE-DMA priority bits in OMR M\_CDP0 EQU 8 ; bit 0 of priority bits in OMR M\_CDP1 EQU 9 ; bit 1 of priority bits in OMR M\_XYS EQU ; Stack Extension space select bit in OMR. 16 M EUN EQU 17 ; Extensed stack UNderflow flag in OMR. M\_EOV EQU 18 ; Extended stack OVerflow flag in OMR. M\_WRP EQU 19 ; Extended WRaP flag in OMR. M\_SEN EQU 20 ; Stack Extension Enable bit in OMR.

# A-3 INTERRUPT EQUATES

; EQUATES for DSP56301 interrupts ; page 132,55,0,0,0 mex opt intequ ident 1,0 if @DEF(I\_VEC) ;leave user definition as is. else I\_VEC EQU \$0 endif ; Non-Maskable interrupts I VEC+\$00 ; Hardware RESET I RESET EQU I\_STACK EQU I\_VEC+\$02 ; Stack Error I\_ILLEQUI\_VEC+\$04; Illegal InstructionI\_DBGEQUI\_VEC+\$06; Debug RequestI\_TRAPEQUI\_VEC+\$08; Trap I\_ILL EQU I\_NMI EQU I\_VEC+\$0A ; Non Maskable Interrupt ;\_\_\_\_\_\_ \_\_\_\_\_

; Interrupt Request Pins I\_IRQA EQU I\_VEC+\$10 ; IRQA I\_IRQB EQU I VEC+\$12 ; IRQB I IRQC EQU I VEC+\$14 ; IRQC I\_IRQD EQU ; IRQD I\_VEC+\$16 ;------; DMA Interrupts I\_DMA0 EQU I\_VEC+\$18 ; DMA Channel 0 I DMA1 EQU I\_VEC+\$1A ; DMA Channel 1 I\_DMA2EQUI\_VEC:910I\_DMA3EQUI\_VEC+\$1E; DMA Channel 3I\_DMA4EQUI\_VEC+\$20; DMA Channel 4T\_VEC+\$22; DMA Channel 5 ;-----; Timer Interrupts I\_TIMOC EQU I\_VEC+\$26 T\_TIMOF EQU I\_VEC+\$28 ; TIMER 0 compare ; TIMER 0 overflow
; TIMER 1 compare
; TIMER 1 overflow
; TIMER 2 compare I\_TIM1OF EQU I\_VEC+\$2A I\_TIM2C EQU I\_VEC+\$2C I\_TIM2OF EQU I\_VEC+\$2E ; TIMER 2 overflow ; ESSI Interrupts ;\_\_\_\_\_\_ ; ESSIO Receive Data I\_SIORD EQU I\_VEC+\$30 I SIORDE EQU I VEC+\$32 ; ESSIO Receive Data With Exception Status I\_SIORLS EQU I\_VEC+\$34 ; ESSIO Receive last slot I SIOTD EQU I\_VEC+\$36 ; ESSIO Transmit data I\_SIOTDE EQU I\_VEC+\$38 ; ESSIO Transmit Data With Exception Status I\_VEC+\$3A I\_VEC+\$40 ; ESSIO Transmit last slot I\_SIOTLS EQU ; ESSI1 Receive Data ; ESSI1 Receive Data With Exception Status I\_SI1RD EQU I SI1RDE EQU I VEC+\$42 I\_SI1RLS EQU I\_VEC+\$44 ; ESSI1 Receive last slot \_\_\_\_ I\_VEC+\$46 ; ESSI1 Transmit data I\_SI1TD EQU I\_SI1TDE EQU I\_VEC+\$48 ; ESSI1 Transmit Data With Exception Status I SI1TLS EQU I VEC+\$4A ; ESSI1 Transmit last slot ; SCI Interrupts ;\_\_\_\_\_\_ I\_SCIRD EQU I\_VEC+\$50 ; SCI Receive Data I\_SCIRDE EQU I\_VEC+\$52 ; SCI Receive Data ; SCI Receive Data With Exception Status I SCITD EQU I VEC+\$54 ; SCI Transmit Data I\_SCIIL EQU ; SCI Idle Line I\_VEC+\$56 I\_VEC+\$58 ; SCI Timer I SCITM EQU ; \_\_\_\_\_ ; HOST Interrupts

| ;                          |     |            |   |                                        |
|----------------------------|-----|------------|---|----------------------------------------|
| I_HPTT                     | EQU | I_VEC+\$60 | ; | Host PCI Transaction Termination       |
| I_HPTA                     | EQU | I_VEC+\$62 | ; | Host PCI Transaction Abort             |
| I_HPPE                     | EQU | I_VEC+\$64 | ; | Host PCI Parity Error                  |
| I_HPTC                     | EQU | I_VEC+\$66 | ; | Host PCI Transfer Complete             |
| I_HPMR                     | EQU | I_VEC+\$68 | ; | Host PCI Master Receive                |
| I_HSR                      | EQU | I_VEC+\$6A | ; | Host Slave Receive                     |
| I_HPMT                     | EQU | I_VEC+\$6C | ; | Host PCI Master Transmit               |
| I_HST                      | EQU | I_VEC+\$6E | ; | Host Slave Transmit                    |
| I_HPMA                     | EQU | I_VEC+\$70 | ; | Host PCI Master Address                |
| I_HCNMI                    | EQU | I_VEC+\$72 | ; | Host Command/Host NMI (Default)        |
|                            |     |            |   |                                        |
| ;                          |     |            |   |                                        |
| ; INTERRUPT ENDING ADDRESS |     |            |   |                                        |
| ;                          |     |            |   |                                        |
| I_INTEND                   | EQU | I_VEC+\$7F | ; | last address of interrupt vector space |

Order this document by DSP56301UM/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 described herein; neither does it convey any license under its patent rights nor the rights of others. Motorola products are not authorized for use as components in life support devices or systems intended for surgical implant into the body or intended to support or sustain life. Buyer agrees to notify Motorola of any such intended end use whereupon Motorola shall determine availability and suitability of its product or products for the use intended. Motorola and registered trademarks of Motorola, Inc. Motorola, Inc. is an Equal Employment Opportunity /Affirmative Action Employer.

OnCE is a trade mark of Motorola, Inc.

Motorola Inc., 1994