# **DSP Microcomputer** # **ADSP-218xN Series** #### PERFORMANCE FEATURES 12.5 ns Instruction Cycle Time @ 1.8 V (Internal), 80 MIPS Sustained Performance **Single-Cycle Instruction Execution** **Single-Cycle Context Switch** 3-Bus Architecture Allows Dual Operand Fetches in Every Instruction Cycle **Multifunction Instructions** Power-Down Mode Featuring Low CMOS Standby Power Dissipation with 200 CLKIN Cycle Recovery from Power-Down Condition Low Power Dissipation in Idle Mode ## **INTEGRATION FEATURES** ADSP-2100 Family Code Compatible (Easy to Use Algebraic Syntax), with Instruction Set Extensions Up to 256K Bytes of On-Chip RAM, Configured as Up to 48K Words Program Memory RAM Up to 56K Words Data Memory RAM Dual-Purpose Program Memory for Both Instruction and Data Storage Independent ALU, Multiplier/Accumulator, and Barrel Shifter Computational Units Two Independent Data Address Generators Powerful Program Sequencer Provides Zero Overhead Looping Conditional Instruction Execution Programmable 16-Bit Interval Timer with Prescaler 100-Lead LQFP and 144-Ball Mini-BGA ## SYSTEM INTERFACE FEATURES Flexible I/O Allows 1.8 V, 2.5 V or 3.3 V Operation All Inputs Tolerate up to 3.6 V Regardless of Mode 16-Bit Internal DMA Port for High-Speed Access to On-Chip Memory (Mode Selectable) 4M-Byte Memory Interface for Storage of Data Tables and Program Overlays (Mode Selectable) 8-Bit DMA to Byte Memory for Transparent Program and Data Memory Transfers (Mode Selectable) Programmable Memory Strobe and Separate I/O Memory Space Permits "Glueless" System Design **Programmable Wait State Generation** Two Double-Buffered Serial Ports with Companding Hardware and Automatic Data Buffering Automatic Booting of On-Chip Program Memory from Byte-Wide External Memory, e.g., EPROM, or through Internal DMA Port Six External Interrupts 13 Programmable Flag Pins Provide Flexible System Signaling UART Emulation through Software SPORT Reconfiguration ICE-Port™ Emulator Interface Supports Debugging in Final Systems ## **FUNCTIONAL BLOCK DIAGRAM** ICE-Port is a trademark of Analog Devices, Inc. ## REV. 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 that may result from its use. No license is granted by implication or otherwise under any patent or patent rights of Analog Devices. #### GENERAL DESCRIPTION The ADSP-218xN series consists of six single chip micro-computers optimized for digital signal processing applications. The high-level block diagram for the ADSP-218xN series members appears on the previous page. All series members are pin-compatible and are differentiated solely by the amount of on-chip SRAM. This feature, combined with ADSP-21xx code compatibility, provides a great deal of flexibility in the design decision. Specific family members are shown in Table 1. Table 1. ADSP-218xN DSP Microcomputer Family | Device | Program<br>Memory<br>(K Words) | Data Memory<br>(K Words) | |------------|--------------------------------|--------------------------| | ADSP-2184N | 4 | 4 | | ADSP-2185N | 16 | 16 | | ADSP-2186N | 8 | 8 | | ADSP-2187N | 32 | 32 | | ADSP-2188N | 48 | 56 | | ADSP-2189N | 32 | 48 | ADSP-218xN series members combine 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. ADSP-218xN series members integrate up to 256K bytes of on-chip memory configured as up to 48K words (24-bit) of program RAM, and up to 56K 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-218xN is available in a 100-lead LQFP package and 144-Ball Mini-BGA. Fabricated in a high-speed, low-power, 0.18 µm CMOS process, ADSP-218xN series members operate with a 12.5 ns instruction cycle time. Every instruction can execute in a single processor cycle. The ADSP-218xN's flexible architecture and comprehensive instruction set allow the processor to perform multiple operations in parallel. In one processor cycle, ADSP-218xN series members 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 #### **DEVELOPMENT SYSTEM** Analog Devices' wide range of software and hardware development tools supports the ADSP-218xN series. The DSP tools include an integrated development environment, an evaluation kit, and a serial port emulator. VisualDSP++<sup>TM</sup> is an integrated development environment, allowing for fast and easy development, debug, and deployment. The VisualDSP++ project management environment lets programmers develop and debug an application. This environment includes an easy-to-use assembler that is based on an algebraic syntax; an archiver (librarian/library builder); a linker; a PROM-splitter utility; a cycle-accurate, instruction-level simulator; a C compiler; and a C run-time library that includes DSP and mathematical functions. Debugging both C and assembly programs with the VisualDSP++ debugger, programmers can: - View mixed C and assembly code (interleaved source and object information) - · Insert break points - Set conditional breakpoints on registers, memory, and stacks - Trace instruction execution - · Fill and dump memory - · Source level debugging The VisualDSP++ IDE lets programmers define and manage DSP software development. The dialog boxes and property pages let programmers configure and manage all of the ADSP-218xN development tools, including the syntax highlighting in the VisualDSP++ editor. This capability controls how the development tools process inputs and generate outputs. The ADSP-2189M EZ-KIT Lite™ provides developers with a cost-effective method for initial evaluation of the powerful ADSP-218xN DSP family architecture. The ADSP-2189M EZ-KIT Lite includes a stand-alone ADSP-2189M DSP board supported by an evaluation suite of VisualDSP++. With this EZ-KIT Lite, users can learn about DSP hardware and software development and evaluate potential applications of the ADSP-218xN series. The ADSP-2189M EZ-KIT Lite provides an evaluation suite of the VisualDSP++ development environment with the C compiler, assembler, and linker. The size of the DSP erxecutable that can be built using the EZ-KIT Lite tools is limited to 8K words. VisualDSP++ and EZ-KIT Lite are trademarks of Analog Devices, Inc. -2- REV. 0 The EZ-KIT Lite includes the following features: - 75 MHz ADSP-2189M - Full 16-Bit Stereo Audio I/O with AD73322 Codec - RS-232 Interface - EZ-ICE Connector for Emulator Control - · DSP Demonstration Programs - Evaluation Suite of VisualDSP++ The ADSP-218x EZ-ICE® Emulator provides an easier and more cost-effective method for engineers to develop and optimize DSP systems, shortening product development cycles for faster time-to-market. ADSP-218xN series members integrate on-chip emulation support with a 14-pin ICE-Port interface. This interface provides a simpler target board connection that requires fewer mechanical clearance considerations than other ADSP-2100 Family EZ-ICEs. ADSP-218xN series members 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 ## **Additional Information** This data sheet provides a general overview of ADSP-218xN series functionality. For additional information on the architecture and instruction set of the processor, refer to the ADSP-218x DSP Hardware Reference and the ADSP-218x DSP Instruction Set Reference. ## ARCHITECTURE OVERVIEW The ADSP-218xN series instruction set provides flexible data moves and multifunction (one or two data moves with a computation) instructions. Every instruction can be executed in a single processor cycle. The ADSP-218xN assembly language uses an algebraic syntax for ease of coding and readability. A comprehensive set of development tools supports program development. The functional block diagram is an overall block diagram of the ADSP-218xN series. The processor contains three independent computational units: the ALU, the multiplier/ accumulator (MAC), and the shifter. The computational units process 16-bit data directly and have provisions to support multiprecision computations. The ALU performs a standard set of arithmetic and logic operations; division primitives are also supported. The MAC performs single-cycle multiply, multiply/add, and multiply/subtract operations with 40 bits of accumulation. The shifter performs logical and arithmetic shifts, normalization, denormalization, and derive exponent operations. The shifter can be used to efficiently implement numeric format control, including multiword and block floating-point representations. The internal result (R) bus connects the computational units so that the output of any unit may be the input of any unit on the next cycle. A powerful program sequencer and two dedicated data address generators ensure efficient delivery of operands to these computational units. The sequencer supports conditional jumps, subroutine calls, and returns in a single cycle. With internal loop counters and loop stacks, ADSP-218xN series members execute looped code with zero overhead; no explicit jump instructions are required to maintain loops. Two data address generators (DAGs) provide addresses for simultaneous dual operand fetches (from data memory and program memory). Each DAG maintains and updates four address pointers. Whenever the pointer is used to access data (indirect addressing), it is post-modified by the value of one of four possible modify registers. A length value may be associated with each pointer to implement automatic modulo addressing for circular buffers. Five internal buses provide efficient data transfer: - Program Memory Address (PMA) Bus - Program Memory Data (PMD) Bus - · Data Memory Address (DMA) Bus - Data Memory Data (DMD) Bus - Result (R) Bus The two address buses (PMA and DMA) share a single external address bus, allowing memory to be expanded off-chip, and the two data buses (PMD and DMD) share a single external data bus. Byte memory space and I/O memory space also share the external buses. Program memory can store both instructions and data, permitting ADSP-218xN series members to fetch two operands in a single cycle, one from program memory and one from data memory. ADSP-218xN series members can fetch an operand from program memory and the next instruction in the same cycle. In lieu of the address and data bus for external memory connection, ADSP-218xN series members may be configured for 16-bit Internal DMA port (IDMA port) connection to external systems. The IDMA port is made up of 16 data/address pins and five control pins. The IDMA port provides transparent, direct access to the DSP's on-chip program and data RAM. An interface to low-cost byte-wide memory is provided by the Byte DMA port (BDMA port). The BDMA port is bidirectional and can directly address up to four megabytes of external RAM or ROM for off-chip storage of program overlays or data tables. The byte memory and I/O memory space interface supports slow memories and I/O memory-mapped peripherals with programmable wait state generation. External devices can gain control of external buses with bus request/grant signals $(\overline{BR}, \overline{BGH}, \text{ and } \overline{BG})$ . One execution mode (Go Mode) allows the ADSP-218xN to continue running from on-chip memory. Normal execution mode requires the processor to halt while buses are granted. ADSP-218xN series members can respond to eleven interrupts. There can be up to six external interrupts (one edgesensitive, two level-sensitive, and three configurable) and seven internal interrupts generated by the timer, the serial ports (SPORT), the Byte DMA port, and the power-down circuitry. There is also a master RESET signal. The two serial ports provide a complete synchronous serial interface with optional companding in hardware and a wide variety of framed or frameless data transmit and receive modes of operation. Each port can generate an internal programmable serial clock or accept an external serial clock. ADSP-218xN series members provide up to 13 generalpurpose flag pins. The data input and output pins on SPORT1 can be alternatively configured as an input flag and an output flag. In addition, eight flags are programmable as inputs or outputs, and three flags are always outputs. A programmable interval timer generates periodic interrupts. A 16-bit count register (TCOUNT) decrements every n processor cycle, where n is a scaling value stored in an 8-bit register (TSCALE). When the value of the count register reaches zero, an interrupt is generated and the count register is reloaded from a 16-bit period register (TPERIOD). ## **Serial Ports** ADSP-218xN series members incorporate two complete synchronous serial ports (SPORT0 and SPORT1) for serial communications and multiprocessor communication. Following is a brief list of the capabilities of the ADSP-218xN SPORTs. For additional information on Serial Ports, refer to the *ADSP-218x DSP Hardware Reference*. - SPORTs are bidirectional and have a separate, doublebuffered transmit and receive section. - SPORTs can use an external serial clock or generate their own serial clock internally. - SPORTs have 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. - SPORTs support serial data word lengths from 3 to 16 bits and provide optional A-law and μ-law companding, according to CCITT recommendation G.711. - SPORT receive and transmit sections can generate unique interrupts on completing a data word transfer. - SPORTs can receive and transmit an entire circular buffer of data with only one overhead cycle per data word. An interrupt is generated after a data buffer transfer. - SPORT0 has a multichannel interface to selectively receive and transmit a 24 or 32 word, time-division multiplexed, serial bitstream. - SPORT1 can be configured to have two external interrupts (IRQ0 and IRQ1) and the FI and FO signals. The internally generated serial clock may still be used in this configuration. #### PIN DESCRIPTIONS ADSP-218xN series members are available in a 100-lead LQFP package and a 144-Ball Mini-BGA 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 in Table 2, while alternate functionality is shown in *italics*. -4- REV. 0 Table 2. Common-Mode Pins | Pin Name | # of Pins | I/O | Function | |------------------------------|-----------|-----|----------------------------------------------------------------| | RESET | 1 | I | Processor Reset Input | | $\overline{\text{BR}}$ | 1 | I | Bus Request Input | | $\overline{\text{BG}}$ | 1 | О | Bus Grant Output | | BGH | 1 | О | Bus Grant Hung Output | | DMS | 1 | О | Data Memory Select Output | | PMS | 1 | О | Program Memory Select Output | | IOMS | 1 | О | Memory Select Output | | BMS | 1 | О | Byte Memory Select Output | | CMS | 1 | О | Combined Memory Select Output | | $\overline{ ext{RD}}$ | 1 | O | Memory Read Enable Output | | WR | 1 | O | Memory Write Enable Output | | ĪRQ2 | 1 | I | Edge- or Level-Sensitive Interrupt Request <sup>1</sup> | | PF7 | | I/O | Programmable I/O pin | | IRQL1 | 1 | I | Level-Sensitive Interrupt Requests <sup>1</sup> | | PF6 | | I/O | Programmable I/O Pin | | ĪRQL0 | 1 | I | Level-Sensitive Interrupt Requests <sup>1</sup> | | <i>PF5</i> | | I/O | Programmable I/O Pin | | <u>IRQE</u> | 1 | I | Edge-Sensitive Interrupt Requests <sup>1</sup> | | PF4 | | I/O | Programmable I/O Pin | | Mode D | 1 | I | Mode Select Input—Checked Only During RESET | | PF3 | | I/O | Programmable I/O Pin During Normal Operation | | Mode C | 1 | I | Mode Select Input—Checked Only During RESET | | PF2 | | I/O | Programmable I/O Pin During Normal Operation | | Mode B | 1 | I | Mode Select Input—Checked Only During RESET | | PF1 | | I/O | Programmable I/O Pin During Normal Operation | | Mode A | 1 | I | Mode Select Input—Checked Only During RESET | | PF0 | | I/O | Programmable I/O Pin During Normal Operation | | CLKIN | 1 | I | Clock Input | | XTAL | 1 | 0 | Quartz Crystal Output | | CLKOUT | 1 | О | Processor Clock Output | | SPORT0 | 5 | I/O | Serial Port I/O Pins | | SPORT1 | 5 | I/O | Serial Port I/O Pins | | $\overline{IRQ1}-0$ , FI, FO | | | Edge- or Level-Sensitive Interrupts, FI, FO <sup>2</sup> | | PWD | 1 | I | Power-Down Control Input | | PWDACK | 1 | О | Power-Down Acknowledge Control Output | | FL0, FL1, FL2 | 3 | O | Output Flags | | $V_{ m DDINT}$ | 2 | I | Internal V <sub>DD</sub> (1.8 V) Power (LQFP) | | V <sub>DDEXT</sub> | 4 | I | External $V_{DD}$ (1.8 V, 2.5 V, or 3.3 V) Power (LQFP) | | GND | 10 | I | Ground (LQFP) | | $ m V_{DDINT}$ | 4 | I | Internal V <sub>DD</sub> (1.8 V) Power (Mini-BGA) | | $V_{ m DDEXT}$ | 7 | I | External V <sub>DD</sub> (1.8 V, 2.5 V, or 3.3 V) Power (Mini- | | GND | 20 | I | BGA) Ground (Mini-BGA) | | EZ-Port | 9 | I/O | For Emulation Use | | 12Z-1 011 | 7 | 1/0 | Tor Emulation Osc | $<sup>^{1}</sup>Interrupt/Flag\ pins\ retain\ both\ functions\ concurrently.\ If\ IMASK\ is\ set\ to\ enable\ the\ corresponding\ interrupts,\ the\ DSP\ 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 DSP System Control Register. Software configurable. REV. 0 -5- ## **Memory Interface Pins** ADSP-218xN series members can be used in one of two modes: Full Memory Mode, which allows BDMA operation with full external overlay memory and I/O capability, or Host Mode, which allows 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 processor is running. Table 3 and Table 4 list the active signals at specific pins of the DSP during either of the two operating modes (Full Memory or Host). A signal in one table shares a pin with a signal from the other table, with the active signal determined by the mode that is set. For the shared pins and their alternate signals (e.g., A4/IAD3), refer to the package pinouts in Table 27 on page 40 and Table 28 on page 42. Table 3. Full Memory Mode Pins (Mode C = 0) | Pin Name | # of Pins | I/O | Function | |----------|-----------|-----|--------------------------------------------------------------------------------------------------------| | A13-0 | 14 | О | Address Output Pins for Program, Data, Byte, and I/O Spaces | | D23-0 | 24 | I/O | Data I/O Pins for Program, Data, Byte, and I/O Spaces (8 MSBs are also used as Byte Memory Addresses.) | Table 4. Host Mode Pins (Mode C = 1) | Pin Name | # of Pins | I/O | Function | | |------------|-----------|-----|--------------------------------------------------------------------------|--| | IAD15-0 | 16 | I/O | IDMA Port Address/Data Bus | | | A0 | 1 | О | Address Pin for External I/O, Program, Data, or Byte Access <sup>1</sup> | | | D23-8 | 16 | I/O | Data I/O Pins for Program, Data, Byte, and I/O Spaces | | | <b>IWR</b> | 1 | I | IDMA Write Enable | | | ĪRD | 1 | I | IDMA Read Enable | | | IAL | 1 | I | IDMA Address Latch Pin | | | ĪS | 1 | I | IDMA Select | | | IACK | 1 | O | IDMA Port Acknowledge Configurable in Mode D; Open Drain | | <sup>&</sup>lt;sup>1</sup>In Host Mode, external peripheral addresses can be decoded using the A0, $\overline{\text{CMS}}$ , $\overline{\text{PMS}}$ , $\overline{\text{DMS}}$ , and $\overline{\text{IOMS}}$ signals. ## **Terminating Unused Pins** Table 5 shows the recommendations for terminating unused pins. Table 5. Unused Pin Terminations | Pin Name <sup>1</sup> | I/O<br>3-State<br>(Z) <sup>2</sup> | Reset<br>State | Hi-Z <sup>3</sup> Caused By | Unused Configuration | |------------------------|------------------------------------|----------------|---------------------------------|----------------------| | XTAL | 0 | О | | Float | | CLKOUT | O | O | | Float <sup>4</sup> | | A13-1 or | O (Z) | Hi-Z | $\overline{BR}, \overline{EBR}$ | Float | | IAD12-0 | I/O (Z) | Hi-Z | ĪS | Float | | A0 | O (Z) | Hi-Z | $\overline{BR}, \overline{EBR}$ | Float | | D23-8 | I/O (Z) | Hi-Z | $\overline{BR}, \overline{EBR}$ | Float | | D7 or | I/O (Z) | Hi-Z | $\overline{BR}, \overline{EBR}$ | Float | | ĪWR | I | I | | High (Inactive) | | D6 or | I/O (Z) | Hi-Z | $\overline{BR}, \overline{EBR}$ | Float | | $\overline{ ext{IRD}}$ | I | I | $\overline{BR}, \overline{EBR}$ | High (Inactive) | | D5 or | I/O (Z) | Hi-Z | | Float | | IAL | I | I | | Low (Inactive) | | D4 or | I/O (Z) | Hi-Z | $\overline{BR}, \overline{EBR}$ | Float | | ĪS | I | I | | High (Inactive) | Table 5. Unused Pin Terminations (Continued) | | I/O | | | | |---------------------------|------------------|-------|---------------------------------|--------------------------------------------------------------------------------| | 1 | 3-State | Reset | 2 | | | Pin Name <sup>1</sup> | $(\mathbf{Z})^2$ | State | Hi-Z <sup>3</sup> Caused By | Unused Configuration | | D3 or | I/O (Z) | Hi-Z | $\overline{BR}, \overline{EBR}$ | Float | | IACK | | | | Float | | D2-0 or | I/O (Z) | Hi-Z | $\overline{BR}, \overline{EBR}$ | Float | | IAD15-13 | I/O (Z) | Hi-Z | ĪS | Float | | PMS | O (Z) | O | $\overline{BR}, \overline{EBR}$ | Float | | $\overline{\mathrm{DMS}}$ | O (Z) | O | $\overline{BR}, \overline{EBR}$ | Float | | BMS | O (Z) | О | $\overline{BR}, \overline{EBR}$ | Float | | IOMS | O (Z) | О | $\overline{BR}, \overline{EBR}$ | Float | | CMS | O (Z) | О | $\overline{BR}, \overline{EBR}$ | Float | | RD | O (Z) | О | $\overline{BR}, \overline{EBR}$ | Float | | WR | O (Z) | O | $\overline{BR}, \overline{EBR}$ | Float | | BR | I | I | | High (Inactive) | | BG | O (Z) | O | EE | Float | | BGH | 0 | 0 | | Float | | IRQ2/PF7 | I/O (Z) | I | | Input = High (Inactive) or Program as | | IDOL 1/DEG | 1/0 (7) | _ | | Output, Set to 1, Let Float <sup>5</sup> | | IRQL1/PF6 | I/O (Z) | I | | Input = High (Inactive) or Program as | | TRQL0/PF5 | 1/0 (7) | т | | Output, Set to 1, Let Float <sup>5</sup> | | IRQL0/PF3 | I/O (Z) | I | | Input = High (Inactive) or Program as Output, Set to 1, Let Float <sup>5</sup> | | IRQE/PF4 | I/O (Z) | I | | Input = High (Inactive) or Program as | | | 1/0 (2) | 1 | | Output, Set to 1, Let Float <sup>5</sup> | | $\overline{ ext{PWD}}$ | I | I | | High | | SCLK0 | I/O | Ī | | Input = High or Low, Output = Float | | RFS0 | I/O | Ī | | High or Low | | DR0 | I | I | | High or Low | | TFS0 | I/O | I | | High or Low | | DT0 | 0 | О | | Float | | SCLK1 | I/O | I | | Input = High or Low, Output = Float | | RFS1/IRQ0 | I/O | I | | High or Low | | DR1/FI | I | I | | High or Low | | TFS1/ <del>IRQ1</del> | I/O | I | | High or Low | | DT1/FO | О | O | | Float | | EE | I | I | | Float | | EBR | I | I | | Float | | EBG | О | О | | Float | | <u>ERESET</u> | I | I | | Float | | EMS | O | O | | Float | | EINT | I | I | | Float | | ECLK | I | I | | Float | | ELIN | I | I | | Float | | ELOUT | O | О | | Float | $<sup>^{1}</sup>$ CLKIN, $\overline{\text{RESET}}$ , and PF3-0/Mode D-A are not included in this table because these pins must be used. REV. 0 -7- <sup>&</sup>lt;sup>2</sup>All bidirectional pins have three-stated outputs. When the pin is configured as an output, the output is Hi-Z (high impedance) when inactive. $<sup>^{3}</sup>$ Hi-Z = High Impedance. <sup>&</sup>lt;sup>4</sup>If the CLKOUT pin is not used, turn it OFF, using CLKODIS in SPORT0 autobuffer control register. <sup>&</sup>lt;sup>5</sup>If the Interrupt/Programmable Flag pins are not used, there are two options: Option 1: When these pins are configured as INPUTS at reset and function as interrupts and input flag pins, pull the pins High (inactive). Option 2: Program the unused pins as OUTPUTS, set them to 1 prior to enabling interrupts, and let pins float. ## Interrupts The interrupt controller allows the processor to respond to the eleven possible interrupts and reset with minimum overhead. ADSP-218xN series members provide four dedicated external interrupt input pins: $\overline{IRQ2}$ , $\overline{IRQL0}$ , $\overline{IRQL1}$ , and $\overline{IRQE}$ (shared with the PF7-4 pins). In addition, SPORT1 may be reconfigured for $\overline{IRQ0}$ , $\overline{IRQ1}$ , FI and FO, for a total of six external interrupts. The ADSP-218xN also supports internal interrupts from the timer, the byte DMA port, the two serial ports, software, and the power-down control circuit. The interrupt levels are internally prioritized and individually maskable (except power-down and reset). The $\overline{IRQ2}$ , $\overline{IRQ0}$ , and $\overline{IRQ1}$ input pins can be programmed to be either level- or edge-sensitive. $\overline{IRQL0}$ and $\overline{IRQL1}$ are level-sensitive and $\overline{IRQE}$ is edge-sensitive. The priorities and vector addresses of all interrupts are shown in Table 6. Table 6. Interrupt Priority and Interrupt Vector Addresses | | Interrupt Vector Address | |-------------------------|---------------------------| | Source Of Interrupt | (Hex) | | Reset (or Power-Up with | 0x0000 (Highest Priority) | | PUCR = 1) | | | Power-Down | 0x002C | | (Nonmaskable) | | | ĪRQ2 | 0x0004 | | ĪRQL1 | 0x0008 | | ĪRQL0 | 0x000C | | SPORT0 Transmit | 0x0010 | | SPORT0 Receive | 0x0014 | | ĪRQE | 0x0018 | | BDMA Interrupt | 0x001C | | SPORT1 Transmit or | 0x0020 | | ĪRQ1 | | | SPORT1 Receive or IRQ0 | 0x0024 | | Timer | 0x0028 (Lowest Priority) | Interrupt routines can either be nested with higher priority interrupts taking precedence or processed sequentially. Interrupts can be masked or unmasked with the IMASK register. Individual interrupt requests are logically ANDed with the bits in IMASK; the highest priority unmasked interrupt is then selected. The power-down interrupt is non-maskable. ADSP-218xN series members mask all interrupts for one instruction cycle following the execution of an instruction that modifies the IMASK register. This does not affect serial port autobuffering or DMA transfers. The interrupt control register, ICNTL, controls interrupt nesting and defines the $\overline{IRQ0}$ , $\overline{IRQ1}$ , and $\overline{IRQ2}$ external interrupts to be either edge- or level-sensitive. The $\overline{IRQE}$ pin is an external edge-sensitive interrupt and can be forced and cleared. The $\overline{IRQL0}$ and $\overline{IRQL1}$ pins are external level sensitive interrupts. The IFC register is a write-only register used to force and clear interrupts. On-chip stacks preserve the processor status and are automatically maintained during interrupt handling. The stacks are 12 levels deep to allow interrupt, loop, and subroutine nesting. The following instructions allow global enable or disable servicing of the interrupts (including power-down), regardless of the state of IMASK: ENA INTS; DIS INTS; Disabling the interrupts does not affect serial port autobuffering or DMA. When the processor is reset, interrupt servicing is enabled. ## LOW-POWER OPERATION ADSP-218xN series members have 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 ADSP-218xN series members have a low-power feature that lets the processor enter a very low-power dormant state through hardware or software control. Following is a brief list of power-down features. Refer to the *ADSP-218x DSP Hardware Reference*, "System Interface" chapter, for detailed information about the power-down feature. - Quick recovery from power-down. The processor begins executing instructions in as few as 200 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 200 CLKIN cycle recovery. - Support for crystal operation includes disabling the oscillator to save power (the processor automatically waits approximately 4096 CLKIN cycles for the crystal oscillator to start or stabilize), and letting the oscillator run to allow 200 CLKIN cycle start-up. - Power-down is initiated by either the power-down pin (PWD) or the software power-down force bit. Interrupt support allows an unlimited number of instructions to be executed before optionally powering down. The powerdown interrupt also can be used as a nonmaskable, edgesensitive interrupt. - Context clear/save control allows the processor to continue where it left off or start with a clean context when leaving the power-down state. –8– REV. 0 - The RESET pin also can be used to terminate powerdown. - Power-down acknowledge pin (PWDACK) indicates when the processor has entered power-down. #### Idle When the ADSP-218xN is in the Idle Mode, the processor 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 auto-buffer cycle steals still occur. #### Slow Idle The IDLE instruction is enhanced on ADSP-218xN series members to let the processor'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 processor fully functional, but operating at the slower clock rate. While it is in this state, the processor'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 processor'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, ADSP-218xN series members remain in the idle state for up to a maximum of n processor 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 processor'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 processor takes to come out of the idle state (a maximum of n processor cycles). ## **SYSTEM INTERFACE** Figure 1 shows typical basic system configurations with the ADSP-218xN series, two serial devices, a byte-wide EPROM, and optional external program and data overlay memories (mode-selectable). Programmable wait state generation allows the processor to connect easily to slow peripheral devices. ADSP-218xN series members also provide four external interrupts and two serial ports or six external interrupts and one serial port. Host Memory Mode allows access to the full external data bus, but limits addressing to a single address bit (A0). Through the use of external hardware, additional system peripherals can be added in this mode to generate and latch address signals. Figure 1. Basic System Interface ## **Clock Signals** ADSP-218xN series members can be clocked by either a crystal or a TTL-compatible clock signal. The CLKIN input cannot be halted, changed during operation, nor operated below the specified frequency during normal operation. The only exception is while the processor is in the power-down state. For additional information, refer to the *ADSP-218x DSP Hardware Reference*, for detailed information on this power-down feature. If an external clock is used, it should be a TTL-compatible signal running at half the instruction rate. The signal is connected to the processor's CLKIN input. When an external clock is used, the XTAL pin must be left unconnected. ADSP-218xN series members use an input clock with a frequency equal to half the instruction rate; a 40 MHz input clock yields a 12.5 ns processor cycle (which is equivalent to 80 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. Because ADSP-218xN series members include an on-chip oscillator circuit, an external crystal may be used. The crystal should be connected across the CLKIN and XTAL pins, with two capacitors connected as shown in Figure 2. Capacitor values are dependent on crystal type and should be specified by the crystal manufacturer. A parallel-resonant, fundamental frequency, microprocessor-grade crystal should be used. A clock output (CLKOUT) signal is generated by the processor at the processor's cycle rate. This can be enabled and disabled by the CLKODIS bit in the SPORT0 Autobuffer Control Register. Figure 2. External Crystal Connections #### RESET The RESET signal initiates a master reset of the ADSP-218xN. The RESET signal must be asserted during the power-up sequence to assure proper initialization. RESET during initial power-up must be held long enough to allow the internal clock to stabilize. If RESET is activated any time after power-up, the clock continues to run and does not require stabilization time. The power-up sequence is defined as the total time required for the crystal oscillator circuit to stabilize after a valid $V_{\rm DD}$ is applied to the processor, and for the internal phase-locked loop (PLL) to lock onto the specific crystal frequency. A minimum of 2000 CLKIN cycles ensures that the PLL has locked, but does not include the crystal oscillator start-up time. During this power-up sequence the $\overline{RESET}$ signal should be held low. On any subsequent resets, the $\overline{RESET}$ signal must meet the minimum pulse-width specification ( $t_{RSP}$ ). The RESET input contains some hysteresis; however, if an RC circuit is used to generate the RESET signal, the use of an external Schmitt trigger is recommended. The master reset sets all internal stack pointers to the empty stack condition, masks all interrupts, and clears the MSTAT register. When $\overline{RESET}$ is released, if there is no pending bus request and the chip is configured for booting, the bootloading sequence is performed. The first instruction is fetched from on-chip program memory location 0x0000 once boot loading completes. ## **POWER SUPPLIES** ADSP-218xN series members have separate power supply connections for the internal ( $V_{\rm DDINT}$ ) and external ( $V_{\rm DDEXT}$ ) power supplies. The internal supply must meet the 1.8 V requirement. The external supply can be connected to a 1.8 V, 2.5 V, or 3.3 V supply. All external supply pins must be connected to the same supply. All input and I/O pins can tolerate input voltages up to 3.6 V, regardless of the external supply voltage. This feature provides maximum flexibility in mixing 1.8 V, 2.5 V, or 3.3 V components. -10- REV. 0 ## MODES OF OPERATION The ADSP-218xN series modes of operation appear in Table 7. Table 7. 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 the byte memory space. Program execution is held off until all 32 words have been loaded. Chip is configured in Full Memory Mode. 1 | | X | 0 | 1 | 0 | No automatic boot operations occur. Program execution starts at external memory location 0. Chip is configured in Full Memory Mode. BDMA can still be used, but the processor does not automatically use or wait for these operations. | | 0 | 1 | 0 | 0 | BDMA feature is used to load the first 32 program memory words from the byte memory space. Program execution is held off until all 32 words have been loaded. Chip is configured in Host Mode. IACK has active pull-down. ( <i>Requires additional hardware</i> .) | | 0 | 1 | 0 | 1 | IDMA feature is used to load any internal memory as desired. Program execution is held off until the host writes to internal program memory location 0. Chip is configured in Host Mode. IACK has active pull-down. | | 1 | 1 | 0 | 0 | BDMA feature is used to load the first 32 program memory words from the byte memory space. Program execution is held off until all 32 words have been loaded. Chip is configured in Host Mode; IACK requires external pull-down. ( <i>Requires additional hardware</i> .) | | 1 | 1 | 0 | 1 | IDMA feature is used to load any internal memory as desired. Program execution is held off until the host writes to internal program memory location 0. Chip is configured in Host Mode. IACK requires external pull-down. <sup>1</sup> | <sup>&</sup>lt;sup>1</sup>Considered as standard operating settings. Using these configurations allows for easier design and better memory management. ## **Setting Memory Mode** Memory Mode selection for the ADSP-218xN series is made during chip reset through the use of the Mode C pin. This pin is multiplexed with the DSP's PF2 pin, so care must be taken in how the mode selection is made. The two methods for selecting the value of Mode C are active and passive. ## **Passive Configuration** Passive Configuration involves the use of a pull-up or pull-down resistor connected to the Mode C pin. To minimize power consumption, or if the PF2 pin is to be used as an output in the DSP application, a weak pull-up or pull-down resistance, on the order of 10 k $\Omega$ , can be used. This value should be sufficient to pull the pin to the desired level and still allow the pin to operate as a programmable flag output without undue strain on the processor's output driver. For minimum power consumption during power-down, reconfigure PF2 to be an input, as the pull-up or pull-down resistance will hold the pin in a known state, and will not switch. ## **Active Configuration** Active Configuration involves the use of a three-statable external driver connected to the Mode C pin. A driver's output enable should be connected to the DSP's RESET signal such that it only drives the PF2 pin when RESET is active (low). When RESET is deasserted, the driver should be three-state, thus allowing full use of the PF2 pin as either an input or output. To minimize power consumption during power-down, configure the programmable flag as an output when connected to a three-stated buffer. This ensures that the pin will be held at a constant level, and will not oscillate should the three-state driver's level hover around the logic switching point. ## **IDMA ACK Configuration** Mode D = 0 and in host mode: $\overline{IACK}$ is an active, driven signal and cannot be "wire ORed." Mode D = 1 and in host mode: $\overline{IACK}$ is an open drain and requires an external pull-down, but multiple $\overline{IACK}$ pins can be "wire ORed" together. REV. 0 –11– ## MEMORY ARCHITECTURE The ADSP-218xN series provides a variety of memory and peripheral interface options. The key functional groups are Program Memory, Data Memory, Byte Memory, and I/O. Refer to Figure 3 through Figure 8, Table 8 on page 14, and Table 9 on page 14 for PM and DM memory allocations in the ADSP-218xN series. Figure 3. ADSP-2184 Memory Architecture Figure 4. ADSP-2185 Memory Architecture Figure 5. ADSP-2186 Memory Architecture -12- REV. 0 Figure 6. ADSP-2187 Memory Architecture Figure 7. ADSP-2188 Memory Architecture Figure 8. ADSP-2189 Memory Architecture REV. 0 -13- ## **Program Memory** Program Memory (Full Memory Mode) is a 24-bit-wide space for storing both instruction opcodes and data. The ADSP-218xN series has up to 48K words of Program Memory RAM on chip, and the capability of accessing up to two 8K external memory overlay spaces, using the external data bus. 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 only 16 bits wide. Table 8. PMOVLAY Bits | Processor | PMOVLAY | Memory | A13 | A12-0 | |----------------|----------------|--------------------|----------------|---------------------------------------| | ADSP-2184N | No Internal | Not Applicable | Not Applicable | Not Applicable | | | Overlay Region | | | | | ADSP-2185N | 0 | Internal Overlay | Not Applicable | Not Applicable | | ADSP-2186N | No Internal | Not Applicable | Not Applicable | Not Applicable | | | Overlay Region | | | | | ADSP-2187N | 0, 4, 5 | Internal Overlay | Not Applicable | Not Applicable | | ADSP-2188N | 0, 4, 5, 6, 7 | Internal Overlay | Not Applicable | Not Applicable | | ADSP-2189N | 0, 4, 5 | Internal Overlay | Not Applicable | Not Applicable | | All Processors | 1 | External Overlay 1 | 0 | 13 LSBs of Address Between 0x2000 and | | | | | | 0x3FFF | | All Processors | 2 | External Overlay 2 | 1 | 13 LSBs of Address Between 0x2000 and | | | | | | 0x3FFF | ## **Data Memory** 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-218xN series has up to 56K words of Data Memory RAM on-chip. Part of this space is used by 32 memory-mapped registers. Support also exists for up to two 8K external memory overlay spaces through the external data bus. All internal accesses com- plete in one cycle. Accesses to external memory are timed using the wait states specified by the DWAIT register and the wait state mode bit. Data Memory (Host Mode) allows access to all internal memory. External overlay access is limited by a single external address line (A0). Table 9. DMOVLAY Bits | Processor | DMOVLAY | Memory | A13 | A12-0 | |----------------|---------------------|--------------------|----------------|--------------------| | ADSP-2184N | No Internal Overlay | Not Applicable | Not Applicable | Not Applicable | | | Region | | | | | ADSP-2185N | 0 | Internal Overlay | Not Applicable | Not Applicable | | ADSP-2186N | No Internal Overlay | Not Applicable | Not Applicable | Not Applicable | | | Region | | | | | ADSP-2187N | 0, 4, 5 | Internal Overlay | Not Applicable | Not Applicable | | ADSP-2188N | 0, 4, 5, 6, 7, 8 | Internal Overlay | Not Applicable | Not Applicable | | ADSP-2189N | 0, 4, 5, 6, 7 | Internal Overlay | Not Applicable | Not Applicable | | All Processors | 1 | External Overlay 1 | 0 | 13 LSBs of Address | | | | | | Between 0x0000 | | | | | | and 0x1FFF | | All Processors | 2 | External Overlay 2 | 1 | 13 LSBs of Address | | | | | | Between 0x0000 | | | | | | and 0x1FFF | -14- REV. 0 # Memory-Mapped Registers (New to the ADSP-218xM and N series) ADSP-218xN series members have three memory-mapped registers that differ from other ADSP-21xx Family DSPs. The slight modifications to these registers (Wait State Control, Programmable Flag and Composite Select Control, and System Control) provide the ADSP-218xN's wait state and $\overline{BMS}$ control features. Default bit values at reset are shown; if no value is shown, the bit is undefined at reset. Reserved bits are shown on a grey field. These bits should always be written with zeros. ## I/O Space (Full Memory Mode) ADSP-218xN series members support 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 as shown in Figure 9, which in combination with the wait state mode bit, specify up to 15 wait states to be automatically generated for each of four regions. The wait states act on address ranges, as shown in Table 10. **Note:** In Full Memory Mode, all 2048 locations of I/O space are directly addressable. In Host Memory Mode, only address pin A0 is available; therefore, additional logic is required externally to achieve complete addressability of the 2048 I/O space locations. Table 10. Wait States | Address Range | Wait State Register | |---------------|-----------------------------| | 0x000-0x1FF | IOWAIT0 and Wait State Mode | | | Select Bit | | 0x200-0x3FF | IOWAIT1 and Wait State Mode | | | Select Bit | | 0x400-0x5FF | IOWAIT2 and Wait State Mode | | | Select Bit | | 0x600-0x7FF | IOWAIT3 and Wait State Mode | | | Select Bit | #### WAIT STATE CONTROL Figure 9. Wait State Control Register #### Composite Memory Select ADSP-218xN series members have a programmable memory select signal that is useful for generating memory select signals for memories mapped to more than one space. The $\overline{CMS}$ signal is generated to have the same timing as each of the individual memory select signals ( $\overline{PMS}$ , $\overline{DMS}$ , $\overline{BMS}$ , $\overline{IOMS}$ ) but can combine their functionality. Each bit in the CMSSEL register, when set, causes the $\overline{CMS}$ signal to be asserted when the selected memory select is asserted. For example, to use a 32K word memory to act as both program and data memory, set the $\overline{PMS}$ and $\overline{DMS}$ bits in the CMSSEL register and use the $\overline{CMS}$ pin to drive the chip select of the memory, and use either $\overline{DMS}$ or $\overline{PMS}$ as the additional address bit. The $\overline{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{CMS}$ signal at the same time as the selected memory select signal. All enable bits default to 1 at reset, except the $\overline{BMS}$ bit. See Figure 10 and Figure 11 for illustration of the programmable flag and composite control register and the system control register. Figure 10. Programmable Flag and Composite Control Register REV. 0 –15– #### SYSTEM CONTROL 0 0 0 0 1 0 0 0 0 0 0 1 DM(0X3FFF) RESERVED RESERVED. AL WAYS PWAIT PROGRAM MEMORY SET TO 0 WAIT STATES SPORTO ENABLE 0 = DISABLE DISABLE BMS 1 = ENABLE = ENABLE BMS = DISABLE BMS SPORT1 ENABLE 0 = DISABLE 1 = ENABLE SPORT1 CONFIGURE 0 = FI, FO, IRQ0, IRQ1, SCLK 1 = SPORT1 NOTE: RESERVED BITS ARE SHOWN ON A GRAY FIELD. THESE BITS SHOULD ALWAYS BE WRITTEN WITH ZEROS. Figure 11. System Control Register ## **Byte Memory Select** The ADSP-218xN's $\overline{BMS}$ disable feature combined with the $\overline{CMS}$ pin allows use of multiple memories in the byte memory space. For example, an EPROM could be attached to the $\overline{BMS}$ select, and a flash memory could be connected to $\overline{CMS}$ . Because at reset $\overline{BMS}$ is enabled, the EPROM would be used for booting. After booting, software could disable $\overline{BMS}$ and set the $\overline{CMS}$ signal to respond to $\overline{BMS}$ , enabling the flash memory. ## **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 $16K \times 8$ bits. The byte memory space on the ADSP-218xN series 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 meg × 8 (32 megabit) ROM or RAM to be used without glue logic. All byte memory accesses are timed by the BMWAIT register and the wait state mode bit. ## Byte Memory DMA (BDMA, Full Memory Mode) The byte memory DMA controller (Figure 12) allows loading and storing of program instructions and data using the byte memory space. The BDMA circuit is able to access the byte memory space while the processor is operating normally and steals only one DSP cycle per 8-, 16-, or 24-bit word transferred. Figure 12. BDMA Control Register 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 11 shows the data formats supported by the BDMA circuit. Table 11. Data Formats | ВТҮРЕ | Internal<br>Memory Space | Word Size | Alignment | |-------|--------------------------|-----------|-----------| | 00 | Program | 24 | Full Word | | | Memory | | | | 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 0s. 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 DSP 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 -16- REV. 0 DSP cycle. DSP 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. Set these bits as indicated in. **Note**: BDMA cannot access external overlay memory regions 1 and 2. The BMWAIT field, which has four bits on ADSP-218xN series members, allows selection up to 15 wait states for BDMA transfers. # Internal Memory DMA Port (IDMA Port; Host Memory Mode) The IDMA Port provides an efficient means of communication between a host system and ADSP-218xN series members. The port is used to access the on-chip program memory and data memory of the DSP with only one DSP cycle per word overhead. The IDMA port cannot, however, be used to write to the DSP's memory-mapped control registers. A typical IDMA transfer process is shown as follows: - 1. Host starts IDMA transfer. - 2. Host checks $\overline{IACK}$ control line to see if the DSP is busy. - 3. Host uses $\overline{\text{IS}}$ and IAL control lines to latch either the DMA starting address (IDMAA) or the PM/DM OVLAY selection into the DSP's IDMA control registers. If Bit 15 = 1, the value of bits 7–0 represent the IDMA overlay; bits 14–8 must be set to 0. If Bit 15 = 0, the value of Bits 13–0 represent the starting address of internal memory to be accessed and Bit 14 reflects PM or DM for access. Set IDDMOVLAY and IDPMOVLAY bits in the IDMA overlay register as indicted in Table 12. - 4. Host uses $\overline{IS}$ and $\overline{IRD}$ (or $\overline{IWR}$ ) to read (or write) DSP internal memory (PM or DM). - 5. Host checks <u>IACK</u> line to see if the DSP has completed the previous IDMA operation. - 6. Host ends IDMA transfer. Table 12. IDMA/BDMA Overlay Bits | Processor | IDMA/BDMA<br>PMOVLAY | IDMA/BDMA<br>DMOVLAY | |------------|----------------------|----------------------| | ADSP-2184N | 0 | 0 | | ADSP-2185N | 0 | 0 | | ADSP-2186N | 0 | 0 | | ADSP-2187N | 0, 4, 5 | 0, 4, 5 | | ADSP-2188N | 0, 4, 5, 6, 7 | 0, 4, 5, 6, 7, 8 | | ADSP-2189N | 0, 4, 5 | 0, 4, 5, 6, 7 | 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 while the ADSP-218xN is operating at full speed. The DSP 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 IDMA address latch signal ( $\overline{\rm IS}$ ) latches this value into the IDMAA register. Once the address is stored, data can be read from, or written to, the ADSP-218xN's on-chip memory. Asserting the select line $(\overline{IS})$ and the appropriate read or write line $(\overline{IRD})$ and $\overline{IWR}$ respectively) signals the ADSP-218xN 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 DSP can also specify the starting address and data format for DMA operation. Asserting the IDMA port select ( $\overline{\text{IS}}$ ) and address latch enable (IAL) directs the ADSP-218xN to write the address onto the IAD14-0 bus into the IDMA Control Register (Figure 13). If Bit 15 is set to 0, IDMA latches the address. If Bit 15 is set to 1, IDMA latches into the OVLAY register. This register, also shown in Figure 13, is memory-mapped at address DM (0x3FE0). Note that the latched address (IDMAA) cannot be read back by the host. When Bit 14 in 0x3FE7 is set to zero, short reads use the timing shown in Figure 34 on page 37. When Bit 14 in 0x3FE7 is set to 1, timing in Figure 35 on page 38 applies for short reads in short read only mode. Set IDDMOVLAY REV. 0 –17– and IDPMOVLAY bits in the IDMA overlay register as indicated in Table 12. Refer to the ADSP-218x DSP Hardware Reference for additional details. **Note:** In full memory mode all locations of 4M-byte memory space are directly addressable. In host memory mode, only address pin A0 is available, requiring additional external logic to provide address information for the byte. Figure 13. IDMA OVLAY/Control Registers ## **Bootstrap Loading (Booting)** ADSP-218xN series members have 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 ADSP-218xN 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 on-chip 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-218xN. The only memory address bit provided by the processor is A0. #### IDMA Port Booting ADSP-218xN series members can also boot programs through its Internal DMA port. If Mode C=1, Mode B=0, and Mode A=1, the ADSP-218xN boots from the IDMA port. IDMA feature can load as much on-chip memory as desired. Program execution is held off until the host writes to on-chip program memory location 0. ## **BUS REQUEST AND BUS GRANT** ADSP-218xN series members 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{BR})$ signal. If the ADSP-218xN is not performing an external memory access, it responds to the active $\overline{BR}$ input in the following processor cycle by: - Three-stating the data and address buses and the PMS, DMS, BMS, CMS, IOMS, RD, WR output drivers, - Asserting the bus grant $(\overline{BG})$ signal, and - · Halting program execution. If Go Mode is enabled, the ADSP-218xN will not halt program execution until it encounters an instruction that requires an external memory access. If an ADSP-218xN series member is performing an external memory access when the external device asserts the $\overline{BR}$ signal, it will not three-state the memory interfaces nor assert the $\overline{BG}$ 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{BR}$ signal is released, the processor releases the $\overline{BG}$ signal, re-enables the output drivers, and continues program execution from the point at which it stopped. The bus request feature operates at all times, including when the processor is booting and when RESET is active. The $\overline{BGH}$ pin is asserted when an ADSP-218xN series member requires the external bus for a memory or BDMA access, but is stopped. The other device can release the bus by deasserting bus request. Once the bus is released, the ADSP-218xN deasserts $\overline{BG}$ and $\overline{BGH}$ and executes the external memory access. ## FLAG I/O PINS ADSP-218xN series members have 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 ADSP-218xN's clock. Bits that are programmed as outputs will read the value being output. The PF pins default to input during reset. -18- REV. 0 In addition to the programmable flags, ADSP-218xN series members have five fixed-mode flags, FI, FO, FL0, FL1, and FL2. FL0-FL2 are dedicated output flags. FI and FO are available as an alternate configuration of SPORT1. **Note:** Pins PF0, PF1, PF2, and PF3 are also used for device configuration during reset. ## INSTRUCTION SET DESCRIPTION The ADSP-218xN series assembly language instruction set has an algebraic syntax that was designed for ease of coding and readability. The assembly language, which takes full advantage of the processor's unique architecture, offers the following benefits: - The algebraic syntax eliminates the need to remember cryptic assembler mnemonics. For example, a typical arithmetic add instruction, such as AR = AX0 + AY0, resembles a simple equation. - Every instruction assembles into a single, 24-bit word that can execute in a single instruction cycle. - The syntax is a superset ADSP-2100 Family assembly language and is completely source and object code compatible with other family members. Programs may need to be relocated to utilize on-chip memory and conform to the ADSP-218xN's interrupt vector and reset vector map. - Sixteen condition codes are available. For conditional jump, call, return, or arithmetic instructions, the condition can be checked and the operation executed in the same instruction cycle. - Multifunction instructions allow parallel execution of an arithmetic instruction, with up to two fetches or one write to processor memory space, during a single instruction cycle. ## DESIGNING AN EZ-ICE-COMPATIBLE SYSTEM ADSP-218xN series members have 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. **Note:** The EZ-ICE uses the same $V_{\rm DD}$ voltage as the $V_{\rm DD}$ voltage used for $V_{\rm DDEXT}$ . Because the input pins of the ADSP-218xN series members are tolerant to input voltages up to 3.6 V, regardless of the value of $V_{\rm DDEXT}$ , the voltage setting for the EZ-ICE must not exceed 3.3 V. Issuing the chip reset command during emulation causes the DSP 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. If a passive method of maintaining mode information is being used (as discussed in Setting Memory Mode on page 11), it does not matter that the mode information is latched by an emulator reset. However, if the $\overline{RESET}$ pin is being used as a method of setting the value of the mode pins, the effects of an emulator reset must be taken into consideration. One method of ensuring that the values located on the mode pins are those desired is to construct a circuit like the one shown in Figure 14. This circuit forces the value located on the Mode A pin to logic high, regardless of whether it is latched via the RESET or ERESET pin. Figure 14. Mode A Pin/EZ-ICE Circuit The ICE-Port interface consists of the following ADSP-218xN pins: $\overline{EBR}$ , $\overline{EINT}$ , EE, $\overline{EBG}$ , ECLK, $\overline{ERESET}$ , ELIN, $\overline{EMS}$ , and ELOUT. These ADSP-218xN 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-218xN and the connector must be kept as short as possible, no longer than 3 inches. The following pins are also used by the EZ-ICE: $\overline{BR}$ , $\overline{BG}$ , $\overline{RESET}$ , and GND. The EZ-ICE uses the EE (emulator enable) signal to take control of the ADSP-218xN in the target system. This causes the processor to use its $\overline{ERESET}$ , $\overline{EBR}$ , and $\overline{EBG}$ pins instead of the $\overline{RESET}$ , $\overline{BR}$ , and $\overline{BG}$ pins. The $\overline{BG}$ output is three-stated. These signals do not need to be jumper-isolated in the system. The EZ-ICE connects to the 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 15. This connector must be added to the target board design to use the EZ-ICE. Be sure to allow enough room in the system to fit the EZ-ICE probe onto the 14-pin connector. The 14-pin, 2-row pin strip header is keyed at the Pin 7 location—Pin 7 must be removed from the header. The pins must be 0.025 inch square and at least 0.20 inch in length. REV. 0 –19– Figure 15. Target Board Connector for EZ-ICE 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 3M, McKenzie, and Samtec. #### **Target Memory Interface** For the 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 the target does not meet the worst-case chip specification for memory access parameters, the circuitry may not be able to be emulated at the desired CLKIN frequency. Depending on the severity of the specification violation, the system may be difficult to manufacture, as DSP components statistically vary in switching characteristic and timing requirements, within published limits. **Restriction:** All memory strobe signals on the ADSP-218xN ( $\overline{RD}$ , $\overline{WR}$ , $\overline{PMS}$ , $\overline{DMS}$ , $\overline{BMS}$ , $\overline{CMS}$ , and $\overline{IOMS}$ ) used in the target system must have 10 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 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 the 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 the target circuitry and the DSP on the RESET signal. - EZ-ICE emulation introduces an 8 ns propagation delay between the target circuitry and the DSP on the $\overline{BR}$ signal. - EZ-ICE emulation ignores RESET and BR, when single-stepping. - EZ-ICE emulation ignores RESET and BR when in Emulator Space (DSP halted). - EZ-ICE emulation ignores the state of target $\overline{BR}$ in certain modes. As a result, the target system may take control of the DSP's external memory bus only if bus grant ( $\overline{BG}$ ) is asserted by the EZ-ICE board's DSP. –20– REV. 0 # **SPECIFICATIONS** # RECOMMENDED OPERATING CONDITIONS | | K Grade ( | K Grade (Commercial) | | B Grade (Industrial) | | |--------------------------|-----------------|----------------------|-----------------|----------------------|------| | Parameter <sup>1</sup> | Min | Max | Min | Max | Unit | | $V_{ m DDINT}$ | 1.71 | 1.89 | 1.8 | 2.0 | V | | $ m V_{ m DDEXT}$ | 1.71 | 3.6 | 1.8 | 3.6 | V | | $ m V_{INPUT}^{\ \ 2}$ | $V_{IL} = -0.3$ | $V_{IH} = +3.6$ | $V_{IL} = -0.3$ | $V_{IH} = + 3.6$ | V | | $\mathrm{T}_{ ext{AMB}}$ | 0 | 70 | -40 | +85 | °C | <sup>&</sup>lt;sup>1</sup>Specifications subject to change without notice. ## **ELECTRICAL CHARACTERISTICS** | Parameter <sup>1</sup> | Description | Test Conditions | Min | Typ | Max | Unit | |--------------------------|--------------------------------------------|--------------------------------------------------------------------|--------------------------|-----|-----|------| | $V_{IH}$ | Hi-Level Input Voltage <sup>2, 3</sup> | @ $V_{DDEXT} = 1.71$ to 2.0 V, | 1.25 | | | V | | | | $V_{DDINT} = max$ | | | | | | | | @ $V_{DDEXT} = 2.1$ to 3.6 V, | | | | | | | | $V_{DDINT} = max$ | | | | | | $ m V_{IL}$ | Lo-Level Input Voltage <sup>2, 3</sup> | $@V_{\text{DDEXT}} \leq 2.0 \text{ V},$ | | | 0.6 | V | | | | $V_{DDINT} = min$ | | | | | | | | $@V_{\text{DDEXT}} \ge 2.0 \text{ V},$ | | | 0.7 | V | | | 2.4.5 | $V_{DDINT} = min$ | | | | | | $V_{OH}$ | Hi-Level Output Voltage <sup>2, 4, 5</sup> | @ $V_{DDEXT} = 1.71 \text{ to } 2.0 \text{ V},$ | 1.35 | | | V | | | | $I_{OH} = -0.5 \text{ mA}$ | | | | | | | | $@V_{\text{DDEXT}} = 2.1 \text{ to } 2.9 \text{ V}, I_{\text{OH}}$ | 2.0 | | | V | | | | = -0.5 mA | | | | | | | | $@V_{DDEXT} = 3.0 \text{ to } 3.6 \text{ V}, I_{OH}$ | 2.4 | | | V | | | | = -0.5 mA | 17 0.2 | | | *** | | | | $@V_{DDEXT} = 1.71 \text{ to } 3.6 \text{ V},$ | $V_{\text{DDEXT}} - 0.3$ | | | V | | <b>3</b> 7 | Lo-Level Output Voltage <sup>2, 4, 5</sup> | $I_{OH} = -100 \mu\text{A}^6$ | | | 0.4 | v | | $V_{OL}$ | Lo-Level Output Voltage | $@V_{DDEXT} = 1.71 \text{ to } 3.6 \text{ V},$ | | | 0.4 | V | | т | Hi-Level Input Current <sup>3</sup> | $I_{OL} = 2.0 \text{ mA}$ | | | 10 | | | $\mathbf{I}_{\text{IH}}$ | Hi-Level Input Current | | | | 10 | μΑ | | ${f I}_{ m IL}$ | Lo-Level Input Current <sup>3</sup> | | | | 10 | μA | | 1 <sub>IL</sub> | Lo-Level Input Current | | | | 10 | μΛ | | $I_{OZH}$ | Three-State Leakage | $0 V_{\text{IN}} = 0 V$<br>$0 V_{\text{DDEXT}} = \text{max},$ | | | 10 | μA | | OZH | Current <sup>7</sup> | $V_{IN} = 3.6 \text{ V}^8$ | | | 10 | μπ | | $I_{OZL}$ | Three-State Leakage | $@V_{DDEXT} = max,$ | | | 10 | μA | | LOZL | Current <sup>7</sup> | $V_{IN} = 0 V^8$ | | | 10 | μ. | | $I_{ m DD}$ | Supply Current (Idle) <sup>9</sup> | | | 6 | | mA | | -טט | | $t_{CK} = 12.5 \text{ ns},$ | | · | | | | | | $T_{AMB} = 25^{\circ}C$ | | | | | | $I_{ m DD}$ | Supply Current (Dynamic) <sup>10</sup> | | | 25 | | mA | | טט | | $t_{CK} = 12.5 \text{ ns}^{11},$ | | - | | | | | | $T_{AMB} = 25^{\circ}C$ | | | | | REV. 0 –21– <sup>&</sup>lt;sup>2</sup>The ADSP-218xN is 3.3 V tolerant (always accepts up to 3.6 V max $V_{IH}$ ), but voltage compliance (on outputs, $V_{OH}$ ) depends on the input $V_{DDEXT}$ , because $V_{OH}$ (max) approximately equals $V_{DDEXT}$ (max). This 3.3 V tolerance applies to bidirectional pins (D23–D0, RFS0, RFS1, SCLK0, SCLK1, TFS0, TFS1, A13–A1, PF7–PF0) and input-only pins (CLKIN, $\overline{RESET}$ , $\overline{BR}$ , DR0, DR1, $\overline{PWD}$ ). ## ELECTRICAL CHARACTERISTICS (CONTINUED) | Parameter <sup>1</sup> | Description | Test Conditions | Min Typ | Max | Unit | |------------------------|------------------------------------------------|-----------------------------------------------------------------------------|---------|-----|------| | $I_{ m DD}$ | Supply Current (Idle) <sup>9</sup> | @ $V_{DDINT} = 1.9 \text{ V},$ | 6.5 | | mA | | | | $t_{\rm CK} = 12.5 \text{ ns},$ | | | | | | 0 10 0 0 | $T_{AMB} = 25^{\circ}C$ | 2.6 | | | | $ m I_{DD}$ | Supply Current (Dynamic) <sup>10</sup> | $@V_{DDINT} = 1.9 \text{ V}, t_{CK} = 12.5 \text{ ns}^{11},$ | 26 | | mA | | | | $t_{CK} = 12.5 \text{ ns}^{-1},$<br>$T_{AMB} = 25^{\circ}\text{C}$ | | | | | T | Supply Current (Power- | | 100 | | μA | | $I_{ m DD}$ | Down) <sup>12</sup> | $T_{AMB} = 25^{\circ}C$ | 100 | | μΛ | | | , | in Lowest Power Mode | | | | | $C_{I}$ | Input Pin Capacitance <sup>3, 6</sup> | @ $V_{IN} = 1.8 \text{ V}$ , | | 8 | pF | | | | $f_{IN} = 1.0 \text{ MHz},$ | | | | | | C D' | $T_{AMB} = 25^{\circ}C$ | | 0 | - | | $C_{o}$ | Output Pin Capacitance <sup>6, 7, 12, 13</sup> | $@V_{IN} = 1.8 \text{ V}, \\ f_{IN} = 1.0 \text{ MHz},$ | | 8 | pF | | | Capacitance | $T_{\text{IN}} = 1.0 \text{ MHz},$<br>$T_{\text{AMB}} = 25^{\circ}\text{C}$ | | | | | | | AMB = 23 C | | | | <sup>&</sup>lt;sup>1</sup>Specifications subject to change without notice. ## ABSOLUTE MAXIMUM RATINGS -22- REV. 0 <sup>&</sup>lt;sup>2</sup>Bidirectional pins: D23-0, RFS0, RFS1, SCLK0, SCLK1, TFS0, TFS1, A13-1, PF7-0. <sup>&</sup>lt;sup>3</sup>Input only pins: CLKIN, RESET, BR, DR0, DR1, PWD. <sup>&</sup>lt;sup>4</sup>Output pins: BG, PMS, DMS, BMS, IOMS, CMS, RD, WR, PWDACK, A0, DT0, DT1, CLKOUT, FL2-FL0, BGH. <sup>&</sup>lt;sup>5</sup>Although specified for TTL outputs, all ADSP-218xN outputs are CMOS-compatible and will drive to V<sub>DDEXT</sub> and GND, assuming no dc loads. <sup>&</sup>lt;sup>6</sup>Guaranteed but not tested. $<sup>^{7}</sup>$ Three-statable pins: A13−A1, D23−D0, $\overline{PMS}$ , $\overline{DMS}$ , $\overline{BMS}$ , $\overline{IOMS}$ , $\overline{CMS}$ , $\overline{RD}$ , $\overline{WR}$ , DT0, DT1, SCLK0, SCLK1, TFS0, TFS1, RFS0, RFS1, PF7−PF0. $^{8}$ 0 V on $\overline{BR}$ . <sup>&</sup>lt;sup>9</sup>Idle refers to ADSP-218xN state of operation during execution of IDLE instruction. Deasserted pins are driven to either V<sub>DD</sub> or GND. $<sup>^{10}</sup>I_{\mathrm{DD}}$ 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. $<sup>^{11}\</sup>mathrm{V_{IN}}$ = 0 V and 3 V. For typical values for supply currents, refer to Power Dissipation section. <sup>&</sup>lt;sup>12</sup>See ADSP-218x DSP Hardware Reference for details. <sup>&</sup>lt;sup>13</sup>Output pin capacitance is the capacitive load for any three-stated output pin. <sup>&</sup>lt;sup>1</sup>Stresses greater than those listed above may cause permanent damage to the device. These are stress ratings only. Functional operation of the device at these or any other conditions greater than 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. <sup>&</sup>lt;sup>2</sup>Applies to Bidirectional pins (D23–0, RFS0, RFS1, SCLK0, SCLK1, TFS0, TFS1, A13–1, PF7–0) and Input only pins (CLKIN, RESET, BR, DR0, DR1, PWD). <sup>&</sup>lt;sup>3</sup>Applies to Output pins (BG, PMS, DMS, BMS, IOMS, CMS, RD, WR, PWDACK, A0, DT0, DT1, CLKOUT, FL2-0, BGH). ## **ESD SENSITIVITY** ## **CAUTION** 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-218xN 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. ## **Power Dissipation** To determine total power dissipation in a specific application, the following equation should be applied for each output: $C \times V_{\rm DD}^2 \times f$ where: C = load capacitance, f = output switching frequency. **Example:** In an application where external data memory is used and no other outputs are active, power dissipation is calculated as follows: ## Assumptions: - External data memory is accessed every cycle with 50% of the address pins switching. - External data memory writes occur every other cycle with 50% of the data pins switching. - Each address and data pin has a 10 pF total load at the pin. - Application operates at $V_{\text{DDEXT}} = 3.3 \text{ V}$ and $t_{\text{CK}} = 30 \text{ ns}$ . Total Power Dissipation = $P_{\text{INT}} + (C \times V_{\text{DDEXT}}^2 \times f)$ $P_{\text{INT}}$ = internal power dissipation from Figure 20 on page 26. $(C \times V_{\text{DDEXT}}^2 \times f)$ is calculated for each output, as in the example in Table 13. Table 13. Example Power Dissipation Calculation | Parameters | # of Pins | × C (pF) | $\times V_{\text{DDEXT}}^{2}(V)$ | × f (MHz) | PD (mW) | |------------------------------|-----------|----------|----------------------------------|-----------|---------| | Address | 7 | 10 | $3.3^{2}$ | 20.0 | 15.25 | | Data Output, WR | 9 | 10 | $3.3^2$ | 20.0 | 19.59 | | RD | 1 | 10 | $3.3^{2}$ | 20.0 | 2.18 | | CLKOUT, $\overline{\rm DMS}$ | 2 | 10 | $3.3^{2}$ | 40.0 | 8.70 | | | | | | | 45.72 | Total power dissipation for this example is $P_{INT}$ + 45.72 mW. REV. 0 –23– #### **Environmental Conditions** Table 14. Thermal Resistance | Rating Description <sup>1</sup> | Symbol | LQFP<br>(°C/W) | Mini-<br>BGA<br>(°C/W) | |------------------------------------------|--------------------|----------------|------------------------| | Thermal Resistance (Case-to-Ambient) | $\theta_{CA}$ | 48 | 63.3 | | Thermal Resistance (Junction-to-Ambient) | $ heta_{ ext{JA}}$ | 50 | 70.7 | | Thermal Resistance (Junction-to-Case) | $\theta_{ m JC}$ | 2 | 7.4 | $<sup>^{1}</sup>$ Where the Ambient Temperature Rating $(T_{AMB})$ is: #### **Test Conditions** Figure 16. Voltage Reference Levels for AC Measurements (Except Output Enable/Disable) Figure 17. Equivalent Loading for AC Measurements (Including All Fixtures) HIGH-IMPEDANCE STATE. TEST CONDITIONS CAUSE THIS VOLTAGE LEVEL TO BE APPROXIMATELY 1.5V. Figure 18. Output Enable/Disable ## 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_{\rm DIS}$ ) is the difference of $t_{\rm MEASURED}$ and $t_{\rm DECAY}$ , as shown in Figure 18. 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, $t_{DECAY}$ , is dependent on the capacitive load, $C_L$ , and the current load, $i_L$ , on the output pin. It can be approximated by the following equation: $$t_{DECAY} = \frac{C_L \times 0.5 \, V}{i_L}$$ from which $$t_{DIS} = t_{MEASURED} - t_{DECAY}$$ is calculated. If multiple pins (such as the data bus) are disabled, the measurement value is that of the last pin to stop driving. #### **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 ( $t_{\rm 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 18. If multiple pins (such as the data bus) are enabled, the measurement value is that of the first pin to start driving. -24- REV. 0 $T_{AMB} = T_{CASE} - (PD \times \theta_{CA})$ $T_{CASE} = Case Temperature in °C$ PD = Power Dissipation in W ## TIMING SPECIFICATIONS This section contains timing information for the DSP's external signals. ## **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, parameters cannot be added up meaningfully to derive longer times. ## **Timing Notes** Switching characteristics specify how the processor changes its signals. Designers have no control over this timing—circuitry external to the processor must be designed for compatibility with these signal characteristics. Switching characteristics tell what the processor will do in a given circumstance. Switching characteristics can also be used 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. ## Frequency Dependency For Timing Specifications $t_{\rm CK}$ is defined as 0.5 $t_{\rm CKI}$ . The ADSP-218xN uses an input clock with a frequency equal to half the instruction rate. For example, a 40 MHz input clock (which is equivalent to 25 ns) yields a 12.5 ns processor cycle (equivalent to 80 MHz). $t_{\rm CK}$ values within the range of 0.5 $t_{\rm CKI}$ period should be substituted for all relevant timing parameters to obtain the specification value. Example: $t_{CKH} = 0.5 t_{CK} - 2 \text{ ns} = 0.5 (12.5 \text{ ns}) - 2 \text{ ns} = 4.25 \text{ ns}$ ## **Output Drive Currents** Figure 19 shows typical I-V characteristics for the output drivers on the ADSP-218xN series. The curves represent the current drive capability of the output drivers as a function of output voltage. Figure 21 shows the typical power-down supply current. ## Capacitive Loading Figure 22 and Figure 23 on page 26 show the capacitive loading characteristics of the ADSP-218xN. Figure 19. Typical Output Driver Characteristics for $V_{DDEXT}$ at 3.6 V, 3.3 V, 2.5 V, and 1.8 V REV. 0 –25– #### NOTES VALID FOR ALL TEMPERATURE GRADES. - <sup>1</sup> POWER REFLECTS DEVICE OPERATING WITH NO OUTPUT LOADS. - $^2$ TYPICAL POWER DISSIPATION AT 1.8V OR 1.9V $\rm V_{DDINT}$ AND 25°C, EXCEPT WHERE SPECIFIED. - <sup>3</sup> I<sub>DD</sub> 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. - $^4$ IDLE REFERS TO STATE OF OPERATION DURING EXECUTION OF IDLE INSTRUCTION. DEASSERTED PINS ARE DRIVEN TO EITHER $\rm V_{DD}$ OR GND. Figure 20. Power vs. Frequency - 1. REFLECTS ADSP-218×N OPERATION IN LOWEST POWER MODE. (SEE THE "SYSTEM INTERFACE" CHAPTER OF THE ADSP-218× DSP HARDWARE REFERENCE FOR DETAILS.) - 2. CURRENT REFLECTS DEVICE OPERATING WITH NO INPUT LOADS. Figure 21. Typical Power-Down Current Figure 22. Typical Output Rise Time vs. Load Capacitance (at Maximum Ambient Operating Temperature) Figure 23. Typical Output Valid Delay or Hold vs. Load Capacitance, $C_{\rm L}$ (at Maximum Ambient Operating Temperature) -26- REV. 0 ## Clock Signals and Reset Table 15. Clock Signals and Reset | Paramet | er | Min | Max | Unit | |-----------------|------------------------------|------------------------------------|-----|------| | Timing R | Pequirements: | | | | | $t_{\rm CKI}$ | CLKIN Period | 25 | 40 | ns | | $t_{CKIL}$ | CLKIN Width Low | 8 | | ns | | $t_{CKIH}$ | CLKIN Width High | 8 | | ns | | Switching | g Characteristics: | | | | | $t_{CKL}$ | CLKOUT Width Low | $0.5t_{CK} - 3$<br>$0.5t_{CK} - 3$ | | ns | | $t_{CKH}$ | CLKOUT Width High | $0.5t_{CK} - 3$ | | ns | | $t_{CKOH}$ | CLKIN High to CLKOUT High | 0 | 8 | ns | | Control S | ignals Timing Requirements: | | | | | $t_{RSP}$ | RESET Width Low | $5t_{CK}^{1}$ | | ns | | t <sub>MS</sub> | Mode Setup before RESET High | 7 | | ns | | $t_{MH}$ | Mode Hold after RESET High | 5 | | ns | <sup>&</sup>lt;sup>1</sup>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). Figure 24. Clock Signals and Reset REV. 0 –27– ## Interrupts and Flags Table 16. Interrupts and Flags | Paramet | er | Min | Max | Unit | |---------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|------------------------|----------| | $t_{ m IFS}$ $t_{ m IFH}$ | Requirements: IRQx, FI, or PFx Setup before CLKOUT Low <sup>1, 2, 3, 4</sup> IRQx, FI, or PFx Hold after CLKOUT High <sup>1, 2, 3, 4</sup> g Characteristics: | 0.25t <sub>CK</sub> + 10<br>0.25t <sub>CK</sub> | | ns<br>ns | | $t_{ m FOH}$ $t_{ m FOD}$ | Flag Output Hold after CLKOUT Low <sup>5</sup> Flag Output Delay from CLKOUT Low <sup>5</sup> | $0.5t_{\rm CK} - 5$ | 0.5t <sub>CK</sub> + 4 | ns<br>ns | $<sup>^{1}</sup>$ If $\overline{\text{IRQx}}$ and FI inputs meet $_{\text{IFS}}$ and $t_{\text{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-218x DSP Hardware Reference* for further information on interrupt servicing.) <sup>&</sup>lt;sup>5</sup>Flag Outputs = PFx, FL0, FL1, FL2, FO. Figure 25. Interrupts and Flags <sup>&</sup>lt;sup>2</sup>Edge-sensitive interrupts require pulsewidths greater than 10 ns; level-sensitive interrupts must be held low until serviced. $<sup>^{3}\</sup>overline{\text{IRQx}} = \overline{\text{IRQ0}}, \overline{\text{IRQ1}}, \overline{\text{IRQ2}}, \overline{\text{IRQL0}}, \overline{\text{IRQL1}}, \overline{\text{IRQLE}}.$ <sup>&</sup>lt;sup>4</sup>PFx = PF0, PF1, PF2, PF3, PF4, PF5, PF6, PF7. ## Bus Request-Bus Grant Table 17. Bus Request-Bus Grant | Parameter | r | Min | Max | Unit | |---------------------|-------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------|------------------|------| | Timing Reg | quirements: | | | | | $t_{\mathrm{BH}}$ | BR Hold after CLKOUT High <sup>1</sup> | $0.25t_{CK} + 2$ | | ns | | $t_{BS}$ | BR Setup before CLKOUT Low <sup>1</sup> | $\begin{array}{c} 0.25t_{CK} + 2 \\ 0.25t_{CK} + 8 \end{array}$ | | ns | | Switching ( | Characteristics: | | | | | $t_{SD}$ | CLKOUT High to $\overline{xMS}$ , $\overline{RD}$ , $\overline{WR}$ Disable <sup>2</sup> | | $0.25t_{CK} + 8$ | ns | | $t_{SDB}$ | $\overline{xMS}$ , $\overline{RD}$ , $\overline{WR}$ Disable to $\overline{BG}$ Low | 0 | | ns | | $t_{SE}$ | $\overline{BG}$ High to $\overline{xMS}$ , $\overline{RD}$ , $\overline{WR}$ Enable | 0 | | ns | | $t_{SEC}$ | $\overline{xMS}$ , $\overline{RD}$ , $\overline{WR}$ Enable to CLKOUT High | $0.25t_{CK} - 3$ | | ns | | $t_{\mathrm{SDBH}}$ | $\overline{xMS}$ , $\overline{RD}$ , $\overline{WR}$ Disable to $\overline{BGH}$ Low <sup>3</sup> | 0 | | ns | | $t_{SEH}$ | $\overline{\text{BGH}}$ High to $\overline{\text{xMS}}$ , $\overline{\text{RD}}$ , $\overline{\text{WR}}$ Enable <sup>3</sup> | 0 | | ns | $<sup>^{1}\</sup>overline{BR}$ is an asynchronous signal. If $\overline{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* for $\overline{BR}/BG$ cycle relationships. $2 \overline{x} \overline{MS} = \overline{PMS}$ , $\overline{DMS}$ , $\overline{CMS}$ , $\overline{IOMS}$ , $\overline{BMS}$ . $<sup>^{3}\</sup>overline{BGH}$ is asserted when the bus is granted and the processor or BDMA requires control of the bus to continue. Figure 26. Bus Request-Bus Grant REV. 0 -29- ## Memory Read Table 18. Memory Read | Parameter | r | Min | Max | Unit | |------------------|------------------------------------------------------------------------|---------------------|----------------------|------| | Timing Red | quirements: | | | | | t <sub>RDD</sub> | $\overline{\text{RD}}$ Low to Data Valid <sup>1</sup> | | $0.5t_{CK} - 5 + w$ | ns | | t <sub>AA</sub> | A13–0, $\overline{xMS}$ to Data Valid <sup>2</sup> | | $0.75t_{CK} - 6 + w$ | ns | | $t_{ m RDH}$ | Data Hold from RD High | 0 | | ns | | Switching ( | Characteristics: | | | | | t <sub>rp</sub> | RD pulsewidth | $0.5t_{CK} - 3 + w$ | | ns | | $t_{CRD}$ | CLKOUT High to RD Low | $0.25t_{CK} - 2$ | $0.25t_{CK} + 4$ | ns | | t <sub>ASR</sub> | A13–0, $\overline{\text{xMS}}$ Setup before $\overline{\text{RD}}$ Low | $0.25t_{CK} - 3$ | | ns | | $t_{RDA}$ | A13–0, $\overline{xMS}$ Hold after $\overline{RD}$ Deasserted | $0.25t_{CK} - 3$ | | ns | | $t_{RWR}$ | $\overline{RD}$ High to $\overline{RD}$ or $\overline{WR}$ Low | $0.5t_{CK} - 3$ | | ns | $$<sup>\</sup>label{eq:wait_states} \begin{split} & \overset{1}{w} = \text{wait states x t}_{\text{CK}}. \\ & \overset{2}{\text{xMS}} = \overline{\text{PMS}}, \overline{\text{DMS}}, \overline{\text{CMS}}, \overline{\text{IOMS}}, \overline{\text{BMS}}. \end{split}$$ Figure 27. Memory Read ## Memory Write Table 19. Memory Write | Paramet | er | Min | Max | Unit | |--------------------|-------------------------------------------------------------------------------------------|--------------------------------------|------------------|------| | Switching | g Characteristics: | | | | | $t_{\mathrm{DW}}$ | Data Setup before $\overline{ m WR}$ High $^1$ | $0.5t_{CK} - 4 + w$ | | ns | | $t_{ m DH}$ | Data Hold after WR High | $0.25t_{CK} - 1$ | | ns | | $t_{\mathrm{WP}}$ | WR pulsewidth | $0.5t_{CK} - 3 + w$ | | ns | | $t_{\mathrm{WDE}}$ | WR Low to Data Enabled | 0 | | ns | | $t_{ASW}$ | A13–0, $\overline{\text{xMS}}$ Setup before $\overline{\text{WR}}$ Low <sup>2</sup> | $0.25t_{CK} - 3$ | | ns | | $t_{ m DDR}$ | Data Disable before $\overline{WR}$ or $\overline{RD}$ Low | $0.25t_{CK} - 3$<br>$0.25t_{CK} - 3$ | | ns | | $t_{CWR}$ | CLKOUT High to WR Low | $0.25t_{CK} - 2$ | $0.25t_{CK} + 4$ | ns | | $t_{AW}$ | A13–0, $\overline{xMS}$ Setup before $\overline{WR}$ Deasserted | $0.75t_{CK} - 5 + w$ | | ns | | $t_{\mathrm{WRA}}$ | A13–0, $\overline{xMS}$ Hold after $\overline{WR}$ Deasserted | $0.25t_{CK} - 1$<br>$0.5t_{CK} - 3$ | | ns | | $t_{\mathrm{WWR}}$ | $\overline{\mathrm{WR}}$ High to $\overline{\mathrm{RD}}$ or $\overline{\mathrm{WR}}$ Low | $0.5t_{CK} - 3$ | | ns | $<sup>\</sup>begin{split} & 1_{\text{W}} = \text{wait states} \times \text{t}_{\text{CK}}. \\ & 2_{\overline{\text{XMS}}} = \overline{\text{PMS}}, \overline{\text{DMS}}, \overline{\text{CMS}}, \overline{\text{IOMS}}, \overline{\text{BMS}}. \end{split}$ Figure 28. Memory Write REV. 0 -31- ## Serial Ports **Table 20. Serial Ports** | Paramet | er | Min | Max | Unit | |--------------|--------------------------------------------------|--------------|------------------|------| | Timing R | equirements: | | | | | $t_{SCK}$ | SCLK Period | 30 | | ns | | $t_{SCS}$ | DR/TFS/RFS Setup before SCLK Low | 4 | | ns | | $t_{SCH}$ | DR/TFS/RFS Hold after SCLK Low | 7 | | ns | | $t_{SCP}$ | SCLKIN Width | 12 | | ns | | Switching | Characteristics: | | | | | $t_{CC}$ | CLKOUT High to SCLKOUT | $0.25t_{CK}$ | $0.25t_{CK} + 6$ | ns | | $t_{SCDE}$ | SCLK High to DT Enable | 0 | | ns | | $t_{SCDV}$ | SCLK High to DT Valid | | 12 | ns | | $t_{RH}$ | TFS/RFS <sub>OUT</sub> Hold after SCLK High | 0 | | ns | | $t_{ m RD}$ | TFS/RFS <sub>OUT</sub> Delay from SCLK High | | 12 | ns | | $t_{SCDH}$ | DT Hold after SCLK High | 0 | | ns | | $t_{ m TDE}$ | TFS (Alt) to DT Enable | 0 | | ns | | $t_{ m TDV}$ | TFS (Alt) to DT Valid | | 12 | ns | | $t_{SCDD}$ | SCLK High to DT Disable | | 12 | ns | | $t_{RDV}$ | RFS (Multichannel, Frame Delay Zero) to DT Valid | | 12 | ns | Figure 29. Serial Ports -32- REV. 0 ## IDMA Address Latch Table 21. IDMA Address Latch | Parameter | | Min | Max | Unit | |-------------------|----------------------------------------------------------------|-----|-----|------| | Timing R | equirements: | | | | | $t_{IALP}$ | Duration of Address Latch <sup>1, 2</sup> | 10 | | ns | | $t_{IASU}$ | IAD15-0 Address Setup before Address Latch End <sup>2</sup> | 5 | | ns | | $t_{IAH}$ | IAD15-0 Address Hold after Address Latch End <sup>2</sup> | 3 | | ns | | t <sub>IKA</sub> | IACK Low before Start of Address Latch <sup>2, 3</sup> | 0 | | ns | | t <sub>IALS</sub> | Start of Write or Read after Address Latch End <sup>2, 3</sup> | 3 | | ns | | t <sub>IALD</sub> | Address Latch Start after Address Latch End <sup>1, 2</sup> | 2 | | ns | <sup>&</sup>lt;sup>1</sup>Start of Address Latch = $\overline{\text{IS}}$ Low and IAL High. <sup>&</sup>lt;sup>2</sup>End of Address Latch = $\overline{\text{IS}}$ High or IAL Low. <sup>3</sup>Start of Write or Read = $\overline{\text{IS}}$ Low and $\overline{\text{IWR}}$ Low or $\overline{\text{IRD}}$ Low. Figure 30. IDMA Address Latch REV. 0 -33- IDMA Write, Short Write Cycle Table 22. IDMA Write, Short Write Cycle | Paramet | er | Min | Max | Unit | |---------------------------|-----------------------------------------------------------|-----|-----|------| | Timing Requirements: | | | | | | $t_{IKW}$ | IACK Low before Start of Write <sup>1</sup> | 0 | | ns | | $t_{IWP}$ | Duration of Write <sup>1, 2</sup> | 10 | | ns | | $t_{ m IDSU}$ | IAD15-0 Data Setup before End of Write <sup>2, 3, 4</sup> | 3 | | ns | | $t_{\mathrm{IDH}}$ | IAD15-0 Data Hold after End of Write <sup>2, 3, 4</sup> | 2 | | ns | | Switching Characteristic: | | | | | | $t_{\rm IKHW}$ | Start of Write to IACK High | | 10 | ns | <sup>&</sup>lt;sup>4</sup>If Write Pulse ends after IACK Low, use specifications t<sub>IKSU</sub>, t<sub>IKH</sub>. Figure 31. IDMA Write, Short Write Cycle Start of Write = $\overline{IS}$ Low and $\overline{IWR}$ Low. <sup>2</sup>End of Write = $\overline{IS}$ High or $\overline{IWR}$ High. <sup>3</sup>If Write Pulse ends before $\overline{IACK}$ Low, use specifications $t_{IDSU}$ , $t_{IDH}$ . ## IDMA Write, Long Write Cycle Table 23. IDMA Write, Long Write Cycle | Paramete | r | Min | Max | Unit | |----------------------------|-----------------------------------------------------------|-----------------|-----|------| | Timing Requirements: | | | | | | $t_{\rm IKW}$ | IACK Low before Start of Write <sup>1</sup> | 0 | | ns | | $t_{IKSU}$ | IAD15-0 Data Setup before End of Write <sup>2, 3, 4</sup> | $0.5t_{CK} + 5$ | | ns | | $t_{IKH}$ | IAD15-0 Data Hold after End of Write <sup>2, 3, 4</sup> | 0 | | ns | | Switching Characteristics: | | | | | | $t_{IKLW}$ | Start of Write to IACK Low <sup>4</sup> | $1.5t_{CK}$ | | ns | | $t_{\rm IKHW}$ | Start of Write to IACK High | | 10 | ns | <sup>&</sup>lt;sup>1</sup>Start of Write = $\overline{\text{IS}}$ Low and $\overline{\text{IWR}}$ Low. <sup>&</sup>lt;sup>3</sup>If Write Pulse ends after IACK Low, use specifications t<sub>IKSU</sub>, t<sub>IKH</sub>. <sup>4</sup>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. Figure 32. IDMA Write, Long Write Cycle REV. 0 -35- <sup>&</sup>lt;sup>2</sup>If Write Pulse ends before $\overline{IACK}$ Low, use specifications $t_{IDSU}$ , $t_{IDH}$ . IDMA Read, Long Read Cycle Table 24. IDMA Read, Long Read Cycle | Parameter | | Min | Max | Unit | |----------------------------|----------------------------------------------------------------------|---------------------|-----|------| | Timing Requirements: | | | | | | $t_{IKR}$ | IACK Low before Start of Read <sup>1</sup> | 0 | | ns | | $t_{IRK}$ | End of read after $\overline{IACK}$ Low <sup>2</sup> | 2 | | ns | | Switching Characteristics: | | | | | | $t_{IKHR}$ | IACK High after Start of Read <sup>1</sup> | | 10 | ns | | $t_{IKDS}$ | IAD15-0 Data Setup before IACK Low | $0.5t_{CK} - 3$ | | ns | | $t_{\rm IKDH}$ | IAD15 –0 Data Hold after End of Read <sup>2</sup> | 0 | | ns | | $t_{\mathrm{IKDD}}$ | IAD15-0 Data Disabled after End of Read <sup>2</sup> | | 10 | ns | | $t_{IRDE}$ | IAD15-0 Previous Data Enabled after Start of Read | 0 | | ns | | $t_{\mathrm{IRDV}}$ | IAD15-0 Previous Data Valid after Start of Read | | 11 | ns | | $t_{\mathrm{IRDH1}}$ | IAD15-0 Previous Data Hold after Start of Read (DM/PM1) <sup>3</sup> | $2t_{CK} - 5$ | | ns | | $t_{\rm IRDH2}$ | IAD15-0 Previous Data Hold after Start of Read (PM2) <sup>4</sup> | t <sub>CK</sub> – 5 | | ns | <sup>&</sup>lt;sup>1</sup>Start of Read = $\overline{\text{IS}}$ Low and $\overline{\text{IRD}}$ Low. <sup>&</sup>lt;sup>4</sup>Second half of PM read. Figure 33. IDMA Read, Long Read Cycle -36- REV. 0 <sup>&</sup>lt;sup>2</sup>End of Read = $\overline{\text{IS}}$ High or $\overline{\text{IRD}}$ High. <sup>&</sup>lt;sup>3</sup>DM read or first half of PM read. #### IDMA Read, Short Read Cycle Table 25. IDMA Read, Short Read Cycle | Parameter | <sub>r</sub> 1, 2 | Min | Max | Unit | |---------------------|------------------------------------------------------|-----|------------------------------------|------| | Timing Req | nuirements: | | | | | $t_{\mathrm{IKR}}$ | IACK Low before Start of Read <sup>3</sup> | 0 | | ns | | $t_{IRP1}$ | Duration of Read (DM/PM1) <sup>4</sup> | 10 | $2t_{CK}-5$ | ns | | $t_{IRP2}$ | Duration of Read (PM2) <sup>5</sup> | 10 | $2t_{\rm CK} - 5$ $t_{\rm CK} - 5$ | ns | | Switching ( | Characteristics: | | | | | t <sub>IKHR</sub> | IACK High after Start of Read <sup>3</sup> | | 10 | ns | | $t_{\rm IKDH}$ | IAD15–0 Data Hold after End of Read <sup>6</sup> | 0 | | ns | | $t_{\rm IKDD}$ | IAD15-0 Data Disabled after End of Read <sup>6</sup> | | 10 | ns | | $t_{IRDE}$ | IAD15-0 Previous Data Enabled after Start of Read | 0 | | ns | | $t_{\mathrm{IRDV}}$ | IAD15-0 Previous Data Valid after Start of Read | | 10 | ns | <sup>&</sup>lt;sup>1</sup>Short Read Only must be disabled in the IDMA overlay memory mapped register. This mode is disabled by clearing (=0) bit 14 of the IDMA overlay register, and is disabled by default upon reset. $<sup>^6</sup>$ End of Read = $\overline{\text{IS}}$ High or $\overline{\text{IRD}}$ High. Figure 34. IDMA Read, Short Read Cycle REV. 0 -37- <sup>&</sup>lt;sup>2</sup>Consider using the Short Read Only mode, instead, because Short Read mode is not applicable at high clock frequencies. $<sup>{}^{3}</sup>$ Start of Read = $\overline{\text{IS}}$ Low and $\overline{\text{IRD}}$ Low. <sup>&</sup>lt;sup>4</sup>DM Read or first half of PM Read. $<sup>^5</sup>$ Second half of PM Read. IDMA Read, Short Read Cycle in Short Read Only Mode Table 26. IDMA Read, Short Read Cycle in Short Read Only Mode | Parameter <sup>1</sup> | | Min | Max | Unit | |------------------------|---------------------------------------------------------------|-----|-----|------| | Timing Requ | urements: | | | | | $t_{IKR}$ | IACK Low before Start of Read <sup>2</sup> | 0 | | ns | | $t_{IRP}$ | Duration of Read <sup>3</sup> | 10 | | ns | | Switching C | haracteristics: | | | | | $t_{IKHR}$ | IACK High after Start of Read <sup>2</sup> | | 10 | ns | | $t_{IKDH}$ | IAD15-0 Previous Data Hold after End of Read <sup>3</sup> | 0 | | ns | | $t_{\rm IKDD}$ | IAD15-0 Previous Data Disabled after End of Read <sup>3</sup> | | 10 | ns | | $t_{ m IRDE}$ | IAD15-0 Previous Data Enabled after Start of Read | 0 | | ns | | $t_{\mathrm{IRDV}}$ | IAD15-0 Previous Data Valid after Start of Read | | 10 | ns | $<sup>^{1}</sup>Short\ Read\ Only\ is\ enabled\ by\ setting\ Bit\ 14\ of\ the\ IDMA\ overlay\ Register\ to\ 1\ (0x3FE7).\ Short\ Read\ Only\ can\ be\ enabled\ by\ the\ processor\ core\ writing$ to the register or by an external host writing to the register. Disabled by default. ${}^2$ Start of Read = $\overline{\text{IS}}$ Low and $\overline{\text{IRD}}$ Low. Previous data remains until end of read. $<sup>^{3}</sup>$ End of Read = $\overline{\text{IS}}$ High or $\overline{\text{IRD}}$ High. Figure 35. IDMA Read, Short Read Cycle in Short Read Only Mode REV. 0 -38- #### **LQFP Package Pinout** The LQFP package pinout is shown in the illustration below and in Table 27. Pin names in bold text in the table replace the plain-text-named functions when Mode C=1. A + sign separates two functions when either function can be active for either major I/O mode. Signals enclosed in brackets [] are state bits latched from the value of the pin at the deassertion of $\overline{\text{RESET}}$ . The multiplexed pins DT1/FO, TFS1/ $\overline{\text{IRQ1}}$ , RFS1/ $\overline{\text{IRQ0}}$ , and DR1/FI, are mode selectable by setting Bit 10 (SPORT1 configure) of the System Control Register. If Bit 10 = 1, these pins have serial port functionality. If Bit 10 = 0, these pins are the external interrupt and flag pins. This bit is set to 1 by default, upon reset. ### 100-LEAD LQFP PIN CONFIGURATION REV. 0 -39- Table 27. LQFP Package Pinout Table 27. LQFP Package Pinout (Continued) | <br>Pin # | Din Nama | Pin # Pin Name | | | |-----------|-----------------------------------------------|----------------|--------------------------------------|--| | | Pin Name | | BR | | | 1 | A4/IAD3 | 52<br>53 | EBG | | | 2 | A5/ <b>IAD</b> 4 | | | | | <b>;</b> | GND | 54<br>55 | BG<br>BO/IAD12 | | | Ł | A6/ <b>IAD5</b> | 55 | D0/IAD13 | | | i | A7/ <b>IAD6</b> | 56 | D1/ <b>IAD1</b> 4 | | | | A8/ <b>IAD</b> 7 | 57 | D2/ <b>IAD1</b> 5 | | | 7 | A9/ <b>IAD8</b> | 58 | D3/ <del>IACK</del> | | | } | A10/ <b>IAD9</b> | 59 | $ m V_{DDINT}$ | | | ) | A11/ <b>IAD10</b> | 60 | GN <u>D</u> | | | 0 | A12/ <b>IAD1</b> 1 | 61 | $\mathrm{D}4/\overline{\mathbf{IS}}$ | | | 1 | A13/ <b>IAD12</b> | 62 | D5/ <u>IAL</u> | | | 2 | GND | 63 | D6/IRD | | | 3 | CLKIN | 64 | D7/ <del>IWR</del> | | | 4 | XTAL | 65 | D8 | | | 5 | $ m V_{ m DDEXT}$ | 66 | GND | | | 6 | CLKOUT | 67 | $ m V_{ m DDEXT}$ | | | 7 | GND | 68 | D9 | | | 8 | $V_{ m DDINT}$ | 69 | D10 | | | 9 | WR | 70 | D11 | | | 0 | RD | 71 | GND | | | 21 | $\frac{RB}{BMS}$ | 72 | D12 | | | 22 | $\frac{\text{DMS}}{\text{DMS}}$ | 73 | D13 | | | 23 | PMS | 74 | D14 | | | 24 | IOMS | 75 | D15 | | | | CMS | 76 | D16 | | | 25 | $\frac{\text{CMS}}{\text{IRQE}} + \text{PF4}$ | 77 | D17 | | | 26 | - | 78 | D18 | | | 27 | $\overline{\text{IRQL0}} + \text{PF5}$ | 79 | D19 | | | 28 | GND | 80 | GND | | | 29 | <u>IRQL1</u> + PF6 | 81 | D20 | | | 30 | $\overline{IRQ2} + PF7$ | | D21 | | | 31 | DT0 | 82 | | | | 52 | TFS0 | 83 | D22 | | | 33 | RFS0 | 84 | D23 | | | 34 | DR0 | 85 | FL2 | | | 55 | SCLK0 | 86 | FL1 | | | 66 | $V_{ m DDEXT}$ | 87 | FL0 | | | 37 | DT1/FO | 88 | PF3 [Mode D] | | | 8 | TFS1/ <del>IRQ1</del> | 89 | PF2 [Mode C] | | | 39 | RFS1/IRQ0 | 90 | $V_{\text{DDEX}T}$ | | | 10 | DR1/FI | 91 | $\overline{ ext{PWD}}$ | | | ł1 | GND | 92 | GND | | | 12 | SCLK1 | 93 | PF1 [Mode B] | | | 13 | ERESET | 94 | PF0 [Mode A] | | | 4 | RESET | 95 | $\overline{\text{BGH}}$ | | | 5 | EMS | 96 | PWDACK | | | ł6 | EE | 97 | A0 | | | ł7 | ECLK | 98 | A1/ <b>IAD0</b> | | | 18 | ELOUT | 99 | A2/ <b>IAD1</b> | | | 19 | ELIN | 100 | A3/ <b>IAD2</b> | | | 50 | EINT | | | | | ,0 | EBR | | | | -40- REV. 0 #### Mini-BGA Package Pinout The Mini-BGA package pinout is shown in the illustration below and in Table 28. Pin names in bold text in the table replace the plain text named functions when Mode C = 1. A + sign separates two functions when either function can be active for either major I/O mode. Signals enclosed in brackets [] are state bits latched from the value of the pin at the deassertion of $\overline{RESET}$ . The multiplexed pins DT1/FO, TFS1/ $\overline{IRQ1}$ , RFS1/ $\overline{IRQ0}$ , and DR1/FI, are mode selectable by setting Bit 10 (SPORT1 configure) of the System Control Register. If Bit 10 = 1, these pins have serial port functionality. If Bit 10 = 0, these pins are the external interrupt and flag pins. This bit is set to 1 by default upon reset. ### 144-BALL MINI-BGA PACKAGE PINOUT (BOTTOM VIEW) | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | ı | |--------------------|--------------------|--------------------|---------|-----------|--------------------|-----------------|--------------------|--------------------|-------------|--------------------|--------------------|---| | GND | GND | D22 | NC | NC | NC | GND | NC | Α0 | GND | A1/IAD0 | A2/IAD1 | A | | D16 | D17 | D18 | D20 | D23 | V <sub>DDEXT</sub> | GND | NC | NC | GND | A3/IAD2 | A4/IAD3 | В | | D14 | NC | D15 | D19 | D21 | V <sub>DDEXT</sub> | PWD | A7/IAD6 | A5/IAD4 | RD | A6/IAD5 | PWDACK | С | | GND | NC | D12 | D13 | NC | PF2<br>[MODE C] | PF1<br>[MODE B] | A9/IAD8 | вдн | NC | WR | NC | D | | D10 | GND | V <sub>DDEXT</sub> | GND | GND | PF3<br>[MODE D] | FL2 | PF0<br>[MODE A] | FL0 | A8/IAD7 | V <sub>DDEXT</sub> | V <sub>DDEXT</sub> | E | | D9 | NC | D8 | D11 | D7/ĪWR | NC | NC | FL1 | A11/IAD10 | A12/IAD11 | NC | A13/IAD12 | F | | D4/ĪS | NC | NC | D5/IAL | D6/IRD | NC | NC | NC | A10/IAD9 | GND | NC | XTAL | G | | GND | NC | GND | D3/IACK | D2/IAD15 | TFS0 | DT0 | V <sub>DDINT</sub> | GND | GND | GND | CLKIN | н | | V <sub>DDINT</sub> | V <sub>DDINT</sub> | D1/IAD14 | BG | RFS1/IRQ0 | D0/IAD13 | SCLK0 | V <sub>DDEXT</sub> | V <sub>DDEXT</sub> | NC | V <sub>DDINT</sub> | CLKOUT | J | | EBG | BR | EBR | ERESET | SCLK1 | TFS1/IRQT | RFS0 | DMS | ВМЅ | NC | NC | NC | к | | EINT | ELOUT | ELIN | RESET | GND | DR0 | PMS | GND | IOMS | ĪRQLĪ + PF6 | NC | ĪRQĒ + PF4 | L | | ECLK | EE | EMS | NC | GND | DR1/FI | DT1/FO | GND | смѕ | NC | ĪRQ2 + PF7 | IRQL0 + PF5 | м | REV. 0 -41- Table 28. Mini-BGA Package Pinout Table 28. Mini-BGA Package Pinout (Continued) | | | (Continued) | | | | |--------|-------------------------|-------------|-------------------------------------------------|--|--| | Ball # | Pin Name | Ball # | Pin Name | | | | A01 | A2/IAD1 | E03 | A8/IAD7 | | | | A02 | A1/ <b>IAD0</b> | E04 | FL0 | | | | A03 | GND | E05 | PF0 [MODE A] | | | | A04 | A0 | E06 | FL2 | | | | A05 | NC | E07 | PF3 [MODE D] | | | | A06 | GND | E08 | GND | | | | A07 | NC | E09 | GND | | | | A08 | NC | E10 | $V_{ m DDEXT}$ | | | | A09 | NC | E11 | GND | | | | A10 | D22 | E12 | D10 | | | | A11 | GND | F01 | A13/ <b>IAD12</b> | | | | A12 | GND | F02 | NC | | | | B01 | A4/IAD3 | F02 | A12/ <b>IAD</b> 11 | | | | B02 | | F04 | A12/IAD11<br>A11/IAD10 | | | | | A3/IAD2 | | | | | | B03 | GND | F05 | FL1 | | | | B04 | NC | F06 | NC | | | | B05 | NC | F07 | NC | | | | B06 | GND | F08 | D7/ <del>IWR</del> | | | | B07 | $V_{ m DDEXT}$ | F09 | D11 | | | | B08 | D23 | F10 | D8 | | | | B09 | D20 | F11 | NC | | | | B10 | D18 | F12 | D9 | | | | B11 | D17 | G01 | XTAL | | | | B12 | D16 | G02 | NC | | | | C01 | PWDACK | G03 | GND | | | | C02 | A6/ <b>IAD5</b> | G04 | A10/ <b>IAD9</b> | | | | C03 | $\overline{ ext{RD}}$ | G05 | NC | | | | C04 | A5/ <b>IAD</b> 4 | G06 | NC | | | | C05 | A7/ <b>IAD6</b> | G07 | NC | | | | C06 | PWD | G08 | D6/ <b>IRD</b> | | | | C07 | $V_{ m DDEXT}$ | G09 | D5/IAL | | | | C08 | D21 | G10 | NC NC | | | | C09 | D19 | G10<br>G11 | NC NC | | | | C10 | D19<br>D15 | G12 | $\overline{\mathrm{D4}}/\overline{\mathbf{IS}}$ | | | | | | | | | | | C11 | NC<br>D14 | H01 | CLKIN | | | | C12 | D14 | H02 | GND | | | | D01 | NC | H03 | GND | | | | D02 | WR | H04 | GND | | | | D03 | NC | H05 | $ m V_{DDINT}$ | | | | D04 | $\overline{\text{BGH}}$ | H06 | DT0 | | | | D05 | A9/ <b>IAD8</b> | H07 | TFS0 | | | | D06 | PF1 [MODE B] | H08 | D2/ <u>IAD15</u> | | | | D07 | PF2 [MODE C] | H09 | D3/ <b>IACK</b> | | | | D08 | NC | H10 | GND | | | | D09 | D13 | H11 | NC | | | | D10 | D12 | H12 | GND | | | | D11 | NC | J01 | CLKOUT | | | | D12 | GND | J02 | $ m V_{DDINT}$ | | | | E01 | $V_{ m DDEXT}$ | J03 | NC | | | | E02 | | J04 | $V_{ m DDEXT}$ | | | | E02 | $V_{ m DDEXT}$ | J04<br>J05 | V <sub>DDEXT</sub> | | | -42- REV. 0 Table 28. Mini-BGA Package Pinout (Continued) | (Continued) | | |-------------|----------------------------------------| | Ball # | Pin Name | | J06 | SCLK0 | | J07 | D0/ <b>IAD13</b> | | J08 | RFS1/IRQ0 | | J09 | $\overline{\mathrm{BG}}$ | | J10 | D1/ <b>IAD14</b> | | J11 | $V_{ m DDINT}$ | | J12 | $V_{ ext{ddint}}$ | | K01 | NC | | K02 | NC | | K03 | NC | | K04 | BMS | | K05 | <del>DMS</del> | | K06 | RFS0 | | K07 | TFS1/IRQ1 | | K08 | SCLK1 | | K09 | ERESET | | K10 | EBR | | K11 | $\overline{BR}$ | | K12 | EBG | | L01 | IRQE + PF4 | | L02 | NC | | L03 | IRQL1 + PF6 | | L04 | ĪOMS | | L05 | GND | | L06 | PMS | | L07 | DR0 | | L08 | GND | | L09 | RESET | | L10 | ELIN | | L11 | ELOUT | | L12 | EINT | | M01 | $\overline{\text{IRQL0}} + \text{PF5}$ | | M02 | $\overline{\text{IRQL2}} + \text{PF7}$ | | M03 | NC | | M04 | CMS | | M05 | GND | | M06 | DT1/FO | | M07 | DR1/FI | | M08 | GND | | M09 | NC | | M10 | EMS | | M11 | EE | | M12 | ECLK | REV. 0 -43- #### **OUTLINE DIMENSIONS** Dimensions in outline dimension drawings are shown in millimeters. #### 144-BALL MINI-BGA (CA-144) ### 100-LEAD METRIC THIN PLASTIC QUAD FLATPACK (LQFP) (ST-100) - 1. DIMENSIONS IN MILLIMETERS. - 2. THE ACTUAL POSITION OF EACH LEAD IS WITHIN 0.08 OF ITS IDEAL POSITION, WHEN MEASURED IN THE LATERAL DIRECTION. - 3. CENTER DIMENSIONS ARE NOMINAL. -44- REV. 0 ### ORDERING GUIDE Table 29. Ordering Guide | Part<br>Number | Ambient<br>Temperature<br>Range | Instruction<br>Rate (MHz) | Package<br>Description | Package<br>Option | |-------------------|------------------------------------|---------------------------|------------------------|-------------------| | ADSP-2184NKST-320 | 0°C to 70°C | 80 | 100-Lead LQFP | ST-100 | | ADSP-2184NBST-320 | $-40^{\circ}$ C to $+85^{\circ}$ C | 80 | 100-Lead LQFP | ST-100 | | ADSP-2185NKST-320 | 0°C to 70°C | 80 | 100-Lead LQFP | ST-100 | | ADSP-2185NBST-320 | $-40^{\circ}$ C to $+85^{\circ}$ C | 80 | 100-Lead LQFP | ST-100 | | ADSP-2186NKST-320 | 0°C to 70°C | 80 | 100-Lead LQFP | ST-100 | | ADSP-2186NBST-320 | $-40^{\circ}$ C to $+85^{\circ}$ C | 80 | 100-Lead LQFP | ST-100 | | ADSP-2187NKST-320 | 0°C to 70°C | 80 | 100-Lead LQFP | ST-100 | | ADSP-2187NBST-320 | $-40^{\circ}$ C to $+85^{\circ}$ C | 80 | 100-Lead LQFP | ST-100 | | ADSP-2188NKST-320 | 0°C to 70°C | 80 | 100-Lead LQFP | ST-100 | | ADSP-2188NBST-320 | $-40^{\circ}$ C to $+85^{\circ}$ C | 80 | 100-Lead LQFP | ST-100 | | ADSP-2189NKST-320 | 0°C to 70°C | 80 | 100-Lead LQFP | ST-100 | | ADSP-2189NBST-320 | $-40^{\circ}$ C to $+85^{\circ}$ C | 80 | 100-Lead LQFP | ST-100 | | ADSP-2184NKCA-320 | 0°C to 70°C | 80 | 144-Ball MBGA | CA-144 | | ADSP-2184NBCA-320 | -40°C to 85°C | 80 | 144-Ball MBGA | CA-144 | | ADSP-2185NKCA-320 | 0°C to 70°C | 80 | 144-Ball MBGA | CA-144 | | ADSP-2185NBCA-320 | $-40^{\circ}$ C to $+85^{\circ}$ C | 80 | 144-Ball MBGA | CA-144 | | ADSP-2186NKCA-320 | 0°C to 70°C | 80 | 144-Ball MBGA | CA-144 | | ADSP-2186NBCA-320 | $-40^{\circ}$ C to $+85^{\circ}$ C | 80 | 144-Ball MBGA | CA-144 | | ADSP-2187NKCA-320 | 0°C to 70°C | 80 | 144-Ball MBGA | CA-144 | | ADSP-2187NBCA-320 | $-40^{\circ}$ C to $+85^{\circ}$ C | 80 | 144-Ball MBGA | CA-144 | | ADSP-2188NKCA-320 | 0°C to 70°C | 80 | 144-Ball MBGA | CA-144 | | ADSP-2188NBCA-320 | $-40^{\circ}$ C to $+85^{\circ}$ C | 80 | 144-Ball MBGA | CA-144 | | ADSP-2189NKCA-320 | 0°C to 70°C | 80 | 144-Ball MBGA | CA-144 | | ADSP-2189NBCA-320 | -40°C to +85°C | 80 | 144-Ball MBGA | CA-144 | REV. 0 -45-