# Multiport Internet Gateway Processor ADSP-21mod970 

FEATURES
PERFORMANCE
Complete Single-Chip Multiport Internet Gateway Processor (No External Memory Required)
Implements Six Modem Channels in One Package
Each Processor Can Implement V.34/V. 90 Data/Fax Modem (Includes Datapump and Controller)
312 MIPS Sustained Performance, 19 ns Instruction Time @ 3.3 V
Open Architecture Extensible to Voice Over IP and Other Applications
Low Power Dissipation, 100 mW (Typical) per Digital Modem Processor
Power-Down Mode Featuring Low CMOS Standby Power Dissipation

INTEGRATION
ADSP-2100 Family Code Compatible, with Instruction Set Extensions
960K Bytes of On-Chip RAM, Configured as 576K Bytes of Program Memory and 384 K Bytes of Data Memory
Dual Purpose Program Memory for Both Instruction and Data Storage
304-Ball PBGA with a 1.45 Square Inch (961 sq. mm) Footprint

## SYSTEM CONFIGURATION

16-Bit Internal DMA Port for High Speed Access to OnChip Memory (Mode Selectable)
Programmable Multichannel Serial Port Supports 24 Channels/32 Channels
Two Double-Buffered Serial Ports with Companding Hardware and Automatic Data Buffering
Separate RESET Pins for Each Internal Processor

## GENERAL DESCRIPTION

The ADSP-21mod970 is a Multiport Internet Gateway Processor optimized for implementation of a complete V.34/56K modem. All data pump and controller functions can be implemented on a single device, offering the lowest power consumption and highest possible modem port density.
The ADSP-21mod 970 combines the ADSP-2100 family base architecture (three computational units, data address generators and a program sequencer) with two serial ports, a 16 -bit internal DMA port, a byte DMA port, a programmable timer, Flag I/O, extensive interrupt capabilities and on-chip program and data memory.
The ADSP-21mod970 integrates 960 bytes of on-chip memory, configured as 192 K words (24-bit) of program RAM, and 192 K words (16-bit) of data RAM. Power-down circuitry is also provided to meet the low power needs of battery operated portable equipment. The ADSP-21mod970 is available in a 31 sq-mm., 304-lead PBGA package.

FUNCTIONAL BLOCK DIAGRAM


REV. 0

[^0]One Technology Way, P.O. Box 9106, Norwood, MA 02062-9106, U.S.A. Tel: 781/329-4700 Fax: 781/326-8703

World Wide Web Site: http://www.analog.com © Analog Devices, Inc., 1999

## ADSP-21mod970

Fabricated in a high speed, low power, CMOS process, the ADSP-21mod 970 operates with a 19 ns instruction cycle time. Every instruction can execute in a single processor cycle.
The ADSP-21mod970's flexible architecture and comprehensive instruction set allow the processor to perform multiple operations in parallel. In one processor cycle, the ADSP21 mod970 can:

- Generate the next program address
- Fetch the next instruction
- Perform one or two data moves
- Update one or two data address pointers
- Perform a computational operation

This takes place while the processor continues to:

- Receive and transmit data through the two serial ports
- Receive and/or transmit data through the internal DMA port
- Receive and/or transmit data through the byte DMA port
- Decrement timer


## Modem Software

The modem software executes general modem control, command sets, error correction and data compression, data modulations (for example, V. 90 and V.34), and host interface functions. The host interface allows system access to modem statistics such as call progress, connect speed, retrain count, symbol rate and other modulation parameters.
The modem data pump and controller software reside in onchip SRAM and do not require additional memory. The user can configure the ADSP-21mod970 dynamically by downloading software from the host through the 16-bit DMA interface. This SRAM-based architecture provides a software upgrade path to future standards and applications, such as voice over IP.
The modem software is available as object code.

## DEVELOPMENT SYSTEM

The ADSP-2100 Family Development Software, a complete set of tools for software and hardware system development, supports the ADSP-21mod970. The System Builder provides a high level method for defining the architecture of systems under development. The Assembler has an algebraic syntax that is easy to program and debug. The Linker combines object files into an executable file. The Simulator provides an interactive instructionlevel simulation with a reconfigurable user interface to display different portions of the hardware environment.

A PROM Splitter generates PROM programmer compatible files. The C Compiler, based on the Free Software Foundation's GNU C Compiler, generates ADSP-21mod970 assembly source code. The source code debugger allows programs to be corrected in the C environment. The Runtime Library includes over 100 ANSI-standard mathematical and DSP-specific functions.
The ADSP-218x EZ-ICE ${ }^{\circledR}$ Emulator aids in the hardware debugging of an ADSP-21mod970 system. The EZ-ICE, in conjunction with the required processor selection hardware, lets you independently debug code on individual modem processors. The emulator consists of hardware, host computer resident software, and the target board connector. The ADSP-21mod970 integrates on-chip emulation support with a 14 -pin ICE-Port ${ }^{\mathrm{TM}}$ interface. The ADSP-21mod970 device need not be removed from the target system when using the EZ-ICE, nor are any adapters needed. Due to the small footprint of the EZ-ICE connector, emulation can be supported in final board designs.
The EZ-ICE performs a full range of functions, including:

- In-target operation
- Up to 20 breakpoints
- Single-step or full-speed operation
- Registers and memory values can be examined and altered
- PC upload and download functions
- Instruction-level emulation of program booting and execution
- Complete assembly and disassembly of instructions
- C source-level debugging

See "Designing An EZ-ICE-Compatible Target System" in the ADSP-2100 Family EZ-Tools Manual (ADSP-2181 sections) as well as the Designing an EZ-ICE Compatible System section of this data sheet for the exact specifications of the EZ-ICE target board connector.

## Additional Information

This data sheet provides a general overview of ADSP-21mod970 functionality. For specific information about the modem processors, refer to the ADSP-21mod870 data sheet. For additional information on the architecture and instruction set of the modem processors, refer to the ADSP-2100 Family User's Manual, Third Edition. For more information about the development tools, refer to the ADSP-2100 Family Development Tools Data Sheet.

## ARCHITECTURE OVERVIEW

Figure 1 is an overall block diagram of the ADSP-21mod970 modem pool. The modem pool contains six independent digital modem processors.
Each individual modem processor has a DSP core, 160 K bytes of RAM, two serial ports, and a DMA port. The signals for a single processor are shown in Figure 2. The signals of each modem processor are accessed through the external pins of the ADSP-21mod970. Some signals are bused with the signals of the other processors and are accessed through a single external pin. Other signals remain separate and they are accessed through separate external pins for each processor.
The arrangement of the six modem processors in the ADSP21 mod 970 makes two basic configurations possible: a master configuration and a slave configuration. In both configurations, the control and data pins of five of the six processors connect to a single bus structure. The control and data pins of the one modem processor (Modem Processor 1) are separate from the other modem processors and accessed through external pins.

In Slave Mode, all six modem processors have identical functions and have equal status. Each modem processor is connected to a common DMA bus and each modem processor is configured to operate in the same mode (see the Slave Mode and the Memory Mode descriptions in the Memory Architecture


Figure 2. Modem Processor Signals


Figure 1. Modem Pool

## ADSP-21mod970

section). The Slave Mode is considered to be the normal mode of operation in a modem pool application. Figure 3 shows the modem pool configured for slave mode operation.
The master mode of the ADSP-21mod970 configures five of the modem processors with identical functions and isolates one of the modem processors, Processor 1. In the Master Mode, Processor 1 is not connected to the DMA bus as are the other five modem processors. Processor 1 operates in a different mode where external pins can be used for access to a 16 -bit data bus, a 14-bit address bus with associated bus control pins. In master
mode, Processor 1 is treated as a master of the modem pool and communicates with an external device such as a RAM, ROM or a memory shared with a host processor. In this configuration, the master processor performs some controlling function of the remaining five modem processors. Figure 4 shows the modem pool configured for Slave Mode operation.
Since the memory bus of Processor 1 is accessible via external pins in master mode, Processor 1 can be configured for one of the several memory modes available on the ADSP-21xx family. (See Full Memory, Host Mode Descriptions.)


Figure 3. Configured for Slave Mode


Figure 4. Configured for Master Mode

## Serial Ports

The ADSP-21mod970 has a multichannel serial port (SPORT) connected to each internal digital modem processor for serial communications.

Following is a brief list of the capabilities of the ADSP-21mod970 SPORT. For additional information on the internal Serial Ports, refer to the ADSP-2100 Family User's Manual, Third Edition.

- SPORT is bidirectional and has a separate, double-buffered transmit and receive section.
- SPORT can use an external serial clock or generate its own serial clock internally.
- SPORT has independent framing for the receive and transmit sections. Sections run in a frameless mode or with frame synchronization signals internally or externally generated. Frame sync signals are active high or inverted, with either of two pulsewidths and timings.
- SPORT supports serial data word lengths from 3 to 16 bits and provides optional A-law and $\mu$-law companding according to CCITT recommendation G.711.
- SPORT receive and transmit sections can generate unique interrupts on completing a data word transfer.
- SPORT can receive and transmit an entire circular buffer of data with one overhead cycle per data word. An interrupt is generated after a data buffer transfer.
- A multichannel interface selectively receives and transmits a 24- or 32-word, time-division multiplexed, serial bitstream.


## PIN DESCRIPTIONS

The ADSP-21mod970 is available in a 304 -lead PBGA package. In order to maintain maximum functionality and reduce package size and pin count, some serial port, programmable flag, interrupt and external bus pins have dual, multiplexed functionality. The external bus pins are configured during RESET only, while serial port pins are software configurable during program execution. Flag and interrupt functionality is retained concurrently on multiplexed pins. In cases where pin functionality is reconfigurable, the default state is shown in plain text; alternate functionality is shown in italics.

| Pin <br> Name(s) | \# <br> of <br> Pins | Input/ Output | Function |
| :---: | :---: | :---: | :---: |
| $\overline{\text { RESET }}$ | 6 | I | Processor Reset Input |
| $\overline{\mathrm{BR}}$ | 6 | I | Bus Request Input |
| $\overline{\mathrm{BG}}$ | 6 | O | Bus Grant Output |
| $\overline{\mathrm{BGH}}$ | 6 | O | Bus Grant Hang Output |
| $\overline{\text { DMS }}$ | 1 | O | Data Memory Select Output |
| $\overline{\text { PMS }}$ | 1 | O | Program Memory Select Output |
| $\overline{\text { BMS }}$ | 1 | O | Byte Memory Select Output |
| $\overline{\text { IOMS }}$ | I | O | I/O Memory Select Output |
| CMS | 1 | O | Combined Memory Select Output |
| $\overline{\mathrm{RD}}$ | 1 | O | Memory Read Enable Output |
| $\overline{\mathrm{WR}}$ | 1 | O | Memory Write Enable Output |
| $\overline{\mathrm{IRQ}}{ }^{\prime}$ | 6 | I | Edge- or Level-Sensitive Interrupt Request ${ }^{1}$ |
| PF7 |  | I/O | Programmable I/O Pin |
| $\begin{aligned} & \overline{\mathrm{IRQL1}} / \\ & \text { PF6 } \end{aligned}$ | 6 | $\begin{aligned} & 1 \\ & \mathrm{I} / \mathrm{O} \end{aligned}$ | Level-Sensitive Interrupt Requests ${ }^{1}$ Programmable I/O Pin |
| $\begin{aligned} & \overline{\mathrm{IRQLO}} / \\ & \text { PF5 } \end{aligned}$ | 6 | $\frac{1}{\mathrm{I} / \mathrm{O}}$ | Level-Sensitive Interrupt Requests ${ }^{1}$ Programmable I/O Pin |
| $\begin{aligned} & \overline{\mathrm{IRQE}} / \\ & P F 4 \end{aligned}$ | 6 | I/O | Edge-Sensitive Interrupt Requests ${ }^{1}$ Programmable I/O Pin |
| Mode D/ | 6 | I | Mode Select Input-Checked Only During RESET |
| PF3 |  | I/O | Programmable I/O Pin During <br> Normal Operation |
| Mode C/ | 6 | I | Mode Select Input-Checked Only During RESET |
| PF2 |  | I/O | Programmable I/O Pin During <br> Normal Operation |
| Mode B/ | 6 | I | Mode Select Input-Checked Only During RESET |
| PF1 |  | I/O | Programmable I/O Pin During <br> Normal Operation |
| Mode A/ | 6 | I | Mode Select Input-Checked Only During RESET |
| PF0 |  | I/O | Programmable I/O Pin During Normal Operation |
| CLKIN | 2 | I | Clock Input |
| CLKOUT | 6 | O | Processor Clock Output |
| SPORT | 24 | I/O | Serial Port I/O Pins ${ }^{2}$ |
| FL0, FL1, FL2 | 18 | O | Output Flags |
| $\mathrm{V}_{\mathrm{DD}}$ and GND | 82 | I | Power and Ground |
| EZ-Port | 14 | I/O | For Emulation Use |
| NOTES |  |  |  |
| ${ }^{1}$ Interrupt/Flag Pins retain both functions concurrently. If IMASK is set to enable the corresponding interrupts, the modem pool will vector to the appropriate interrupt vector address when the pin is asserted, either by external devices, or set as a programmable flag. |  |  |  |
| ${ }^{2}$ SPORT configuration determined by the modem pool's System Control Register. Software configurable. |  |  |  |

## ADSP-21mod970

## Memory Interface Pins

The ADSP-21mod970 modem pool can be used in one of two modes, master mode or slave mode. In master mode, Modem Processor 1 operates with full memory (BDMA operation with full external overlay memory and I/O capability). In Slave Mode, Modem Processor 1 operates in host configuration (IDMA operation with limited external addressing capabilities). The operating mode is determined by the state of the Mode C pin during RESET and cannot be changed while the modem pool is running. See the Memory Architecture section for more information.
Full Memory Pins (Mode C=0) Modem Processor 1 Only

| Pin <br> Name | $\#$ <br> of <br> Pins | Input/ <br> Output | Function |
| :--- | :--- | :--- | :--- |
| A13:0 | 14 | O | Address Output Pins for Program, <br> Data, Byte and I/O Spaces |
| D23:0 | 24 | I/O | Data I/O Pins for Program, Data, <br> Byte and I/O Spaces (8 MSBs Are <br> Also Used as Byte Memory Addresses) |

Host Pins (Mode C = 1)*
Modem Processor 1 and Modem Processors 2-6

| Pin <br> Name | $\begin{array}{\|l} \hline \# \\ \text { of } \\ \text { Pins } \end{array}$ | Input/ Output | Function |
| :---: | :---: | :---: | :---: |
| IAD15:0 | 32 | I/O | IDMA Port Address/Data Bus |
| A0 | 1 | O | Address Pin for External I/O, Program, Data, or Byte Access (Modem Processor 1 Only) |
| D23:8 | 32 | I/O | Data I/O Pins for Program, Data Byte and I/O Spaces |
| $\overline{\text { IWR }}$ | 2 | I | IDMA Write Enable |
| $\overline{\text { IRD }}$ | 2 | I | IDMA Read Enable |
| IAL | 2 | I | IDMA Address Latch Pin |
| $\overline{\mathrm{IS}}$ | 6 | I | IDMA Select |
| $\overline{\text { IACK }}$ | 2 | O | IDMA Port Acknowledge Configurable in Mode D; Open Drain |

*In Host Mode, external peripheral addresses can be decoded using the A0, $\overline{\mathrm{CMS}}, \overline{\mathrm{PMS}}, \overline{\mathrm{DMS}}, \overline{\mathrm{BMS}}$ and $\overline{\mathrm{IOMS}}$ signals of Modem Processor 1.

## Interrupts

The interrupt controller allows each modem processor in the modem pool to respond individually to eleven possible interrupts and reset with minimum overhead. The ADSP-21mod970 provides four dedicated external interrupt input pins, $\overline{\mathrm{IRQ}} 2$, $\overline{\mathrm{IRQL1}}, \overline{\mathrm{IRQLO}}$, and $\overline{\mathrm{IRQE}}$ (shared with the PF7:4 pins) for each modem processor. The ADSP-21mod970 also supports internal interrupts from the timer, the byte DMA port, the serial port, software and the power-down control circuit. The interrupt levels are internally prioritized and individually maskable (except power-down and reset). The $\overline{\mathrm{IRQ}} 2, \overline{\mathrm{IRQL}}$, and $\overline{\mathrm{IRQLO}}$ input pins can be programmed to be either level- or edge-sensitive.
$\overline{\mathrm{IRQLO}}$ and $\overline{\mathrm{IRQL1}}$ are level-sensitive and $\overline{\mathrm{IRQE}}$ is edge sensitive. The priorities and vector addresses of all interrupts are shown in Table I.

Table I. Interrupt Priority and Interrupt Vector Addresses

| Source Of Interrupt | Interrupt Vector <br> Address (Hex) |
| :--- | :--- |
| $\overline{\text { RESET (or Power-Up with PUCR = 1) }}$ | 0000 (Highest Priority) |
| Power-Down (Nonmaskable) | 002 C |
| $\overline{\mathrm{IRQ} 2}$ | 0004 |
| $\overline{\mathrm{IRQL1}}$ | 0008 |
| $\overline{\mathrm{IRQL0} 0}$ | 000 C |
| SPORT0 Transmit | 0010 |
| SPORT0 Receive | 0014 |
| $\overline{\mathrm{IRQE}}$ | 0018 |
| BDMA Interrupt | 001 C |
| SPORT1 Transmit or $\overline{\mathrm{IRQ} 1}$ | 0020 |
| SPORT1 Receive or $\overline{\mathrm{IRQ} 0}$ | 0024 |
| Timer | 0028 (Lowest Priority) |

When the modem pool is reset, interrupt servicing is disabled.

## LOW POWER OPERATION

The ADSP-21mod970 has three low power modes that significantly reduce the power dissipation when the device operates under standby conditions. These modes are:

- Power-Down
- Idle
- Slow Idle

The CLKOUT pin may also be disabled to reduce external power dissipation.

## Power-Down

The ADSP-21mod970 modem pool has a low power feature that lets the modem pool enter a very low power dormant state through software control. Following is a brief list of power-down features. Refer to the ADSP-2100 Family User's Manual, Third Edition, "System Interface" chapter, for detailed information about the power-down feature.

- Quick recovery from power-down. The modem pool begins executing instructions in as few as 400 CLKIN cycles.
- Support for an externally generated TTL or CMOS processor clock. The external clock can continue running during power-down without affecting the lowest power rating and 400 CLKIN cycle recovery.
- Power-down is initiated by the software power-down force bit. Interrupt support allows an unlimited number of instructions to be executed before optionally powering down. The power-down interrupt also can be used as a nonmaskable, edge-sensitive interrupt.
- Context clear/save control allows the modem pool to continue where it left off or start with a clean context when leaving the power-down state.
- The $\overline{\operatorname{RESET}}$ pin also can be used to terminate power-down.


## Idle

When the ADSP-21mod970 is in the idle mode, the modem pool waits indefinitely in a low power state until an interrupt occurs. When an unmasked interrupt occurs, it is serviced; execution then continues with the instruction following the IDLE instruction. In idle mode IDMA, BDMA and autobuffer cycle steals still occur.

## Slow Idle

The IDLE instruction is enhanced on the ADSP-21mod970 to let the modem pool's internal clock signal be slowed, further reducing power consumption. The reduced clock frequency, a programmable fraction of the normal clock rate, is specified by a selectable divisor given in the IDLE instruction.
The format of the instruction is

## IDLE ( $n$ );

where $n=16,32,64$ or 128 . This instruction keeps the modem pool fully functional, but operating at the slower clock rate. While it is in this state, the modem pool's other internal clock signals, such as SCLK, CLKOUT and timer clock, are reduced by the same ratio. The default form of the instruction, when no clock divisor is given, is the standard IDLE instruction.
When the IDLE ( $n$ ) instruction is used, it effectively slows down the modem pool's internal clock and thus its response time to incoming interrupts. The one-cycle response time of the standard idle state is increased by $n$, the clock divisor. When an enabled interrupt is received, the ADSP-21mod970 will remain in the idle state for up to a maximum of $n$ modem pool cycles ( $n=16,32,64$ or 128 ) before resuming normal operation.
When the IDLE ( $n$ ) instruction is used in systems that have an externally generated serial clock (SCLK), the serial clock rate may be faster than the modem pool's reduced internal clock rate. Under these conditions, interrupts must not be generated at a faster rate than can be serviced, due to the additional time the modem pool takes to come out of the idle state (a maximum of $n$ cycles).

## SYSTEM CONFIGURATION

Figure 5 shows a typical multichannel modem configuration with the ADSP-21mod970. A line interface can be used to connect the multichannel subscriber or client data stream to the multichannel serial port of the ADSP-21mod970. The ADSP$21 \bmod 970$ can support up to 64 channels. The IDMA port of the ADSP-21mod970 is used to give a host processor full access to the internal memory of the ADSP-21mod970. This lets the host dynamically configure the ADSP-21mod 970 by loading code and data into its internal memory. This configuration also lets
the host access server data directly from the ADSP-21mod970's internal memory. In this configuration, the Modem Processor 1 should be put into host memory mode where Mode $\mathrm{D}=1$, Mode C $=1$, Mode $\mathrm{B}=0$, and Mode A = 1 (see Table II).

## CLOCK SIGNALS

The ADSP-21mod970 is clocked by a TTL-compatible clock signal that runs at half the instruction rate; a 26 MHz input clock yields a 19 ns processor cycle (which is equivalent to 52 MHz ). Normally, instructions are executed in a single processor cycle. All device timing is relative to the internal instruction clock rate, which is indicated by the CLKOUT signal when enabled. The clock input signal is connected to the processor's CLKIN input.

The CLKIN input cannot be halted, changed during operation, or operated below the specified frequency during normal operation. The only exception is while the processor is in the powerdown state. For additional information, refer to Chapter 9, ADSP-2100 Family User's Manual, Third Edition, for a detailed explanation of this power-down feature.
A clock output (CLKOUT) signal is generated by the processor at the processor's cycle rate.

## Reset

The RESET signals initiate a reset of each modem processor in the ADSP-21mod970. The RESET signals must be asserted during the power-up sequence to assure proper initialization. RESET during initial power-up must be held long enough to let the internal clocks stabilize. If $\overline{\text { RESETs }}$ are activated any time after power-up, the clocks continue to run and do not require stabilization time.
The power-up sequence is defined as the total time required for the oscillator circuits to stabilize after a valid $\mathrm{V}_{\mathrm{DD}}$ is applied to the processors, and for the internal phase-locked loops (PLL) to lock onto the specific frequency. A minimum of 2000 CLKIN cycles ensures that the PLLs have locked, but this does not include the oscillators start-up time. During this power-up sequence, the RESET signals should be held low. On any subsequent resets, the RESET signals must meet the minimum pulsewidth specification, $t_{\text {RSP }}$.


Figure 5. Multichannel Modem Configuration

## ADSP-21mod970

The $\overline{\text { RESET }}$ inputs contain some hysteresis; however, if an RC circuit is used to generate the RESET signals, the use of external Schmidt triggers are recommended.
The reset for each individual modem processor sets the internal stack pointers to the empty stack condition, masks all interrupts and clears the MSTAT register. When a $\overline{\text { RESET }}$ is released, if there is no pending bus request and the modem processor is configured for booting, the boot-loading sequence is performed. The first instruction is fetched from on-chip program memory location $0 \times 0000$ once boot loading completes.

## MEMORY ARCHITECTURE

The ADSP-21mod970 provides a variety of memory and peripheral interface options for Modem Processor 1. The key functional groups are Program Memory, Data Memory, Byte


| PMOVLAY | MEMORY | A13* | A12:0* |
| :--- | :--- | :--- | :--- |
| $0,4,5$ | INTERNAL | NOT APPLICABLE | NOT APPLICABLE |
| 1 | EXTERNAL | 0 | 13 LSBs OF ADDRESS BETWEEN |
|  | OVERLAY1 |  | $0 \times 2000$ AND 0x3FFF |
| 2 | EXTERNAL | 1 | 13 LSBs OF ADDRESS BETWEEN |
|  | OVERLAY2 |  | $0 \times 2000$ AND 0x3FFF |

*FULL-MEMORY MODE ONLY
Figure 6. Program Memory (Memory Shown in Grey Is Accessible Only in Full-Memory Mode)

Memory and I/O. Refer to the figures and tables below for PM and DM memory allocations in the ADSP-21mod970.
The ADSP-21mod970 modem pool operates in one of two memory modes: Slave Mode or Master Mode. The memory modes determine the memory access to Modem Processor 1. In Slave Mode, the memory of Modem Processor 1 is configured for Host Mode; in Master Mode, the memory of Modem Processor 1 is configured for Full-Memory Mode. Memories for Modem Processors 2-6 are configured only for Host Mode. The differences between these memory modes are explained in the following sections. Figure 6 shows Program Memory, while Figure 7 shows Data Memory. Table II summarizes ADSP21 mod970 operating modes. Table III explains the mode bits and memory booting.


| PMOVLAY | MEMORY | A13* | A12:0* |
| :--- | :--- | :--- | :--- |
| $0,4,5$ | INTERNAL | NOT APPLICABLE | NOT APPLICABLE |
| 1 | EXTERNAL | 0 | 13 LSBs OF ADDRESS BETWEEN |
|  | OVERLAY1 |  | 0x2000 AND 0x3FFF |
| 2 | EXTERNAL | 1 | 13 LSBs OF ADDRESS BETWEEN |
|  | OVERLAY2 |  | $0 \times 2000$ AND 0x3FFF |

*FULL-MEMORY MODE ONLY
Figure 7. Data Memory

Table II. Processor and Memory Mode

| Memory Modes for Modem Processor 1 | ADSP-21mod970 Modes |  |
| :---: | :---: | :---: |
|  | Master | Slave |
| Host | - All Internal Program Memory Available <br> - All Internal Data Memory Available <br> - IDMA Port Enabled | - All Internal Program Memory Available <br> - All Internal Data Memory Available <br> - IDMA Port Enabled |
| Full-Memory | - All Internal and External Program Memory Available <br> - All Internal and External Data Memory Available <br> - I/O Space Available <br> - Byte Memory DMA (BDMA) Enabled | Not Applicable |

Table III. Modes of Operation

| MODE D | MODE C | MODE B | MODE A | Booting Method |
| :--- | :--- | :--- | :--- | :--- |
| X | 0 | 0 | 0 | BDMA feature is used to load the first 32 program memory words from <br> byte memory space. Program execution is held off until all 32 words are <br> loaded. Chip is configured in Full-Memory Mode |
| 0 | 1 | 0 | 0 | BDMA feature is used to load the first 32 program memory words from <br> byte memory space. Program execution is held off until all 32 words are <br> loaded. Chip is configured in Host Mode. IACK requires pull-down. <br> (REQUIRES ADDITIONAL HARDWARE.) |
| 0 | 1 | 0 | 1 | IDMA feature is used to load internal memory as desired. Program execu- <br> tion is held off until internal program memory location 0x0000 is written <br> to. Chip is configured in Host Mode. ${ }^{1} \overline{\text { IACK requires pull-down. }}$ |
| 1 | 1 | 0 | 0 | BDMA feature is used to load the first 32 program memory words from <br> byte memory space. Program execution is held off until all 32 words are <br> loaded. Chip is configured in Host Mode. IACK requires external pull- <br> down. (REQUIRES ADDITIONAL HARDWARE.) |
| 1 | 1 | 0 | 1 | IDMA feature is used to load internal memory as desired. Program execu- <br> tion is held off until internal program memory location 0x0000 is written <br> to. Chip is configured in Host Mode. ${ }^{1} \overline{\text { IACK requires external pull-down. }}$ |

## NOTE

${ }^{1}$ Considered standard operating settings. These configurations simplify your design and improve memory management.

## Slave Mode

This section describes the Slave Mode memory configuration of Modem Processor 1. Modem Processors 2-6 are always configured for Slave Mode.
Program Memory (Host Mode) allows access to all internal memory. External overlay access is limited by a single external address line (A0). External program execution is not available in host mode due to a restricted data bus that is 16 -bits wide only.
Data Memory (Host Mode) allows access to all internal memory. External overlay access is limited by a single external address line (A0).

## Internal Memory DMA Port (IDMA Port; Host Memory Mode)

The IDMA Port provides an efficient way for a host system and the ADSP-21mod970 to communicate. The port is used to access the on-chip program memory and data memory of each modem processor with only one processor cycle per word overhead. The IDMA port cannot be used, however, to write to the processor's memory-mapped control registers. A typical IDMA transfer process is described as follows:

1. Host starts IDMA transfer.
2. Host checks $\overline{\mathrm{IACK}}$ control line to see if the processor is busy.
3. Host uses $\overline{\mathrm{IS}}$ and IAL control lines to latch either the DMA starting address (IDMAA) or the PM/DM OVLAY selection into the processor's IDMA control registers.
If IAD [15] $=1$, the value of IAD [7:0] represent the IDMA overlay: IAD [14:8] must be set to 0 .
If IAD [15] $=0$, the value of IAD [13:0] represent the starting address of internal memory to be accessed and IAD [14] reflects PM or DM for access.
4. Host uses $\overline{\mathrm{IS}}$ and $\overline{\text { IRD }}$ (or $\overline{\mathrm{IWR}}$ ) to read (or write) processor internal memory (PM or DM).
5. Host checks $\overline{\text { IACK }}$ line to see if the processor has completed the previous IDMA operation.
6. Host ends IDMA transfer.

The IDMA port has a 16-bit multiplexed address and data bus and supports 24 -bit program memory. The IDMA port is completely asynchronous and can be written to while the ADSP$21 \bmod 970$ is operating at full speed.
The processor memory address is latched and then automatically incremented after each IDMA transaction. An external device can therefore access a block of sequentially addressed memory by specifying only the starting address of the block. This increases throughput as the address does not have to be sent for each memory access.
IDMA Port access occurs in two phases. The first is the IDMA Address Latch cycle. When the acknowledge is asserted, a 14-bit address and 1-bit destination type can be driven onto the bus by an external device. The address specifies an on-chip memory location, the destination type specifies whether it is a DM or PM access. The falling edge of the address latch signal latches this value into the IDMAA register.
Once the address is stored, data can then either be read from or written to, the ADSP-21mod970's on-chip memory. Asserting the select line $(\overline{\mathrm{IS}})$ and the appropriate read or write line ( $\overline{\mathrm{IRD}}$ and $\overline{\text { IWR }}$ respectively) signals the ADSP-21mod970 that a particular transaction is required. In either case, there is a one-processor-cycle delay for synchronization. The memory access consumes one additional processor cycle.
Once an access has occurred, the latched address is automatically incremented, and another access can occur.
Through the IDMAA register, the processor can also specify the starting address and data format for DMA operation. Asserting the IDMA port select ( $\overline{\mathrm{IS}}$ ) and address latch enable (IAL) directs the ADSP-21mod970 to write the address onto the

## ADSP-21mod970

IAD0 [14.0] bus into the IDMA Control Register. If IAD[15] is set to 0 , IDMA latches the address. If IAD [15] is set to 1 , IDMA latches OVLAY memory. The IDMAA register is memory mapped at address DM ( $0 \times 3 \mathrm{FE} 0$ ). Note that the latched address (IDMAA) cannot be read back by the host. The IDMA Overlay Register is memory mapped at address DM (0x3FE7). See Figure 8 for more information on IDMA memory maps.


IDMA AND BDMA HAVE SEPERATE DMA CONTROL REGISTERS


IDMA CONTROL (U = UNDEFINED AT RESET)

$0=P M$
$1=D M$
Figure 8. IDMA Control/OVLAY Registers

## IDMA Port Booting

The ADSP-21mod970 can also boot programs through its Internal DMA port. If Mode $\mathrm{C}=1$, Mode $\mathrm{B}=0$, and Mode $\mathrm{A}=1$, the ADSP-21mod970 boots from the IDMA port. IDMA feature can load as much on-chip memory as desired. Program execution is held off until on-chip program memory location 0 is written to.

## Master Mode

This section describes the Master Mode memory configuration of Modem Processor 1. Master Mode is not available for Modem Processors 2-6.

Program Memory (Full Memory Mode) is a 24-bit-wide space for storing both instruction op codes and data. The ADSP-21mod970 has 32 K words of Program Memory RAM on chip, and it can access up to two 8 K external memory overlay spaces using the external data bus.
Data Memory (Full Memory Mode) is a 16 -bit-wide space used for the storage of data variables and for memory-mapped control registers. The ADSP-21mod970 has 32 K words on Data Memory RAM on chip, consisting of 16,352 user-accessible locations and 32 memory-mapped registers. The ADSP-21mod970 also supports up to two 8 K external memory overlay spaces through the external data bus. All internal accesses complete in one cycle. Accesses to external memory are timed using the wait states specified by the DWAIT register.

## I/O Space (Full Memory Mode)

The ADSP-21mod970 supports an additional external memory space called I/O space. This space is designed to support simple connections to peripherals (such as data converters and external registers) or to bus interface ASIC data registers. I/O space supports 2048 locations of 16 -bit wide data. The lower eleven bits of the external address bus are used; the upper three bits are undefined. Two instructions were added to the core ADSP-2100 Family instruction set to read from and write to I/O memory space. The I/O space also has four dedicated three-bit wait state registers, IOWAIT0-3, which specify up to seven wait states to be automatically generated for each of four regions. The wait states act on address ranges as shown in Table IV.

Table IV. Wait States

| Address Range | Wait State Register |
| :--- | :--- |
| $0 \times 000-0 \times 1 \mathrm{FF}$ | IOWAIT0 |
| $0 \times 2000-0 \times 3 \mathrm{FF}$ | IOWAIT1 |
| $0 \times 400-0 \times 5 \mathrm{FF}$ | IOWAIT2 |
| $0 \times 600-0 \times 7 \mathrm{FF}$ | IOWAIT3 |

## Byte Memory

The byte memory space is a bidirectional, 8-bit-wide, external memory space used to store programs and data. Byte memory is accessed using the BDMA feature. The byte memory space consists of 256 pages, each of which is $16 \mathrm{~K} \times 8$.

The byte memory space on the ADSP-21mod970 supports read and write operations as well as four different data formats. The byte memory uses data bits 15:8 for data. The byte memory uses Data Bits 23:16 and Address Bits 13:0 to create a 22-bit address. This allows up to a $4 \mathrm{meg} \times 8$ ( 32 megabit) ROM or RAM to be used without glue logic. All byte memory accesses are timed by the BMWAIT register.

## Byte Memory DMA (BDMA, Full Memory Mode)

The byte memory DMA controller allows loading and storing of program instructions and data using the byte memory space. The BDMA circuit can access the byte memory space while the processor is operating normally and steals only one processor cycle per 8 -, 16 - or 24 -bit word transferred.
The BDMA circuit supports four different data formats that are selected by the BTYPE register field. The appropriate number of 8-bit accesses are done from the byte memory space to build the word size selected. Table V shows the data formats supported by the BDMA circuit.

Table V. Data Formats

| BTYPE | Internal <br> Memory Space | Word Size | Alignment |
| :--- | :--- | :--- | :--- |
| 00 | Program Memory | 24 | Full Word |
| 01 | Data Memory | 16 | Full Word |
| 10 | Data Memory | 8 | MSBs |
| 11 | Data Memory | 8 | LSBs |

Unused bits in the 8 -bit data memory formats are filled with 0 s. The BIAD register field is used to specify the starting address for the on-chip memory involved with the transfer. The 14 -bit BEAD register specifies the starting address for the external byte
memory space. The 8 -bit BMPAGE register specifies the starting page for the external byte memory space. The BDIR register field selects the direction of the transfer. Finally the 14 -bit BWCOUNT register specifies the number of DSP words to transfer and initiates the BDMA circuit transfers.

BDMA accesses can cross page boundaries during sequential addressing. A BDMA interrupt is generated on the completion of the number of transfers specified by the BWCOUNT register.
The BWCOUNT register is updated after each transfer so it can be used to check the status of the transfers. When it reaches zero, the transfers have finished and a BDMA interrupt is generated. The BMPAGE and BEAD registers must not be accessed by the processor during BDMA operations.
The source or destination of a BDMA transfer will always be on-chip program or data memory.
When the BWCOUNT register is written with a nonzero value the BDMA circuit starts executing byte memory accesses with wait states set by BMWAIT. These accesses continue until the count reaches zero. When enough accesses have occurred to create a destination word, it is transferred to or from on-chip memory. The transfer takes one processor cycle. Processor accesses to external memory have priority over BDMA byte memory accesses.
The BDMA Context Reset bit (BCR) controls whether the processor is held off while the BDMA accesses are occurring. Setting the BCR bit to 0 allows the processor to continue operations. Setting the BCR bit to 1 causes the processor to stop execution while the BDMA accesses are occurring, to clear the context of the processor, and start execution at Address 0 when the BDMA accesses have completed. The BDMA overlay bits specify the OVLAY memory blocks to be accessed for internal memory.

## Bootstrap Loading (Booting)

The ADSP-21mod970 has two mechanisms to allow automatic loading of the internal program memory after reset. The method for booting is controlled by the Mode A, B and C configuration bits. When the MODE pins specify BDMA booting, the ADSP21 mod 970 initiates a BDMA boot sequence when reset is released.
The BDMA interface is set up during reset to the following defaults when BDMA booting is specified: the BDIR, BMPAGE, BIAD and BEAD registers are set to 0 , the BTYPE register is set to 0 to specify program memory 24 -bit words, and the BWCOUNT register is set to 32 . This causes 32 words of onchip program memory to be loaded from byte memory. These 32 words are used to set up the BDMA to load in the remaining program code. The BCR bit is also set to 1 , which causes program execution to be held off until all 32 words are loaded into on-chip program memory. Execution then begins at Address 0.

The ADSP-2100 Family development software (Revision 5.02 and later) fully supports the BDMA booting feature and can generate byte memory space compatible boot code.
The IDLE instruction can also be used to allow the processor to hold off execution while booting continues through the BDMA interface. For BDMA accesses while in Host Mode, the addresses to boot memory must be constructed externally to the ADSP$21 \bmod 970$. The only memory address bit provided by the processor is A0.

## Composite Memory Select ( $\overline{\mathbf{C M S}}$ )

The ADSP-21mod970 has a programmable memory select signal that is useful for generating memory select signals for memories mapped to more than one space. The $\overline{\mathrm{CMS}}$ signal is generated to have the same timing as each of the individual memory select signals ( $\overline{\mathrm{PMS}}, \overline{\mathrm{DMS}}, \overline{\mathrm{BMS}}, \overline{\mathrm{IOMS}}$ ) but can combine their functionality.
Each bit in the CMSSEL register, when set, causes the $\overline{\text { CMS }}$ signal to be asserted when the selected memory select is asserted. For example, to use a 32 K word memory to act as both program and data memory, set the $\overline{\text { PMS }}$ and $\overline{\mathrm{DMS}}$ bits in the CMSSEL register and use the $\overline{\mathrm{CMS}}$ pin to drive the chip select of the memory, and use either $\overline{\mathrm{DMS}}$ or $\overline{\mathrm{PMS}}$ as the additional address bit.
The $\overline{\mathrm{CMS}}$ pin functions like the other memory select signals with the same timing and bus request logic. A 1 in the enable bit causes the assertion of the $\overline{\mathrm{CMS}}$ signal at the same time as the selected memory select signal. All enable bits default to 1 at reset, except the $\overline{\mathrm{BMS}}$ bit.

## Boot Memory Select ( $\overline{\mathbf{B M S}}$ ) Disable

The ADSP-21mod970 also lets you boot the processor from one external memory space while using a different external memory space for BDMA transfers during normal operation. You can use the $\overline{\mathrm{CMS}}$ to select the first external memory space for BDMA transfers and $\overline{\mathrm{BMS}}$ to select the second external memory space for booting. The $\overline{\mathrm{BMS}}$ signal can be disabled by setting Bit 3 of the System Control Register to 1. The System Control Register is illustrated in Figure 9.

## Bus Request and Bus Grant

Each modem processor in the ADSP-21mod970 can relinquish control of the data and address buses to an external device. When the external device requires access to memory, it asserts the bus request $(\overline{\mathrm{BR}})$ signal. If the modem processor is not performing an external memory access, then it responds to the active $\overline{\mathrm{BR}}$ input in the following processor cycle by:

- Three-stating the data and address buses and the $\overline{\text { PMS }}$, $\overline{\mathrm{DMS}}, \overline{\mathrm{BMS}}, \overline{\mathrm{CMS}}, \overline{\mathrm{IOMS}}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ output drivers,
- Asserting the bus grant $(\overline{\mathrm{BG}})$ signal, and
- Halting program execution.

SYSTEM CONTROL REGISTER


Figure 9. System Control Register

## ADSP-21mod970

If Go Mode is enabled, the modem processor will not halt program execution until it encounters an instruction that requires an external memory access.
If a modem processor is performing an external memory access when an external device asserts the $\overline{\mathrm{BR}}$ signal, it will not threestate the memory interfaces or assert the $\overline{B G}$ signal until the processor cycle after the access completes. The instruction does not need to be completed when the bus is granted. If a single instruction requires two external memory accesses, the bus will be granted between the two accesses.
When the $\overline{\mathrm{BR}}$ signal is released, the processor releases the $\overline{\mathrm{BG}}$ signal, reenables the output drivers and continues program execution from the point where it stopped.
The bus request feature operates at all times, including when the processor is booting and when RESET is active.
The $\overline{\mathrm{BGH}}$ pin is asserted when a modem processor is ready to execute an instruction, but is stopped because the external bus is already granted to another device. The other device can release the bus by deasserting bus request. Once the bus is released, the modem processor deasserts $\overline{\mathrm{BG}}$ and $\overline{\mathrm{BGH}}$ and executes the external memory access.
When the ADSP-21mod970 is powered up, all the modem processors must relinquish bus control, and only one processor at a time may control the bus.

## Flag I/O Pins

Each modem processor has eight general purpose programmable input/output flag pins. They are controlled by two memory mapped registers. The PFTYPE register determines the direction, $1=$ output and $0=$ input. The PFDATA register is used to read and write the values on the pins. Data being read from a pin configured as an input is synchronized to the ADSP21 mod970's clock. Bits that are programmed as outputs will read the value being output. The PF pins default to input during reset.

In addition to the programmable flags, each modem processor has three fixed-mode output flags, FL0, FL1, and FL2.

Note: Pins PF0, PF1, PF2 and PF3 are also used for device configuration during reset.

## DESIGNING AN EZ-ICE-COMPATIBLE SYSTEM

The ADSP-21mod970 has on-chip emulation support and an ICE-Port, a special set of pins that interface to the EZ-ICE. These features allow in-circuit emulation without replacing the target system processor by using only a 14 -pin connection from the target system to the EZ-ICE. Target systems must have a 14-pin connector to accept the EZ-ICE's in-circuit probe, a 14 -pin plug.
The EZ-ICE can emulate only one modem processor at a time. You must include hardware to select which processor in the ADSP-21mod 970 you want to emulate. Figure 10 is a functional representation of the modem processor selection hardware. You can use one ICE-Port connector with two ADSP-21mod970 processors without using additional buffers.
Issuing the "chip reset" command during emulation causes the modem processor to perform a full chip reset, including a reset
of its memory mode. Therefore, it is vital that the mode pins are set correctly PRIOR to issuing a chip reset command from the emulator user interface. As the mode pins share functionality with PF0:3 on the ADSP-21mod970, it may be necessary to reset the target hardware separately to insure the proper mode selection state on emulator chip reset. See the ADSP-2100 Family EZ-Tools data sheet for complete information on ICE products.
The ICE-Port interface consists of the following ADSP-21mod970 pins:

| $\overline{\text { EBR }}$ | $\overline{\text { EMS }}$ | ELIN |
| :--- | :--- | :--- |
| $\overline{\text { EBG }}$ | $\overline{\text { EINT }}$ | ELOUT |
| $\overline{\text { ERESET }}$ | ECLK | EE |

These ADSP-21mod970 pins must be connected only to the EZ-ICE connector in the target system. These pins have no function except during emulation, and do not require pull-up or pull-down resistors. The traces for these signals between the ADSP-21mod970 and the connector must be kept as short as possible, no longer that 3 inches.


Figure 10. Selecting a Modem Processor in the ADSP-21mod970

The following pins are also used by the EZ-ICE:
$\overline{\mathrm{BR}} \quad \overline{\mathrm{BG}} \quad \overline{\mathrm{RESET}} \quad$ GND

The EZ-ICE uses the EE (emulator enable) signal to take control of the ADSP-21mod970 in the target system. This causes the processor to use its $\overline{\mathrm{ERESET}}, \overline{\mathrm{EBR}}$ and $\overline{\mathrm{EBG}}$ pins instead of the $\overline{\mathrm{RESET}}, \overline{\mathrm{BR}}$ and $\overline{\mathrm{BG}}$ pins. The $\overline{\mathrm{BG}}$ output is three-stated. These signals do not need to be jumper-isolated in a system.

The EZ-ICE connects to target system via a ribbon cable and a 14 -pin female plug. The female plug is plugged onto the 14 -pin connector (a pin strip header) on the target board.

## Target Board Connector for EZ-ICE Probe

The EZ-ICE connector (a standard pin strip header) is shown in Figure 11. This connector must be added to the target board design if the EZ-ICE is to be used. Be sure to allow enough room in the system to fit the EZ-ICE probe onto the 14-pin connector.


Figure 11. Target Board Connector for EZ-ICE
The 14-pin, 2-row pin strip header is keyed at the Pin 7 loca-tion-you must remove Pin 7 from the header. The pins must be 0.025 inch square and at least 0.20 inch in length. Pin spacing should be $0.1 \times 0.1$ inches. The pin strip header must have at least 0.15 inch clearance on all sides to accept the EZ-ICE probe plug.
Pin strip headers are available from vendors such as 3 M , McKenzie, and Samtec.

## Target Memory Interface

For your target system to be compatible with the EZ-ICE emulator, it must comply with the memory interface guidelines listed below.

## PM, DM, BM, IOM, and CM

Design the Program Memory (PM), Data Memory (DM), Byte Memory (BM), I/O Memory (IOM) and Composite Memory (CM) external interfaces to comply with worst case device timing requirements and switching characteristics as specified in
this data sheet. The performance of the EZ-ICE may approach published worst case specification for some memory access timing requirements and switching characteristics.
Note: If your target does not meet the worst case chip specification for memory access parameters, you may not be able to emulate your circuitry at the desired CLKIN frequency. Depending on the severity of the specification violation, you may have trouble manufacturing your system as processor components statistically vary in switching characteristic and timing requirements within published limits.
Restriction: All memory strobe signals on the ADSP-21mod970 ( $\overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \overline{\mathrm{PMS}}, \overline{\mathrm{DMS}}, \overline{\mathrm{BMS}}, \overline{\mathrm{CMS}}$, and $\overline{\mathrm{IOMS}}$ ) used in your target system must have $10 \mathrm{k} \Omega$ pull-up resistors connected when the EZ-ICE is being used. The pull-up resistors are necessary because there are no internal pull-ups to guarantee their state during prolonged three-state conditions resulting from typical EZ-ICE debugging sessions. These resistors may be removed at your option when the EZ-ICE is not being used.

## Target System Interface Signals

When the EZ-ICE board is installed, the performance on some system signals changes. Design your system to be compatible with the following system interface signal changes introduced by the EZ-ICE board:

- EZ-ICE emulation introduces an 8 ns propagation delay between your target circuitry and the processor on the RESET signal.
- EZ-ICE emulation introduces an 8 ns propagation delay between your target circuitry and the processor on the $\overline{\mathrm{BR}}$ signal.
- EZ-ICE emulation ignores $\overline{\operatorname{RESET}}$ and $\overline{\mathrm{BR}}$ when singlestepping.
- EZ-ICE emulation ignores $\overline{\mathrm{RESET}}$ and $\overline{\mathrm{BR}}$ when in Emulator Space (processor halted).
- EZ-ICE emulation ignores the state of target $\overline{\mathrm{BR}}$ in certain modes. As a result, the target system may take control of the processor's external memory bus only if bus grant $(\overline{\mathrm{BG}})$ is asserted by the EZ-ICE board's processor.

ADSP-21mod970-SPECIFICATIONS
recommended operating conditions

| Parameter | Min | K Grade | Max |
| :--- | :---: | :---: | :---: |
| $\mathrm{V}_{\mathrm{DD}}$ | 3.15 | 3.45 | Unit |
| $\mathrm{T}_{\mathrm{AMB}}$ | 0 | +70 | V |

## ELECTRICAL CHARACTERISTICS

| Parameter |  | Test Conditions | K/B Grades |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max |  |
| $\mathrm{V}_{\text {IH }}$ | Hi-Level Input Voltage ${ }^{1,2}$ |  | (a) $\mathrm{V}_{\mathrm{DD}}=\mathrm{max}$ | 2.0 |  |  | V |
| $\mathrm{V}_{\text {IH }}$ | Hi-Level CLKIN Voltage | $\begin{aligned} & \text { @ } \mathrm{V}_{\mathrm{DD}}=\max \\ & \text { @ } \mathrm{V}_{\mathrm{DD}}=\max \end{aligned}$ | 2.2 |  |  | V |
| $\mathrm{V}_{\text {IL }}$ | Lo-Level Input Voltage ${ }^{1,3}$ | (a) $\mathrm{V}_{\mathrm{DD}}=\max$ <br> (a) $\mathrm{V}_{\mathrm{DD}}=\min$ <br> (a) $\mathrm{V}_{\mathrm{DD}}=\min$ | 0.8 |  |  | V |
| $\mathrm{V}_{\mathrm{OH}}$ | Hi-Level Output Voltage ${ }^{1,4,5}$ |  | 2.4 |  |  |  |
|  |  | $\begin{aligned} & @ V_{\mathrm{DD}}=\mathrm{min} \\ & \mathrm{I}_{\mathrm{OH}}=-0.5 \mathrm{~mA} \\ & @ \text { ( } \mathrm{V}_{\mathrm{DD}}=\mathrm{min} \end{aligned}$ |  |  |  | V |
|  |  | $\mathrm{I}_{\mathrm{OH}}=-100 \mu \mathrm{~A}^{6}$$\text { @ } \mathrm{V}_{\mathrm{DD}}=\min$ | $\mathrm{V}_{\mathrm{DD}}-0.3$ |  |  | V |
| $\mathrm{V}_{\text {OL }}$ | Lo-Level Output Voltage ${ }^{\text {1,4, } 5}$ |  | 0.4 |  |  | V |
| $\mathrm{I}_{\mathrm{IH}}$ | Hi-Level Input Current ${ }^{3}$ | $\mathrm{I}_{\mathrm{OL}}=2 \mathrm{~mA}$ <br> (a) $\mathrm{V}_{\mathrm{DD}}=\max$ |  |  | 10 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {IL }}$ | Lo-Level Input Current ${ }^{3}$ | $V_{\text {IN }}=V_{D D} \max$ <br> (a) $\mathrm{V}_{\mathrm{DD}}=$ max |  |  | 10 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {OZH }}$ | Three-State Leakage Current ${ }^{7}$ | $\mathrm{V}_{\mathrm{IN}}=\mathrm{V}_{\mathrm{DD}} \mathrm{max}^{8}$ |  |  | 10 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {OZL }}$ | Three-State Leakage Current ${ }^{7}$ | $\begin{aligned} & @ V_{\mathrm{DD}}=\max \\ & \mathrm{V}_{\mathrm{IN}}=0 \mathrm{~V}^{8} \end{aligned}$ |  |  | 10 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\mathrm{DD}}$ | Supply Current (Idle) ${ }^{9}$ | (a) $\mathrm{V}_{\mathrm{DD}}=3.3$ |  | 62 |  | $\mu \mathrm{A}$ mA |
|  |  | $\mathrm{t}_{\mathrm{CK}}=25 \mathrm{~ns}^{10}$ |  | 53 |  | mA |
| $\mathrm{I}_{\mathrm{DD}}$ | Supply Current (Dynamic) ${ }^{11}$ | $\begin{aligned} & \mathrm{t}_{\mathrm{CK}}=30 \mathrm{~ns}^{10} \\ & \text { @ } \mathrm{V}_{\mathrm{DD}}=3.3 \end{aligned}$ |  | 47 |  | mA |
|  |  | $\mathrm{t}_{\mathrm{CK}}=19 \mathrm{~ns}^{10}$ |  | 387 |  | mA |
|  |  | $\mathrm{t}_{\mathrm{CK}}=25 \mathrm{~ns}^{10}$ |  | 299 |  | mA |
| $\mathrm{C}_{\mathrm{I}}$ | Input Pin Capacitance ${ }^{6}$ | $\begin{aligned} & \mathrm{t}_{\mathrm{CK}}=30 \mathrm{~ns}^{10} \\ & @ \text { V } \mathrm{V}_{\mathrm{IN}}=2.5 \mathrm{~V}, \end{aligned}$ |  | 253 | 40 | mA pF |
| $\mathrm{C}_{0}$ | Output Pin Capacitance ${ }^{6,7,12}$ | $\begin{aligned} & \mathrm{T}_{\mathrm{AMB}}=+25^{\circ} \mathrm{C} \\ & @ \text { V } \mathrm{V}_{\mathrm{IN}}=2.5 \mathrm{~V}, \\ & \mathrm{f}_{\mathrm{IN}}=1.0 \mathrm{MHz}, \\ & \mathrm{~T}_{\mathrm{AMB}}=+25^{\circ} \mathrm{C} \end{aligned}$ |  |  | 40 | pF |

[^1]
## ABSOLUTE MAXIMUM RATINGS*

| Supply Voltage | . 3 V to +4.6 V |
| :---: | :---: |
| Input Voltage | -0.5 V to $\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}$ |
| Output Voltage Swing | -0.5 V to $\mathrm{V}_{\mathrm{DD}}+0.5 \mathrm{~V}$ |
| Storage Temperature Range | $-65^{\circ} \mathrm{C}$ to $+150^{\circ} \mathrm{C}$ |

*Stresses above those listed under Absolute Maximum Ratings may cause permanent damage to the device. These are stress ratings only; functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

## TIMING PARAMETERS

## GENERAL NOTES

Use the exact timing information given. Do not attempt to derive parameters from the addition or subtraction of others. While addition or subtraction would yield meaningful results for an individual device, the values given in this data sheet reflect statistical variations and worst cases. Consequently, you cannot meaningfully add up parameters to derive longer times.

## TIMING NOTES

Switching characteristics specify how the processor changes its signals. You have no control over this timing-circuitry external to the processor must be designed for compatibility with these signal characteristics. Switching characteristics tell you what the processor will do in a given circumstance. You can also use switching characteristics to ensure that any timing requirement of a device connected to the processor (such as memory) is satisfied.
Timing requirements apply to signals that are controlled by circuitry external to the processor, such as the data input for a read operation. Timing requirements guarantee that the processor operates correctly with other devices.

## MEMORY TIMING SPECIFICATIONS

Table VI shows common memory device specifications and the corresponding ADSP-21mod970 timing parameter.

Table VI. Memory Devices and Timing Parameters

| Memory <br> Device Specification | ADSP- <br> 21mod970 <br> Timing <br> Parameter | Timing Parameter Definition |
| :---: | :---: | :---: |
| Address Setup to Write Start | $\mathrm{t}_{\text {ASW }}$ | A0-A13, $\overline{x M S}$ Setup before WR Low |
| Address Setup to Write End | $\mathrm{t}_{\text {AW }}$ | A0-A13, $\overline{x M S}$ Setup before $\overline{\mathrm{WR}}$ Deasserted |
| Address Hold Time | $\mathrm{t}_{\text {WRA }}$ | A0-A13, $\overline{\mathrm{xMS}}$ Hold before $\overline{\mathrm{WR}}$ Low |
| Data Setup Time | $t_{\text {DW }}$ | Data Setup before $\overline{\mathrm{WR}}$ High |
| Data Hold Time | $\mathrm{t}_{\mathrm{DH}}$ | Data Hold after $\overline{\mathrm{WR}}$ High |
| $\overline{\mathrm{OE}}$ to Data Valid | $\mathrm{t}_{\text {RDD }}$ | $\overline{\mathrm{RD}}$ Low to Data Valid |
| Address Access Time | $\mathrm{t}_{\text {AA }}$ | A0-A13, $\overline{\mathrm{xMS}}$ to Data Valid |

Note: $\overline{\mathrm{xMS}}=\overline{\mathrm{PMS}}, \overline{\mathrm{DMS}}, \overline{\mathrm{BMS}}, \overline{\mathrm{CMS}}, \overline{\mathrm{IOMS}}$.

## FREQUENCY DEPENDENCY FOR TIMING SPECIFICATIONS

$\mathrm{t}_{\mathrm{CK}}$ is defined as $0.5 \mathrm{t}_{\mathrm{CKI}}$. The ADSP-21mod970 uses an input clock with a frequency equal to half the instruction rate: a 26.32 MHz input clock (which is equivalent to 38.0 ns ) yields a 19 ns processor cycle (equivalent to 52 MHz ). $\mathrm{t}_{\mathrm{CK}}$ values within the range of $0.5 \mathrm{t}_{\mathrm{CKI}}$ period should be substituted for all relevant timing parameters to obtain the specification value.
Example: $\mathrm{t}_{\mathrm{CKH}}=0.5 \mathrm{t}_{\mathrm{CK}}-7 \mathrm{~ns}=0.5(19 \mathrm{~ns})-7 \mathrm{~ns}=2.5 \mathrm{~ns}$

## ENVIRONMENTAL CONDITIONS

Ambient Temperature Rating:

| $\mathrm{T}_{\mathrm{AMB}}$ | $=\mathrm{T}_{\mathrm{J}}-\left(\mathrm{PD} \times \theta_{\mathrm{JA}}\right)$ |
| :--- | :--- |
| $\mathrm{T}_{\mathrm{J}}$ | $=$ Junction Temperature in ${ }^{\circ} \mathrm{C}$ |
| PD | $=$ Power Dissipation in W |
| $\theta_{\mathrm{JA}}$ | $=$ Thermal Resistance (Junction-to-Ambient) |


| Package | $\boldsymbol{\theta}_{\text {JA }}$ |
| :--- | :--- |
| PBGA | $26.9^{\circ} \mathrm{C} / \mathrm{W}$ |

## ESD SENSITIVITY

ESD (electrostatic discharge) sensitive device. Electrostatic charges as high as 4000 V readily accumulate on the human body and test equipment and can discharge without detection. Although the ADSP-21mod970 features proprietary ESD protection circuitry, permanent damage may occur on devices subjected to high energy electrostatic discharges. Therefore, proper ESD precautions are recommended to avoid performance degradation or loss of functionality.


## ADSP-21mod970

## POWER DISSIPATION

To determine total power dissipation in a specific application, the following equation should be applied for each output:

$$
C \times V_{D D}^{2} \times f
$$

$C=$ load capacitance, $f=$ output switching frequency.




Figure 12. Power vs. Frequency

## CAPACITIVE LOADING

Figures 13 and 14 show the capacitive loading characteristics of the ADSP-21mod970.


Figure 13. Typical Output Rise Time vs. Load Capacitance, $C_{L}$ (at Maximum Ambient Operating Temperature)


Figure 14. Typical Output Valid Delay or Hold vs. Load Capacitance, $C_{L}$ (at Maximum Ambient Operating Temperature)

## TEST CONDITIONS

## Output Disable Time

Output pins are considered to be disabled when they have stopped driving and started a transition from the measured output high or low voltage to a high impedance state. The output disable time ( $t_{\text {DII }}$ ) is the difference between $t_{\text {MEASURED }}$ and $\mathrm{t}_{\mathrm{DECAY}}$, as shown in Figure 15. The time is the interval from when a reference signal reaches a high or low voltage level to when the output voltages have changed by 0.5 V from the measured output high or low voltage.
The decay time, $\mathrm{t}_{\text {DECAY }}$, is dependent on the capacitive load, $\mathrm{C}_{\mathrm{L}}$, and the current load, $\mathrm{i}_{\mathrm{L}}$, on the output pin. It can be approximated by the following equation:

$$
t_{D E C A Y}=\frac{C_{L} \times 0.5 \mathrm{~V}}{i_{L}}
$$

from which

$$
t_{D I S}=t_{\text {MEASURED }}-t_{D E C A Y}
$$

is calculated. If multiple pins (such as the data bus) are disabled, the measurement value is that of the last pin to stop driving.


Figure 15. Voltage Reference Levels for AC Measurements (Except Output Enable/Disable)

## Output Enable Time

Output pins are considered to be enabled when they have made a transition from a high impedance state to when they start driving. The output enable time ( $\mathrm{t}_{\mathrm{ENA}}$ ) is the interval from when a reference signal reaches a high or low voltage level to when the
output has reached a specified high or low trip point, as shown in Figure 16. If multiple pins (such as the data bus) are enabled, the measurement value is that of the first pin to start driving.


Figure 16. Output Enable/Disable


Figure 17. Equivalent Device Loading for AC Measurements (Including All Fixtures)

TIMING PARAMETERS

| Parameter | Min | Max |
| :--- | :--- | :---: |
| Clock Signals and Reset |  |  |
| Timing Requirements: |  |  |
| $\mathrm{t}_{\mathrm{CKI}}$ | CLKIN Period |  |
| $\mathrm{t}_{\mathrm{CKIL}}$ | CLKIN Width Low | 100 |
| $\mathrm{t}_{\mathrm{CKIH}}$ | CLKIN Width High | 15 |
| Switching Characteristics: | 15 |  |
| $\mathrm{t}_{\mathrm{CKL}}$ | CLKOUT Width Low |  |
| $\mathrm{t}_{\mathrm{CKH}}$ | CLKOUT Width High |  |
| $\mathrm{t}_{\mathrm{CKOH}}$ | CLKIN High to CLKOUT High | $0.5 \mathrm{t}_{\mathrm{CK}}-7$ |
| Control Signals | $0.5 \mathrm{t}_{\mathrm{CK}}-7$ | ns |
| Timing Requirements: | 0 | ns |
| $\mathrm{t}_{\text {RSP }}$ |  |  |
| $\mathrm{t}_{\mathrm{MS}}$ |  | 20 |
| $\mathrm{t}_{\mathrm{MH}}$ |  |  |

NOTE
${ }^{1}$ Applies after power-up sequence is complete. Internal phase lock loop requires no more than 2000 CLKIN cycles assuming stable CLKIN (not including crystal oscillator start-up time).

*PF3 IS MODE D, PF2 IS MODE C, PF1 IS MODE B, PF0 IS MODE A
Figure 18. Clock Signals

| Parameter | Min | Max | Unit |
| :---: | :---: | :---: | :---: |
| Interrupts and Flags |  |  |  |
| Timing Requirements: |  |  |  |
| $\mathrm{t}_{\mathrm{IFS}} \quad \overline{\mathrm{IRQx}}, \mathrm{FI}$, or PFx Setup before CLKOUT Low ${ }^{1,2,3,4}$ | $0.25 \mathrm{t}_{\mathrm{CK}}+15$ |  | ns |
| $\mathrm{t}_{\mathrm{IFH}} \quad \overline{\mathrm{IRQx}}, \mathrm{FI}$, or PFx Hold after CLKOUT High ${ }^{1,2,3,4}$ | $0.25 \mathrm{t}_{\mathrm{CK}}$ |  | ns |
| Switching Characteristics: |  |  |  |
| $\mathrm{t}_{\mathrm{FOH}} \quad$ Flag Output Hold after CLKOUT Low ${ }^{5}$ | $0.25 \mathrm{t}_{\mathrm{CK}}-7$ |  | ns |
| $\mathrm{t}_{\mathrm{FOD}} \quad$ Flag Output Delay from CLKOUT Low ${ }^{5}$ |  | $0.5 \mathrm{t}_{\mathrm{CK}}+6$ | ns |

## NOTES

${ }^{1}$ If $\overline{\mathrm{IRQx}}$ and FI inputs meet $\mathrm{t}_{\mathrm{IFS}}$ and $\mathrm{t}_{\mathrm{IFH}}$ setup/hold requirements, they will be recognized during the current clock cycle; otherwise the signals will be recognized on the following cycle. (Refer to Interrupt Controller Operation in the Program Control chapter of the ADSP-2100 Family User's Manual, Third Edition, for further information on interrupt servicing.)
${ }^{2}$ Edge-sensitive interrupts require pulsewidths greater than 10 ns ; level-sensitive interrupts must be held low until serviced.
${ }^{3} \overline{\mathrm{IRQx}}=\overline{\mathrm{IRQ} 0}, \overline{\mathrm{IRQ1}}, \overline{\mathrm{IRQ}} 2, \overline{\mathrm{IRQL0}}, \overline{\overline{\mathrm{IRQL1}}, \overline{\mathrm{IRQE}} .}$
${ }^{4} \mathrm{PFx}=\mathrm{PF} 0, \mathrm{PF} 1, \mathrm{PF} 2, \mathrm{PF} 3, \mathrm{PF} 4, \mathrm{PF} 5, \mathrm{PF} 6, \mathrm{PF} 7$.
${ }^{5}$ Flag outputs $=$ PFx, FL0, FL1, FL2, Flag_out.


Figure 19. Interrupts and Flags

## ADSP-21mod970

TIMING PARAMETERS

| Parameter | Min | Max | Unit |
| :---: | :---: | :---: | :---: |
| Bus Request-Bus Grant |  |  |  |
| Timing Requirements: |  |  |  |
| $\mathrm{t}_{\mathrm{BH}} \quad \overline{\mathrm{BR}}$ Hold after CLKOUT High ${ }^{1}$ | $0.25 \mathrm{t}_{\mathrm{CK}}+2$ |  | ns |
| $\mathrm{t}_{\mathrm{BS}} \quad \overline{\mathrm{BR}}$ Setup before CLKOUT Low ${ }^{1}$ | $0.25 \mathrm{t}_{\mathrm{CK}}+17$ |  | ns |
| Switching Characteristics: |  |  |  |
| $\mathrm{t}_{\mathrm{SD}} \quad$ CLKOUT High to $\overline{\mathrm{xMS}}$, $\overline{\mathrm{RD}}$, WR Disable |  | $0.25 \mathrm{t}_{\mathrm{CK}}+10$ | ns |
| $\mathrm{t}_{\text {SDB }} \quad \overline{\mathrm{xMS}}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ Disable to $\overline{\mathrm{BG}}$ Low | 0 |  | ns |
| $\mathrm{t}_{\mathrm{SE}} \quad \overline{\overline{B G}}$ High to $\overline{\mathrm{xMS}}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ Enable | 0 |  | ns |
| $\mathrm{t}_{\text {SEC }} \quad \overline{\mathrm{xMS}}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ Enable to CLKOUT High | $0.25 \mathrm{t}_{\mathrm{CK}}-4$ |  | ns |
| $\mathrm{t}_{\text {SDBH }} \quad \overline{\mathrm{xMS}}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ Disable to $\overline{\mathrm{BGH}}$ Low $^{2}$ | 0 |  | ns |
| $\mathrm{t}_{\text {SEH }} \quad \overline{\mathrm{BGH}}$ High to $\overline{\mathrm{xMS}}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$ Enable $^{2}$ | 0 |  | ns |

NOTES
$\overline{\mathrm{xMS}}=\overline{\mathrm{PMS}}, \overline{\mathrm{DMS}}, \overline{\mathrm{CMS}}, \overline{\mathrm{IOMS}}, \overline{\mathrm{BMS}}$.
${ }^{1} \overline{\mathrm{BR}}$ is an asynchronous signal. If $\overline{\mathrm{BR}}$ meets the setup/hold requirements, it will be recognized during the current clock cycle; otherwise the signal will be recognized on the following cycle. Refer to the ADSP-2100 Family User's Manual, Third Edition, for $\overline{\mathrm{BR}} / \overline{\mathrm{BG}}$ cycle relationships.
${ }^{2} \overline{\mathrm{BGH}}$ is asserted when the bus is granted and the processor requires control of the bus to continue.


Figure 20. Bus Request-Bus Grant

## ADSP-21mod970

| Parameter | Min | Max | Unit |
| :---: | :---: | :---: | :---: |
| Memory Read |  |  |  |
| Timing Requirements: |  |  |  |
| $\mathrm{t}_{\mathrm{RDD}} \quad \overline{\mathrm{RD}}$ Low to Data Valid |  | $0.5 \mathrm{t}_{\mathrm{CK}}-9+\mathrm{w}$ | ns |
| $\mathrm{t}_{\mathrm{AA}} \quad \mathrm{A} 0-\mathrm{A} 13, \overline{\mathrm{xMS}}$ to Data Valid |  | $0.75 \mathrm{t}_{\mathrm{CK}}-12.5+\mathrm{w}$ | ns |
| $\mathrm{t}_{\mathrm{RDH}} \quad$ Data Hold from $\overline{\mathrm{RD}}$ High | 0 |  | ns |
| Switching Characteristics: |  |  |  |
| $\mathrm{t}_{\mathrm{RP}} \quad \overline{\mathrm{RD}}$ Pulsewidth | $0.5 \mathrm{t}_{\mathrm{CK}}-5+\mathrm{w}$ |  | ns |
| $\mathrm{t}_{\mathrm{CRD}} \quad$ CLKOUT High to $\overline{\mathrm{RD}}$ Low | $0.25 \mathrm{t}_{\mathrm{CK}}-5$ | $0.25 \mathrm{t}_{\mathrm{CK}}+7$ | ns |
| $\mathrm{t}_{\text {ASR }} \quad \mathrm{A} 0-\mathrm{A} 13, \overline{\mathrm{xMS}}$ Setup before $\overline{\mathrm{RD}}$ Low | $0.25 \mathrm{t}_{\mathrm{CK}}-6$ |  | ns |
| $\mathrm{t}_{\mathrm{RDA}} \quad \mathrm{A} 0-\mathrm{Al3}, \overline{\mathrm{xMS}}$ Hold after $\overline{\mathrm{RD}}$ Deasserted | $0.25 \mathrm{t}_{\mathrm{CK}}-3$ |  | ns |
| $\mathrm{t}_{\text {RWR }} \quad \overline{\mathrm{RD}}$ High to $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ Low | $0.5 \mathrm{t}_{\mathrm{CK}}-5$ |  | ns |

$\mathrm{w}=$ wait states $\times \mathrm{t}_{\mathrm{CK}}$.
$\overline{\mathrm{xMS}}=\overline{\mathrm{PMS}}, \overline{\mathrm{DMS}}, \overline{\mathrm{CMS}}, \overline{\mathrm{IOMS}}, \overline{\mathrm{BMS}}$.


Figure 21. Memory Read

## ADSP-21mod970

TIMING PARAMETERS

| Parameter | Min | Max | Unit |
| :---: | :---: | :---: | :---: |
| Memory Write |  |  |  |
| Switching Characteristics: |  |  |  |
| $\mathrm{t}_{\text {Dw }} \quad$ Data Setup before $\overline{\mathrm{WR}}$ High | $0.5 \mathrm{t}_{\mathrm{CK}}-7+\mathrm{w}$ |  | ns |
| $\mathrm{t}_{\mathrm{DH}} \quad$ Data Hold after $\overline{\mathrm{WR}}$ High | $0.25 \mathrm{t}_{\mathrm{CK}}-2$ |  | ns |
| $\mathrm{t}_{\mathrm{WP}} \quad \overline{\mathrm{WR}}$ Pulsewidth | $0.5 \mathrm{t}_{\mathrm{CK}}-5+\mathrm{w}$ |  | ns |
| $\mathrm{t}_{\text {WDE }} \quad$ WR Low to Data Enabled |  |  | ns |
| $\mathrm{t}_{\text {ASw }}$ A0-A13, $\overline{\mathrm{xMS}}$ Setup before $\overline{\mathrm{WR}}$ Low | $0.25 \mathrm{t}_{\mathrm{CK}}-6$ |  | ns |
| $\mathrm{t}_{\mathrm{DDR}} \quad$ Data Disable before $\overline{\mathrm{WR}}$ or $\overline{\mathrm{RD}}$ Low | $0.25 \mathrm{t}_{\mathrm{CK}}-7$ |  | ns |
| $\mathrm{t}_{\text {CWR }} \quad$ CLKOUT High to $\overline{\mathrm{WR}}$ Low | $0.25 \mathrm{t}_{\mathrm{CK}}-5$ | $0.25 \mathrm{t}_{\mathrm{CK}}+7$ | ns |
| $\mathrm{t}_{\mathrm{AW}} \quad \mathrm{A} 0-\mathrm{A} 13, \mathrm{xMS}$, Setup before WR Deasserted | $0.75 \mathrm{t}_{\mathrm{CK}}-9+\mathrm{w}$ |  | ns |
| $\mathrm{t}_{\mathrm{WRA}} \quad \mathrm{A} 0-\mathrm{A} 13, \mathrm{xMS}$ Hold after WR Deasserted | $0.25 \mathrm{t}_{\mathrm{CK}}-3$ |  | ns |
| $\mathrm{t}_{\text {WWW }} \quad \overline{\mathrm{WR}}$ High to $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ Low | $0.5 \mathrm{t}_{\mathrm{CK}}-5$ |  | ns |

$\mathrm{w}=$ wait states $\times \mathrm{t}_{\mathrm{CK}}$.
$\overline{\mathrm{xMS}}=\overline{\mathrm{PMS}}, \overline{\mathrm{DMS}}, \overline{\mathrm{CMS}}, \overline{\mathrm{IOMS}}, \overline{\mathrm{BMS}}$.


Figure 22. Memory Write



Figure 23. Serial Ports

## ADSP-21mod970

TIMING PARAMETERS

| Parameter | Min | Max |
| :--- | :--- | :---: |
| IDMA Address Latch |  | Unit |
| Timing Requirements: |  |  |
| $\mathrm{t}_{\text {IALP }}$ | Duration of Address Latch |  |
| $\mathrm{t}_{\text {IASU }}$ | IAD15-0 Address Setup before Address Latch End ${ }^{2}$ | 10 |
| $\mathrm{t}_{\text {IAH }}$ | IAD15-0 Address Hold after Address Latch End ${ }^{2}$ | 5 |
| $\mathrm{t}_{\text {IKA }}$ | IACK Low before Start of Address Latch ${ }^{2,3}$ | 2 |
| $\mathrm{t}_{\text {IALS }}$ | Start of Write or Read after Address Latch End ${ }^{1,2}$ | 0 |
| $\mathrm{t}_{\text {IALD }}$ | Address Latch Start after Address Latch End ${ }^{1,2}$ | 3 |
| ns |  |  |

## NOTES

${ }^{1}$ Start of Address Latch $=\overline{\mathrm{IS}}$ Low and IAL High.
${ }^{2}$ End of Address Latch = IS High or IAL Low.
${ }^{3}$ Start of Write or Read $=\overline{\mathrm{IS}}$ Low and $\overline{\text { IWR }}$ Low or $\overline{\text { IRD }}$ Low.


Figure 24. IDMA Address Latch

| Parameter | Min | Max | Unit |
| :---: | :---: | :---: | :---: |
| IDMA Write, Short Write Cycle |  |  |  |
| Timing Requirements: |  |  |  |
| $\mathrm{t}_{\text {IKW }} \quad \overline{\text { IACK }}$ Low before Start of Write ${ }^{1}$ | 0 |  | ns |
| $\mathrm{t}_{\text {IWP }} \quad$ Duration of Write ${ }^{1,2}$ | 15 |  | ns |
| $\mathrm{t}_{\text {IDSU }} \quad$ IAD15-0 Data Setup before End of Write ${ }^{2,3,4}$ | 5 |  | ns |
| $\mathrm{t}_{\mathrm{IDH}} \quad$ IAD15-0 Data Hold after End of Write ${ }^{2,3,4}$ | 2 |  | ns |
| Switching Characteristic: |  |  |  |
| $\mathrm{t}_{\text {IKHW }} \quad$ Start of Write to $\overline{\text { IACK }}$ High | 4 | 15 | ns |

NOTES
${ }^{1}$ Start of Write $=\overline{\overline{I S}}$ Low and $\overline{\overline{\text { IWR }}}$ Low.
${ }^{2}$ End of Write $=\overline{\text { IS }}$ High or $\overline{\text { IWR }}$ High.
${ }^{3}$ If Write Pulse ends before $\overline{\text { IACK }}$ Low, use specifications $\mathrm{t}_{\mathrm{IDSu}}, \mathrm{t}_{\mathrm{IDH}}$.
${ }^{4}$ If Write Pulse ends after IACK Low, use specifications $t_{\text {IKsu }}, t_{\text {IKH }}$.


Figure 25. IDMA Write, Short Write Cycle

TIMING PARAMETERS

| Parameter | Min | Max | Unit |
| :---: | :---: | :---: | :---: |
| IDMA Write, Long Write Cycle |  |  |  |
| Timing Requirements: |  |  |  |
| $\mathrm{t}_{\text {IKW }} \quad \overline{\text { IACK }}$ Low before Start of Write ${ }^{1}$ | 0 |  | ns |
| $\mathrm{t}_{\text {IKSU }} \quad$ IAD15-0 Data Setup before IACK Low $^{2,3,4}$ | $0.5 \mathrm{t}_{\mathrm{CK}}+10$ |  | ns |
| $\mathrm{t}_{\text {IKH }} \quad$ IAD15-0 Data Hold after $\overline{\text { IACK }}$ Low ${ }^{2,3,4}$ | 2 |  | ns |
| Switching Characteristics: |  |  |  |
| $\mathrm{t}_{\text {IKLW }} \quad$ Start of Write to $\overline{\text { IACK }}$ Low ${ }^{4}$ | $1.5 \mathrm{t}_{\mathrm{CK}}$ |  | ns |
| $\mathrm{t}_{\text {IKHW }} \quad$ Start of Write to $\overline{\text { IACK }}$ High | 4 | 15 | ns |

NOTES
${ }^{1}$ Start of Write $=\overline{\mathrm{IS}}$ Low and $\overline{\text { IWR }}$ Low .
${ }^{2}$ If Write Pulse ends before $\overline{\text { IACK }}$ Low, use specifications $t_{\text {IDSU }}, t_{\text {IDH }}$.
${ }^{3}$ If Write Pulse ends after IACK Low, use specifications $\mathrm{t}_{\text {IKSU }}$, $\mathrm{t}_{\mathrm{IKH}}$.
${ }^{4}$ This is the earliest time for IACK Low from Start of Write. For IDMA Write cycle relationships, please refer to the ADSP-2100 Family User's Manual, Third Edition.


Figure 26. IDMA Write, Long Write Cycle

| Parameter | Min | Max | Unit |
| :---: | :---: | :---: | :---: |
| IDMA Read, Long Read Cycle |  |  |  |
| Timing Requirements: |  |  |  |
| $\mathrm{t}_{\text {IKR }} \quad \overline{\text { IACK }}$ Low before Start of Read ${ }^{1}$ | 0 |  | ns |
| $\mathrm{t}_{\text {IRK }} \quad$ End of Read after $\overline{\text { IACK }}$ Low $^{2}$ | 2 |  | ns |
| Switching Characteristics: |  |  |  |
| $\mathrm{t}_{\text {IKHR }} \quad \overline{\text { IACK }}$ High after Start of Read ${ }^{1}$ | 4 | 15 | ns |
| $\mathrm{t}_{\text {IKDS }} \quad$ IAD15-0 Data Setup before $\overline{\text { IACK }}$ Low | $0.5 \mathrm{t}_{\mathrm{CK}}-7$ |  | ns |
| $\mathrm{t}_{\text {IKDH }} \quad$ IAD15-0 Data Hold after End of Read ${ }^{2}$ | 0 |  | ns |
| $\mathrm{t}_{\text {IKDD }} \quad$ IAD15-0 Data Disabled after End of Read ${ }^{2}$ |  | 10 | ns |
| $\mathrm{t}_{\text {IRDE }} \quad$ IAD15-0 Previous Data Enabled after Start of Read | 0 |  | ns |
| $\mathrm{t}_{\text {IRDV }} \quad$ IAD15-0 Previous Data Valid after Start of Read |  | 10 | ns |
| $\mathrm{t}_{\text {IRDH1 }} \quad$ IAD15-0 Previous Data Hold after Start of Read (DM/PM1) ${ }^{3}$ | $2 \mathrm{t}_{\mathrm{CK}}-5$ |  | ns |
| $\mathrm{t}_{\text {IRDH2 }} \quad$ IAD15-0 Previous Data Hold after Start of Read (PM2) ${ }^{4}$ | $\mathrm{t}_{\mathrm{CK}}-5$ |  | ns |

## NOTES

${ }^{1}$ Start of Read $=\overline{\text { IS }}$ Low and $\overline{\text { IRD }}$ Low.
${ }^{2}$ End of Read $=\overline{\text { IS }}$ High or $\overline{\text { IRD }}$ High.
${ }^{3}$ DM read or first half of PM read.
${ }^{4}$ Second half of PM read.


Figure 27. IDMA Read, Long Read Cycle

TIMING PARAMETERS

| Parameter | Min | Max | Unit |
| :---: | :---: | :---: | :---: |
| IDMA Read, Short Read Cycle |  |  |  |
| Timing Requirements: |  |  |  |
| $\mathrm{t}_{\text {IKR }} \quad \overline{\text { IACK }}$ Low before Start of Read ${ }^{1}$ | 0 |  | ns |
| $\mathrm{t}_{\text {IRP }} \quad$ Duration of Read | 15 |  | ns |
| Switching Characteristics: |  |  |  |
| $\mathrm{t}_{\text {IKHR }} \quad \overline{\text { IACK }}$ High after Start of Read ${ }^{1}$ | 4 | 15 | ns |
| $\mathrm{t}_{\text {IKDH }} \quad$ IAD15-0 Data Hold after End of Read ${ }^{2}$ | 0 |  | ns |
| $\mathrm{t}_{\text {IKDD }} \quad$ IAD15-0 Data Disabled after End of Read ${ }^{2}$ |  | 10 | ns |
| $\mathrm{t}_{\text {IRDE }} \quad$ IAD15-0 Previous Data Enabled after Start of Read | 0 |  | ns |
| $\mathrm{t}_{\text {IRDV }} \quad$ IAD15-0 Previous Data Valid after Start of Read |  | 10 | ns |

## NOTES

${ }^{1}$ Start of Read $=\overline{\text { IS }}$ Low and $\overline{\text { IRD }}$ Low.
${ }^{2}$ End of Read $=\overline{\text { IS }}$ High or $\overline{\text { IRD }}$ High.


Figure 28. IDMA Read, Short Read Cycle

304-Ball PBGA Package Pinout
The ADSP-21mod970 package pinout is shown in the table below.

| Ball <br> Number | Signal <br> Name | Ball <br> Number | Signal <br> Name | Ball <br> Number | Signal <br> Name | Ball <br> Number | Signal <br> Name |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| A1 | GND | B23 | IAD1 | D22 | IAD4 | K4 | $\overline{\text { CMS_1 }}$ |
| A2 | PF0_1 | C1 | IAD5_1 | D23 | IAD3 | K20 | PF5_3 |
| A3 | PF2_1 | C2 | IAD0_1 | E1 | IAD8_1 | K21 | $\overline{\text { EBG }}$ |
| A4 | FL1_1 | C3 | GND | E2 | IAD7_1 | K22 | $\overline{\mathrm{EBR}}$ |
| A5 | D23_1 | C4 | $\overline{\text { BGH_1 }}$ | E3 | IAD2_1 | K23 | $\overline{\text { EINT }}$ |
| A6 | D21_1 | C5 | PF3_1 | E4 | IAD1_1 | L1 | D17 |
| A7 | D13_1 | C6 | FL2_1 | E20 | CLKIN | L2 | D18 |
| A8 | D16_1 | C7 | D12_1 | E21 | GND | L3 | PF5_1 |
| A9 | GND | C8 | D17_1 | E22 | GND | L4 | PF7_1 |
| A10 | PF0_2 | C9 | GND | E23 | GND | L20 | $\mathrm{V}_{\mathrm{DD}}$ |
| A11 | PF1_2 | C10 | IAD13_1 | F1 | IAD12_1 | L21 | ERESET |
| A12 | FL0_2 | C11 | IAD15_1 | F2 | IAD9_1 | L22 | ELIN |
| A13 | FL1_2 | C12 | PF2_2 | F3 | IAD10_1 | L23 | ELOUT |
| A14 | $\mathrm{V}_{\mathrm{DD}}$ | C13 | $\mathrm{V}_{\mathrm{DD}}$ | F4 | $\overline{\text { IWR_1 }}$ | M1 | D15 |
| A15 | $V_{\text {DD }}$ | C14 | $\mathrm{V}_{\mathrm{DD}}$ | F20 | GND | M2 | D16 |
| A16 | PF0_3 | C15 | $\mathrm{V}_{\mathrm{DD}}$ | F21 | GND | M3 | PF6_1 |
| A17 | PF1_3 | C16 | IS_2 | F22 | GND | M4 | $\overline{\text { BGH_4 }}$ |
| A18 | FL0_3 | C17 | CLKOUT_2 | F23 | GND | M20 | $\mathrm{V}_{\mathrm{DD}}$ |
| A19 | FL1_3 | C18 | PF4_2 | G1 | CLKIN_1 | M21 | $\mathrm{V}_{\mathrm{DD}}$ |
| A20 | D21 | C19 | DT1_2 | G2 | IAD11_1 | M22 | $\mathrm{V}_{\mathrm{DD}}$ |
| A21 | D22 | C20 | EE_2 | G3 | D8_1 | M23 | $\mathrm{V}_{\mathrm{DD}}$ |
| A22 | D23 | C21 | GND | G4 | $\overline{\overline{I R D} \_1}$ | N1 | D13 |
| A23 | GND | C22 | IAD2 | G20 | $\overline{\mathrm{IAL}}$ | N2 | D12 |
| B1 | IAD3_1 | C23 | IAD0 | G21 | $\overline{\text { IRD }}$ | N3 | D14 |
| B2 | GND | D1 | IAD6_1 | G22 | $\overline{\text { IWR }}$ | N4 | PF1_4 |
| B3 | PF1_1 | D2 | IAD4_1 | G23 | GND | N20 | $\mathrm{V}_{\mathrm{DD}}$ |
| B4 | FL0_1 | D3 | A0_1 | H1 | $\overline{\mathrm{RD}}$-1 | N21 | PF6_3 |
| B5 | D22_1 | D4 | GND | H2 | WR_1 | N22 | ECLK |
| B6 | D20_1 | D5 | D10_1 | H3 | $\overline{\text { IAL_1 }}$ | N23 | $\overline{\text { EMS }}$ |
| B7 | D19_1 | D6 | D11_1 | H4 | $\overline{\text { IS_1 }}$ | P1 | GND |
| B8 | D15_1 | D7 | D9_1 | H20 | CLKOUT_3 | P2 | GND |
| B9 | GND | D8 | D18_1 | H21 | RFS0A | P3 | GND |
| B10 | D14_1 | D9 | GND | H22 | DR0A | P4 | TFS0_1 |
| B11 | $\overline{\text { BGH_2 }}$ | D10 | IAD14_1 | H23 | $\overline{\text { IS_3 }}$ | P20 | DT1_3 |
| B12 | PF3_2 | D11 | $\overline{\text { BR_1 }}$ | J1 | $\overline{\text { DMS_1 }}$ | P21 | PF2_6 |
| B13 | FL2_2 | D12 | $\overline{\text { BG_1 }}$ | J2 | $\overline{\text { BMS_1 }}$ | P22 | RESET_3 |
| B14 | $\mathrm{V}_{\mathrm{DD}}$ | D13 | $\overline{\text { IACK_1 }}$ | J3 | PMS_1 | P23 | EE_3 |
| B15 | $V_{\text {DD }}$ | D14 | $V_{\text {DD }}$ | J4 | CLKOUT_1 | R1 | IAD6 |
| B16 | BGH_3 | D15 | $\mathrm{V}_{\mathrm{DD}}$ | J20 | SCLK0A | R2 | IAD7 |
| B17 | PF2_3 | D16 | $\overline{\text { BG_2 }}$ | J21 | PF4_3 | R3 | IAD5 |
| B18 | PF3_3 | D17 | $\overline{\text { BR_2 }}$ | J22 | $\overline{\text { BG_3 }}$ | R4 | PF0_4 |
| B19 | FL2_3 | D18 | PF5_2 | J23 | $\overline{\text { BR_3 }}$ | R20 | PF0_6 |
| B20 | D20 | D19 | $\overline{\text { RESET_2 }}$ | K1 | D19 | R21 | PF1_6 |
| B21 | DT0A | D20 | GND | K2 | PF4_1 | R22 | FL2_6 |
| B22 | GND | D21 | GND | K3 | $\overline{\text { IOMS_1 }}$ | R23 | FL1_6 |

304-Ball PBGA Package Pinout (continued)

| Ball <br> Number | Signal <br> Name | Ball <br> Number | Signal <br> Name | Ball <br> Number | Signal <br> Name | Ball <br> Number | Signal <br> Name |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| T1 | D10 | W23 | GND | AA8 | PF4_5 | AB16 | PF2_5 |
| T2 | D9 | Y1 | $\mathrm{V}_{\mathrm{DD}}$ | AA9 | GND | AB17 | CLKOUT_6 |
| T3 | D11 | Y2 | $\mathrm{V}_{\mathrm{DD}}$ | AA10 | PF6_5 | AB18 | RFS0B |
| T4 | EE_1 | Y3 | $\mathrm{V}_{\mathrm{DD}}$ | AA11 | $V_{\text {DD }}$ | AB19 | GND |
| T20 | $\overline{\text { BGH_6 }}$ | Y4 | GND | AA12 | DT1_5 | AB20 | SCLK0B |
| T21 | TFS0_3 | Y5 | FL0_4 | AA13 | BGH_5 | AB21 | RESET_6 |
| T22 | PF3_6 | Y6 | $\mathrm{V}_{\mathrm{DD}}$ | AA14 | PF7_2 | AB22 | GND |
| T23 | FL0_6 | Y7 | FL2_4 | AA15 | PF1_5 | AB23 | $\overline{\text { BG_6 }}$ |
| U1 | IAD9 | Y8 | CLKOUT_5 | AA16 | FL1_5 | AC1 | GND |
| U2 | IAD11 | Y9 | GND | AA17 | TFS1 | AC2 | $\overline{\text { BR_4 }}$ |
| U3 | IAD8 | Y10 | IS_5 | AA18 | DR1 | AC3 | PF7_4 |
| U4 | PF2_4 | Y11 | $V_{\text {DD }}$ | AA19 | GND | AC4 | GND |
| U20 | GND | Y12 | TFS0_2 | AA20 | DT1_6 | AC5 | TFS0_4 |
| U21 | GND | Y13 | PF6_2 | AA21 | GND | AC6 | $\mathrm{V}_{\mathrm{DD}}$ |
| U22 | GND | Y14 | PF0_5 | AA22 | $\overline{\text { BG_5 }}$ | AC7 | $\mathrm{V}_{\mathrm{DD}}$ |
| U23 | GND | Y15 | FL0_5 | AA23 | IAD14 | AC8 | GND |
| V1 | IAD10 | Y16 | FL2_5 | AB1 | PF5_4 | AC9 | GND |
| V2 | IAD12 | Y17 | RFS1 | AB2 | GND | AC10 | TFS0_5 |
| V3 | DT1_1 | Y18 | SCLK1 | AB3 | PF6_4 | AC11 | $V_{\text {DD }}$ |
| V4 | PF3_4 | Y19 | GND | AB4 | GND | AC12 | EE_5 |
| V20 | GND | Y20 | GND | AB5 | DT1_4 | AC13 | PF5_6 |
| V21 | GND | Y21 | $\overline{\text { BR_5 }}$ | AB6 | $\mathrm{V}_{\mathrm{DD}}$ | AC14 | GND |
| V22 | GND | Y22 | IAD13 | AB7 | RESET_4 | AC15 | PF6_6 |
| V23 | GND | Y23 | IACK | AB8 | PF5_5 | AC16 | PF7_6 |
| W1 | D8 | AA1 | PF4_4 | AB9 | GND | AC17 | DT0B |
| W2 | CLKOUT_4 | AA2 | $\overline{\text { BG_4 }}$ | AB10 | PF7_5 | AC18 | TFS0_6 |
| W3 | RESET_1 | AA3 | GND | AB11 | $\mathrm{V}_{\mathrm{DD}}$ | AC19 | GND |
| W4 | $\overline{\text { IS_4 }}$ | AA4 | GND | AB12 | RESET_5 | AC20 | DR0B |
| W20 | $\overline{\text { IS_6 }}$ | AA5 | FL1_4 | AB13 | PF4_6 | AC21 | EE_6 |
| W21 | PF7_3 | AA6 | $\mathrm{V}_{\mathrm{DD}}$ | AB14 | GND | AC22 | $\overline{\text { BR_6 }}$ |
| W22 | IAD15 | AA7 | EE_4 | AB15 | PF3_5 | AC23 | GND |

ORDERING GUIDE

| Part <br> Number | Ambient <br> Temperature Range | Processor Clock | Package <br> Description | Package <br> Option |
| :--- | :--- | :--- | :--- | :--- |
| ADSP-21mod $970-000$ | $0^{\circ} \mathrm{C}$ to $+70^{\circ} \mathrm{C}$ | 26.0 MHz | $304-\mathrm{Ball}$ PBGA | B-304 |

## RELATED DOCUMENTS

ADSP-21mod970-110 Multiport Internet Gateway Processor solution.


## OUTLINE DIMENSIONS

Dimensions shown in inches and（mm）．

## 304－Ball Metric Plastic Ball Grid Array

（B－304）



[^0]:    Information furnished by Analog Devices is believed to be accurate and reliable. However, no responsibility is assumed by Analog Devices for its use, nor for any infringements of patents or other rights of third parties which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of Analog Devices.

[^1]:    NOTES
    ${ }^{1}$ Bidirectional pins: D0-D23, RFS0, RFS1, SCLK0, SCLK1, TFS0, TFS1, A1-A13, PF0-PF7.
    ${ }^{2}$ Input only pins: $\overline{\mathrm{RESET}}, \overline{\mathrm{BR}}, \mathrm{DR} 0, \mathrm{DR} 1, \overline{\mathrm{PWD}}$.
    ${ }^{3}$ Input only pins: CLKIN, $\overline{\text { RESET, }} \overline{\mathrm{BR}}, \mathrm{DR} 0, \mathrm{DR} 1, \overline{\mathrm{PWD}}$.
    ${ }^{4}$ Output pins: $\overline{\mathrm{BG}}, \overline{\mathrm{PMS}}, \overline{\mathrm{DMS}}, \overline{\mathrm{BMS}}, \overline{\mathrm{IOMS}}, \overline{\mathrm{CMS}}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}$, PWDACK, A0, DT0, DT1, CLKOUT, FL2-0, $\overline{\mathrm{BGH}}$.
    ${ }^{5}$ Although specified for TTL outputs, all ADSP-21mod970 outputs are CMOS-compatible and will drive to $\mathrm{V}_{\mathrm{DD}}$ and GND, assuming no dc loads.
    ${ }^{6}$ Guaranteed but not tested.
    ${ }^{7}$ Three-statable pins: A0-A13, D0-D23, $\overline{\text { PMS }}, \overline{\mathrm{DMS}}, \overline{\mathrm{BMS}}, \overline{\mathrm{IOMS}}, \overline{\mathrm{CMS}}, \overline{\mathrm{RD}}, \overline{\mathrm{WR}}, \mathrm{DT} 0, \mathrm{DT} 1, \mathrm{SCLK} 0, \mathrm{SCLK} 1, \mathrm{TFS} 0, \mathrm{TFS} 1, \mathrm{RFS} 0, \mathrm{RFS} 1$.
    ${ }^{8} 0 \mathrm{~V}$ on $\overline{\mathrm{BR}}$.
    ${ }^{9}$ Idle refers to ADSP-21mod970 state of operation during execution of IDLE instruction. Deasserted pins are driven to either VDD or GND.
    ${ }^{10} \mathrm{~V}_{\text {IN }}=0 \mathrm{~V}$ and 3 V . For typical figures for supply currents, refer to Power Dissipation section.
    ${ }^{11} I_{D D}$ measurement taken with all instructions executing from internal memory. $50 \%$ of the instructions are multifunction (types $1,4,5,12,13,14$ ), $30 \%$ are type 2 and type 6 , and $20 \%$ are idle instructions.
    ${ }^{12}$ Output pin capacitance is the capacitive load for any three-stated output pin.
    Specifications subject to change without notice.

