Analog Devices ADSP-2184 Datasheet

a
DSP Microcomputer
ADSP-2184
FEATURES PERFORMANCE 25 ns Instruction Cycle Time 40 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 Cycle Recovery from
Power-Down Condition Low Power Dissipation in Idle Mode
INTEGRATION ADSP-2100 Family Code Compatible, with Instruction
Set Extensions 20K Bytes of On-Chip RAM, Configured as
4K Words On-Chip Program Memory RAM and
4K Words On-Chip 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
SYSTEM INTERFACE 16-Bit Internal DMA Port for High Speed Access to
On-Chip Memory (Mode Selectable) 4 MByte Byte Memory Interface for Storage of Data
Tables and Program Overlays (Made Selectable) 8-Bit DMA to Byte Memory for Transparent Program
and Data Memory Transfers (Mode Selectable) I/O Memory Interface with 2048 Locations Supports
Parallel Peripherals (Mode Selectable) Programmable Memory Strobe and Separate I/O Memory
Space Permits “Glueless” System Design
(Mode Selectable) 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
ICE-Port is a trademark of Analog Devices, Inc. All trademarks are the property of their respective holders.
FUNCTIONAL BLOCK DIAGRAM
POWER-DOWN
DATA ADDRESS
GENERATORS
DAG 2DAG 1
ARITHMETIC UNITS
ALU
MAC
ADSP-2100 BASE
ARCHITECTURE
PROGRAM
SEQUENCER
PROGRAM MEMORY ADDRESS
DATA MEMORY ADDRESS
PROGRAM MEMORY DATA
DATA MEMORY DATA
SHIFTER
CONTROL
MEMORY
4K 3 24
PROGRAM
MEMORY
SERIAL PORTS
4K 3 16
DATA
MEMORY
SPORT 1SPORT 0
PROGRAMMABLE
I/O
AND
FLAGS
TIMER
FULL MEMORY
MODE
EXTERNAL
ADDRESS
BUS
EXTERNAL
DATA
BUS
BYTE DMA
CONTROLLER
OR
EXTERNAL
DATA
BUS
INTERNAL
DMA
PORT
HOST MODE
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
GENERAL DESCRIPTION
The ADSP-2184 is a single-chip microcomputer optimized for digital signal processing (DSP) and other high speed numeric processing applications.
The ADSP-2184 combines the ADSP-2100 family base archi­tecture (three computational units, data address generators and a program sequencer) with two serial ports, a 16-bit internal DMA port, a byte DMA port, a programmable timer, Flag I/O, extensive interrupt capabilities and on-chip program and data memory.
The ADSP-2184 integrates 20K bytes of on-chip memory con­figured as 4K words (24-bit) of program RAM and 4K words (16-bit) of data RAM. Power-down circuitry is also provided to meet the low power needs of battery operated portable equip­ment. The ADSP-2184 is available in 100-lead LQFP package.
In addition, the ADSP-2184 supports instructions that include bit manipulations—bit set, bit clear, bit toggle, bit test— ALU constants, multiplication instruction (x squared), biased round­ing, result free ALU operations, I/O memory transfers, and global interrupt masking for increased flexibility.
Fabricated in a high speed, double metal, low power, CMOS process, the ADSP-2184 operates with a 25 ns instruction cycle time. Every instruction can execute in a single processor cycle.
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 which may result from its use. No license is granted by implication or otherwise under any patent or patent rights of Analog Devices.
One Technology Way, P.O. Box 9106, Norwood, MA 02062-9106, U.S.A. Tel: 781/329-4700 World Wide Web Site: http://www.analog.com Fax: 781/326-8703 © Analog Devices, Inc., 1999
ADSP-2184
SERIAL PORTS
SPORT 1SPORT 0
MEMORY
PROGRAMMABLE
I/O
AND
FLAGS
BYTE DMA
CONTROLLER
4K 3 24
PROGRAM
MEMORY
4K 3 16
DATA
MEMORY
TIMER
ADSP-2100 BASE
ARCHITECTURE
SHIFTER
MAC
ALU
ARITHMETIC UNITS
POWER-DOWN
CONTROL
PROGRAM
SEQUENCER
DAG 2DAG 1
DATA ADDRESS
GENERATORS
PROGRAM MEMORY ADDRESS
DATA MEMORY ADDRESS
PROGRAM MEMORY DATA
DATA MEMORY DATA
EXTERNAL
DATA
BUS
EXTERNAL
ADDRESS
BUS
INTERNAL
DMA
PORT
EXTERNAL
DATA
BUS
OR
FULL MEMORY
MODE
HOST MODE
The ADSP-21xx family DSPs contain a shadow bank register that is useful for single cycle context switching of the processor.
The ADSP-2184’s flexible architecture and comprehensive instruction set allow the processor to perform multiple opera­tions in parallel. In one processor cycle the ADSP-2184 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 or transmit data through the internal DMA port
• Receive or transmit data through the byte DMA port
• Decrement timer
Development System
The ADSP-2100 Family Development Software, a complete set of tools for software and hardware system development, sup­ports the ADSP-2184. The System Builder provides a high level method for defining the architecture of systems under develop­ment. The Assembler has an algebraic syntax that is easy to program and debug. The Linker combines object files into an executable file. The Simulator provides an interactive instruction­level simulation with a reconfigurable user interface to display different portions of the hardware environment. A PROM Splitter generates PROM programmer compatible files. The C Compiler, based on the Free Software Foundation’s GNU C Compiler, generates ADSP-2184 assembly source code. The source code debugger allows programs to be corrected in the C environment. The Runtime Library includes over 100 ANSI-standard mathematical and DSP-specific functions.
The EZ-KIT Lite is a hardware/software kit offering a complete development environment for the entire ADSP-21xx family: an ADSP-218x based evaluation board with PC monitor software plus Assembler, Linker, Simulator and PROM Splitter software. The ADSP-21xx EZ-KIT Lite is a low cost, easy to use hardware platform on which you can quickly get started with your DSP soft­ware design. The EZ-KIT Lite includes the following features:
• 33 MHz ADSP-2181
• Full 16-bit Stereo Audio I/O with AD1847 SoundPort Codec
• RS-232 Interface to PC with Microsoft Windows Control Software
®
• EZ-ICE
Connector for Emulator Control
®
3.1
• DSP Demo Programs
The ADSP-218x EZ-ICE Emulator aids in the hardware debug­ging of an ADSP-2184 system. The emulator consists of hard­ware, host computer resident software, and the target board connector. The ADSP-2184 integrates on-chip emulation sup­port 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. The ADSP-2184 device need not be removed from the target system when using the EZ-ICE, nor are any adapters needed. Due to the small footprint of the EZ-ICE connector, emulation can be supported in final board designs.
SoundPort and EZ-ICE are registered trademarks of Analog Devices, Inc. Windows is a registered trademark of Microsoft Corporation.
The EZ-ICE performs a full range of functions, including:
• In-target operation
• Up to 20 breakpoints
• Single-step or full-speed operation
• Registers and memory values can be examined and altered
• PC upload and download functions
• Instruction-level emulation of program booting and execution
• Complete assembly and disassembly of instructions
• C source-level debugging
See Designing An EZ-ICE-Compatible Target System in the ADSP-2100 Family EZ-Tools Manual (ADSP-2181 sections), as well as the Target Board Connector for EZ-ICE Probe section of this data sheet, for the exact specifications of the EZ-ICE target board connector.
Additional Information
This data sheet provides a general overview of ADSP-2184 functionality. For additional information on the architecture and instruction set of the processor, refer to the ADSP-2100 Family User’s Manual, Third Edition. For more information about the development tools, refer to the ADSP-2100 Family Development Tools Data Sheet.
ARCHITECTURE OVERVIEW
The ADSP-2184 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 pro­cessor cycle. The ADSP-2184 assembly language uses an alge­braic syntax for ease of coding and readability. A comprehensive set of development tools supports program development.
®
Figure 1. Block Diagram
Figure 1 is an overall block diagram of the ADSP-2184. 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 provi­sions to support multiprecision computations. The ALU per­forms 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 arith­metic shifts, normalization, denormalization and derive expo­nent operations.
The shifter can be used to efficiently implement numeric format control including multiword and block floating-point representations.
–2–
REV. 0
ADSP-2184
The internal result (R) bus connects the computational units so 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 compu­tational units. The sequencer supports conditional jumps, sub­routine calls and returns in a single cycle. With internal loop counters and loop stacks, the ADSP-2184 executes 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 pro­gram 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 pos­sible modify registers. A length value may be associated with each pointer to implement automatic modulo addressing for circular buffers.
Efficient data transfer is achieved with the use of five internal buses:
• 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, permit­ting the ADSP-2184 to fetch two operands in a single cycle, one from program memory and one from data memory. The ADSP­2184 can fetch an operand from program memory and the next instruction in the same cycle.
When configured in host mode, the ADSP-2184 has a 16-bit Internal DMA port (IDMA port) for 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 DSPs 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 (BR, BGH and BG). One execution mode (Go Mode) allows the ADSP-2184 to continue running from on-chip memory. Normal execution mode requires the processor to halt while buses are granted.
The ADSP-2184 can respond to eleven interrupts. There are up to six external interrupts (one edge-sensitive, two level-sensitive and three configurable) and seven internal interrupts generated by the timer, the serial ports (SPORTs), 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
REV. 0
–3–
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.
The ADSP-2184 provides up to 13 general-purpose 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
The ADSP-2184 incorporates two complete synchronous serial ports (SPORT0 and SPORT1) for serial communications and multiprocessor communication.
Here is a brief list of the capabilities of the ADSP-2184 SPORTs. For additional information on Serial Ports, refer to the ADSP- 2100 Family User’s Manual, Third Edition.
• SPORTs are bidirectional and have a separate, double-buff­ered 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 trans­mit 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 Flag In and Flag Out signals. The internally generated serial clock may still be used in this configuration.
PIN DESCRIPTIONS
The ADSP-2184 is available in a 100-lead LQFP package. In order to maintain maximum functionality and reduce package size and pin count, some serial port, programmable flag, inter­rupt 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 execu­tion. Flag and interrupt functionality is retained concurrently on multiplexed pins. In cases where pin functionality is re­configurable, the default state is shown in plain text; alternate functionality is shown in italics.
ADSP-2184
Common-Mode Pins
# Input/ Pin of Out­Name(s) Pins put Function
RESET 1 I Processor Reset Input BR 1 I Bus Request Input BG 1 O Bus Grant Output BGH 1 O Bus Grant Hung Output DMS 1 O Data Memory Select Output PMS 1 O Program Memory Select Output IOMS 1 O I/O Memory Select Output BMS 1 O Byte Memory Select Output CMS 1 O Combined Memory Select Output RD 1 O Memory Read Enable Output WR 1 O Memory Write Enable Output IRQ2/ 1 I Edge- or Level-Sensitive
Interrupt Request
1
PF7 I/O Programmable I/O Pin IRQL0/ 1 I Level-Sensitive Interrupt Requests
1
PF5 I/O Programmable I/O Pin IRQL1/ 1 I Level-Sensitive Interrupt Requests
1
PF6 I/O Programmable I/O Pin IRQE/ 1 I Edge-Sensitive Interrupt Requests
1
PF4 I/O Programmable I/O Pin PF3 1 I/O Programmable I/O Pin
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, XTAL 2 I Clock or Quartz Crystal Input CLKOUT 1 O Processor Clock Output SPORT0 5 I/O Serial Port I/O Pins SPORT1/ 5 I/O Serial Port I/O Pins
IRQ1:0 Edge- or Level-Sensitive Interrupts, FI, FO Flag In, Flag Out
2
PWD 1 I Power-Down Control Input PWDACK 1 O Power-Down Control Output FL0, FL1, FL2 3 O Output Flags
and GND 16 I Power and Ground
V
DD
EZ-Port 9 I/O For Emulation Use
NOTES
1
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. Soft­ware configurable.
Memory Interface Pins
The ADSP-2184 processor 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.
Full Memory Mode Pins (Mode C = 0)
# of Input/
Pin Name Pins Output Function
A13:0 14 O Address Output Pins for Pro-
gram, 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)
Host Mode Pins (Mode C = 1)
# of Input/
Pin Name Pins Output Function
IAD15:0 16 I/O IDMA Port Address/Data Bus A0 1 O Address Pin for External I/O,
Program, Data, or Byte Access
D23:8 16 I/O Data I/O Pins for Program,
Data Byte and I/O Spaces
IWR 1 I IDMA Write Enable IRD 1 I IDMA Read Enable
IAL 1 I IDMA Address Latch Pin
IS 1 I IDMA Select IACK 1 O IDMA Port Acknowledge
In Host Mode, external peripheral addresses can be decoded using the A0, BMS, CMS, PMS, DMS, and IOMS signals.
Setting Memory Mode
Memory Mode selection for the ADSP-2184 is made during chip reset through the use of the Mode C pin. This pin is multi­plexed 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 passive and active.
Passive configuration involves the use 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, on the order of
100 k, 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 will hold the pin in a known state, and will not switch.
Active configuration involves the use of a three-stateable exter­nal driver connected to the Mode C pin. A driver’s output en­able should be connected to the DSP’s RESET signal such that it only drives the PF2 pin when RESET is active (low). After RESET is deasserted, the driver should three-state, thus allow­ing full use of the PF2 pin as either an input or output.
–4–
REV. 0
ADSP-2184
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 not oscillate should the three-state driver’s level hover around the logic switching point.
Interrupts
The interrupt controller allows the processor to respond to the eleven possible interrupts and reset with minimum overhead. The ADSP-2184 provides four dedicated external interrupt input pins, IRQ2, IRQL0, IRQL1 and IRQE (shared with the PF7:4 pins). In addition, SPORT1 may be reconfigured for IRQ0, IRQ1, FLAG_IN and FLAG_OUT, for a total of six external interrupts. The ADSP-2184 also supports internal interrupts from the timer, the byte DMA port, the two serial ports, software and the power-down control circuit. The inter­rupt levels are internally prioritized and individually maskable (except power-down and RESET). The IRQ2, IRQ0 and IRQ1 input pins can be programmed to be either level- or edge-sensitive. IRQL0 and IRQL1 are level-sensitive and IRQE is edge-sensitive. The priorities and vector addresses of all interrupts are shown in Table I.
Table I. Interrupt Priority & Interrupt Vector Addresses
Source Of Interrupt Interrupt Vector Address (Hex)
Reset (or Power-Up with
PUCR = 1) 0000 (Highest Priority)
Power-Down (Nonmaskable) 002C
IRQ2 0004 IRQL1 0008 IRQL0 000C
SPORT0 Transmit 0010 SPORT0 Receive 0014 IRQE 0018 BDMA Interrupt 001C SPORT1 Transmit or IRQ1 0020 SPORT1 Receive or IRQ0 0024 Timer 0028 (Lowest Priority)
Interrupt routines can either be nested, with higher priority interrupts taking precedence, or processed sequentially. Inter­rupts 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 nonmaskable.
The ADSP-2184 masks 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 nest­ing and defines the IRQ0, IRQ1 and IRQ2 external interrupts to be either edge- or level-sensitive. The IRQE pin is an external edge-sensitive interrupt and can be forced and cleared. The IRQL0 and 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 automati­cally maintained during interrupt handling. The stacks are twelve levels deep to allow interrupt, loop and subroutine nesting.
The following instructions allow global enable or disable servic­ing of the interrupts (including power-down), regardless of the state of IMASK. Disabling the interrupts does not affect serial port autobuffering or DMA.
ENA INTS;
DIS INTS;
When the processor is reset, interrupt servicing is enabled.
LOW POWER OPERATION
The ADSP-2184 has three low power modes that significantly reduce the power dissipation when the device operates under standby conditions. These modes are:
• Power-Down
• Idle
• Slow Idle
The CLKOUT pin may also be disabled to reduce external power dissipation.
Power-Down
The ADSP-2184 processor has a low power feature that lets the processor enter a very low power dormant state through hard­ware or software control. Following is a brief list of power-down features. Refer to the ADSP-2100 Family User’s Manual, Third Edition, “System Interface” chapter, for detailed information about the power-down feature.
• Quick recovery from power-down. The processor begins executing instructions in as few as 200 CLKIN cycles.
• Support for an externally generated TTL or CMOS proces­sor 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 approxi­mately 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 power­down interrupt also can be used as a nonmaskable, edge­sensitive 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.
• The RESET pin also can be used to terminate power-down.
• Power-down acknowledge pin indicates when the processor has entered power-down.
REV. 0
–5–
ADSP-2184
1/2x CLOCK
OR
CRYSTAL
SERIAL DEVICE
SERIAL DEVICE
SCLK1 RFS1 OR IRQ0 TFS1 OR IRQ1 DT1 OR FO DR1 OR FI
SPORT1
SCLK0 RFS0 TFS0 DT0 DR0
SPORT0
A0-A21
DATA
CS
BYTE
MEMORY
I/O SPACE
(PERIPHERALS)
CS
DATA
ADDR
DATA
ADDR
2048 LOCATIONS
OVERLAY
MEMORY
TWO 8K
PM SEGMENTS
TWO 8K
DM SEGMENTS
D
23-0
A
13-0
D
23-8
A
10-0
D
15-8
D
23-16
A
13-0
14
24
FL0-2 PF3
CLKIN
XTAL
ADDR13-0
DATA23-0
BMS
IOMS
PMS DMS CMS
BR BG
BGH
PWD
ADSP-2184
1/2x CLOCK
OR
CRYSTAL
SERIAL DEVICE
SERIAL DEVICE
SYSTEM
INTERFACE
OR
mCONTROLLER
16
1
16
SCLK1 RFS1 OR IRQ0 TFS1 OR IRQ1 DT1 OR FO DR1 OR FI
SPORT1
SCLK0 RFS0 TFS0 DT0 DR0
SPORT0
IRD/D6 IWR/D7 IS/D4
IAL/D5 IACK/D3
IAD15-0
IDMA PORT
FL0-2 PF3
CLKIN
XTAL
ADDR0
DATA23-8
BMS
IOMS
PMS DMS CMS
BR
BG
BGH PWD
ADSP-2184
IRQ2/PF7 IRQE/PF4 IRQL0/PF5 IRQL1/PF6
MODE C/PF2 MODE B/PF1 MODE A/PF0
HOST MEMORY MODE
IRQ2/PF7 IRQE/PF4 IRQL0/PF5 IRQL1/PF6
MODE C/PF2 MODE B/PF1 MODE A/PF0
FULL MEMORY MODE
PWDACK
PWDACK
CS
Idle
When the ADSP-2184 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 autobuffer cycle steals still occur.
Slow Idle
The IDLE instruction is enhanced on the ADSP-2184 to let the processor’s internal clock signal be slowed, further reducing power consumption. The reduced clock frequency, a program­mable fraction of the normal clock rate, is specified by a select­able 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 proces­sor 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 in­coming interrupts. The one-cycle response time of the standard idle state is increased by n, the clock divisor. When an enabled interrupt is received, the ADSP-2184 will 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 2 shows typical basic system configurations with the ADSP-2184, 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. The ADSP-2184 also provides 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). Additional system peripherals can be added in this mode through the use of external hardware to generate and latch address signals.
–6–
Figure 2. Basic System Configuration
REV. 0
ADSP-2184
Clock Signals
The ADSP-2184 can be clocked by either a crystal or a TTL­compatible clock signal.
The CLKIN input cannot be halted, changed during operation or operated below the specified frequency during normal opera­tion. The only exception is while the processor is in the power­down state. For additional information, refer to Chapter 9, ADSP-2100 Family User’s Manual, Third Edition, 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 con­nected to the processor’s CLKIN input. When an external clock is used, the XTAL input must be left unconnected.
The ADSP-2184 uses an input clock with a frequency equal to half the instruction rate; a 20.00 MHz input clock yields a 25 ns processor cycle (which is equivalent to 40 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 the ADSP-2184 includes an on-chip oscillator circuit, an external crystal may be used. The crystal should be con­nected across the CLKIN and XTAL pins, with two capacitors connected as shown in Figure 3. Capacitor values are dependent on crystal type and should be specified by the crystal manufac­turer. A parallel-resonant, fundamental frequency, microproces­sor-grade crystal should be used.
A clock output (CLKOUT) signal is generated by the proces­sor at the processor’s cycle rate. This can be enabled and disabled by the CLKODIS bit in the SPORT0 Autobuffer Control Register.
CLKIN CLKOUT
XTAL
DSP
Figure 3. External Crystal Connections
Reset
The RESET signal initiates a master reset of the ADSP-2184. 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
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 RESET signal should be held low. On any subsequent resets, the RESET signal must meet the mini­mum pulsewidth specification, t
RSP
.
The RESET input contains some hysteresis; however, if you use an RC circuit is used to generate your RESET signal, the use of an external Schmidt 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 RESET is released, if there is no pending bus request and the chip is configured for booting, the boot-loading sequence is performed. The first instruction is fetched from on-chip program memory location 0x0000 once boot loading completes. In an EZ-ICE-compatible system RESET and ERESET have the same functionality. For complete informa­tion, see Designing an EZ-ICE-Compatible Systems section.
MEMORY ARCHITECTURE
The ADSP-2184 provides a variety of memory and peripheral interface options. The key functional groups are Program Memory, Data Memory, Byte Memory and I/O.
Program Memory (Full Memory Mode) is a 24-bit-wide space for storing both instruction opcodes and data. The ADSP-2184 has 4K words of Program Memory RAM on chip, and the capabil­ity of accessing up to two 8K external memory overlay spaces using the external data bus. Both an instruction opcode and a data value can be read from on-chip program memory in a single cycle.
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-2184 has 4K words on Data Memory RAM on chip. Support also exists for up to two 8K external memory overlay spaces through the external data bus.
Byte Memory (Full Memory Mode) provides access to an 8-bit wide memory space through the Byte DMA (BDMA) port. The Byte Memory interface provides access to 4 MBytes of memory by utilizing eight data lines as additional address lines. This gives the BDMA Port an effective 22-bit address range. On power-up, the DSP can automatically load bootstrap code from byte memory.
I/O Space (Full Memory Mode) allows access to 2048 loca­tions of 16-bit-wide data. It is intended to be used to communi­cate with parallel peripheral devices such as data converters and external registers or latches.
Program Memory
The ADSP-2184 contains 4K × 24 of on-chip program RAM.
The on-chip program memory is designed to allow up to two accesses each cycle so that all operations can complete in a single cycle. In addition, the ADSP-2184 allows the use of 8K external memory overlays.
The program memory space organization is controlled by the Mode B pin and the PMOVLAY register. Normally, the ADSP­2184 is configured with Mode B = 0 and program memory organized as shown in Figure 4.
PROGRAM MEMORY
EXTERNAL 8K
(PMOVLAY = 1 or 2,
MODE B = 0)
RESERVED
MEMORY
RANGE
4K INTERNAL
ADDRESS
0x3FFF
0x2000 0x1FFF
0x1000 0x0FFF
0x0000
Figure 4. Program Memory (Mode B = 0)
REV. 0
–7–
ADSP-2184
When PMOVLAY is set to 1 or 2, external accesses occur at addresses 0x2000 through 0x3FFF. The external address is generated as shown in Table II.
Table II.
PMOVLAY Memory A13 A12:0
0 Internal Not Applicable Not Applicable 1 External 13 LSBs of Address
Overlay 1 0 Between 0x2000
and 0x3FFF
2 External 13 LSBs of Address
Overlay 2 1 Between 0x2000
and 0x3FFF
NOTE: Addresses 0x2000 through 0x3FFF should not be accessed when PMOVLAY = 0.
This organization provides for two external 8K overlay segments using only the normal 14 address bits, which allows for simple program overlays using one of the two external segments in place of the on-chip memory. Care must be taken in using this overlay space in that the processor core (i.e., the sequencer) does not take into account the PMOVLAY register value. For example, if a loop operation is occurring on one of the external overlays and the program changes to another external overlay or internal memory, an incorrect loop operation could occur. In addition, care must be taken in interrupt service routines as the overlay registers are not automatically saved and restored on the processor mode stack.
When Mode B = 1, booting is disabled and overlay memory is disabled the 4K internal PM cannot be accessed with MODE B = 1. Figure 5 shows the memory map in this configuration.
PROGRAM MEMORY ADDRESS
0x3FFF
RESERVED
0x2000 0x1FFF
8K EXTERNAL
0x0000
Figure 5. Program Memory (Mode B = 1)
Data Memory
The ADSP-2184 has 4K 16-bit words of internal data memory. In addition, the ADSP-2184 allows the use of 8K external memory overlays. Figure 6 shows the organization of the data memory.
DATA MEMORY
32 MEMORY–
MAPPED REGISTERS
4064
RESERVED
WORDS
INTERNAL 4K WORDS
EXTERNAL 8K
(DMOVLAY = 1, 2)
ADDRESS
0x3FFF
0x3FEO
0x3FDF
0x3000
0x2FFF
0x2000 0x1FFF
0x0000
Figure 6. Data Memory
There are 4K words of memory accessible internally when the DMOVLAY register is set to 0. When DMOVLAY is set to 1 or 2, external accesses occur at addresses 0x0000 through 0x1FFF. The external address is generated as shown in Table III.
Table III.
DMOVLAY Memory A13 A12:0
0 Internal Not Applicable Not Applicable 1 External 13 LSBs of Address
Overlay 1 0 Between 0x0000
and 0x1FFF
2 External 13 LSBs of Address
Overlay 2 1 Between 0x0000
and 0x1FFF
This organization allows for two external 8K overlays using only the normal 14 address bits. All internal accesses complete in one cycle. Accesses to external memory are timed using the wait states specified by the DWAIT register.
I/O Space (Full Memory Mode)
The ADSP-2184 supports an additional external memory space called I/O space. This space is designed to support simple con­nections to peripherals or to bus interface ASIC data registers. I/O space supports 2048 locations. The lower eleven bits of the external address bus are used; the upper three bits are unde­fined. 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, that specify up to seven wait states to be automatically generated for each of four regions. The wait states act on address ranges as shown in Table IV.
Table IV.
Address Range Wait State Register
0x000–0x1FF IOWAIT0 0x200–0x3FF IOWAIT1 0x400–0x5FF IOWAIT2 0x600–0x7FF IOWAIT3
Composite Memory Select (CMS)
The ADSP-2184 has a programmable memory select signal that is useful for generating memory select signals for memories mapped to more than one space. The CMS signal is generated to have the same timing as each of the individual memory select signals (PMS, DMS, BMS, IOMS), but can combine their functionality.
Each bit in the CMSSEL register, when set, causes the CMS signal to be asserted when the selected memory select is as­serted. For example, to use a 32K word memory to act as both program and data memory, set the PMS and DMS bits in the CMSSEL register and use the CMS pin to drive the chip select of the memory and use either DMS or PMS as the additional address bit.
The CMS pin functions as the other memory select signals, with the same timing and bus request logic. A 1 in the enable bit causes the assertion of the CMS signal at the same time as the selected memory select signal. All enable bits, except the BMS bit, default to 1 at reset.
–8–
REV. 0
ADSP-2184
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 × 8.
The byte memory space on the ADSP-2184 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.
Byte Memory DMA (BDMA, Full Memory Mode)
The Byte memory DMA controller allows loading and storing of program instructions and data using the byte memory space. The BDMA circuit 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.
The BDMA circuit supports four different data formats that are selected by the BTYPE register field. The appropriate number of 8-bit accesses is done from the byte memory space to build the word size selected. Table V shows the data formats sup­ported by the BDMA circuit.
Table V.
Internal
BTYPE Memory Space Word Size Alignment
00 Program Memory 24 Full Word 01 Data Memory 16 Full Word 10 Data Memory 8 MSBs 11 Data Memory 8 LSBs
Unused bits in the 8-bit data memory formats are filled with 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. 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 gener­ated. 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, regardless of the values of Mode B, PMOVLAY or DMOVLAY.
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 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 opera­tions. 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.
Internal Memory DMA Port (IDMA Port; Host Memory Mode)
The IDMA Port provides an efficient means of communication between a host system and the ADSP-2184. 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.
The IDMA port has a 16-bit multiplexed address and data bus and supports 24-bit program memory. The IDMA port is com­pletely asynchronous and can be written to while the ADSP­2184 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 in­creases 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 (IAL) or the missing edge of the IDMA select signal (IS) latches this value into the IDMAA register.
Once the address is stored, data can then either be read from or written to the ADSP-2184’s on-chip memory. Asserting the select line (IS) and the appropriate read or write line (IRD and IWR respectively) signals the ADSP-2184 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 automati­cally incremented and another access can occur.
Through the IDMAA register, the DSP can also specify the starting address and data format for DMA operation.
REV. 0
–9–
ADSP-2184
Bootstrap Loading (Booting)
The ADSP-2184 has two mechanisms to allow automatic load­ing of the internal program memory after reset. The method for booting is controlled by the Mode A, B and C configuration bits as shown in Table VI. These four states can be compressed into two-state bits by allowing an IDMA boot with Mode C = 1. However, three bits are used to ensure future compatibility with parts containing internal program memory ROM.
BDMA Booting
When the MODE pins specify BDMA booting, the ADSP-2184 initiates a BDMA boot sequence when RESET is released.
Table VI. Boot Summary Table
MODE C MODE B MODE A Booting Method
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 config­ured in Full Memory Mode.
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 pro­cessor does not automatically use or wait for these operations.
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 config­ured in Host Mode. Additional interface hardware is required.
1 0 1 IDMA feature is used to load
any internal memory as de­sired. Program execution is held off until internal program memory location 0 is written to. Chip is configured in Host Mode.
The BDMA interface is set up during reset to the following de­faults 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 pro­gram execution to be held off until all 32 words are loaded into on-chip program memory. Execution then begins at address 0.
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 ad­dresses to boot memory must be constructed externally to the ADSP-2184. The only memory address bit provided by the processor is A0.
IDMA Port Booting
The ADSP-2184 can also boot programs through its Internal DMA port. If Mode C = 1, Mode B = 0, and Mode A = 1, the ADSP-2184 boots from the IDMA port. The IDMA feature can load as much on-chip memory as desired. Program execution is held off until on-chip program memory location 0 is written to.
Bus Request and Bus Grant
The ADSP-2184 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 (BR) signal. If the ADSP-2184 is not performing an external memory access, it responds to the active 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 (BG) signal, and
• Halting program execution.
If Go Mode is enabled, the ADSP-2184 will not halt program execution until it encounters an instruction that requires an external memory access.
If the ADSP-2184 is performing an external memory access when the external device asserts the BR signal, it will not three­state the memory interfaces or assert the 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 BR signal is released, the processor releases the BG signal, reenables 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 BGH pin is asserted when the ADSP-2184 is ready to execute an instruction but is stopped because the external bus is already granted to another device. The other device can release the bus by deasserting bus request. Once the bus is released, the ADSP-2184 deasserts BG and BGH and executes the external memory access.
Flag I/O Pins
The ADSP-2184 has eight general purpose programmable input/ output flag pins. They are controlled by two memory mapped registers. The PFTYPE register determines the direction, 1 = output and 0 = input. The PFDATA register is used to read and write the values on the pins. Data being read from a pin configured as an input is synchronized to the ADSP-2184’s clock. Bits that are programmed as outputs will read the value being output. The PF pins default to input during reset.
–10–
REV. 0
Loading...
+ 21 hidden pages