## TMS320C674x/OMAP-L1x Processor Host Port Interface (HPI)

# **User's Guide**



Literature Number: SPRUFM7D April 2010



| Prefa | ce      |                                                         | . 6       |
|-------|---------|---------------------------------------------------------|-----------|
| 1     | Introd  | uction                                                  | . 8       |
|       | 1.1     | Purpose of the Peripheral                               | . 8       |
|       | 1.2     | Features                                                | . 8       |
|       | 1.3     | Functional Block Diagram                                | . 9       |
|       | 1.4     | Industry Standard(s) Compliance Statement               | 10        |
|       | 1.5     | Terminology Used in This Document                       | 10        |
| 2     | Archite | ecture                                                  | 11        |
|       | 2.1     | Clock Control                                           | 11        |
|       | 2.2     | Memory Map                                              | 11        |
|       | 2.3     | Signal Descriptions                                     | 11        |
|       | 2.4     | Pin Multiplexing and General-Purpose I/O Control Blocks | 12        |
|       | 2.5     | Protocol Description                                    | 13        |
|       | 2.6     | Operation                                               | 13        |
|       | 2.7     | Reset Considerations                                    | 28        |
|       | 2.8     | Initialization                                          | 28        |
|       | 2.9     | Interrupt Support                                       | 29        |
|       | 2.10    | EDMA Event Support                                      | 30        |
|       | 2.11    | Power Management                                        | 30        |
|       | 2.12    | Emulation Considerations                                | 31        |
| 3     | Regist  | ers                                                     | 31        |
|       | 3.1     | Revision Identification Register (REVID)                | 32        |
|       | 3.2     | Power and Emulation Management Register (PWREMU_MGMT)   | 32        |
|       | 3.3     | GPIO Enable Register (GPIO_EN)                          | 33        |
|       | 3.4     | GPIO Direction 1 Register (GPIO_DIR1)                   | 34        |
|       | 3.5     | GPIO Data 1 Register (GPIO_DAT1)                        | 34        |
|       | 3.6     | GPIO Direction 2 Register (GPIO_DIR2)                   | 35        |
|       | 3.7     | GPIO Data 2 Register (GPIO_DAT2)                        | 36        |
|       | 3.8     | Host Port Interface Control Register (HPIC)             | 37        |
|       | 3.9     | Host Port Interface Write Address Register (HPIAW)      | 39        |
|       | 3.10    | Host Port Interface Read Address Register (HPIAR)       | 39        |
| Appe  | ndix A  | Revision History                                        | <b>40</b> |



## List of Figures

| 1  | HPI Block Diagram                                                                                                                               | 9  |
|----|-------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 2  | Example of Host-Processor Signal Connections                                                                                                    | 14 |
| 3  | HPI Strobe and Select Logic                                                                                                                     | 16 |
| 4  | Multiplexed-Mode Host Read Cycle                                                                                                                | 18 |
| 5  | Multiplexed-Mode Host Write Cycle                                                                                                               | 19 |
| 6  | Multiplexed-Mode Single-Halfword HPIC Cycle (Read or Write)                                                                                     | 20 |
| 7  | UHPI_HRDY Behavior During an HPIC or HPIA Read Cycle in the Multiplexed Mode                                                                    | 21 |
| 8  | UHPI_HRDY Behavior During a Data Read Operation in the Multiplexed Mode (Case 1: HPIA Write Cycle Followed by Nonautoincrement HPID Read Cycle) | 21 |
| 9  | UHPI_HRDY Behavior During a Data Read Operation in the Multiplexed Mode (Case 2: HPIA Write Cycle Followed by Autoincrement HPID Read Cycles)   | 21 |
| 10 | UHPI_HRDY Behavior During an HPIC Write Cycle in the Multiplexed Mode                                                                           | 22 |
| 11 | UHPI_HRDY Behavior During a Data Write Operation in the Multiplexed Mode (Case 1: No Autoincrementing)                                          | 22 |
| 12 | UHPI_HRDY Behavior During a Data Write Operation in the Multiplexed Mode (Case 2:<br>Autoincrementing Selected, FIFO Empty Before Write)        | 22 |
| 13 | UHPI_HRDY Behavior During a Data Write Operation in the Multiplexed Mode (Case 3:<br>Autoincrementing Selected, FIFO Not Empty Before Write)    | 23 |
| 14 | FIFOs in the HPI                                                                                                                                | 24 |
| 15 | Host-to-CPU Interrupt State Diagram                                                                                                             |    |
| 16 | CPU-to-Host Interrupt State Diagram                                                                                                             | 30 |
| 17 | Revision Identification Register (REVID)                                                                                                        | 32 |
| 18 | Power and Emulation Management Register (PWREMU_MGMT)                                                                                           | 32 |
| 19 | GPIO Enable Register (GPIO_EN)                                                                                                                  | 33 |
| 20 | GPIO Direction 1 Register (GPIO_DIR1)                                                                                                           | 34 |
| 21 | GPIO Data 1 Register (GPIO_DAT1)                                                                                                                | 34 |
| 22 | GPIO Direction 2 Register (GPIO_DIR2)                                                                                                           | 35 |
| 23 | GPIO Data 2 Register (GPIO_DAT2)                                                                                                                | 36 |
| 24 | Host Port Interface Control Register (HPIC)-Host Access Permissions                                                                             | 37 |
| 25 | Host Port Interface Control Register (HPIC)–CPU Access Permissions                                                                              | 37 |
| 26 | Host Port Interface Write Address Register (HPIAW)                                                                                              |    |
| 27 | Host Port Interface Read Address Register (HPIAR)                                                                                               | 39 |



## List of Tables

| HPI Pins                                                                                                                           | 11       |
|------------------------------------------------------------------------------------------------------------------------------------|----------|
| Value on Optional Pins when Configured as General-Purpose I/O                                                                      | 12       |
| Options for Connecting Host and HPI Data Strobe Pins                                                                               | 16       |
| Access Types Selectable With the UHPI_HCNTL Signals                                                                                | 17       |
| Cycle Types Selectable With the UHPI_HCNTL and UHPI_HR/ $\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!\!$ | 17       |
| HPI Registers                                                                                                                      | 31       |
| Revision Identification Register (REVID) Field Descriptions                                                                        | 32       |
| Power and Emulation Management Register (PWREMU_MGMT) Field Descriptions                                                           | 32       |
| GPIO Enable Register (GPIO_EN) Field Descriptions                                                                                  | 33       |
| GPIO Direction 1 Register (GPIO_DIR1) Field Descriptions                                                                           | 34       |
| GPIO Data 1 Register (GPIO_DAT1) Field Descriptions                                                                                | 34       |
| GPIO Direction 2 Register (GPIO_DIR2) Field Descriptions                                                                           | 35       |
| GPIO Data 2 Register (GPIO_DAT2) Field Descriptions                                                                                | 36       |
| Host Port Interface Control Register (HPIC) Field Descriptions                                                                     | 38       |
| Host Port Interface Write Address Register (HPIAW) Field Descriptions                                                              | 39       |
| Host Port Interface Read Address Register (HPIAR) Field Descriptions                                                               | 39       |
| Document Revision History                                                                                                          | 40       |
|                                                                                                                                    | HPI Pins |



Preface SPRUFM7D–April 2010

## About This Manual

This document describes the features and operation of the host port interface (HPI).

#### **Notational Conventions**

This document uses the following conventions.

- Hexadecimal numbers are shown with the suffix h. For example, the following number is 40 hexadecimal (decimal 64): 40h.
- Registers in this document are shown in figures and described in tables.
  - Each register figure shows a rectangle divided into fields that represent the fields of the register.
     Each field is labeled with its bit name, its beginning and ending bit numbers above, and its read/write properties below. A legend explains the notation used for the properties.
  - Reserved bits in a register figure designate a bit that is used for future device expansion.

#### **Related Documentation From Texas Instruments**

The following documents describe the TMS320C674x Digital Signal Processors (DSPs) and OMAP-L1x Applications Processors. Copies of these documents are available on the Internet at <u>www.ti.com</u>. *Tip:* Enter the literature number in the search box provided at www.ti.com.

The current documentation that describes the DSP, related peripherals, and other technical collateral, is available in the C6000 DSP product folder at: <a href="http://www.ti.com/c6000">www.ti.com/c6000</a>.

SPRUGM5 — TMS320C6742 DSP System Reference Guide. Describes the C6742 DSP subsystem, system memory, device clocking, phase-locked loop controller (PLLC), power and sleep controller (PSC), power management, and system configuration module.

- <u>SPRUGJ0</u> TMS320C6743 DSP System Reference Guide. Describes the System-on-Chip (SoC) including the C6743 DSP subsystem, system memory, device clocking, phase-locked loop controller (PLLC), power and sleep controller (PSC), power management, and system configuration module.
- SPRUFK4 TMS320C6745/C6747 DSP System Reference Guide. Describes the System-on-Chip (SoC) including the C6745/C6747 DSP subsystem, system memory, device clocking, phase-locked loop controller (PLLC), power and sleep controller (PSC), power management, and system configuration module.
- SPRUGM6 TMS320C6746 DSP System Reference Guide. Describes the C6746 DSP subsystem, system memory, device clocking, phase-locked loop controller (PLLC), power and sleep controller (PSC), power management, and system configuration module.
- <u>SPRUGJ7</u> TMS320C6748 DSP System Reference Guide. Describes the C6748 DSP subsystem, system memory, device clocking, phase-locked loop controller (PLLC), power and sleep controller (PSC), power management, and system configuration module.
- <u>SPRUG84</u> OMAP-L137 Applications Processor System Reference Guide. Describes the System-on-Chip (SoC) including the ARM subsystem, DSP subsystem, system memory, device clocking, phase-locked loop controller (PLLC), power and sleep controller (PSC), power management, ARM interrupt controller (AINTC), and system configuration module.

- SPRUGM7 OMAP-L138 Applications Processor System Reference Guide. Describes the System-on-Chip (SoC) including the ARM subsystem, DSP subsystem, system memory, device clocking, phase-locked loop controller (PLLC), power and sleep controller (PSC), power management, ARM interrupt controller (AINTC), and system configuration module.
- SPRUFK9 TMS320C674x/OMAP-L1x Processor Peripherals Overview Reference Guide. Provides an overview and briefly describes the peripherals available on the TMS320C674x Digital Signal Processors (DSPs) and OMAP-L1x Applications Processors.
- <u>SPRUFK5</u> TMS320C674x DSP Megamodule Reference Guide. Describes the TMS320C674x digital signal processor (DSP) megamodule. Included is a discussion on the internal direct memory access (IDMA) controller, the interrupt controller, the power-down controller, memory protection, bandwidth management, and the memory and cache.
- <u>SPRUFE8</u> *TMS320C674x DSP CPU and Instruction Set Reference Guide.* Describes the CPU architecture, pipeline, instruction set, and interrupts for the TMS320C674x digital signal processors (DSPs). The C674x DSP is an enhancement of the C64x+ and C67x+ DSPs with added functionality and an expanded instruction set.
- SPRUG82 TMS320C674x DSP Cache User's Guide. Explains the fundamentals of memory caches and describes how the two-level cache-based internal memory architecture in the TMS320C674x digital signal processor (DSP) can be efficiently used in DSP applications. Shows how to maintain coherence with external memory, how to use DMA to reduce memory latencies, and how to optimize your code to improve cache efficiency. The internal memory architecture in the C674x DSP is organized in a two-level hierarchy consisting of a dedicated program cache (L1P) and a dedicated data cache (L1D) on the first level. Accesses by the CPU to the these first level caches can complete without CPU pipeline stalls. If the data requested by the CPU is not contained in cache, it is fetched from the next lower memory level, L2 or external memory.



## Host Port Interface (HPI)

## 1 Introduction

The host port interface (HPI) provides a parallel port interface through which an external host processor can directly access the processor's resources (configuration and program/data memories). The external host device is asynchronous to the CPU clock and functions as a master to the HPI interface. The HPI enables a host device and the processor to exchange information via internal or external memory. Dedicated address (HPIA) and data (HPID) registers within the HPI provide the data path between the external host interface and the processor resources. An HPI control register (HPIC) is available to the host and the CPU for various configuration and interrupt functions.

#### 1.1 Purpose of the Peripheral

The HPI enables an external host processor (host) to directly access program/data memory on the processor using a parallel interface. The primary purpose is to provide a mechanism to move data to and from the processor. In addition to data transfer, the host can also use the HPI to bootload the processor by downloading program and data information to the processor's memory after power-up.

## 1.2 Features

The HPI supports the following features:

- Multiplexed address/data
- Dual 16-bit halfword cycle access (internal data word is 32-bits wide)
- 16-bit-wide host data bus interface
- Internal data bursting using 8-word read and write first-in, first-out (FIFO) buffers
- HPI control register (HPIC) accessible by both the DSP CPU and the external host
- HPI address register (HPIA) accessible by both the DSP CPU and the external host
- Separate HPI address registers for read (HPIAR) and write (HPIAW) with configurable option for operating as a single HPI address register
- HPI data register (HPID)/FIFOs providing data-path between external host interface and CPU resources
- Multiple strobes and control signals to allow flexible host connection
- · Asynchronous UHPI\_HRDY output to allow the HPI to insert wait states to the host
- · Software control of data prefetching to the HPID/FIFOs
- · Processor-to-Host interrupt output signal controlled by HPIC accesses
- Host-to-Processor interrupt controlled by HPIC accesses
- Register controlled HPIA and HPIC ownership and FIFO timeout
- Memory-mapped peripheral identification register (PID)
- Bus holders on host data and address buses (these are actually external to HPI module)



Figure 1 is a high-level block diagram showing how the HPI connects a host (left side of figure) and the processor internal memory (right side of figure). Host activity is asynchronous to the internal processor clock that drives the HPI. The host functions as a master to the HPI. When HPI resources are temporarily busy or unavailable, the HPI communicates this to the host by deasserting the HPI ready (UHPI\_HRDY) output signal.

The HPI supports multiplexed operation meaning the data bus is used for both address and data. Each host cycle consists of two consecutive 16-bit transfers. When the host drives an address on the bus, the address is stored in a 32-bit address register (HPIA) in the HPI, so that the bus can then be used for data. The HPI contains two address registers (HPIAR and HPIAW), which can be used as separate address registers for read accesses and write accesses (for details, see Section 2.6.1).

A control register (HPIC) is accessible by the CPU and the host. The CPU uses HPIC to send an interrupt request to the host, to clear an interrupt request from the host, and to monitor the HPI. The host uses HPIC to configure and monitor the HPI, to send an interrupt request to the CPU, and to clear an interrupt request from the CPU.

Data flow between the host and the HPI uses a temporary storage register, the 32-bit data register (HPID). Data arriving from the host is held in HPID until the data can be stored elsewhere in the processor. Data to be sent to the host is held in HPID until the HPI is ready to perform the transfer. When address autoincrementing is used, read and write FIFOs are used to store burst data. If autoincrementing is not used, the FIFO memory acts as a single register (only one location is used).



Figure 1. HPI Block Diagram



Introduction

## 1.4 Industry Standard(s) Compliance Statement

The HPI is not an industry standard interface that is developed and monitored by an international organization. It is a generic parallel interface that can be configured to gluelessly interface to a variety of parallel devices.

## 1.5 Terminology Used in This Document

The following is a brief explanation of some terms used in this document:

| Term          | Meaning                                                                                                                                                     |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CPU           | DSP CPU                                                                                                                                                     |
| host          | External host device                                                                                                                                        |
| HPI DMA logic | Logic used to communicate between the HPI and the DMA system that moves data to<br>and from memory. This is independent of the EDMA system on the processor |
| processor     | Entire system-on-chip                                                                                                                                       |

## 2 Architecture

#### 2.1 Clock Control

For detailed information on the PLLs and clock distribution on the processor, see your device-specific *System Reference Guide*.

#### 2.2 Memory Map

The HPI can be used by the host to access on-chip device memory, peripheral, and memory-mapped registers. See your device-specific data manual for more detailed information.

#### 2.3 Signal Descriptions

Table 1 shows the a description of the HPI signals.

| Pin                        | Туре  | Host Connection                                                | Function                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|----------------------------|-------|----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| UHPI_HCNTL[1:0]            | I     | Address or control pins                                        | HPI access control inputs. The HPI latches the logic levels of these pins on the falling edge of internal HSTRB (for details about internal HSTRB, see Section 2.6.4). The four binary states of these pins determine the access type of the current transfer (HPIC, HPIA, HPID with and without autoincrementing).                                                                                                                                                                                          |
| UHPI_HCS                   | I     | Chip select pin                                                | HPI chip select. UHPI_HCS must be low for the HPI to be selected by the host. UHPI_HCS can be kept low between accesses. UHPI_HCS normally precedes an active UHPI_HDS (data strobe) signal, but can be connected to a UHPI_HDS pin for simultaneous select and strobe activity.                                                                                                                                                                                                                             |
| UHPI_HR/W                  | I     | R/W strobe pin                                                 | <b>HPI read/write</b> . On the falling edge of internal $\overline{\text{HSTRB}}$ , UHPI_HR/W indicates whether the current access is to be a read or write operation. Driving UHPI_HR/W high indicates the transfer is a read from the HPI, while driving UHPI_HR/W low indicates a write to the HPI.                                                                                                                                                                                                       |
| UHPI_HHWIL                 | Ι     | Address or control pins                                        | Halfword identification line. The host uses UHPI_HHWIL to identify the first and second halfwords of the host cycle. UHPI_HHWIL must be driven low for the first halfword and high for the second halfword.                                                                                                                                                                                                                                                                                                  |
| UHPI_HAS                   | I     | None                                                           | Address strobe. Connect to logic high.                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| UHPI_HINT                  | O/Z   | Interrupt pin                                                  | <b>Host Interrupt</b> . The CPU can interrupt the host processor by writing a 1 to the HINT bit of HPIC. Before subsequent UHPI_HINT interrupts can occur, the host must acknowledge interrupts by writing a 1 to the HINT bit. This pin is active-low (that is, when an interrupt is asserted from the host, the state of this signal is low) and inverted from the HINT bit value in HPIC.                                                                                                                 |
| UHPI_HDS1 and<br>UHPI_HDS2 | I     | Read strobe and write<br>strobe pins or any data<br>strobe pin | <b>HPI data strobe pins</b> . These pins are used for strobing data in and out of the HPI (for data strobing details, see Section 2.6.4). The direction of the data transfer depends on the logic level of the UHPI_HR/W signal. The UHPI_HDS signals are also used to latch control information on the falling edge. During an HPID write access, data is latched into the HPID register on the rising edge of UHPI_HDS. During read operations, these pins act as output-enable pins of the host data bus. |
| UHPI_HD[15:0]              | I/O/Z | Data bus                                                       | HPI data bus. The HPI data bus carries the address and data to/from the HPI.                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| UHPI_HRDY                  | O/Z   | Asynchronous ready pin                                         | HPI-ready signal. When the HPI drives UHPI_HRDY low, the host has permission to complete the current host cycle. When the HPI drives UHPI_HRDY high, the HPI is not ready for the current host cycle to complete.                                                                                                                                                                                                                                                                                            |

## Table 1. HPI Pins



## 2.4 Pin Multiplexing and General-Purpose I/O Control Blocks

Extensive pin multiplexing is used to accommodate the largest number of peripheral functions in the smallest possible package. Pin multiplexing is controlled using a combination of hardware configuration at device reset and software programmable register settings. See your device-specific data manual to determine how pin multiplexing affects the HPI.

The HPI supports general-purpose I/O (GPIO) capability on all pins. All HPI pins may be enabled for GPIO mode when the HPI is disabled via the HPIENA bit in the chip configuration 1 register (CFGCHIP1) of the system configuration module.

When the HPI is enabled, the pins not being used for host accesses may be configured as general-purpose I/O.

#### 2.4.1 Treatment of Optional Pins when Configured as General-Purpose I/O

Certain pins are optional, but if used to interface to the external hosts, the pins are inputs to the HPI. For the purpose of host accesses, the HPI treats these pins as if they were driven to the values listed in Table 2.

| Pin           | GPIO Enable Bit(s) | When Enabled as GPIO,<br>Treated as Driven: |
|---------------|--------------------|---------------------------------------------|
| UHPI_HD[15:8] | GPIOEN8            | 0                                           |
| UHPI_HD[7:0]  | GPIOEN7            | 0                                           |
| UHPI_HCNTL0   | GPIOEN1            | 1                                           |
| UHPI_HCNTL1   | GPIOEN1            | 1                                           |
| UHPI_HAS      | GPIOEN2            | 1                                           |

#### Table 2. Value on Optional Pins when Configured as General-Purpose I/O

#### 2.4.2 General-Purpose I/O Programmer's Model

For each HPI pin, there are three bits that control this pin as general-purpose I/O (GPIO):

- Enable: GPIO\_EN.GPIOEN[xx]
- Direction: GPIO\_DIR*n*.DIR[yy]
- Data: GPIO\_DAT*n*.DIR[yy]

For example, the UHPI\_HAS pin is enabled with the GPIO\_EN.GPIOEN2 bit. In the default setting, the GPIO\_EN.GPIOEN2 bit is cleared to 0; therefore, the UHPI\_HAS pin functions as the host address strobe.

Enabling this pin for GPIO, by setting the GPIO\_EN.GPIOEN2 bit to 1 does two things:

- Transfers control of the UHPI\_HAS pin to GPIO direction and data bits.
- Drives a 1 into the UHPI\_HAS pin input of the external host interface block (regardless of the actual pin value).

Once enabled as GPIO, the direction of the UHPI\_HAS pin is controlled by the GPIO\_DIR2.HASZ bit. If this bit is set to 1, the pin will be driven as an output; if this bit is cleared to 0, the pin will be an input.

Once the direction of the UHPI\_HAS pin is set, the data value is either written to or read from the GPIO\_DAT2.HASZ bit. If the pin was configured as an output, then writing to this bit determines the value to drive out the pin. Reading from this bit will return the value written.

When the GPIO\_DIR2.HASZ bit is cleared to 0, configuring the UHPI\_HAS pin as an input, writing to the GPIO\_DAT2.HASZ bit has no effect. Reading from this bit will return the value on the UHPI\_HAS pin.

**NOTE:** Note that you cannot preload a value into the DAT field before configuring the pin as an output. This means that when switching the pin from input to output, the pin will initially drive the last value input back out on the pin. Then the DAT bit can be written to change the value on the pin. If the intermediate value between writing to DIR and writing to DAT will cause a problem at the system level, it is suggested to use another general-purpose I/O pin on the device.

## 2.5 Protocol Description

The HPI does not conform to any industry standard protocol.

#### 2.6 Operation

#### 2.6.1 Using the Address Registers

The HPI contains two 32-bit address registers: one for read operations (HPIAR) and one for write operations (HPIAW). These roles are unchanging from the viewpoint of the HPI logic. The HPI DMA logic gets the address from HPIAR when reading from processor resources (see Section 2.2) and gets the address from HPIAW when writing to processor resources (see Section 2.2).

However, unlike the HPI logic, the host can choose how to interact with the two HPI address registers. Using the DUALHPIA bit in the HPI control register (HPIC), the host determines whether HPIAR and HPIAW act as a single 32-bit register (single-HPIA mode) or as two independent 32-bit registers (dual-HPIA mode).

Note that the addresses loaded into the HPI address registers must be byte addresses, and must be 32-bit word aligned (with the least-significant two bits equal to zero), for use in addressing memory space within the DSP.

#### 2.6.1.1 Single-HPIA Mode

When DUALHPIA = 0 in HPIC, HPIAR and HPIAW become a single HPI address register (HPIA) from the perspective of the host. In this mode:

- A host HPIA write cycle (UHPI\_HCNTL[1:0] = 10b, UHPI\_HR/W = 0) updates HPIAR and HPIAW with the same value.
- Both HPI address registers are incremented during autoincrement read/write cycles (UHPI\_HCNTL[1:0] = 01b).
- An HPIA read cycle (UHPI\_HCNTL[1:0] = 10b, UHPI\_HR/W = 1) returns the content of HPIAR, which should be identical to the content of HPIAW.

To maintain consistency between the contents of HPIAR and HPIAW, the host should always reinitialize the HPI address registers after changing the state of the DUALHPIA bit. In addition, when DUALHPIA = 0, the host must always reinitialize the HPI address registers when it changes the data direction (from an HPID read cycle to an HPID write cycle, or conversely). Otherwise, the memory location accessed by the HPI DMA logic might not be the location intended by the host.



#### 2.6.1.2 Dual-HPIA Mode

When DUALHPIA = 1 in HPIC, HPIAR and HPIAW are two independent HPI address registers from the perspective of the host. In this mode:

- A host HPIA access (UHPI\_HCNTL[1:0] = 10b) reads/updates either HPIAR or HPIAW, depending on the value of the HPIA read/write select (HPIASEL) bit in HPIC. This bit is programmed by the host. While HPIASEL = 1, only HPIAR is read or updated by the host. While HPIASEL = 0, only HPIAW is read or updated by the host. The HPIASEL bit is only meaningful in the dual-HPIA mode.
  - **NOTE:** The HPIASEL bit does not affect the HPI DMA logic. Regardless of the value of HPIASEL, the HPI DMA logic uses HPIAR when reading from memory and HPIAW when writing to memory.
- A host HPID access with autoincrementing (UHPI\_HCNTL[1:0] = 01b) causes only the relevant HPIA value to be incremented to the next consecutive memory address. In an autoincrement read cycle, HPIAR is incremented after it has been used to perform the current read from memory. In an autoincrement write cycle, HPIAW is incremented after it has been used for the write operation.

#### 2.6.2 Host-HPI Signal Connections

Figure 2 shows an example of a signal connection between the HPI and a host.



Figure 2. Example of Host-Processor Signal Connections

A Data strobing options are given in Section 2.6.4



#### 2.6.3 HPI Configuration and Data Flow

The host accomplishes a multiplexed access in the following manner:

- 1. The host writes to the HPI control register (HPIC) to properly configure the HPI. Typically, this means programming the halfword order bit (HWOB) and the HPIA-related bits (DUALHPIA and HPIASEL). This step is normally performed once before the initial data access.
- The host writes the desired internal processor memory address to an address register (HPIAR and/or HPIAW). For an introduction to the two HPI address registers and the two ways the host can interact with them, see Section 2.6.1.
- 3. The host reads from or writes to the data register (HPID). Data transfers between HPID and the internal memory of the processor are handled by the HPI DMA logic and are transparent to the CPU.

Each step of the access uses the same bus. Therefore, the host must drive the appropriate levels on the UHPI\_HCNTL1 and UHPI\_HCNTL0 signals to indicate which register is to be accessed. The host must also drive the appropriate level on the UHPI\_HR/W signal to indicate the data direction (read or write) and must drive other control signals as appropriate. When HPI resources are temporarily busy or unavailable, the HPI can communicate this to the host by deasserting the HPI-ready (UHPI\_HRDY) output signal.

When performing an access, the HPI first latches the levels on UHPI\_HCNTL[1:0], UHPI\_HR/ $\overline{W}$ , and other control signals. This latching can occur on the falling edge of the internal strobe signal (for details, see Section 2.6.4). After the control information is latched, the HPI initiates an access based on the control signals.

If the host wants to read data from processor resources (see Section 2.2), the HPI DMA logic reads the resource address from HPIAR and retrieves the data from the addressed memory location. When the data has been placed in HPID, the HPI drives the data onto its UHPI\_HD bus. The UHPI\_HRDY signal informs the host whether the data on the UHPI\_HD bus is valid (UHPI\_HRDY low) or not valid yet (UHPI\_HRDY high). When the data is valid, the host should latch the data and drive the connected data strobe (UHPI\_HDS1 or UHPI\_HDS2) inactive, which, in turn, will cause the internal strobe (internal HSTRB) signal to transition from low to high.

If the host wants to write data to processor resources (see Section 2.2), the operation is similar. After the host determines that the HPI is ready to latch the data (UHPI\_HRDY is low), it must cause internal HSTRB to transition from low to high, which causes the data to be latched into HPID. Once the data is in HPID, the HPI DMA logic reads the memory address from HPIAW and transfers the data from HPID to the addressed memory location.



## 2.6.4 UHPI\_HDS2, UHPI\_HDS1, and UHPI\_HCS: Data Strobing and Chip Selection

As shown in Figure 3, the strobing logic is a function of three key inputs: the chip select pin (UHPI\_HCS) and two data strobe signals (UHPI\_HDS1 and UHPI\_HDS2). The internal strobe signal, which is referred to as internal HSTRB throughout this document, functions as the actual strobe signal inside the HPI. UHPI\_HCS must be low (HPI selected) during strobe activity on the UHPI\_HDS pins. If UHPI\_HCS remains high (HPI not selected), activity on the UHPI\_HDS pins is ignored.





Strobe connections between the host and the HPI depend in part on the number and types of strobe pins available on the host. Table 3 describes some options for connecting to the UHPI\_HDS pins.

Notice in Figure 3 that UHPI\_HRDY is also gated by UHPI\_HCS. If UHPI\_HCS goes high (HPI not selected), UHPI\_HRDY goes low, regardless of whether the current internal transfer is completed in the processor.

**NOTE:** The <u>UHPI\_HCS</u> input and one <u>UHPI\_HDS</u> strobe input can be tied together and driven with a single strobe signal from the host. This technique selects the HPI and provides the strobe, simultaneously. When using this method, be aware that <u>UHPI\_HRDY</u> is gated by <u>UHPI\_HCS</u> as previously described.

It is not recommended to tie both UHPI\_HDS1 and UHPI\_HDS2 to static logic levels and use UHPI\_HCS as a strobe.

| Available Host Data Strobe Pins                                | Connections to HPI Data Strobe Pins                                                                                                                                                                                                                                                        |
|----------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Host has separate read and write strobe pins, both active-low  | Connect one strobe pin to <u>UHPI_HDS1</u> and the other to <u>UHPI_HDS2</u> <sup>(1)</sup> . Since such a host might not provide a R/W line, take care to satisfy UHPI_HR/W timings as stated in your device-specific data manual. This could possibly be done using a host address line. |
| Host has separate read and write strobe pins, both active-high | Connect one strobe pin to UHPI_HDS1 and the other to UHPI_HDS2 <sup>(1)</sup> . Since such a host might not provide a $R/W$ line, take care to satisfy UHPI_HR/W timings as stated in your device-specific data manual. This could possibly be done using a host address line.             |
| Host has one active-low strobe pin                             | Connect the strobe pin to UHPI_HDS1 or UHPI_HDS2, and connect the other pin to logic-level 1.                                                                                                                                                                                              |
| Host has one active-high strobe pin                            | Connect the strobe pin to UHPI_HDS1 or UHPI_HDS2, and connect the other strobe pin to logic-level 0.                                                                                                                                                                                       |

Table 3. Options for Connecting Host and HPI Data Strobe Pins

<sup>(1)</sup> The UHPI\_HR/ $\overline{W}$  signal could be driven by a host address line in this case.

## 2.6.5 UHPI\_HCNTL[1:0] and UHPI\_HR/W: Indicating the Cycle Type

The cycle type consists of:

- The access type that the host selects by driving the appropriate levels on the UHPI\_HCNTL[1:0] pins of the HPI. Table 4 describes the four available access types.
- The transfer direction that the host selects with the UHPI\_HR/W pin. The host must drive the UHPI\_HR/W signal high (read) or low (write).

A summary of cycle types is in Table 5. The HPI samples the UHPI\_HCNTL levels at the falling edge of the internal strobe signal HSTRB.

| UHPI_HCNTL1 | UHPI_HCNTL0 | Access Type                                                                                                                                                                                                        |
|-------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0           | 0           | <b>HPIC access.</b> The host requests to access the HPI control register (HPIC).                                                                                                                                   |
| 0           | 1           | HPID access with autoincrementing. The host requests to access the HPI data register (HPID) and to have the appropriate HPI address register (HPIAR and/or HPIAW) automatically incremented by 1 after the access. |
| 1           | 0           | <b>HPIA access.</b> The host requests to access the appropriate HPI address register (HPIAR and/or HPIAW).                                                                                                         |
| 1           | 1           | HPID access without autoincrementing. The host requests to access the HPI data register (HPID) but requests no automatic post-increment of the HPI address register.                                               |

Table 4. Access Types Selectable With the UHPI\_HCNTL Signals

| Table 5. Cycle Types Selectable With the UHPI_HCNTL and UHPI_HR/W Signals |
|---------------------------------------------------------------------------|
|---------------------------------------------------------------------------|

| UHPI_HCNTL1 | UHPI_HCNTL0 | UHPI_HR/W | Сусіе Туре                                |  |
|-------------|-------------|-----------|-------------------------------------------|--|
| 0           | 0           | 0         | HPIC write cycle                          |  |
| 0           | 0           | 1         | HPIC read cycle                           |  |
| 0           | 1           | 0         | HPID write cycle with autoincrementing    |  |
| 0           | 1           | 1         | HPID read cycle with autoincrementing     |  |
| 1           | 0           | 0         | HPIA write cycle                          |  |
| 1           | 0           | 1         | HPIA read cycle                           |  |
| 1           | 1           | 0         | HPID write cycle without autoincrementing |  |
| 1           | 1           | 1         | HPID read cycle without autoincrementing  |  |

#### 2.6.6 UHPI\_HHWIL: Identifying the First and Second Halfwords in Multiplexed Mode Transfers

Each host cycle consists of two consecutive halfword transfers. For each transfer, the host must specify the cycle type with UHPI\_HCNTL[1:0] and UHPI\_HR/W, and the host must use UHPI\_HHWIL to indicate whether the first or second halfword is being transferred. For HPID and HPIA accesses, UHPI\_HHWIL must always be driven low for the first halfword transfer and high for the second halfword transfer. Results are undefined if the sequence is broken. For examples of using UHPI\_HHWIL, see Section 2.6.7.

When the host sends the two halfwords of a 32-bit word in this manner, the host can send the most-significant and the least-significant halfwords of the word in either order (most-significant halfword first or most-significant halfword second). However, the host must inform the HPI of the selected order before beginning the host cycle. This is done by programming the halfword order (HWOB) bit in HPIC. Although HWOB is written at bit 0 in HPIC, its current value is readable at both bit 0 and bit 8 (HWOBSTAT). Thus, the host can determine the current halfword order configuration by checking the least-significant bit of either half of HPIC.

There is one case when the HPI does not require a dual halfword access with UHPI\_HHWIL low for the first halfword and UHPI\_HHWIL high for the second halfword. This is the case when accessing the HPIC register. When accessing HPIC, the state of UHPI\_HHWIL is ignored and the same 16-bit HPIC register is accessed regardless of whether the host performs a single or dual access. For an example timing diagram of this case, see Section 2.6.8.



#### 2.6.7 Performing a Multiplexed Access

Figure 2 shows an example of signal connections for multiplexed transfers. Figure 4 and Figure 5 show typical HPI signal activity when performing a read and write transfer, respectively. In these cases, the falling edge of internal HSTRB is used to latch the UHPI\_HCNTL[1:0], UHPI\_HR/W, and UHPI\_HHWIL states into the HPI. Internal HSTRB is derived from UHPI\_HCS, UHPI\_HDS1, and UHPI\_HDS2 as described in Section 2.6.4.



NOTE: Depending on the type of write operation (HPID without autoincrementing, HPIA, HPIC, or HPID with autoincrementing) and the state of the FIFO, transitions on UHPI\_HRDY may or may not occur. For more information, see Section 2.6.9.





NOTE: Depending on the type of write operation (HPID without autoincrementing, HPIA, HPIC, or HPID with autoincrementing) and the state of the FIFO, transitions on UHPI\_HRDY may or may not occur. For more information, see Section 2.6.9.



#### 2.6.8 Single-Halfword HPIC Cycle

Figure 6 shows the special case (see Section 2.6.6) when the host performs a single-halfword cycle to access the HPIC. The state of UHPI\_HHWIL is ignored and if a dual-halfword access is performed, then the same HPIC register is accessed twice.



#### 2.6.9 Hardware Handshaking Using the HPI-Ready (UHPI\_HRDY) Signal

The HPI uses its ready signal, <u>UHPI\_HRDY</u>, to tell the host whether it is ready to complete an access. During a read cycle, the HPI is ready (<u>UHPI\_HRDY</u> is low) when it has data available for the host. During a write cycle, the HPI is ready (<u>UHPI\_HRDY</u> is low) when it is ready to latch data from the host. If the HPI is not ready, it can drive <u>UHPI\_HRDY</u> high to insert wait states. These wait states indicate to the host that read data is not yet valid (read cycle) or that the HPI is not ready to latch write data (write cycle). The number of wait states that must be inserted by the HPI is dependent upon the state of the resource that is being accessed.

When the HPI is not ready to complete the current cycle (UHPI\_HRDY is high), the host can begin a new host cycle by forcing the HPI to latch new control information. However, once the cycle has been initiated, the host must wait until UHPI\_HRDY goes low before causing a rising edge on the internal strobe signal (internal HSTRB) to complete the cycle. If internal HSTRB goes high when the HPI is not ready, the cycle will be terminated with invalid data being returned (read cycle) or written (write cycle).

One reason the HPI may drive UHPI\_HRDY high is a not-ready condition in one of its first-in, first-out buffers (FIFOs). For example, any HPID access that occurs while the write FIFO is full or the read FIFO is empty may result in some number of wait states being inserted by the HPI. The FIFOs are explained in Section 2.6.10.

The following sections describe the behavior of <u>UHPI\_HRDY</u> during HPI register accesses. In all cases, the chip select signal, <u>UHPI\_HCS</u>, must be asserted for <u>UHPI\_HRDY</u> to go low.



#### 2.6.9.1 UHPI\_HRDY Behavior During Multiplexed-Mode Read Operations

Figure 7 shows an HPIC (UHPI\_HCNTL[1:0] = 00b) or HPIA (UHPI\_HCNTL[1:0] = 10b) read cycle. Neither an HPIC read cycle nor an HPIA read cycle causes UHPI\_HRDY to go high. For this type of access, the state of UHPI\_HHWIL is ignored, so if a dual halfword access is performed, the same register will be accessed twice.



Figure 8 includes an HPID read cycle without autoincrementing. The host writes the memory address during the HPIA (UHPI\_HCNTL[1:0] = 10b) write cycle, and the host reads the data during the HPID (UHPI\_HCNTL[1:0] = 11b) read cycle. UHPI\_HRDY goes high for each HPIA halfword access, but UHPI\_HRDY goes high for only the first halfword access in each HPID read cycle.

Figure 8. UHPI\_HRDY Behavior During a Data Read Operation in the Multiplexed Mode (Case 1: HPIA Write Cycle Followed by Nonautoincrement HPID Read Cycle)



Figure 9 includes an autoincrement HPID read cycle. The host writes the memory address while asserting UHPI\_HCNTL[1:0] = 10b and reads the data while asserting UHPI\_HCNTL[1:0] = 01b. During the first HPID read cycle, UHPI\_HRDY goes high for only the first halfword access, and subsequent HPID read cycles do not cause UHPI\_HRDY to go high.





SPRUFM7D-April 2010



#### 2.6.9.2 <u>UHPI\_HRDY</u> Behavior During Multiplexed-Mode Write Operations

Figure 10 shows an HPIC (UHPI\_HCNTL[1:0] = 00b) write cycle operation. An HPIC write cycle does not cause UHPI\_HRDY to go high and the state of UHPI\_HHWIL is ignored. Firmware is not required to perform a dual access to access HPIC.



Figure 11 includes a HPID write cycle without autoincrementing. The host writes the memory address while UHPI\_HCNTL[1:0] = 10b and writes the data while UHPI\_HCNTL[1:0] = 11b. During the HPID write cycle, UHPI\_HRDY goes high only for the second halfword access.

Figure 11. UHPI\_HRDY Behavior During a Data Write Operation in the Multiplexed Mode (Case 1: No Autoincrementing)



Figure 12 shows autoincrement HPID write cycles when the write FIFO is empty prior to the HPIA write. The host writes the memory address while UHPI\_HCNTL[1:0] = 10b and writes the data while UHPI\_HCNTL[1:0] = 01b. UHPI\_HRDY does not go high during any of the HPID write cycles until the FIFO is full.





Figure 13 shows a case similar to that of Figure 12. However, in the case of Figure 13, the write FIFO is not empty when the HPIA access is made. UHPI\_HRDY goes high twice for the first halfword access of the HPIA write cycle. The first UHPI\_HRDY high period is due to the nonempty FIFO. The data currently in the FIFO must first be written to the memory. This results in UHPI\_HRDY going high immediately after the falling edge of the data strobe (HSTRB). The second and third UHPI\_HRDY high periods occur for the writes to the HPIA. UHPI\_HRDY remains low for the HPID accesses.





#### 2.6.10 FIFOs and Bursting

The HPI data register (HPID) is a port through which the host accesses two first-in, first-out buffers (FIFOs). As shown in Figure 14, a read FIFO supports host read cycles, and a write FIFO supports host write cycles. Both read and write FIFOs are 8-words deep (each word is 32 bits). If the host is performing multiple reads or writes to consecutive memory addresses (autoincrement HPID cycles), the FIFOs are used for bursting. The HPI DMA logic reads or writes a burst of four words at a time when accessing one of the FIFOs.

Bursting is essentially invisible to the host because the host interface signaling is not affected. Its benefit to the host is that the UHPI\_HRDY signal is deasserted less often when there are multiple reads or writes to consecutive addresses.



Figure 14. FIFOs in the HPI



#### 2.6.10.1 Read Bursting

When the host writes to the read address register (HPIAR), the read FIFO is flushed. Any host read data that was in the read FIFO is discarded (the read FIFO pointers are reset). If an HPI DMA write to the read FIFO is in progress at the time of a flush request, the HPI allows this write to complete and then performs the flush.

Read bursting can begin in one of two ways: the host initiates an HPID read cycle with autoincrementing, or the host initiates issues a FETCH command (writes 1 to the FETCH bit in HPIC).

If the host initiates an HPID read cycle with autoincrementing, the HPI DMA logic performs two 4-word burst operations to fill the read FIFO. The host is initially held off by the deassertion of the UHPI\_HRDY signal until data is available to be read from the read FIFO. Once data is available in the read FIFO, the host can read data from the read FIFO by performing subsequent reads of HPID with autoincrementing. Once the initial read has been performed, the HPI DMA logic continues to perform 4-word burst operations to consecutive memory addresses every time there are four empty word locations in the read FIFO. The HPI DMA logic continues to prefetch data to keep the read FIFO full, until the occurrence of an event that causes a read FIFO flush (see Section 2.6.10.3).

As mentioned, the second way that read bursting may begin is with a FETCH command. The host should always precede the FETCH command with the initialization of the HPIAR register or a nonautoincrement access, so that the read FIFO is flushed beforehand. When the host initiates a FETCH command, the HPI DMA logic begins to prefetch data to keep the read FIFO full, as described in the previous paragraph. The FETCH bit in HPIC does not actually store the value that is written to it; rather, the decoding of a host write of 1 to this bit is considered a FETCH command.

The FETCH command can be helpful if the host wants to minimize a stall condition on the interface. The host can initiate prefetching by writing 1 to the FETCH bit and later perform a read. The host can make use of the time it takes to load the read FIFO with read data, during which the HPI was not ready, by using the CPU to service other tasks.

Both types of continuous or burst reads described in the previous paragraphs begin with a write to the HPI address register, which causes a read FIFO flush. This is the typical way of initiating read cycles, because the initial read address needs to be specified.

**NOTE:** An HPID read cycle without autoincrementing does not initiate any prefetching activity. Instead, it causes the read FIFO to be flushed and causes the HPI DMA logic to perform a single-word read from the processor memory. As soon as the host activates a read cycle without autoincrementing, prefetching activity ceases until the occurrence of a FETCH command or an autoincrement read cycle.



#### 2.6.10.2 Write Bursting

A write to the write address register (HPIAW) causes the write FIFO to be flushed. This means that any write data in the write FIFO is forced to its destination in the processor memory (the HPI DMA logic performs burst operations until the write FIFO is empty). When the FIFO has been flushed, the only action that will cause the HPI DMA logic to perform burst writes is a host write to HPID with autoincrementing. The initial host-write data is stored in the write FIFO. An HPI DMA write is not requested until there are four words in the write FIFO. As soon as four words have been written to the FIFO via HPID write cycles with autoincrementing, the HPI DMA logic performs a 4-word burst operation to the processor memory. The burst operations continue as long as there are at least four words in the FIFO. If the FIFO becomes full (eight words are waiting in the FIFO), the HPI holds off the host by deasserting UHPI\_HRDY until at least one empty word location is available in the FIFO.

Because excessive time might pass between consecutive burst operations, the HPI has a time-out counter. If there are fewer than four words in the write FIFO and the time-out counter expires, the HPI DMA logic empties the FIFO immediately by performing a 2-word or 3-word burst, or a single-word write, as necessary. Every time new data is written to the write FIFO, the time-out counter is automatically reset to begin its count again. The time-out period is set to a value of 160. For more detailed information about the time-out period, see your device-specific data manual.

**NOTE:** An HPID write cycle without autoincrementing does not initiate any bursting activity. Instead, it causes the write FIFO to be flushed and causes the HPI DMA logic to perform a single-word write to the processor memory. As soon as the host activates a write cycle without autoincrementing, bursting activity ceases until the occurrence of an autoincrement write cycle. A nonautoincrement write cycle always should be preceded by the initialization of HPIAW or by another nonautoincrement access, so that the write FIFO is flushed beforehand.



#### 2.6.10.3 FIFO Flush Conditions

When specific conditions occur within the HPI, the read or write FIFO must be flushed to prevent the reading of stale data from the FIFOs. When a read FIFO flush condition occurs, all current host accesses and direct memory accesses (DMAs) to the read FIFO are allowed to complete. This includes DMAs that have been requested but not yet initiated. The read FIFO pointers are then reset, causing any read data to be discarded.

Similarly, when a write FIFO flush condition occurs, all current host accesses and DMAs to the write FIFO are allowed to complete. This includes DMAs that have been requested but not yet initiated. All posted writes in the FIFO are then forced to completion with a final burst or single-word write, as necessary.

If the host initiates an HPID host cycle during a FIFO flush, the cycle is held off with the deassertion of UHPI\_HRDY until the flush is complete and the FIFO is ready to be accessed.

The following conditions cause the read and write FIFOs to be flushed:

- Read FIFO flush conditions:
  - A value from the host is written to the read address register (HPIAR).
  - The host performs an HPID read cycle without autoincrementing.
- Write FIFO flush conditions:
  - A value from the host is written to the write address register (HPIAW).
  - The host performs an HPID write cycle without autoincrementing.
  - The write-burst time-out counter expires.

When operating with DUALHPIA = 0, any read or write flush condition causes both read and write FIFOs to be flushed. In addition, the following scenarios cause both FIFOs to be flushed when DUALHPIA = 0:

- The host performs a write to the HPIA register.
- The host performs an HPID write cycle with autoincrementing while the read FIFO is not empty (the read FIFO still contains data from prefetching or an HPID read cycle with autoincrementing).
- The host performs an HPID read cycle with autoincrementing while the write FIFO is not empty (there is still posted write data in the write FIFO).

This is useful in providing protection against reading stale data by reading a memory address when a previous write cycle has not been completed at the same address. Similarly, this protects against overwriting data at a memory address when a previous read cycle has not been completed at the same address.

When operating with DUALHPIA = 1 (HPIAR and HPIAW are independent), there is no such protection. However, when DUALHPIA = 1, data flow can occur in both directions without flushing both FIFOs simultaneously, thereby improving HPI bandwidth.

#### 2.6.10.4 FIFO Behavior When a Hardware Reset or Software Reset Occurs

A hardware reset (RESET pin driven low) or an HPI software reset causes the FIFOs to be reset. The FIFO pointers are cleared, so that all data in the FIFOs are discarded. In addition, all associated FIFO logic is reset.

If a host cycle is active when a hardware or HPI software reset occurs, the <u>UHPI\_HRDY</u> signal is asserted (driven low), allowing the host to complete the cycle. When the cycle is complete, <u>UHPI\_HRDY</u> is deasserted (driven high). Any access interrupted by a reset may result in corrupted read data or a lost write data (if the write does not actually update the intended memory or register). Although data may be lost, the host interface protocol is not violated. While either of reset condition is true, and the host is idle (internal HSTRB is held high), the FIFOs are held in reset, and host transactions are held off with an inactive UHPI\_HRDY signal.

#### 2.7 Reset Considerations

The HPI has two reset sources: software reset and hardware reset.

#### 2.7.1 Software Reset Considerations

The HPI is not affected by a software reset issued by the emulator.

#### 2.7.2 Hardware Reset Considerations

When the entire processor is reset with the RESET pin:

- If the internal strobe signal, internal HSTRB, is high (host is inactive), UHPI\_HRDY is driven low and remains low until the reset condition is over.
- If internal HSTRB is low (host cycle is active), UHPI\_HRDY is driven high, allowing the host to
  complete the cycle. When internal HSTRB goes high (cycle is complete), UHPI\_HRDY is driven low
  and remains low until the reset condition is over. If the active cycle was a write cycle, the memory or
  register may not have been correctly updated. If the active cycle was a read cycle, the fetched value
  may not be valid.
- The HPI registers are reset to their default values (see Section 3).
- The read and write FIFOs and the associated FIFO logic are reset (this includes a flush of the FIFOs).
- Host-to-CPU and CPU-to-host interrupts are cleared.

## 2.8 Initialization

The following steps are required to configure the HPI after a hardware reset:

- 1. Perform the necessary device pin multiplexing setup (see your device-specific data manual).
- 2. Configure the HPIENA and HPIBYTEAD bits in the chip configuration 1 register (CFGCHIP1) of the system configuration module. See your device-specific *System Reference Guide* for the bit definitions.
- 3. Choose how HPIAR and HPIAW will be controlled by configuring the DUALHPIA bit in HPIC.
- 4. Choose how halfword ordering will be handled by configuring the HWOB bit in HPIC.
- 5. Choose how the HPI will respond to emulation suspend events by configuring the FREE and SOFT bits in PWREMU\_MGMT.
- 6. Choose the desired initial addresses and write the addresses to HPIAW and HPIAR, appropriately.
- 7. Release the HPI logic from reset by clearing the HPIRST bit in HPIC.

The HPI is now ready to perform data transactions.



## 2.9 Interrupt Support

The host can interrupt the CPU via the DSPINT bit in HPIC, as described in Section 2.9.1. The CPU can send an interrupt to the host by using the HINT bit in HPIC, as described in Section 2.9.2.

#### 2.9.1 DSPINT Bit: Host-to-CPU Interrupts

The DSPINT bit in HPIC allows the host to send an interrupt request to the CPU. The use of the DSPINT bit is summarized in Figure 15.



#### Figure 15. Host-to-CPU Interrupt State Diagram

A When the DSPINT bit transitions from 0 to 1, an interrupt is generated to the CPU. No new interrupt can be generated until the CPU has cleared the bit (DSPINT = 0).

To interrupt the CPU, the host must:

- 1. Drive both UHPI\_HCNTL1 and UHPI\_HCNTL0 low to request a write to HPIC.
- 2. Write 1 to the DSPINT bit in HPIC.

When the host sets the DSPINT bit, the HPI generates an interrupt pulse to the CPU. If this maskable interrupt is properly enabled in the CPU, the CPU executes the corresponding interrupt service routine (ISR).

Before the host can use DSPINT to generate a subsequent interrupt to the CPU, the CPU must acknowledge the current interrupt by writing a 1 to the DSPINT bit. When the CPU writes 1, DSPINT is forced to 0. The host should verify that DSPINT = 0 before generating subsequent interrupts. While DSPINT = 1, host writes to the DSPINT bit do not generate an interrupt pulse.

Writes of 0 have no effect. A hardware reset immediately clears DSPINT and thus clears an active host-to-CPU interrupt.



#### 2.9.2 HINT Bit: CPU-to-Host Interrupts

The HINT bit in HPIC allows the CPU to send an interrupt request to the host. The use of the HINT bit is summarized in Figure 16.



#### Figure 16. CPU-to-Host Interrupt State Diagram

If the CPU writes 1 to the HINT bit of HPIC, the HPI drives the <u>UHPI\_HINT</u> signal low, indicating an interrupt condition to the host. Before the CPU can use the HINT bit generate a subsequent interrupt to host, the host must acknowledge the current interrupt by writing 1 to the HINT bit. When the host does this, the HPI clears the HINT bit (HINT = 0), and this drives the <u>UHPI\_HINT</u> signal high. The CPU should read HPIC and make sure HINT = 0 before generating subsequent interrupts.

Writes of 0 have no effect. A hardware reset immediately clears the HINT bit and thus clears an active CPU-to-host interrupt.

#### 2.10 EDMA Event Support

The HPI does not provide synchronization events to the EDMA system. Memory accesses from the HPI are handled automatically, independent of the EDMA controller. The HPI controller has its own dedicated DMA and its operation and configuration are transparent.

#### 2.11 Power Management

The HPI peripheral can be placed in reduced-power modes to conserve power during periods of low activity. The power management of the HPI peripheral is controlled by the processor Power and Sleep Controller (PSC). The PSC acts as a master controller for power management for all of the peripherals on the device. For detailed information on power management procedures using the PSC, see your device-specific *System Reference Guide*.



## 2.12 Emulation Considerations

The FREE and SOFT bits in the power and emulation management register (PWREMU\_MGMT) determine the response of the HPI to an emulation suspend condition. If FREE = 1, the HPI is not affected, and the SOFT bit has no effect. If FREE = 0 and SOFT = 0, the HPI is not affected. If FREE = 0 and SOFT = 1:

- The HPI DMA logic halts after the current host and HPI DMA operations are completed.
- The external host interface functions as normal throughout the emulation suspend condition. The host
  may access the control register (HPIC). The host may also access the HPIA registers and may perform
  data reads until the read FIFO is empty or data writes until the write FIFO is full. As in normal
  operation, UHPI\_HRDY is driven low during a host cycle that cannot be completed due to the write
  FIFO being full or the read FIFO being empty. If this occurs, UHPI\_HRDY continues to be driven low,
  holding off the host, until the emulation suspend condition is over, and the FIFOs are serviced by the
  HPI DMA logic, allowing the host cycle to complete.
- When the emulation suspend condition is over, the appropriate requests by the HPI DMA logic are made to process any posted host writes in the write FIFO or to fill the read FIFO as necessary. HPI operation then continues as normal.

## 3 Registers

Table 6 lists the memory-mapped registers for the HPI. See your device-specific data manual for the memory addresses of these registers.

| Offset | Acronym     | Register Description                       | Section      |
|--------|-------------|--------------------------------------------|--------------|
| 0      | REVID       | Revision Identification Register           | Section 3.1  |
| 4h     | PWREMU_MGMT | Power and Emulation Management Register    | Section 3.2  |
| Ch     | GPIO_EN     | GPIO Enable Register                       | Section 3.3  |
| 10h    | GPIO_DIR1   | GPIO Direction 1 Register                  | Section 3.4  |
| 14h    | GPIO_DAT1   | GPIO Data 1 Register                       | Section 3.5  |
| 18h    | GPIO_DIR2   | GPIO Direction 2 Register                  | Section 3.6  |
| 1Ch    | GPIO_DAT2   | GPIO Data 2 Register                       | Section 3.7  |
| 30h    | HPIC        | Host Port Interface Control Register       | Section 3.8  |
| 34h    | HPIAW       | Host Port Interface Write Address Register | Section 3.9  |
| 38h    | HPIAR       | Host Port Interface Read Address Register  | Section 3.10 |

#### Table 6. HPI Registers



#### 3.1 Revision Identification Register (REVID)

The revision identification register (REVID) contains identification data for the peripheral. REVID is shown in Figure 17 and described in Table 7.

#### Figure 17. Revision Identification Register (REVID)

| 31 |              | 0 |
|----|--------------|---|
|    | REV          |   |
|    | R-4421 210Ah |   |

LEGEND: R = Read only; -n = value after reset

#### Table 7. Revision Identification Register (REVID) Field Descriptions

| Bit  | Field | Value        | Description             |
|------|-------|--------------|-------------------------|
| 31-0 | REV   | 0-4421 210Ah | Revision identification |

#### 3.2 Power and Emulation Management Register (PWREMU\_MGMT)

The power and emulation management register (PWREMU\_MGMT) determines the emulation mode of the HPI. PWREMU\_MGMT is shown in Figure 18 and described in Table 8.

#### Figure 18. Power and Emulation Management Register (PWREMU\_MGMT)

| 31 |          |   |       | 16    |
|----|----------|---|-------|-------|
|    | Reserved |   |       |       |
|    | R-0      |   |       |       |
| 15 |          | 2 | 1     | 0     |
|    | Reserved |   | SOFT  | FREE  |
|    | R-0      |   | R/W-0 | R/W-0 |
|    |          |   |       |       |

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

#### Table 8. Power and Emulation Management Register (PWREMU\_MGMT) Field Descriptions

| Bit  | Field    | Value | Description                                                                                                                                           |
|------|----------|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-2 | Reserved | 0     | Reserved                                                                                                                                              |
| 1    | SOFT     |       | Determines emulation mode functionality of the HPI. When the FREE bit is cleared to 0, the SOFT bit selects the HPI mode.                             |
|      |          | 0     | Upon emulation suspend, the HPI operation is not affected.                                                                                            |
|      |          | 1     | In response to an emulation suspend event, the HPI logic halts after the current HPI transaction is completed.                                        |
| 0    | FREE     |       | Free run emulation control. Determines emulation mode functionality of the HPI. When the FREE bit is cleared to 0, the SOFT bit selects the HPI mode. |
|      |          | 0     | The SOFT bit selects the HPI mode.                                                                                                                    |
|      |          | 1     | The HPI runs free regardless of the SOFT bit.                                                                                                         |

~ .

. .

## 3.3 GPIO Enable Register (GPIO\_EN)

The GPIO enable register (GPIO\_EN) enables the pin for general-purpose I/O. GPIO\_EN is shown in Figure 19 and described in Table 9.

## Figure 19. GPIO Enable Register (GPIO\_EN)

| 31      |          |         |          |          |         |         | 16      |  |  |
|---------|----------|---------|----------|----------|---------|---------|---------|--|--|
|         | Reserved |         |          |          |         |         |         |  |  |
|         |          |         | R        | -0       |         |         |         |  |  |
| 15      |          |         |          |          |         | 9       | 8       |  |  |
|         |          |         | Reserved |          |         |         | GPIOEN8 |  |  |
|         |          |         | R-0      |          |         |         | R/W-0   |  |  |
| 7       | 6        | 5       | 4        | 3        | 2       | 1       | 0       |  |  |
| GPIOEN7 | GPIOEN6  | GPIOEN5 | GPIOEN4  | Reserved | GPIOEN2 | GPIOEN1 | GPIOEN0 |  |  |
| R/W-0   | R/W-0    | R/W-0   | R/W-0    | R-0      | R/W-0   | R/W-0   | R/W-0   |  |  |
|         |          |         |          |          |         |         |         |  |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

#### Table 9. GPIO Enable Register (GPIO\_EN) Field Descriptions

| Bit  | Field    | Value | Description                                                        |
|------|----------|-------|--------------------------------------------------------------------|
| 31-9 | Reserved | 0     | Reserved                                                           |
| 8    | GPIOEN8  |       | Enable as GPIO for UHPI_HD[15:8] pins                              |
|      |          | 0     | Disable pins for GPIO. Pins functions as HPI signal.               |
|      |          | 1     | Enable pins for GPIO.                                              |
| 7    | GPIOEN7  |       | Enable as GPIO for UHPI_HD[7:0] pins.                              |
|      |          | 0     | Disable pins for GPIO. Pins functions as HPI signal.               |
|      |          | 1     | Enable pins for GPIO.                                              |
| 6    | GPIOEN6  |       | Enable as GPIO for UHPI_HINT pin.                                  |
|      |          | 0     | Disable pin for GPIO. Pin functions as HPI signal.                 |
|      |          | 1     | Enable pin for GPIO.                                               |
| 5    | GPIOEN5  |       | Enable as GPIO for UHPI_HRDY pin.                                  |
|      |          | 0     | Disable pin for GPIO. Pin functions as HPI signal.                 |
|      |          | 1     | Enable pin for GPIO.                                               |
| 4    | GPIOEN4  |       | Enable as GPIO for UHPI_HHWIL pin.                                 |
|      |          | 0     | Disable pin for GPIO. Pin functions as HPI signal.                 |
|      |          | 1     | Enable pin for GPIO.                                               |
| 3    | Reserved | 0     | Reserved                                                           |
| 2    | GPIOEN2  |       | Enable as GPIO for UHPI_HAS pin.                                   |
|      |          | 0     | Disable pin for GPIO. Pin functions as HPI signal.                 |
|      |          | 1     | Enable pin for GPIO.                                               |
| 1    | GPIOEN1  |       | Enable as GPIO for UHPI_HCNTL[1:0] pins.                           |
|      |          | 0     | Disable pins for GPIO. Pins functions as HPI signal.               |
|      |          | 1     | Enable pins for GPIO.                                              |
| 0    | GPIOEN0  |       | Enable as GPIO for UHPI_HCS, UHPI_HDS1, UHPI_HDS2, UHPI_HR/W pins. |
|      |          | 0     | Disable pins for GPIO. Pins functions as HPI signal.               |
|      |          | 1     | Enable pins for GPIO.                                              |



## 3.4 GPIO Direction 1 Register (GPIO\_DIR1)

The GPIO direction 1 register (GPIO\_DIR1) determines if the UHPI\_HD*n* pin is an input or an output. GPIO\_DIR1 is shown in Figure 20 and described in Table 10.

#### Figure 20. GPIO Direction 1 Register (GPIO\_DIR1)

| 31    |          |        |            |         |                    |            |       |       |       |       |       |       |       |       | 16    |
|-------|----------|--------|------------|---------|--------------------|------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|       |          |        |            |         |                    |            | Rese  | erved |       |       |       |       |       |       |       |
|       |          |        |            |         |                    |            | R     | -0    |       |       |       |       |       |       |       |
| 15    | 14       | 13     | 12         | 11      | 10                 | 9          | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| HD15  | HD14     | HD13   | HD12       | HD11    | HD10               | HD9        | HD8   | HD7   | HD6   | HD5   | HD4   | HD3   | HD2   | HD1   | HD0   |
| R/W-0 | R/W-0    | R/W-0  | R/W-0      | R/W-0   | R/W-0              | R/W-0      | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
| LEGEN | D: R/W = | Read/W | /rite; R = | Read on | y; - <i>n</i> = va | alue after | reset |       |       |       |       |       |       |       |       |

#### Table 10. GPIO Direction 1 Register (GPIO\_DIR1) Field Descriptions

| Bit   | Field       | Value | Description                         |
|-------|-------------|-------|-------------------------------------|
| 31-16 | Reserved    | 0     | Reserved                            |
| 15-0  | HD <i>n</i> |       | Direction control for UHPI_HDn pin. |
|       |             | 0     | UHPI_HD <i>n</i> pin is an input.   |
|       |             | 1     | UHPI_HD <i>n</i> pin is an output.  |

## 3.5 GPIO Data 1 Register (GPIO\_DAT1)

The GPIO data 1 register (GPIO\_DAT1) determines the value driven on the corresponding UHPI\_HD*n* pin, if the pin is configured as an output (GPIO\_DIR1.HD*n* = 1). Writes do not affect pins not configured as GPIO outputs. The bits in GPIO\_DAT1 are set or cleared by writing directly to this register. A read of GPIO\_DAT1 returns the value of the register bit (HD*n*) not the value at the UHPI\_HD*n* pin (that might be configured as an input). GPIO\_DAT1 is shown in Figure 21 and described in Table 11.

#### Figure 21. GPIO Data 1 Register (GPIO\_DAT1)

| 31    |          |        |            |         |            |            |       |       |       |       |       |       |       |       | 16    |
|-------|----------|--------|------------|---------|------------|------------|-------|-------|-------|-------|-------|-------|-------|-------|-------|
|       |          |        |            |         |            |            | Rese  | erved |       |       |       |       |       |       |       |
|       |          |        |            |         |            |            | R     | -0    |       |       |       |       |       |       |       |
| 15    | 14       | 13     | 12         | 11      | 10         | 9          | 8     | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
| HD15  | HD14     | HD13   | HD12       | HD11    | HD10       | HD9        | HD8   | HD7   | HD6   | HD5   | HD4   | HD3   | HD2   | HD1   | HD0   |
| R/W-0 | R/W-0    | R/W-0  | R/W-0      | R/W-0   | R/W-0      | R/W-0      | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |
| LEGEN | D: R/W = | Read/W | /rite; R = | Read on | y; -n = va | alue after | reset |       |       |       |       |       |       |       |       |

| Table 11. GPIO Data 1 Register (GP | <b>IO_DAT1)</b> Field Descriptions |
|------------------------------------|------------------------------------|
|------------------------------------|------------------------------------|

| Bit   | Field       | Value | Description                             |
|-------|-------------|-------|-----------------------------------------|
| 31-16 | Reserved    | 0     | Reserved                                |
| 15-0  | HD <i>n</i> | 0-1   | Data read from/written to UHPI_HDn pin. |

## 3.6 GPIO Direction 2 Register (GPIO\_DIR2)

The GPIO direction 2 register (GPIO\_DIR2) determines if the HPI pin is an input or an output. GPIO\_DIR2 is shown in Figure 22 and described in Table 12.

## Figure 22. GPIO Direction 2 Register (GPIO\_DIR2)

| 31     |                     |                   |                  |       |       |       | 16    |  |  |  |
|--------|---------------------|-------------------|------------------|-------|-------|-------|-------|--|--|--|
|        | Reserved            |                   |                  |       |       |       |       |  |  |  |
|        |                     |                   | F                | २-०   |       |       |       |  |  |  |
| 15     |                     |                   |                  |       | 10    | 9     | 8     |  |  |  |
|        |                     |                   | HRDY             | HINTZ |       |       |       |  |  |  |
|        |                     | R                 | -0               |       |       | R/W-0 | R/W-0 |  |  |  |
| 7      | 6                   | 5                 | 4                | 3     | 2     | 1     | 0     |  |  |  |
| HCNTL0 | HCNTL1              | HHWIL             | HRW              | HDS2Z | HDS1Z | HCSZ  | HASZ  |  |  |  |
| R/W-0  | R/W-0               | R/W-0             | R/W-0            | R/W-0 | R/W-0 | R/W-0 | R/W-0 |  |  |  |
|        | - Road/Mrite: R - I | Read only: -n - y | alua aftar rasat |       |       |       |       |  |  |  |

LEGEND: R/W = Read/Write; R = Read only; -n = value after reset

## Table 12. GPIO Direction 2 Register (GPIO\_DIR2) Field Descriptions

| Bit   | Field    | Value | Description                            |
|-------|----------|-------|----------------------------------------|
| 31-10 | Reserved | 0     | Reserved                               |
| 9     | HRDY     |       | Direction control for UHPI_HRDY pin.   |
|       |          | 0     | UHPI_HRDY pin is an input.             |
|       |          | 1     | UHPI_HRDY pin is an output.            |
| 8     | HINTZ    |       | Direction control for UHPI_HINT pin.   |
|       |          | 0     | UHPI_HINT pin is an input.             |
|       |          | 1     | UHPI_HINT pin is an output.            |
| 7     | HCNTL0   |       | Direction control for UHPI_HCNTL0 pin. |
|       |          | 0     | UHPI_HCNTL0 pin is an input.           |
|       |          | 1     | UHPI_HCNTL0 pin is an output.          |
| 6     | HCNTL1   |       | Direction control for UHPI_HCNTL1 pin. |
|       |          | 0     | UHPI_HCNTL1 pin is an input.           |
|       |          | 1     | UHPI_HCNTL1 pin is an output.          |
| 5     | HHWIL    |       | Direction control for UHPI_HHWIL pin.  |
|       |          | 0     | UHPI_HHWIL pin is an input.            |
|       |          | 1     | UHPI_HHWIL pin is an output.           |
| 4     | HRW      |       | Direction control for UHPI_HR/W pin.   |
|       |          | 0     | UHPI_HR/W pin is an input.             |
|       |          | 1     | UHPI_HR/W pin is an output.            |
| 3     | HDS2Z    |       | Direction control for UHPI_HDS2 pin.   |
|       |          | 0     | UHPI_HDS2 pin is an input.             |
|       |          | 1     | UHPI_HDS2 pin is an output.            |
| 2     | HDS1Z    |       | Direction control for UHPI_HDS1 pin.   |
|       |          | 0     | UHPI_HDS1 pin is an input.             |
|       |          | 1     | UHPI_HDS1 pin is an output.            |
| 1     | HCSZ     |       | Direction control for UHPI_HCS pin.    |
|       |          | 0     | UHPI_HCS pin is an input.              |
|       |          | 1     | UHPI_HCS pin is an output.             |
| 0     | HASZ     |       | Direction control for UHPI_HAS pin.    |
|       |          | 0     | UHPI_HAS pin is an input.              |
|       |          | 1     | UHPI_HAS pin is an output.             |



## 3.7 GPIO Data 2 Register (GPIO\_DAT2)

The GPIO data 2 register (GPIO\_DAT2) determines the value driven on the corresponding HPI pin, if the pin is configured as an output (GPIO\_DIR2 bit = 1). Writes do not affect pins not configured as GPIO outputs. The bits in GPIO\_DAT2 are set or cleared by writing directly to this register. A read of GPIO\_DAT2 returns the value of the register bit not the value at the HPI pin (that might be configured as an input). GPIO\_DAT2 is shown in Figure 23 and described in Table 13.

| 31     |        |       |       |       |       |       | 16    |
|--------|--------|-------|-------|-------|-------|-------|-------|
|        |        |       | Res   | erved |       |       |       |
|        |        |       | F     | R-0   |       |       |       |
| 15     |        |       |       |       | 10    | 9     | 8     |
|        |        | Rese  | erved |       |       | HRDY  | HINTZ |
|        |        | R     | -0    |       |       | R/W-0 | R/W-0 |
| 7      | 6      | 5     | 4     | 3     | 2     | 1     | 0     |
| HCNTL0 | HCNTL1 | HHWIL | HRW   | HDS2Z | HDS1Z | HCSZ  | HASZ  |
| R/W-0  | R/W-0  | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 | R/W-0 |

Figure 23. GPIO Data 2 Register (GPIO\_DAT2)

LEGEND: R/W = Read/Write; R = Read only; -*n* = value after reset

| Table 13. GPIO Data 2 Register | (GPIO_DAT2) Field Descriptions |
|--------------------------------|--------------------------------|
|                                |                                |

| Bit   | Field    | Value | Description                                |
|-------|----------|-------|--------------------------------------------|
| 31-10 | Reserved | 0     | Reserved                                   |
| 9     | HRDY     | 0-1   | Data read from/written to UHPI_HRDY pin.   |
| 8     | HINTZ    | 0-1   | Data read from/written to UHPI_HINT pin.   |
| 7     | HCNTL0   | 0-1   | Data read from/written to UHPI_HCNTL0 pin. |
| 6     | HCNTL1   | 0-1   | Data read from/written to UHPI_HCNTL1 pin. |
| 5     | HHWIL    | 0-1   | Data read from/written to UHPI_HHWIL pin.  |
| 4     | HRW      | 0-1   | Data read from/written to UHPI_HR/W pin.   |
| 3     | HDS2Z    | 0-1   | Data read from/written to UHPI_HDS2 pin.   |
| 2     | HDS1Z    | 0-1   | Data read from/written to UHPI_HDS1 pin.   |
| 1     | HCSZ     | 0-1   | Data read from/written to UHPI_HCS pin.    |
| 0     | HASZ     | 0-1   | Data read from/written to UHPI_HAS pin.    |

3.8

The host port interface control register (HPIC) stores configuration and control information for the HPI. As shown in Figure 24 and Figure 25 and described in Table 14, the host and CPU do not have the same access permissions. The host has full read/write access; the CPU has primarily read-only access, but with the exception that the CPU can write 1 to the HINT bit to generate an interrupt to the host.

Figure 24. Host Port Interface Control Register (HPIC)–Host Access Permissions

| 31     |      |       |       |          |                               |          | 16       |
|--------|------|-------|-------|----------|-------------------------------|----------|----------|
|        |      |       | Re    | eserved  |                               |          |          |
|        |      |       |       | R-0      |                               |          |          |
| 15     |      |       | 12    | 11       | 10                            | 9        | 8        |
|        | Rese | erved |       | HPIASEL  | Reserved                      | DUALHPIA | HWOBSTAT |
|        | R    | -0    |       | R/W-0    | R/W-0                         | R/W-0    | R-0      |
| 7      | 6    | 5     | 4     | 3        | 2                             | 1        | 0        |
| HPIRST | Rese | erved | FETCH | Reserved | HINT                          | DSPINT   | HWOB     |
| R-1    | R-   | 2h    | R/W-0 | R-1      | R/W-1 (Host)<br>R/W1C-0 (CPU) | R/W-0    | R/W-0    |

LEGEND: R/W = Read/Write; R = Read only; W1C = Write 1 to clear (writing 0 has no effect); -n = value after reset

| 31     | rigute 25 |       |       | ioi negistei ( | (HPIC)–CPU Acce               |          | 16      |
|--------|-----------|-------|-------|----------------|-------------------------------|----------|---------|
|        |           |       | Re    | eserved        |                               |          |         |
|        |           |       |       | R-0            |                               |          |         |
| 15     |           |       | 12    | 11             | 10                            | 9        | 8       |
|        | Res       | erved |       | HPIASEL        | Reserved                      | DUALHPIA | HWOBSTA |
|        | R         | -0    |       | R-0            | R-0                           | R-0      | R-0     |
| 7      | 6         | 5     | 4     | 3              | 2                             | 1        | 0       |
| HPIRST | Res       | erved | FETCH | Reserved       | HINT                          | DSPINT   | HWOB    |
| R/W-1  | R         | -2h   | R-0   | R-1            | R/W-1 (Host)<br>R/W1C-0 (CPU) | R/W-0    | R-0     |

LEGEND: R/W = Read/Write; R = Read only; W1C = Write 1 to clear (writing 0 has no effect); -n = value after reset

Registers



| www | v.ti. | com |
|-----|-------|-----|
|     |       |     |

| Bit   | Field    | Value | Description                                                                                                                                                                                                                                                          |
|-------|----------|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31-12 | Reserved | 0     | Reserved                                                                                                                                                                                                                                                             |
| 11    | HPIASEL  |       | HPI address register select bit. When DUALHPIA = 1, the HPIASEL bit is used to select the HPI address register to be accessed.                                                                                                                                       |
|       |          | 0     | Selects the HPI write address register (HPIAW).                                                                                                                                                                                                                      |
|       |          | 1     | Selects the HPI read address register (HPIAR).                                                                                                                                                                                                                       |
| 10    | Reserved | 0     | Reserved. Always write 0 to this bit.                                                                                                                                                                                                                                |
| 9     | DUALHPIA |       | Dual HPIA mode configuration bit. The CPU can access both HPI address registers separately, regardless of the DUALHPIA setting. (Regardless of this bit, dual HPIA mode is implied when the CPU has ownership of the HPI address registers).                         |
|       |          | 0     | The two HPI address registers (HPIAW and HPIAR) operate as a single HPI address register in terms of host accesses.                                                                                                                                                  |
|       |          | 1     | Dual HPIA mode operation is enabled.                                                                                                                                                                                                                                 |
| 8     | HWOBSTAT |       | HWOB status. The value of the HWOB bit is also stored in this bit position. A write to the HWOB bit also updates HWOBSTAT.                                                                                                                                           |
|       |          | 0     | HWOB bit is logic 0.                                                                                                                                                                                                                                                 |
|       |          | 1     | HWOB bit is logic 1.                                                                                                                                                                                                                                                 |
| 7     | HPIRST   |       | HPI reset. Some HPI logic is held in reset when the HPIRST bit is set. The HPIRST bit must be cleared to 0 before data transactions can take place.                                                                                                                  |
|       |          | 0     | HPI is released from reset.                                                                                                                                                                                                                                          |
|       |          | 1     | HPI is held in reset.                                                                                                                                                                                                                                                |
| 6-5   | Reserved | 2h    | Reserved                                                                                                                                                                                                                                                             |
| 4     | FETCH    |       | Host data fetch request bit. Only the host may write to FETCH. When a host writes a 1 to FETCH, a request is posted in the HPI to prefetch data into the read FIFO. Host and CPU reads of FETCH return a 0.                                                          |
| 3     | Reserved | 1     | Reserved                                                                                                                                                                                                                                                             |
| 2     | HINT     |       | Processor-to-host interrupt. The CPU writes a 1 to HINT to generate a host interrupt. HINT has an inverted logic level to the UHPI_HINT pin. The host must write a 1 to HINT to clear the UHPI_HINT pin; writing a 0 to HINT by the host or processor has no effect. |
|       |          | 0     | No effect.                                                                                                                                                                                                                                                           |
|       |          | 1     | A CPU write generates a host interrupt (UHPI_HINT signal goes low). A host write sets the UHPI_HINT signal high (clears the interrupt).                                                                                                                              |
| 1     | DSPINT   |       | Host-to-processor interrupt. The host writes a 1 to DSPINT to generate a processor interrupt; writing a 0 to DSPINT by the host or processor has no effect.                                                                                                          |
|       |          | 0     | No effect.                                                                                                                                                                                                                                                           |
|       |          | 1     | A host write generates a processor interrupt.                                                                                                                                                                                                                        |
| 0     | HWOB     |       | Halfword ordering bit. HWOB affects both data and address transfers. HWOB must be initialized before the first data or address register access.                                                                                                                      |
|       |          | 0     | First halfword is most significant.                                                                                                                                                                                                                                  |
|       |          | 1     | First halfword is least significant.                                                                                                                                                                                                                                 |

## Table 14. Host Port Interface Control Register (HPIC) Field Descriptions



## 3.9 Host Port Interface Write Address Register (HPIAW)

The HPI contains two 32-bit address registers: one for read operations (HPIAR) and one for write operations (HPIAW). The host port interface write address register (HPIAW) is shown in Figure 26 and described in Table 15. The HPI can be configured such that HPIAR and HPIAW act as a single 32-bit HPIA (single-HPIA mode) or as two separate 32-bit HPIAs (dual-HPIA mode) from the perspective of the host. For details about these HPIA modes, see Section 2.6.1.

Note that the addresses loaded into the HPI address registers can be configured by the HPIBYTEAD bit in the chip configuration 1 register (CFGCHIP1) of the system configuration module. If byte address is selected (HPIBYTEAD = 1), the address must be 32-bit word aligned (with the least-significant two bits equal to zero).

#### Figure 26. Host Port Interface Write Address Register (HPIAW)

| 31           | 0 |
|--------------|---|
| HPIAW        |   |
| R-0000 8000h |   |

LEGEND: R = Read only; -n = value after reset

#### Table 15. Host Port Interface Write Address Register (HPIAW) Field Descriptions

| Bit  | Field | Value        | Description                        |
|------|-------|--------------|------------------------------------|
| 31-0 | HPIAW | 0-FFFF FFFFh | Host port interface write address. |

#### 3.10 Host Port Interface Read Address Register (HPIAR)

The HPI contains two 32-bit address registers: one for read operations (HPIAR) and one for write operations (HPIAW). The host port interface read address register (HPIAR) is shown in Figure 27 and described in Table 16. The HPI can be configured such that HPIAR and HPIAW act as a single 32-bit HPIA (single-HPIA mode) or as two separate 32-bit HPIAs (dual-HPIA mode) from the perspective of the host. For details about these HPIA modes, see Section 2.6.1.

Note that the addresses loaded into the HPI address registers can be configured by the HPIBYTEAD bit in the chip configuration 1 register (CFGCHIP1) of the system configuration module. If byte address is selected (HPIBYTEAD = 1), the address must be 32-bit word aligned (with the least-significant two bits equal to zero).

#### Figure 27. Host Port Interface Read Address Register (HPIAR)

| 31 |              | 0 |
|----|--------------|---|
|    | HPIAR        |   |
|    | R-0000 8000h |   |

LEGEND: R = Read only; -n = value after reset

#### Table 16. Host Port Interface Read Address Register (HPIAR) Field Descriptions

| Bit  | Field | Value        | Description                       |
|------|-------|--------------|-----------------------------------|
| 31-0 | HPIAR | 0-FFFF FFFFh | Host port interface read address. |

## Appendix A Revision History

Table 17 lists the changes made since the previous version of this document.

| Reference   | Additions/Modifications/Deletions |  |
|-------------|-----------------------------------|--|
| Section 2.8 | Added step 7.                     |  |
| Figure 24   | Changed bit 7.                    |  |
|             | Changed bits 6-5 reset value.     |  |
| Figure 25   | Changed bit 7.                    |  |
|             | Changed bits 6-5 reset value.     |  |
| Table 14    | Changed bit 7.                    |  |
|             | Changed bits 6-5 reset value.     |  |

## Table 17. Document Revision History

#### **IMPORTANT NOTICE**

Texas Instruments Incorporated and its subsidiaries (TI) reserve the right to make corrections, modifications, enhancements, improvements, and other changes to its products and services at any time and to discontinue any product or service without notice. Customers should obtain the latest relevant information before placing orders and should verify that such information is current and complete. All products are sold subject to TI's terms and conditions of sale supplied at the time of order acknowledgment.

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

TI assumes no liability for applications assistance or customer product design. Customers are responsible for their products and applications using TI components. To minimize the risks associated with customer products and applications, customers should provide adequate design and operating safeguards.

TI does not warrant or represent that any license, either express or implied, is granted under any TI patent right, copyright, mask work right, or other TI intellectual property right relating to any combination, machine, or process in which TI products or services are used. Information published by TI regarding third-party products or services does not constitute a license from TI to use such products or services or a warranty or endorsement thereof. Use of such information may require a license from a third party under the patents or other intellectual property of the third party, or a license from TI under the patents or other intellectual property of TI.

Reproduction of TI information in TI data books or data sheets is permissible only if reproduction is without alteration and is accompanied by all associated warranties, conditions, limitations, and notices. Reproduction of this information with alteration is an unfair and deceptive business practice. TI is not responsible or liable for such altered documentation. Information of third parties may be subject to additional restrictions.

Resale of TI products or services with statements different from or beyond the parameters stated by TI for that product or service voids all express and any implied warranties for the associated TI product or service and is an unfair and deceptive business practice. TI is not responsible or liable for any such statements.

TI products are not authorized for use in safety-critical applications (such as life support) where a failure of the TI product would reasonably be expected to cause severe personal injury or death, unless officers of the parties have executed an agreement specifically governing such use. Buyers represent that they have all necessary expertise in the safety and regulatory ramifications of their applications, and acknowledge and agree that they are solely responsible for all legal, regulatory and safety-related requirements concerning their products and any use of TI products in such safety-critical applications, notwithstanding any applications-related information or support that may be provided by TI. Further, Buyers must fully indemnify TI and its representatives against any damages arising out of the use of TI products in such safety-critical applications.

TI products are neither designed nor intended for use in military/aerospace applications or environments unless the TI products are specifically designated by TI as military-grade or "enhanced plastic." Only products designated by TI as military-grade meet military specifications. Buyers acknowledge and agree that any such use of TI products which TI has not designated as military-grade is solely at the Buyer's risk, and that they are solely responsible for compliance with all legal and regulatory requirements in connection with such use.

TI products are neither designed nor intended for use in automotive applications or environments unless the specific TI products are designated by TI as compliant with ISO/TS 16949 requirements. Buyers acknowledge and agree that, if they use any non-designated products in automotive applications, TI will not be responsible for any failure to meet such requirements.

Following are URLs where you can obtain information on other Texas Instruments products and application solutions:

| Products                    |                        | Applications                  |                                   |
|-----------------------------|------------------------|-------------------------------|-----------------------------------|
| Amplifiers                  | amplifier.ti.com       | Audio                         | www.ti.com/audio                  |
| Data Converters             | dataconverter.ti.com   | Automotive                    | www.ti.com/automotive             |
| DLP® Products               | www.dlp.com            | Communications and<br>Telecom | www.ti.com/communications         |
| DSP                         | dsp.ti.com             | Computers and<br>Peripherals  | www.ti.com/computers              |
| Clocks and Timers           | www.ti.com/clocks      | Consumer Electronics          | www.ti.com/consumer-apps          |
| Interface                   | interface.ti.com       | Energy                        | www.ti.com/energy                 |
| Logic                       | logic.ti.com           | Industrial                    | www.ti.com/industrial             |
| Power Mgmt                  | power.ti.com           | Medical                       | www.ti.com/medical                |
| Microcontrollers            | microcontroller.ti.com | Security                      | www.ti.com/security               |
| RFID                        | www.ti-rfid.com        | Space, Avionics & Defense     | www.ti.com/space-avionics-defense |
| RF/IF and ZigBee® Solutions | www.ti.com/lprf        | Video and Imaging             | www.ti.com/video                  |
|                             |                        | Wireless                      | www.ti.com/wireless-apps          |

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