

Welcome to E-XFL.COM

#### Understanding <u>Embedded - DSP (Digital</u> <u>Signal Processors)</u>

#### Embedded - DSP (Digital Signal Processors) are specialized microprocessors designed to perform complex mathematical computations on digital signals in real-time. Unlike general-purpose processors, DSPs are optimized for high-speed numeric processing tasks, making them ideal for applications that require efficient and precise manipulation of digital data. These processors are fundamental in converting and processing signals in various forms, including audio, video, and communication signals, ensuring that data is accurately interpreted and utilized in embedded systems.

### Applications of <u>Embedded - DSP (Digital</u> <u>Signal Processors)</u>

### Details

E·XFl

| Product Status          | Obsolete                                                            |
|-------------------------|---------------------------------------------------------------------|
| Туре                    | Fixed Point                                                         |
| Interface               | SPI, SSP, UART                                                      |
| Clock Rate              | 400MHz                                                              |
| Non-Volatile Memory     | ROM (1kB)                                                           |
| On-Chip RAM             | 52kB                                                                |
| Voltage - I/O           | 3.30V                                                               |
| Voltage - Core          | 1.20V                                                               |
| Operating Temperature   | -40°C ~ 105°C (TA)                                                  |
| Mounting Type           | Surface Mount                                                       |
| Package / Case          | 160-LFBGA, CSPBGA                                                   |
| Supplier Device Package | 160-CSPBGA (12x12)                                                  |
| Purchase URL            | https://www.e-xfl.com/product-detail/analog-devices/adbf531wybcz406 |
|                         |                                                                     |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong

## **GENERAL DESCRIPTION**

The ADSP-BF531/ADSP-BF532/ADSP-BF533 processors are members of the Blackfin<sup>®</sup> family of products, incorporating the Analog Devices, Inc./Intel Micro Signal Architecture (MSA). Blackfin processors combine a dual-MAC state-of-the-art signal processing engine, the advantages of a clean, orthogonal RISClike microprocessor instruction set, and single instruction, multiple data (SIMD) multimedia capabilities into a single instruction set architecture.

The ADSP-BF531/ADSP-BF532/ADSP-BF533 processors are completely code and pin-compatible, differing only with respect to their performance and on-chip memory. Specific performance and memory configurations are shown in Table 1.

#### Table 1. Processor Comparison

| Fe                                         | atures                    | ADSP-BF531                       | ADSP-BF532                       | ADSP-BF533                       |
|--------------------------------------------|---------------------------|----------------------------------|----------------------------------|----------------------------------|
| SP                                         | ORTs                      | 2                                | 2                                | 2                                |
| UA                                         | RT                        | 1                                | 1                                | 1                                |
| SP                                         |                           | 1                                | 1                                | 1                                |
| GP                                         | Timers                    | 3                                | 3                                | 3                                |
| Wa                                         | atchdog Timers            | 1                                | 1                                | 1                                |
| RT                                         | с                         | 1                                | 1                                | 1                                |
| Parallel Peripheral Interface              |                           | 1                                | 1                                | 1                                |
| GP                                         | lOs                       | 16                               | 16                               | 16                               |
| ion                                        | L1 Instruction SRAM/Cache | 16K bytes                        | 16K bytes                        | 16K bytes                        |
| urat                                       | L1 Instruction SRAM       | 16K bytes                        | 32K bytes                        | 64K bytes                        |
| fig                                        | L1 Data SRAM/Cache        | 16K bytes                        | 32K bytes                        | 32K bytes                        |
| õ                                          | L1 Data SRAM              |                                  |                                  | 32K bytes                        |
| ory                                        | L1 Scratchpad             | 4K bytes                         | 4K bytes                         | 4K bytes                         |
| Memo                                       | L3 Boot ROM               | 1K bytes                         | 1K bytes                         | 1K bytes                         |
| Ma                                         | aximum Speed Grade        | 400 MHz                          | 400 MHz                          | 600 MHz                          |
| Package Options:<br>CSP_BGA<br>Plastic BGA |                           | 160-Ball<br>169-Ball<br>176-Lead | 160-Ball<br>169-Ball<br>176-Lead | 160-Ball<br>169-Ball<br>176-Lead |
|                                            | 11                        |                                  |                                  |                                  |

By integrating a rich set of industry-leading system peripherals and memory, Blackfin processors are the platform of choice for next generation applications that require RISC-like programmability, multimedia support, and leading-edge signal processing in one integrated package.

## PORTABLE LOW POWER ARCHITECTURE

Blackfin processors provide world-class power management and performance. Blackfin processors are designed in a low power and low voltage design methodology and feature dynamic power management—the ability to vary both the voltage and frequency of operation to significantly lower overall power consumption. Varying the voltage and frequency can result in a substantial reduction in power consumption, compared with just varying the frequency of operation. This translates into longer battery life for portable appliances.

## SYSTEM INTEGRATION

The ADSP-BF531/ADSP-BF532/ADSP-BF533 processors are highly integrated system-on-a-chip solutions for the next generation of digital communication and consumer multimedia applications. By combining industry-standard interfaces with a high performance signal processing core, users can develop cost-effective solutions quickly without the need for costly external components. The system peripherals include a UART port, an SPI port, two serial ports (SPORTs), four general-purpose timers (three with PWM capability), a real-time clock, a watchdog timer, and a parallel peripheral interface.

## **PROCESSOR PERIPHERALS**

The ADSP-BF531/ADSP-BF532/ADSP-BF533 processors contain a rich set of peripherals connected to the core via several high bandwidth buses, providing flexibility in system configuration as well as excellent overall system performance (see the functional block diagram in Figure 1 on Page 1). The generalpurpose peripherals include functions such as UART, timers with PWM (pulse-width modulation) and pulse measurement capability, general-purpose I/O pins, a real-time clock, and a watchdog timer. This set of functions satisfies a wide variety of typical system support needs and is augmented by the system expansion capabilities of the part. In addition to these generalpurpose peripherals, the processors contain high speed serial and parallel ports for interfacing to a variety of audio, video, and modem codec functions; an interrupt controller for flexible management of interrupts from the on-chip peripherals or external sources; and power management control functions to tailor the performance and power characteristics of the processor and system to many application scenarios.

All of the peripherals, except for general-purpose I/O, real-time clock, and timers, are supported by a flexible DMA structure. There is also a separate memory DMA channel dedicated to data transfers between the processor's various memory spaces, including external SDRAM and asynchronous memory. Multiple on-chip buses running at up to 133 MHz provide enough bandwidth to keep the processor core running along with activity on all of the on-chip and external peripherals.

The processors include an on-chip voltage regulator in support of the processor's dynamic power management capability. The voltage regulator provides a range of core voltage levels from  $V_{\text{DDEXT}}$ . The voltage regulator can be bypassed at the user's discretion.

## **BLACKFIN PROCESSOR CORE**

As shown in Figure 2 on Page 5, the Blackfin processor core contains two 16-bit multipliers, two 40-bit accumulators, two 40-bit ALUs, four video ALUs, and a 40-bit shifter. The computation units process 8-bit, 16-bit, or 32-bit data from the register file.

The compute register file contains eight 32-bit registers. When performing compute operations on 16-bit operand data, the register file operates as 16 independent 16-bit registers. All operands for compute operations come from the multiported register file and instruction constant fields.

Each MAC can perform a 16-bit by 16-bit multiply in each cycle, accumulating the results into the 40-bit accumulators. Signed and unsigned formats, rounding, and saturation are supported.

The ALUs perform a traditional set of arithmetic and logical operations on 16-bit or 32-bit data. In addition, many special instructions are included to accelerate various signal processing tasks. These include bit operations such as field extract and population count, modulo 2<sup>32</sup> multiply, divide primitives, saturation and rounding, and sign/exponent detection. The set of video instructions includes byte alignment and packing operations, 16-bit and 8-bit adds with clipping, 8-bit average operations, and 8-bit subtract/absolute value/accumulate (SAA) operations. Also provided are the compare/select and vector search instructions.

For certain instructions, two 16-bit ALU operations can be performed simultaneously on register pairs (a 16-bit high half and 16-bit low half of a compute register). Quad 16-bit operations are possible using the second ALU.

The 40-bit shifter can perform shifts and rotates and is used to support normalization, field extract, and field deposit instructions.

The program sequencer controls the flow of instruction execution, including instruction alignment and decoding. For program flow control, the sequencer supports PC relative and indirect conditional jumps (with static branch prediction), and subroutine calls. Hardware is provided to support zero-overhead looping. The architecture is fully interlocked, meaning that the programmer need not manage the pipeline when executing instructions with data dependencies.

The address arithmetic unit provides two addresses for simultaneous dual fetches from memory. It contains a multiported register file consisting of four sets of 32-bit index, modify, length, and base registers (for circular buffering), and eight additional 32-bit pointer registers (for C-style indexed stack manipulation).

Blackfin processors support a modified Harvard architecture in combination with a hierarchical memory structure. Level 1 (L1) memories are those that typically operate at the full processor speed with little or no latency. At the L1 level, the instruction memory holds instructions only. The two data memories hold data, and a dedicated scratchpad data memory stores stack and local variable information. In addition, multiple L1 memory blocks are provided, offering a configurable mix of SRAM and cache. The memory management unit (MMU) provides memory protection for individual tasks that may be operating on the core and can protect system registers from unintended access.

The architecture provides three modes of operation: user mode, supervisor mode, and emulation mode. User mode has restricted access to certain system resources, thus providing a protected software environment, while supervisor mode has unrestricted access to the system and core resources.

The Blackfin processor instruction set has been optimized so that 16-bit opcodes represent the most frequently used instructions, resulting in excellent compiled code density. Complex DSP instructions are encoded into 32-bit opcodes, representing fully featured multifunction instructions. Blackfin processors support a limited multi-issue capability, where a 32-bit instruction can be issued in parallel with two 16-bit instructions, allowing the programmer to use many of the core resources in a single instruction cycle.

The Blackfin processor assembly language uses an algebraic syntax for ease of coding and readability. The architecture has been optimized for use in conjunction with the C/C++ compiler, resulting in fast and efficient software implementations.

## MEMORY ARCHITECTURE

The ADSP-BF531/ADSP-BF532/ADSP-BF533 processors view memory as a single unified 4G byte address space, using 32-bit addresses. All resources, including internal memory, external memory, and I/O control registers, occupy separate sections of this common address space. The memory portions of this address space are arranged in a hierarchical structure to provide a good cost/performance balance of some very fast, low latency on-chip memory as cache or SRAM, and larger, lower cost and performance off-chip memory systems. See Figure 3, Figure 4, and Figure 5 on Page 6.

The L1 memory system is the primary highest performance memory available to the Blackfin processor. The off-chip memory system, accessed through the external bus interface unit (EBIU), provides expansion with SDRAM, flash memory, and SRAM, optionally accessing up to 132M bytes of physical memory.

The memory DMA controller provides high bandwidth datamovement capability. It can perform block transfers of code or data between the internal memory and the external memory spaces.

## Internal (On-Chip) Memory

The processors have three blocks of on-chip memory that provide high bandwidth access to the core.

The first block is the L1 instruction memory, consisting of up to 80K bytes SRAM, of which 16K bytes can be configured as a four way set-associative cache. This memory is accessed at full processor speed.

Each event type has an associated register to hold the return address and an associated return-from-event instruction. When an event is triggered, the state of the processor is saved on the supervisor stack.

The ADSP-BF531/ADSP-BF532/ADSP-BF533 processors' event controller consists of two stages, the core event controller (CEC) and the system interrupt controller (SIC). The core event controller works with the system interrupt controller to prioritize and control all system events. Conceptually, interrupts from the peripherals enter into the SIC, and are then routed directly into the general-purpose interrupts of the CEC.

### Core Event Controller (CEC)

The CEC supports nine general-purpose interrupts (IVG15–7), in addition to the dedicated interrupt and exception events. Of these general-purpose interrupts, the two lowest priority interrupts (IVG15–14) are recommended to be reserved for software interrupt handlers, leaving seven prioritized interrupt inputs to support the peripherals of the processor. Table 2 describes the inputs to the CEC, identifies their names in the event vector table (EVT), and lists their priorities.

#### Table 2. Core Event Controller (CEC)

| Priority       |                        |           |
|----------------|------------------------|-----------|
| (0 is Highest) | Event Class            | EVT Entry |
| 0              | Emulation/Test Control | EMU       |
| 1              | Reset                  | RST       |
| 2              | Nonmaskable Interrupt  | NMI       |
| 3              | Exception              | EVX       |
| 4              | Reserved               |           |
| 5              | Hardware Error         | IVHW      |
| 6              | Core Timer             | IVTMR     |
| 7              | General Interrupt 7    | IVG7      |
| 8              | General Interrupt 8    | IVG8      |
| 9              | General Interrupt 9    | IVG9      |
| 10             | General Interrupt 10   | IVG10     |
| 11             | General Interrupt 11   | IVG11     |
| 12             | General Interrupt 12   | IVG12     |
| 13             | General Interrupt 13   | IVG13     |
| 14             | General Interrupt 14   | IVG14     |
| 15             | General Interrupt 15   | IVG15     |

#### System Interrupt Controller (SIC)

The system interrupt controller provides the mapping and routing of events from the many peripheral interrupt sources to the prioritized general-purpose interrupt inputs of the CEC. Although the processors provide a default mapping, the user can alter the mappings and priorities of interrupt events by writing the appropriate values into the interrupt assignment registers (SIC\_IARx). Table 3 describes the inputs into the SIC and the default mappings into the CEC. Table 3. System Interrupt Controller (SIC)

| Peripheral Interrupt Event       | Default Mapping |
|----------------------------------|-----------------|
| PLL Wakeup                       | IVG7            |
| DMA Error                        | IVG7            |
| PPI Error                        | IVG7            |
| SPORT 0 Error                    | IVG7            |
| SPORT 1 Error                    | IVG7            |
| SPI Error                        | IVG7            |
| UART Error                       | IVG7            |
| Real-Time Clock                  | IVG8            |
| DMA Channel 0 (PPI)              | IVG8            |
| DMA Channel 1 (SPORT 0 Receive)  | IVG9            |
| DMA Channel 2 (SPORT 0 Transmit) | IVG9            |
| DMA Channel 3 (SPORT 1 Receive)  | IVG9            |
| DMA Channel 4 (SPORT 1 Transmit) | IVG9            |
| DMA Channel 5 (SPI)              | IVG10           |
| DMA Channel 6 (UART Receive)     | IVG10           |
| DMA Channel 7 (UART Transmit)    | IVG10           |
| Timer 0                          | IVG11           |
| Timer 1                          | IVG11           |
| Timer 2                          | IVG11           |
| Port F GPIO Interrupt A          | IVG12           |
| Port F GPIO Interrupt B          | IVG12           |
| Memory DMA Stream 0              | IVG13           |
| Memory DMA Stream 1              | IVG13           |
| Software Watchdog Timer          | IVG13           |

### **Event Control**

The processors provide a very flexible mechanism to control the processing of events. In the CEC, three registers are used to coordinate and control events. Each register is 32 bits wide:

- CEC interrupt latch register (ILAT) The ILAT register indicates when events have been latched. The appropriate bit is set when the processor has latched the event and cleared when the event has been accepted into the system. This register is updated automatically by the controller, but it can also be written to clear (cancel) latched events. This register can be read while in supervisor mode and can only be written while in supervisor mode when the corresponding IMASK bit is cleared.
- CEC interrupt mask register (IMASK) The IMASK register controls the masking and unmasking of individual events. When a bit is set in the IMASK register, that event is unmasked and is processed by the CEC when asserted. A cleared bit in the IMASK register masks the event, preventing the processor from servicing the event even though the event may be latched in the ILAT register. This register can be read or written while in supervisor mode. Note that general-purpose interrupts can be globally enabled and disabled with the STI and CLI instructions, respectively.

 CEC interrupt pending register (IPEND) – The IPEND register keeps track of all nested events. A set bit in the IPEND register indicates the event is currently active or nested at some level. This register is updated automatically by the controller but can be read while in supervisor mode.

The SIC allows further control of event processing by providing three 32-bit interrupt control and status registers. Each register contains a bit corresponding to each of the peripheral interrupt events shown in Table 3.

- SIC interrupt mask register (SIC\_IMASK) This register controls the masking and unmasking of each peripheral interrupt event. When a bit is set in this register, that peripheral event is unmasked and is processed by the system when asserted. A cleared bit in this register masks the peripheral event, preventing the processor from servicing the event.
- SIC interrupt status register (SIC\_ISR) As multiple peripherals can be mapped to a single event, this register allows the software to determine which peripheral event source triggered the interrupt. A set bit indicates the peripheral is asserting the interrupt, and a cleared bit indicates the peripheral is not asserting the event.
- SIC interrupt wakeup enable register (SIC\_IWR) By enabling the corresponding bit in this register, a peripheral can be configured to wake up the processor, should the core be idled when the event is generated. See Dynamic Power Management on Page 11.

Because multiple interrupt sources can map to a single generalpurpose interrupt, multiple pulse assertions can occur simultaneously, before or during interrupt processing for an interrupt event already detected on this interrupt input. The IPEND register contents are monitored by the SIC as the interrupt acknowledgement.

The appropriate ILAT register bit is set when an interrupt rising edge is detected (detection requires two core clock cycles). The bit is cleared when the respective IPEND register bit is set. The IPEND bit indicates that the event has entered into the processor pipeline. At this point the CEC recognizes and queues the next rising edge event on the corresponding event input. The minimum latency from the rising edge transition of the general-purpose interrupt to the IPEND output asserted is three core clock cycles; however, the latency can be much higher, depending on the activity within and the state of the processor.

## **DMA CONTROLLERS**

The ADSP-BF531/ADSP-BF532/ADSP-BF533 processors have multiple, independent DMA channels that support automated data transfers with minimal overhead for the processor core. DMA transfers can occur between the processor's internal memories and any of its DMA-capable peripherals. Additionally, DMA transfers can be accomplished between any of the DMA-capable peripherals and external devices connected to the external memory interfaces, including the SDRAM controller and the asynchronous memory controller. DMA-capable peripherals include the SPORTs, SPI port, UART, and PPI. Each individual DMA-capable peripheral has at least one dedicated DMA channel.

The DMA controller supports both 1-dimensional (1-D) and 2dimensional (2-D) DMA transfers. DMA transfer initialization can be implemented from registers or from sets of parameters called descriptor blocks.

The 2-D DMA capability supports arbitrary row and column sizes up to 64K elements by 64K elements, and arbitrary row and column step sizes up to  $\pm 32$ K elements. Furthermore, the column step size can be less than the row step size, allowing implementation of interleaved data streams. This feature is especially useful in video applications where data can be de-interleaved on the fly.

Examples of DMA types supported by the DMA controller include:

- A single, linear buffer that stops upon completion
- A circular, autorefreshing buffer that interrupts on each full or fractionally full buffer
- 1-D or 2-D DMA using a linked list of descriptors
- 2-D DMA using an array of descriptors, specifying only the base DMA address within a common page

In addition to the dedicated peripheral DMA channels, there are two pairs of memory DMA channels provided for transfers between the various memories of the processor system. This enables transfers of blocks of data between any of the memories—including external SDRAM, ROM, SRAM, and flash memory—with minimal processor intervention. Memory DMA transfers can be controlled by a very flexible descriptor-based methodology or by a standard register-based autobuffer mechanism.

### **REAL-TIME CLOCK**

The processor real-time clock (RTC) provides a robust set of digital watch features, including current time, stopwatch, and alarm. The RTC is clocked by a 32.768 kHz crystal external to the ADSP-BF531/ADSP-BF532/ADSP-BF533 processors. The RTC peripheral has dedicated power supply pins so that it can remain powered up and clocked even when the rest of the processor is in a low power state. The RTC provides several programmable interrupt options, including interrupt per second, minute, hour, or day clock ticks, interrupt on programmable stopwatch countdown, or interrupt at a programmed alarm time.

The 32.768 kHz input clock frequency is divided down to a 1 Hz signal by a prescaler. The counter function of the timer consists of four counters: a 60 second counter, a 60 minute counter, a 24 hour counter, and a 32,768 day counter.

When enabled, the alarm function generates an interrupt when the output of the timer matches the programmed value in the alarm control register. The two alarms are time of day and a day and time of that day.

- Interrupts Each transmit and receive port generates an interrupt upon completing the transfer of a data-word or after transferring an entire data buffer or buffers through DMA.
- Multichannel capability Each SPORT supports 128 channels out of a 1,024-channel window and is compatible with the H.100, H.110, MVIP-90, and HMVIP standards.

An additional 250 mV of SPORT input hysteresis can be enabled by setting Bit 15 of the PLL\_CTL register. When this bit is set, all SPORT input pins have the increased hysteresis.

## **SERIAL PERIPHERAL INTERFACE (SPI) PORT**

The ADSP-BF531/ADSP-BF532/ADSP-BF533 processors have an SPI-compatible port that enables the processor to communicate with multiple SPI-compatible devices.

The SPI interface uses three pins for transferring data: two data pins (master output-slave input, MOSI, and master input-slave output, MISO) and a clock pin (serial clock, SCK). An SPI chip select input pin (SPISS) lets other SPI devices select the processor, and seven SPI chip select output pins (SPISEL7–1) let the processor select other SPI devices. The SPI select pins are reconfigured general-purpose I/O pins. Using these pins, the SPI port provides a full-duplex, synchronous serial interface which supports both master/slave modes and multimaster environments.

The baud rate and clock phase/polarities for the SPI port are programmable, and it has an integrated DMA controller, configurable to support transmit or receive data streams. The SPI DMA controller can only service unidirectional accesses at any given time.

The SPI port clock rate is calculated as:

$$SPI Clock Rate = \frac{f_{SCLK}}{2 \times SPI\_BAUD}$$

where the 16-bit SPI\_BAUD register contains a value of 2 to 65,535.

During transfers, the SPI port simultaneously transmits and receives by serially shifting data in and out on its two serial data lines. The serial clock line synchronizes the shifting and sampling of data on the two serial data lines.

## **UART PORT**

The ADSP-BF531/ADSP-BF532/ADSP-BF533 processors provide a full-duplex universal asynchronous receiver/transmitter (UART) port, which is fully compatible with PC-standard UARTs. The UART port provides a simplified UART interface to other peripherals or hosts, supporting full-duplex, DMA-supported, asynchronous transfers of serial data. The UART port includes support for 5 data bits to 8 data bits, 1 stop bit or 2 stop bits, and none, even, or odd parity. The UART port supports two modes of operation:

• PIO (programmed I/O) – The processor sends or receives data by writing or reading I/O-mapped UART registers. The data is double-buffered on both transmit and receive.

• DMA (direct memory access) – The DMA controller transfers both transmit and receive data. This reduces the number and frequency of interrupts required to transfer data to and from memory. The UART has two dedicated DMA channels, one for transmit and one for receive. These DMA channels have lower default priority than most DMA channels because of their relatively low service rates.

The baud rate, serial data format, error code generation and status, and interrupts for the UART port are programmable.

The UART programmable features include:

- Supporting bit rates ranging from (f<sub>SCLK</sub>/1,048,576) bits per second to (f<sub>SCLK</sub>/16) bits per second.
- Supporting data formats from seven bits to 12 bits per frame.
- Both transmit and receive operations can be configured to generate maskable interrupts to the processor.

The UART port's clock rate is calculated as:

$$UART \ Clock \ Rate = \frac{f_{SCLK}}{16 \times UART\_Divisor}$$

where the 16-bit UART\_Divisor comes from the UART\_DLH register (most significant 8 bits) and UART\_DLL register (least significant 8 bits).

In conjunction with the general-purpose timer functions, autobaud detection is supported.

The capabilities of the UART are further extended with support for the Infrared Data Association (IrDA<sup>®</sup>) serial infrared physical layer link specification (SIR) protocol.

## **GENERAL-PURPOSE I/O PORT F**

The ADSP-BF531/ADSP-BF532/ADSP-BF533 processors have 16 bidirectional, general-purpose I/O pins on Port F (PF15–0). Each general-purpose I/O pin can be individually controlled by manipulation of the GPIO control, status and interrupt registers:

- GPIO direction control register Specifies the direction of each individual PFx pin as input or output.
- GPIO control and status registers The processor employs a "write one to modify" mechanism that allows any combination of individual GPIO pins to be modified in a single instruction, without affecting the level of any other GPIO pins. Four control registers are provided. One register is written in order to set GPIO pin values, one register is written in order to clear GPIO pin values, one register is written in order to toggle GPIO pin values, and one register is written in order to specify GPIO pin values. Reading the GPIO status register allows software to interrogate the sense of the GPIO pin.
- GPIO interrupt mask registers The two GPIO interrupt mask registers allow each individual PFx pin to function as an interrupt to the processor. Similar to the two GPIO control registers that are used to set and clear individual GPIO pin values, one GPIO interrupt mask register sets bits to enable interrupt function, and the other GPIO interrupt mask register clears bits to disable interrupt function.

As shown in Figure 9, the core clock (CCLK) and system peripheral clock (SCLK) are derived from the input clock (CLKIN) signal. An on-chip PLL is capable of multiplying the CLKIN signal by a user programmable 0.5× to 64× multiplication factor (bounded by specified minimum and maximum VCO frequencies). The default multiplier is 10×, but it can be modified by a software instruction sequence. On-the-fly frequency changes can be effected by simply writing to the PLL\_DIV register.



Figure 9. Frequency Modification Methods

All on-chip peripherals are clocked by the system clock (SCLK). The system clock frequency is programmable by means of the SSEL3–0 bits of the PLL\_DIV register. The values programmed into the SSEL fields define a divide ratio between the PLL output (VCO) and the system clock. SCLK divider values are 1 through 15. Table 6 illustrates typical system clock ratios.

| Table 6. | <b>Example System</b> | <b>Clock Ratios</b> |
|----------|-----------------------|---------------------|
|----------|-----------------------|---------------------|

| Signal Name | Divider Ratio | Example Frequency Ratios<br>(MHz) |      |  |
|-------------|---------------|-----------------------------------|------|--|
| SSEL3-0     | VCO/SCLK      | VCO                               | SCLK |  |
| 0001        | 1:1           | 100                               | 100  |  |
| 0101        | 5:1           | 400                               | 80   |  |
| 1010        | 10:1          | 500                               | 50   |  |

The maximum frequency of the system clock is  $f_{SCLK}$ . The divisor ratio must be chosen to limit the system clock frequency to its maximum of  $f_{SCLK}$ . The SSEL value can be changed dynamically without any PLL lock latencies by writing the appropriate values to the PLL divisor register (PLL\_DIV). When the SSEL value is changed, it affects all of the peripherals that derive their clock signals from the SCLK signal.

The core clock (CCLK) frequency can also be dynamically changed by means of the CSEL1–0 bits of the PLL\_DIV register. Supported CCLK divider ratios are 1, 2, 4, and 8, as shown in Table 7. This programmable core clock capability is useful for fast core frequency modifications.

#### Table 7. Core Clock Ratios

| Signal Name | Divider Ratio | Example Frequency Ratio<br>(MHz)<br>VCO CCLK |     |  |
|-------------|---------------|----------------------------------------------|-----|--|
| CSEL1-0     | VCO/CCLK      |                                              |     |  |
| 00          | 1:1           | 300                                          | 300 |  |
| 01          | 2:1           | 300                                          | 150 |  |
| 10          | 4:1           | 400                                          | 100 |  |
| 11          | 8:1           | 200                                          | 25  |  |

## **BOOTING MODES**

The ADSP-BF531/ADSP-BF532/ADSP-BF533 processors have two mechanisms (listed in Table 8) for automatically loading internal L1 instruction memory after a reset. A third mode is provided to execute from external memory, bypassing the boot sequence.

#### Table 8. Booting Modes

| BMODE1-0 | Description                                                                                                                           |
|----------|---------------------------------------------------------------------------------------------------------------------------------------|
| 00       | Execute from 16-bit external memory (bypass boot ROM)                                                                                 |
| 01       | Boot from 8-bit or 16-bit FLASH                                                                                                       |
| 10       | Boot from serial master connected to SPI                                                                                              |
| 11       | Boot from serial slave EEPROM/flash (8-,16-, or 24-<br>bit address range, or Atmel AT45DB041,<br>AT45DB081, or AT45DB161serial flash) |

The BMODE pins of the reset configuration register, sampled during power-on resets and software-initiated resets, implement the following modes:

- Execute from 16-bit external memory Execution starts from address 0x2000 0000 with 16-bit packing. The boot ROM is bypassed in this mode. All configuration settings are set for the slowest device possible (3-cycle hold time; 15-cycle R/W access times; 4-cycle setup).
- Boot from 8-bit or 16-bit external flash memory The flash boot routine located in boot ROM memory space is set up using asynchronous Memory Bank 0. All configuration settings are set for the slowest device possible (3-cycle hold time; 15-cycle R/W access times; 4-cycle setup).
- Boot from SPI serial EEPROM/flash (8-, 16-, or 24-bit addressable, or Atmel AT45DB041, AT45DB081, or AT45DB161) The SPI uses the PF2 output pin to select a single SPI EEPROM/flash device, submits a read command and successive address bytes (0x00) until a valid 8-, 16-, or 24-bit addressable EEPROM/flash device is detected, and begins clocking data into the processor at the beginning of L1 instruction memory.
- Boot from SPI serial master The Blackfin processor operates in SPI slave mode and is configured to receive the bytes of the LDR file from an SPI host (master) agent. To hold off the host device from transmitting while the boot ROM is busy, the Blackfin processor asserts a GPIO pin, called host wait (HWAIT), to signal the host device not to send any

more bytes until the flag is deasserted. The GPIO pin is chosen by the user and this information is transferred to the Blackfin processor via bits[10:5] of the FLAG header in the LDR image.

For each of the boot modes, a 10-byte header is first read from an external memory device. The header specifies the number of bytes to be transferred and the memory destination address. Multiple memory blocks can be loaded by any boot sequence. Once all blocks are loaded, program execution commences from the start of L1 instruction SRAM.

In addition, Bit 4 of the reset configuration register can be set by application code to bypass the normal boot sequence during a software reset. For this case, the processor jumps directly to the beginning of L1 instruction memory.

## **INSTRUCTION SET DESCRIPTION**

The Blackfin processor family assembly language instruction set employs an algebraic syntax designed for ease of coding and readability. The instructions have been specifically tuned to provide a flexible, densely encoded instruction set that compiles to a very small final memory size. The instruction set also provides fully featured multifunction instructions that allow the programmer to use many of the processor core resources in a single instruction. Coupled with many features more often seen on microcontrollers, this instruction set is very efficient when compiling C and C++ source code. In addition, the architecture supports both user (algorithm/application code) and supervisor (O/S kernel, device drivers, debuggers, ISRs) modes of operation, allowing multiple levels of access to core processor resources.

The assembly language, which takes advantage of the processor's unique architecture, offers the following advantages:

- Seamlessly integrated DSP/CPU features are optimized for both 8-bit and 16-bit operations.
- A multi-issue load/store modified Harvard architecture, which supports two 16-bit MAC or four 8-bit ALU + two load/store + two pointer updates per cycle.
- All registers, I/O, and memory are mapped into a unified 4G byte memory space, providing a simplified programming model.
- Microcontroller features, such as arbitrary bit and bit-field manipulation, insertion, and extraction; integer operations on 8-, 16-, and 32-bit data types; and separate user and supervisor stack pointers.
- Code density enhancements, which include intermixing of 16-bit and 32-bit instructions (no mode switching, no code segregation). Frequently used instructions are encoded in 16 bits.

## **DEVELOPMENT TOOLS**

Analog Devices supports its processors with a complete line of software and hardware development tools, including integrated development environments (which include CrossCore<sup>®</sup> Embedded Studio and/or VisualDSP++<sup>®</sup>), evaluation products, emulators, and a wide variety of software add-ins.

### Integrated Development Environments (IDEs)

For C/C++ software writing and editing, code generation, and debug support, Analog Devices offers two IDEs.

The newest IDE, CrossCore Embedded Studio, is based on the Eclipse<sup>™</sup> framework. Supporting most Analog Devices processor families, it is the IDE of choice for future processors, including multicore devices. CrossCore Embedded Studio seamlessly integrates available software add-ins to support real time operating systems, file systems, TCP/IP stacks, USB stacks, algorithmic software modules, and evaluation hardware board support packages. For more information visit www.analog.com/ cces.

The other Analog Devices IDE, VisualDSP++, supports processor families introduced prior to the release of CrossCore Embedded Studio. This IDE includes the Analog Devices VDK real time operating system and an open source TCP/IP stack. For more information visit www.analog.com/visualdsp. Note that VisualDSP++ will not support future Analog Devices processors.

## EZ-KIT Lite Evaluation Board

For processor evaluation, Analog Devices provides wide range of EZ-KIT Lite<sup>®</sup> evaluation boards. Including the processor and key peripherals, the evaluation board also supports on-chip emulation capabilities and other evaluation and development features. Also available are various EZ-Extenders<sup>®</sup>, which are daughter cards delivering additional specialized functionality, including audio and video processing. For more information visit www.analog.com and search on "ezkit" or "ezextender".

## **EZ-KIT Lite Evaluation Kits**

For a cost-effective way to learn more about developing with Analog Devices processors, Analog Devices offer a range of EZ-KIT Lite evaluation kits. Each evaluation kit includes an EZ-KIT Lite evaluation board, directions for downloading an evaluation version of the available IDE(s), a USB cable, and a power supply. The USB controller on the EZ-KIT Lite board connects to the USB port of the user's PC, enabling the chosen IDE evaluation suite to emulate the on-board processor in-circuit. This permits the customer to download, execute, and debug programs for the EZ-KIT Lite system. It also supports in-circuit programming of the on-board Flash device to store user-specific boot code, enabling standalone operation. With the full version of Cross-Core Embedded Studio or VisualDSP++ installed (sold separately), engineers can develop software for supported EZ-KITs or any custom system utilizing supported Analog Devices processors.

### Software Add-Ins for CrossCore Embedded Studio

Analog Devices offers software add-ins which seamlessly integrate with CrossCore Embedded Studio to extend its capabilities and reduce development time. Add-ins include board support packages for evaluation hardware, various middleware packages, and algorithmic modules. Documentation, help, configuration dialogs, and coding examples present in these add-ins are viewable through the CrossCore Embedded Studio IDE once the add-in is installed.

## **ELECTRICAL CHARACTERISTICS**

|                                        |                                                     |                                                                                                                                   | 400 MHz <sup>1</sup> 500 MHz/533 MHz/60 |         | /600 MHz <sup>2</sup>                            |                   |         |                                                   |             |
|----------------------------------------|-----------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|---------|--------------------------------------------------|-------------------|---------|---------------------------------------------------|-------------|
| Parameter                              |                                                     | Test Conditions                                                                                                                   | Min                                     | Typical | Max                                              | Min               | Typical | Max                                               | Unit        |
| V <sub>OH</sub>                        | High Level<br>Output Voltage <sup>3</sup>           | $V_{DDEXT} = 1.75 V, I_{OH} = -0.5 mA$ $V_{DDEXT} = 2.25 V, I_{OH} = -0.5 mA$ $V_{DDEXT} = 3.0 V, I_{OH} = -0.5 mA$               | 1.5<br>1.9<br>2.4                       |         |                                                  | 1.5<br>1.9<br>2.4 |         |                                                   | V<br>V<br>V |
| V <sub>OL</sub>                        | Low Level<br>Output Voltage <sup>3</sup>            | $V_{DDEXT} = 1.75 \text{ V}, I_{OL} = 2.0 \text{ mA}$<br>$V_{DDEXT} = 2.25 \text{ V}/3.0 \text{ V},$<br>$I_{OL} = 2.0 \text{ mA}$ |                                         |         | 0.2<br>0.4                                       |                   |         | 0.2<br>0.4                                        | V<br>V      |
| I <sub>IH</sub>                        | High Level Input<br>Current <sup>4</sup>            | $V_{DDEXT} = Max, V_{IN} = V_{DD} Max$                                                                                            |                                         |         | 10.0                                             |                   |         | 10.0                                              | μA          |
| I <sub>IHP</sub>                       | High Level Input<br>Current JTAG⁵                   | $V_{DDEXT} = Max, V_{IN} = V_{DD} Max$                                                                                            |                                         |         | 50.0                                             |                   |         | 50.0                                              | μA          |
| I <sub>IL</sub> <sup>6</sup>           | Low Level Input<br>Current <sup>4</sup>             | $V_{DDEXT} = Max, V_{IN} = 0 V$                                                                                                   |                                         |         | 10.0                                             |                   |         | 10.0                                              | μA          |
| I <sub>OZH</sub>                       | Three-State<br>Leakage<br>Current <sup>7</sup>      | $V_{DDEXT} = Max, V_{IN} = V_{DD} Max$                                                                                            |                                         |         | 10.0                                             |                   |         | 10.0                                              | μΑ          |
| I <sub>OZL</sub> <sup>6</sup>          | Three-State<br>Leakage<br>Current <sup>7</sup>      | $V_{DDEXT} = Max, V_{IN} = 0 V$                                                                                                   |                                         |         | 10.0                                             |                   |         | 10.0                                              | μΑ          |
| C <sub>IN</sub>                        | Input<br>Capacitance <sup>8</sup>                   | $f_{IN} = 1 \text{ MHz}, T_{AMBIENT} = 25^{\circ}\text{C},$<br>$V_{IN} = 2.5 \text{ V}$                                           |                                         | 4       | 8 <sup>9</sup>                                   |                   | 4       | 8 <sup>9</sup>                                    | pF          |
| I <sub>DDDEEPSLEEP</sub> <sup>10</sup> | V <sub>DDINT</sub> Current in<br>Deep Sleep<br>Mode | $V_{DDINT} = 1.0 V, f_{CCLK} = 0 MHz,$<br>T <sub>J</sub> = 25°C, ASF = 0.00                                                       |                                         | 7.5     |                                                  |                   | 32.5    |                                                   | mA          |
| IDDSLEEP                               | V <sub>DDINT</sub> Current in Sleep Mode            | V <sub>DDINT</sub> = 0.8 V, T <sub>J</sub> = 25°C,<br>SCLK = 25 MHz                                                               |                                         |         | 10                                               |                   |         | 37.5                                              | mA          |
| I <sub>DD-TYP</sub> <sup>11</sup>      | V <sub>DDINT</sub> Current                          | $V_{DDINT} = 1.14 V, f_{CCLK} = 400 MHz, T_{J} = 25^{\circ}C$                                                                     |                                         | 125     |                                                  |                   | 152     |                                                   | mA          |
| I <sub>DD-TYP</sub> <sup>11</sup>      | V <sub>DDINT</sub> Current                          | $V_{DDINT} = 1.2 \text{ V}, f_{CCLK} = 500 \text{ MHz},$<br>$T_J = 25^{\circ}\text{C}$                                            |                                         |         |                                                  |                   | 190     |                                                   | mA          |
| I <sub>DD-TYP</sub> <sup>11</sup>      | V <sub>DDINT</sub> Current                          | $V_{DDINT} = 1.2 \text{ V}, f_{CCLK} = 533 \text{ MHz},$<br>$T_J = 25^{\circ}\text{C}$                                            |                                         |         |                                                  |                   | 200     |                                                   | mA          |
| I <sub>DD-TYP</sub> <sup>11</sup>      | V <sub>DDINT</sub> Current                          | $V_{DDINT} = 1.3 V$ , $f_{CCLK} = 600 MHz$ ,<br>$T_{J} = 25^{\circ}C$                                                             |                                         |         |                                                  |                   | 245     |                                                   | mA          |
| I <sub>DDHIBERNATE</sub> <sup>10</sup> | V <sub>DDEXT</sub> Current in<br>Hibernate State    | $V_{DDEXT} = 3.6 V$ , CLKIN = 0 MHz,<br>T <sub>J</sub> = Max, voltage regulator off<br>( $V_{DDINT} = 0 V$ )                      |                                         | 50      | 100                                              |                   | 50      | 100                                               | μΑ          |
| I <sub>DDRTC</sub>                     | V <sub>DDRTC</sub> Current                          | $V_{DDRTC} = 3.3 V, T_J = 25^{\circ}C$                                                                                            |                                         | 20      |                                                  |                   | 20      |                                                   | μA          |
| I <sub>DDDEEPSLEEP</sub> <sup>10</sup> | V <sub>DDINT</sub> Current in<br>Deep Sleep<br>Mode | $f_{CCLK} = 0 MHz$                                                                                                                |                                         | 6       | Table 15                                         |                   | 16      | Table 14                                          | mA          |
| I <sub>DD-INT</sub>                    | V <sub>DDINT</sub> Current                          | f <sub>CCLK</sub> > 0 MHz                                                                                                         |                                         |         | I <sub>DDDEEPSLEEP</sub><br>+(Table 17<br>× ASF) |                   |         | I <sub>DDDEEPSLEEP</sub><br>+ (Table 17<br>× ASF) | mA          |

<sup>1</sup> Applies to all 400 MHz speed grade models. See Ordering Guide on Page 63.
<sup>2</sup> Applies to all 500 MHz, 533 MHz, and 600 MHz speed grade models. See Ordering Guide on Page 63.

<sup>3</sup> Applies to output and bidirectional pins.

<sup>4</sup>Applies to input pins except JTAG inputs.

### SDRAM Interface Timing

### Table 25. SDRAM Interface Timing<sup>1</sup>

|                     |                                                     | VDDEXT | -= 1.8 V | V <sub>DDEXT</sub> = 2 | 2.5 V/3.3 V |      |
|---------------------|-----------------------------------------------------|--------|----------|------------------------|-------------|------|
| Paramet             | er                                                  | Min    | Max      | Min                    | Max         | Unit |
| Timing R            | equirements                                         |        |          |                        |             |      |
| t <sub>SSDAT</sub>  | DATA Setup Before CLKOUT                            | 2.1    |          | 1.5                    |             | ns   |
| t <sub>HSDAT</sub>  | DATA Hold After CLKOUT                              | 0.8    |          | 0.8                    |             | ns   |
| Switching           | g Characteristics                                   |        |          |                        |             |      |
| t <sub>DCAD</sub>   | Command, ADDR, Data Delay After CLKOUT <sup>2</sup> |        | 6.0      |                        | 4.0         | ns   |
| t <sub>HCAD</sub>   | Command, ADDR, Data Hold After CLKOUT <sup>2</sup>  | 1.0    |          | 1.0                    |             | ns   |
| t <sub>DSDAT</sub>  | Data Disable After CLKOUT                           |        | 6.0      |                        | 4.0         | ns   |
| t <sub>ensdat</sub> | Data Enable After CLKOUT                            | 1.0    |          | 1.0                    |             | ns   |
| t <sub>SCLK</sub>   | CLKOUT Period <sup>3</sup>                          | 10.0   |          | 7.5                    |             | ns   |
| t <sub>SCLKH</sub>  | CLKOUT Width High                                   | 2.5    |          | 2.5                    |             | ns   |
| t <sub>SCLKL</sub>  | CLKOUT Width Low                                    | 2.5    |          | 2.5                    |             | ns   |

 $^1$  SDRAM timing for T<sub>J</sub> > 105°C is limited to 100 MHz.

<sup>2</sup> Command pins include: SRAS, SCAS, SWE, SDQM, SMS, SA10, SCKE.

 $^3$  Refer to Table 13 on Page 21 for maximum  $f_{SCLK}$  at various  $V_{DDINT}.$ 



NOTE: COMMAND = SRAS, SCAS, SWE, SDQM, SMS, SA10, SCKE.

Figure 15. SDRAM Interface Timing

## Parallel Peripheral Interface Timing

Table 27 and Figure 17 through Figure 22 describe parallelperipheral interface operations.

### Table 27. Parallel Peripheral Interface Timing

|                     |                                                       | V <sub>DDE</sub> | ιτ = 1.8 V<br>GA Packages | V <sub>DDEX</sub> | ⊤ = 1.8 V<br>A Package | V <sub>DDEXT</sub> =<br>All Pa | 2.5 V/3.3 V<br>ackages |      |
|---------------------|-------------------------------------------------------|------------------|---------------------------|-------------------|------------------------|--------------------------------|------------------------|------|
| Param               | eter                                                  | Min              | Max                       | Min               | Max                    | Min                            | Max                    | Unit |
| Timing              | Requirements                                          |                  |                           |                   |                        |                                |                        |      |
| t <sub>PCLKW</sub>  | PPI_CLK Width                                         | 8.0              |                           | 8.0               |                        | 6.0                            |                        | ns   |
| t <sub>PCLK</sub>   | PPI_CLK Period <sup>1</sup>                           | 20.0             |                           | 20.0              |                        | 15.0                           |                        | ns   |
| t <sub>SFSPE</sub>  | External Frame Sync Setup Before PPI_CLK Edge         | 6.0              |                           | 6.0               |                        | 4.0 <sup>2</sup>               |                        | ns   |
|                     | (Nonsampling Edge for Rx, Sampling Edge for Tx)       |                  |                           |                   |                        |                                |                        | ns   |
| t <sub>HFSPE</sub>  | External Frame Sync Hold After PPI_CLK                | 1.0 <sup>2</sup> |                           | 1.0 <sup>2</sup>  |                        | 1.0 <sup>2</sup>               |                        | ns   |
| t <sub>SDRPE</sub>  | Receive Data Setup Before PPI_CLK                     | 3.5              |                           | 3.5               |                        | 3.5                            |                        | ns   |
| t <sub>HDRPE</sub>  | Receive Data Hold After PPI_CLK                       | 1.5              |                           | 1.5               |                        | 1.5                            |                        | ns   |
| Switch              | ing Characteristics—GP Output and Frame Capture Modes |                  |                           |                   |                        |                                |                        |      |
| t <sub>DFSPE</sub>  | Internal Frame Sync Delay After PPI_CLK               |                  | 11.0                      |                   | 8.0                    |                                | 8.0                    | ns   |
| t <sub>HOFSPE</sub> | Internal Frame Sync Hold After PPI_CLK                | 1.7              |                           | 1.7               |                        | 1.7                            |                        | ns   |
| t <sub>DDTPE</sub>  | Transmit Data Delay After PPI_CLK                     |                  | 11.0                      |                   | 9.0                    |                                | 9.0                    | ns   |
| t <sub>HDTPE</sub>  | Transmit Data Hold After PPI_CLK                      | 1.8              |                           | 1.8               |                        | 1.8                            |                        | ns   |

<sup>1</sup> PPI\_CLK frequency cannot exceed  $f_{SCLK}/2$ .

<sup>2</sup> Applies when PPI\_CONTROL Bit 8 is cleared. See Figure 19 and Figure 22.



Figure 17. PPI GP Rx Mode with Internal Frame Sync Timing



Figure 18. PPI GP Rx Mode with External Frame Sync Timing (PPI\_CONTROL Bit 8 = 1)

### Serial Port Timing

Table 28 through Table 31 on Page 37 and Figure 23 on Page 35 through Figure 26 on Page 37 describe Serial Port operations.

### Table 28. Serial Ports-External Clock

|                     |                                                                                   | V <sub>DDEXT</sub> = 1.8 V | V <sub>DDEXT</sub> = 2.5     | V/3.3 V |
|---------------------|-----------------------------------------------------------------------------------|----------------------------|------------------------------|---------|
| Param               | eter                                                                              | Min Max                    | Min Ma                       | ax Unit |
| Timing              | Requirements                                                                      |                            |                              |         |
| t <sub>SFSE</sub>   | TFSx/RFSx Setup Before TSCLKx/RSCLKx <sup>1</sup>                                 | 3.0                        | 3.0                          | ns      |
| t <sub>HFSE</sub>   | TFSx/RFSx Hold After TSCLKx/RSCLKx <sup>1</sup>                                   | 3.0                        | 3.0                          | ns      |
| t <sub>SDRE</sub>   | Receive Data Setup Before RSCLKx <sup>1</sup>                                     | 3.0                        | 3.0                          | ns      |
| t <sub>HDRE</sub>   | Receive Data Hold After RSCLKx <sup>1</sup>                                       | 3.0                        | 3.0                          | ns      |
| t <sub>SCLKEW</sub> | TSCLKx/RSCLKx Width                                                               | 8.0                        | 4.5                          | ns      |
| t <sub>SCLKE</sub>  | TSCLKx/RSCLKx Period                                                              | 20.0                       | 15.0 <sup>2</sup>            | ns      |
| t <sub>SUDTE</sub>  | Start-Up Delay From SPORT Enable To First External TFSx <sup>3</sup>              | $4.0 \times t_{SCLKE}$     | $4.0 	imes t_{SCLKE}$        | ns      |
| t <sub>SUDRE</sub>  | Start-Up Delay From SPORT Enable To First External RFSx <sup>3</sup>              | $4.0 \times t_{SCLKE}$     | $4.0 	imes t_{\text{SCLKE}}$ | ns      |
| Switch              | ing Characteristics                                                               |                            |                              |         |
| t <sub>DFSE</sub>   | TFSx/RFSx Delay After TSCLKx/RSCLKx (Internally Generated TFSx/RFSx) <sup>4</sup> | 10.0                       | 10                           | .0 ns   |
| t <sub>HOFSE</sub>  | TFSx/RFSx Hold After TSCLKx/RSCLKx (Internally Generated TFSx/RFSx) <sup>1</sup>  | 0.0                        | 0.0                          | ns      |
| t <sub>DDTE</sub>   | Transmit Data Delay After TSCLKx <sup>1</sup>                                     | 10.0                       | 10                           | .0 ns   |
| t <sub>HDTE</sub>   | Transmit Data Hold After TSCLKx <sup>1</sup>                                      | 0.0                        | 0.0                          | ns      |

<sup>1</sup>Referenced to sample edge.

<sup>2</sup> For receive mode with external RSCLKx and external RFSx only, the maximum specification is 11.11 ns (90 MHz).

<sup>3</sup> Verified in design but untested. After being enabled, the serial port requires external clock pulses—before the first external frame sync edge—to initialize the serial port. <sup>4</sup> Referenced to drive edge.

#### Table 29. Serial Ports—Internal Clock

|                           |                                                                                   | <b>V</b> <sub>DDEXT</sub> = <b>1.8 V</b> |     | V <sub>DDEXT</sub> = 2.5 V/3.3 V |     |      |
|---------------------------|-----------------------------------------------------------------------------------|------------------------------------------|-----|----------------------------------|-----|------|
| Parameter                 |                                                                                   | Min                                      | Max | Min                              | Max | Unit |
| Timing Requirements       |                                                                                   |                                          |     |                                  |     |      |
| t <sub>SFSI</sub>         | TFSx/RFSx Setup Before TSCLKx/RSCLKx <sup>1</sup>                                 | 11.0                                     |     | 9.0                              |     | ns   |
| t <sub>HFSI</sub>         | TFSx/RFSx Hold After TSCLKx/RSCLKx <sup>1</sup>                                   | -2.0                                     |     | -2.0                             |     | ns   |
| t <sub>SDRI</sub>         | Receive Data Setup Before RSCLKx <sup>1</sup>                                     | 9.5                                      |     | 9.0                              |     | ns   |
| t <sub>HDRI</sub>         | Receive Data Hold After RSCLKx <sup>1</sup>                                       | 0.0                                      |     | 0.0                              |     | ns   |
| Switching Characteristics |                                                                                   |                                          |     |                                  |     |      |
| t <sub>DFSI</sub>         | TFSx/RFSx Delay After TSCLKx/RSCLKx (Internally Generated TFSx/RFSx) <sup>2</sup> |                                          | 3.0 |                                  | 3.0 | ns   |
| t <sub>HOFSI</sub>        | TFSx/RFSx Hold After TSCLKx/RSCLKx (Internally Generated TFSx/RFSx) <sup>1</sup>  | -1.0                                     |     | -1.0                             |     | ns   |
| t <sub>DDTI</sub>         | Transmit Data Delay After TSCLKx <sup>1</sup>                                     |                                          | 3.0 |                                  | 3.0 | ns   |
| t <sub>HDTI</sub>         | Transmit Data Hold After TSCLKx <sup>1</sup>                                      | -2.5                                     |     | -2.0                             |     | ns   |
| t <sub>SCLKIW</sub>       | TSCLKx/RSCLKx Width                                                               | 6.0                                      |     | 4.5                              |     | ns   |

<sup>1</sup>Referenced to sample edge.

<sup>2</sup> Referenced to drive edge.

### **Timer Clock Timing**

Table 35 and Figure 30 describe timer clock timing.

### Table 35. Timer Clock Timing



Figure 30. Timer Clock Timing

### **Timer Cycle Timing**

Table 36 and Figure 31 describe timer expired operations. The input signal is asynchronous in width capture mode and external clock mode and has an absolute maximum input frequency of  $f_{SCLK}/2$  MHz.

#### Table 36. Timer Cycle Timing

|                                                                        | <b>V</b> <sub>DDEXT</sub> = <b>1.8 V</b> |                              | V <sub>DDEXT</sub> = 2.5 V/3.3 V |                              |      |
|------------------------------------------------------------------------|------------------------------------------|------------------------------|----------------------------------|------------------------------|------|
| Parameter                                                              |                                          | Max                          | Min                              | Max                          | Unit |
| Timing Characteristics                                                 |                                          |                              |                                  |                              |      |
| t <sub>WL</sub> Timer Pulse Width Low <sup>1</sup>                     | $1 \times t_{\text{SCLK}}$               |                              | $1 \times t_{SCLK}$              |                              | ns   |
| t <sub>wH</sub> Timer Pulse Width High <sup>1</sup>                    | $1 \times t_{SCLK}$                      |                              | $1 \times t_{SCLK}$              |                              | ns   |
| t <sub>TIS</sub> Timer Input Setup Time Before CLKOUT Low <sup>2</sup> | 8.0                                      |                              | 6.5                              |                              | ns   |
| $t_{\Pi H}$ Timer Input Hold Time After CLKOUT $Low^2$                 | 1.5                                      |                              | 1.5                              |                              | ns   |
| Switching Characteristics                                              |                                          |                              |                                  |                              |      |
| t <sub>HTO</sub> Timer Pulse Width Output                              | $1 \times t_{SCLK}$                      | $(2^{32}-1) \times t_{SCLK}$ | $1 \times t_{SCLK}$              | $(2^{32}-1) \times t_{SCLK}$ | ns   |
| $t_{\text{TOD}}$ Timer Output Update Delay After CLKOUT High           |                                          | 7.5                          |                                  | 6.5                          | ns   |

<sup>1</sup> The minimum pulse widths apply for TMRx input pins in width capture and external clock modes. They also apply to the PF1 or PPI\_CLK input pins in PWM output mode. <sup>2</sup> Either a valid setup and hold time or a valid pulse width is sufficient. There is no need to resynchronize programmable flag inputs.



Figure 31. Timer PWM\_OUT Cycle Timing

## JTAG Test and Emulation Port Timing

### Table 37. JTAG Port Timing

|                           |                                                        | V <sub>DDEXT</sub> = 1.8 V |     | V <sub>DDEXT</sub> = 2.5 V/3.3 V |     |      |
|---------------------------|--------------------------------------------------------|----------------------------|-----|----------------------------------|-----|------|
| Parameter                 |                                                        | Min                        | Max | Min                              | Max | Unit |
| Timing Requirements       |                                                        |                            |     |                                  |     |      |
| t <sub>TCK</sub>          | TCK Period                                             | 20                         |     | 20                               |     | ns   |
| t <sub>STAP</sub>         | TDI, TMS Setup Before TCK High                         | 4                          |     | 4                                |     | ns   |
| t <sub>HTAP</sub>         | TDI, TMS Hold After TCK High                           | 4                          |     | 4                                |     | ns   |
| t <sub>ssys</sub>         | System Inputs Setup Before TCK High <sup>1</sup>       | 4                          |     | 4                                |     | ns   |
| t <sub>HSYS</sub>         | System Inputs Hold After TCK High <sup>1</sup>         | 5                          |     | 5                                |     | ns   |
| t <sub>TRSTW</sub>        | TRST Pulse Width <sup>2</sup> (Measured in TCK Cycles) | 4                          |     | 4                                |     | ТСК  |
| Switching Characteristics |                                                        |                            |     |                                  |     |      |
| t <sub>DTDO</sub>         | TDO Delay from TCK Low                                 |                            | 10  |                                  | 10  | ns   |
| t <sub>DSYS</sub>         | System Outputs Delay After TCK Low <sup>3</sup>        | 0                          | 12  | 0                                | 12  | ns   |

<sup>1</sup> System Inputs = DATA15-0, ARDY, TMR2-0, PF15-0, PPI\_CLK, RSCLK0-1, RFS0-1, DR0PRI, DR0SEC, TSCLK0-1, TFS0-1, DR1PRI, DR1SEC, MOSI, MISO, SCK, RX, RESET, NMI, BMODE1-0, BR, PPI3-0.

<sup>2</sup> 50 MHz maximum.

<sup>3</sup> System Outputs = DATA15-0, ADDR19-1, ABE1-0, AOE, ARE, AWE, AMS3-0, SRAS, SCAS, SWE, SCKE, CLKOUT, SA10, SMS, TMR2-0, PF15-0, RSCLK0-1, RFS0-1, TSCLK0-1, TFS0-1, DT0PRI, DT0SEC, DT1PRI, DT1SEC, MOSI, MISO, SCK, TX, BG, BGH, PPI3-0.



Figure 32. JTAG Port Timing







Figure 40. Drive Current C ( $V_{DDEXT} = 1.8 V$ )



Figure 41. Drive Current C ( $V_{DDEXT} = 3.3 V$ )



Figure 42. Drive Current D ( $V_{DDEXT} = 2.5 V$ )







Figure 44. Drive Current D ( $V_{DDEXT} = 3.3 V$ )

## **TEST CONDITIONS**

All timing parameters appearing in this data sheet were measured under the conditions described in this section. Figure 45 shows the measurement point for ac measurements (except output enable/disable). The measurement point  $V_{MEAS}$  is 0.95 V for  $V_{DDEXT}$  (nominal) = 1.8 V or 1.5 V for  $V_{DDEXT}$  (nominal) = 2.5 V/ 3.3 V.



Measurements (Except Output Enable/Disable)

#### **Output Enable Time Measurement**

Output pins are considered to be enabled when they have made a transition from a high impedance state to the point when they start driving.

The output enable time  $t_{ENA}$  is the interval from the point when a reference signal reaches a high or low voltage level to the point when the output starts driving as shown on the right side of Figure 46.

The time  $t_{ENA\_MEASURED}$  is the interval, from when the reference signal switches, to when the output voltage reaches  $V_{TRIP}$ (high) or  $V_{TRIP}$  (low).

For  $V_{DDEXT}$  (nominal) = 1.8 V— $V_{TRIP}$  (high) is 1.3 V and  $V_{TRIP}$  (low) is 0.7 V.

For  $V_{DDEXT}$  (nominal) = 2.5 V/3.3 V—V<sub>TRIP</sub> (high) is 2.0 V and  $V_{TRIP}$  (low) is 1.0 V.

Time  $t_{TRIP}$  is the interval from when the output starts driving to when the output reaches the  $V_{TRIP}$  (high) or  $V_{TRIP}$  (low) trip voltage.

Time  $t_{ENA}$  is calculated as shown in the equation:

 $t_{ENA} = t_{ENA\_MEASURED} - t_{TRIP}$ 

If multiple pins (such as the data bus) are enabled, the measurement value is that of the first pin to start driving.

### **Output Disable Time Measurement**

Output pins are considered to be disabled when they stop driving, go into a high impedance state, and start to decay from their output high or low voltage. The output disable time  $t_{DIS}$  is the difference between  $t_{DIS\_MEASURED}$  and  $t_{DECAY}$  as shown on the left side of Figure 45.

$$t_{DIS} = t_{DIS\_MEASURED} - t_{DECAY}$$

The time for the voltage on the bus to decay by  $\Delta V$  is dependent on the capacitive load  $C_L$  and the load current  $I_I$ . This decay time can be approximated by the equation:

$$t_{DECAY} = (C_L \Delta V) / I_L$$

The time  $t_{DECAY}$  is calculated with test loads  $C_L$  and  $I_L$ , and with  $\Delta V$  equal to 0.1 V for  $V_{DDEXT}$  (nominal) = 1.8 V or 0.5 V for  $V_{DDEXT}$  (nominal) = 2.5 V/3.3 V.

The time  $t_{DIS\_MEASURED}$  is the interval from when the reference signal switches, to when the output voltage decays  $\Delta V$  from the measured output high or output low voltage.



Figure 46. Output Enable/Disable

### **Example System Hold Time Calculation**

To determine the data output hold time in a particular system, first calculate  $t_{DECAY}$  using the equation given above. Choose  $\Delta V$  to be the difference between the processor's output voltage and the input threshold for the device requiring the hold time.  $C_L$  is the total bus capacitance (per data line), and  $I_L$  is the total leakage or three-state current (per data line). The hold time is  $t_{DECAY}$  plus the various output disable times as specified in the Timing Specifications on Page 27 (for example  $t_{DSDAT}$  for an SDRAM write cycle as shown in SDRAM Interface Timing on Page 30).



Figure 51. Typical Rise and Fall Times (10% to 90%) vs. Load Capacitance for Driver B at V<sub>DDEXT</sub> = 1.75 V



Figure 52. Typical Rise and Fall Times (10% to 90%) vs. Load Capacitance for Driver B at  $V_{DDEXT}$  = 2.25 V



Figure 53. Typical Rise and Fall Times (10% to 90%) vs. Load Capacitance for Driver B at V<sub>DDEXT</sub> = 3.65 V



Figure 54. Typical Rise and Fall Times (10% to 90%) vs. Load Capacitance for Driver C at V<sub>DDEXT</sub> = 1.75 V



Figure 55. Typical Rise and Fall Times (10% to 90%) vs. Load Capacitance for Driver C at V<sub>DDEXT</sub> = 2.25 V



Figure 56. Typical Rise and Fall Times (10% to 90%) vs. Load Capacitance for Driver C at V<sub>DDEXT</sub> = 3.65 V



Figure 57. Typical Rise and Fall Times (10% to 90%) vs. Load Capacitance for Driver D at  $V_{DDEXT} = 1.75 V$ 



Figure 58. Typical Rise and Fall Times (10% to 90%) vs. Load Capacitance for Driver D at  $V_{DDEXT}$  = 2.25 V



Figure 59. Typical Rise and Fall Times (10% to 90%) vs. Load Capacitance for Driver D at  $V_{DDEXT}$  = 3.65 V

## **OUTLINE DIMENSIONS**

Dimensions in the outline dimension figures are shown in millimeters.



COMPLIANT TO JEDEC STANDARDS MS-026-BGA

Figure 64. 176-Lead Low Profile Quad Flat Package [LQFP] (ST-176-1) Dimensions shown in millimeters



Figure 65. 160-Ball Chip Scale Package Ball Grid Array [CSP\_BGA] (BC-160-2) Dimensions shown in millimeters



Figure 66. 169-Ball Plastic Ball Grid Array [PBGA] (B-169) Dimensions shown in millimeters