FEATURES

Up to 600 MHz high performance Blackfin processor
Two 16-bit MACs, two 40-bit ALUs, four 8-bit video ALUs, 40-bit shifter
RISC-like register and instruction model for ease of programming and compiler-friendly support
Advanced debug, trace, and performance monitoring
Accepts a wide range of supply voltages for internal and I/O operations. See Specifications on Page 28
Programmable on-chip voltage regulator (ADSP-BF523/ADSP-BF525/ADSP-BF527 processors only)
Qualified for Automotive Applications. See Automotive Products on Page 87
289-ball and 208-ball CSP_BGA packages

MEMORY

132K bytes of on-chip memory (See Table 1 on Page 3 for L1 and L3 memory size details)
External memory controller with glueless support for SDRAM and asynchronous 8-bit and 16-bit memories
Flexible booting options from external flash, SPI, and TWI memory or from host devices including SPI, TWI, and UART
Code security with Lockbox Secure Technology
one-time-programmable (OTP) memory
Memory management unit providing memory protection

PERIPHERALS

USB 2.0 high speed on-the-go (OTG) with integrated PHY
IEEE 802.3-compliant 10/100 Ethernet MAC
Parallel peripheral interface (PPI), supporting ITU-R 656 video data formats
Host DMA port (HOSTDP), supporting ITU-R 656 video data formats
2 dual-channel, full-duplex synchronous serial ports (SPORTs), supporting eight stereo I²S channels
12 peripheral DMAs, 2 mastered by the Ethernet MAC
2 memory-to-memory DMAs with external request lines
Event handler with 54 interrupt inputs
Serial peripheral interface (SPI) compatible port
2 UARTs with IrDA support
2-wire interface (TWI) controller
Eight 32-bit timers/counters with PWM support
32-bit up/down counter with rotary support
Real-time clock (RTC) and watchdog timer
32-bit core timer
48 general-purpose I/Os (GPIOs), with programmable hysteresis
NAND flash controller (NFC)
Debug/JTAG interface
On-chip PLL capable of frequency multiplication

Figure 1. Processor Block Diagram
# TABLE OF CONTENTS

- **Features** ................................................................. 1  
- **Memory** ................................................................ 1  
- **Peripherals** ............................................................. 1  
- **General Description** ................................................. 3  
  - Portable Low Power Architecture ............................. 3  
  - System Integration .................................................. 3  
  - Processor Peripherals ............................................. 3  
  - Blackfin Processor Core .......................................... 4  
  - Memory Architecture ............................................ 5  
  - DMA Controllers .................................................. 9  
  - Host DMA Port .................................................... 9  
  - Real-Time Clock ................................................... 9  
  - Watchdog Timer .................................................. 10  
  - Timers .................................................................. 10  
  - Up/Down Counter and Thumbwheel Interface .......... 10  
  - Serial Ports ........................................................ 10  
  - Serial Peripheral Interface (SPI) Port ...................... 11  
  - UART Ports ....................................................... 11  
  - TWI Controller Interface ...................................... 12  
  - 10/100 Ethernet MAC .......................................... 12  
  - Ports .................................................................. 12  
  - Parallel Peripheral Interface (PPI) ......................... 13  
  - USB On-The-Go Dual-Role Device Controller .......... 14  
  - Code Security with Lockbox Secure Technology ..... 14  
  - Dynamic Power Management ............................... 14  
  - ADSP-BF523/ADSP-BF525/ADSP-BF527 Voltage Regulation ........................................... 16  
  - ADSP-BF522/ADSP-BF524/ADSP-BF526 Voltage Regulation .................................................. 16  
  - Clock Signals .......................................................... 16  
  - Booting Modes ....................................................... 18  
  - Instruction Set Description .................................... 20  
  - Development Tools ............................................... 20  
  - Additional Information .......................................... 21  
  - Related Signal Chains ......................................... 22  
  - Lockbox Secure Technology Disclaimer .................... 22  
  - Signal Descriptions ................................................. 23  
  - Specifications ........................................................ 28  
  - Operating Conditions for ADSP-BF522/ADSP-BF524/ADSP-BF526 Processors .......................... 28  
  - Operating Conditions for ADSP-BF523/ADSP-BF525/ADSP-BF527 Processors ....................... 30  
  - Electrical Characteristics ...................................... 32  
  - Absolute Maximum Ratings .................................. 37  
  - Package Information .............................................. 38  
  - ESD Sensitivity ..................................................... 38  
  - Timing Specifications ........................................... 39  
  - Output Drive Currents ......................................... 73  
  - Test Conditions .................................................... 75  
  - Environmental Conditions .................................... 79  
  - 289-Ball CSP_BGA Ball Assignment ....................... 80  
  - 208-Ball CSP_BGA Ball Assignment ....................... 83  
  - Outline Dimensions ............................................. 86  
  - Surface-Mount Design .......................................... 87  
  - Automotive Products ........................................... 87  
  - Ordering Guide ..................................................... 88

# REVISION HISTORY

7/13—Rev. C to Rev. D

Updated Development Tools ......................................... 20

Corrected footnote 9 and added footnote 11 in Operating Conditions for ADSP-BF523/ADSP-BF525/ADSP-BF527 Processors ....................... 30
GENERAL DESCRIPTION

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

The ADSP-BF52x processors are completely code compatible with other Blackfin processors. The ADSP-BF523/ADSP-BF525/ADSP-BF527 processors offer performance up to 600 MHz. The ADSP-BF522/ADSP-BF524/ADSP-BF526 processors offer performance up to 400 MHz and reduced static power consumption. Differences with respect to peripheral combinations are shown in Table 1.

PORTABLE LOW POWER ARCHITECTURE

Blackfin processors provide world-class power management and performance. They are produced with a low power and low voltage design methodology and feature on-chip dynamic power management, which is the ability to vary both the voltage and frequency of operation to significantly lower overall power consumption. This capability can result in a substantial reduction in power consumption, compared with just varying the frequency of operation. This allows longer battery life for portable appliances.

SYSTEM INTEGRATION

The ADSP-BF52x processors are highly integrated system-on-a-chip solutions for the next generation of embedded network connected applications. By combining industry-standard interfaces with a high performance signal processing core, cost-effective applications can be developed quickly, without the need for costly external components. The system peripherals include an IEEE-compliant 802.3 10/100 Ethernet MAC, a USB 2.0 high speed OTG controller, a TWI controller, a NAND flash controller, two UART ports, an SPI port, two serial ports (SPORTs), eight general purpose 32-bit timers with PWM capability, a core timer, a real-time clock, a watchdog timer, a Host DMA (HOSTDP) interface, and a parallel peripheral interface (PPI).

PROCESSOR PERIPHERALS

The ADSP-BF52x 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 block diagram on Page 1).

These Blackfin processors contain dedicated network communication modules and high speed serial and parallel ports, 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 the general-purpose I/O, TWI, real-time clock, and timers, are supported by a flexible DMA structure. There are also separate memory DMA channels 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 ADSP-BF523/ADSP-BF525/ADSP-BF527 processors include an on-chip voltage regulator in support of the processor’s dynamic power management capability. The voltage

---

Table 1. Processor Comparison

<table>
<thead>
<tr>
<th>Feature</th>
<th>ADSP-BF522</th>
<th>ADSP-BF524</th>
<th>ADSP-BF526</th>
<th>ADSP-BF523</th>
<th>ADSP-BF525</th>
<th>ADSP-BF527</th>
</tr>
</thead>
<tbody>
<tr>
<td>Host DMA</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>USB</td>
<td>–</td>
<td>1</td>
<td>1</td>
<td>–</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>Ethernet MAC</td>
<td>–</td>
<td>–</td>
<td>1</td>
<td>–</td>
<td>–</td>
<td>–</td>
</tr>
<tr>
<td>Internal Voltage Regulator</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>TWI</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>SPORTs</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
</tr>
<tr>
<td>UARTs</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
<td>2</td>
</tr>
<tr>
<td>SPI</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>GP Timers</td>
<td>8</td>
<td>8</td>
<td>8</td>
<td>8</td>
<td>8</td>
<td>8</td>
</tr>
<tr>
<td>GP Counter</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>Watchdog Timers</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>RTC</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>Parallel Peripheral Interface</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
<td>1</td>
</tr>
<tr>
<td>GPIOs</td>
<td>48</td>
<td>48</td>
<td>48</td>
<td>48</td>
<td>48</td>
<td>48</td>
</tr>
</tbody>
</table>

Memory (bytes)

| L1 Instruction SRAM     | 48K        | 48K        | 48K        | 48K        | 48K        | 48K        |
| L1 Instruction SRAM/Cache| 16K        | 16K        | 16K        | 16K        | 16K        | 16K        |
| L1 Data SRAM            | 32K        | 32K        | 32K        | 32K        | 32K        | 32K        |
| L1 Data SRAM/Cache      | 32K        | 32K        | 32K        | 32K        | 32K        | 32K        |
| L1 Scratchpad           | 4K         | 4K         | 4K         | 4K         | 4K         | 4K         |
| L3 Boot ROM             | 32K        | 32K        | 32K        | 32K        | 32K        | 32K        |

Maximum Instruction Rate

- 400 MHz
- 600 MHz

Maximum System Clock Speed

- 100 MHz
- 133 MHz

Package Options

- 289-Ball CSP_BGA
- 208-Ball CSP_BGA

1 Maximum instruction rate is not available with every possible SCLK selection.
regulator provides a range of core voltage levels when supplied from \( V_{DD}\text{EXT} \). The voltage regulator can be bypassed at the user’s discretion.

**BLACKFIN PROCESSOR CORE**

As shown in Figure 2, 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-, 16-, 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^{32} \) multiply, divide primitives, saturation and rounding, and sign/exponent detection. The set of video instructions include 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). If the second ALU is used, quad 16-bit operations are possible.

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,
The Blackfin processor assembly language uses an algebraic syntax, resulting in fast and efficient software implementations. Optimized for use in conjunction with the C/C++ compiler, this language offers ease of coding and readability. The architecture has been designed to protect system registers from unintended access.

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 processor has 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 Blackfin processor views 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 cost/performance cost/efficiency 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.

The on-chip L1 memory system is the 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 data movement capability. It can perform block transfers of code or data between the internal memory and the external memory spaces.

---

**Internal (On-Chip) Memory**

The processor has three blocks of on-chip memory providing high-bandwidth access to the core.

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

The second on-chip memory block is the L1 data memory, consisting of up to two banks of up to 32K bytes each. Each memory bank is configurable, offering both cache and SRAM functionality. This memory block is accessed at full processor speed.

The third memory block is a 4K byte scratchpad SRAM which runs at the same speed as the L1 memories, but is only accessible as data SRAM and cannot be configured as cache memory.

**External (Off-Chip) Memory**

External memory is accessed via the EBIU. This 16-bit interface provides a glueless connection to a bank of synchronous DRAM (SDRAM), as well as up to four banks of asynchronous memory devices including flash, EPROM, ROM, SRAM, and memory mapped I/O devices.
The SDRAM controller can be programmed to interface to up to 128M bytes of SDRAM. A separate row can be open for each SDRAM internal bank and the SDRAM controller supports up to 4 internal SDRAM banks, improving overall performance. The asynchronous memory controller can be programmed to control up to four banks of devices with very flexible timing requirements for a wide variety of devices. Each bank occupies a 1M byte segment regardless of the size of the devices used, so that these banks are only contiguous if each is fully populated with 1M byte of memory.

**NAND Flash Controller (NFC)**

The ADSP-BF52x processors provide a NAND flash controller (NFC). NAND flash devices provide high-density, low-cost memory. However, NAND flash devices also have long random access times, invalid blocks, and lower reliability over device lifetimes. Because of this, NAND flash is often used for read-only code storage. In this case, all DSP code can be stored in NAND flash and then transferred to a faster memory (such as SDRAM or SRAM) before execution. Another common use of NAND flash is for storage of multimedia files or other large data segments. In this case, a software file system may be used to manage reading and writing of the NAND flash device. The file system selects memory segments for storage with the goal of avoiding bad blocks and equally distributing memory accesses across all address locations. Hardware features of the NFC include:

- Support for page program, page read, and block erase of NAND flash devices, with accesses aligned to page boundaries.
- Error checking and correction (ECC) hardware that facilitates error detection and correction.
- A single 8-bit external bus interface for commands, addresses, and data.
- Support for SLC (single level cell) NAND flash devices unlimited in size, with page sizes of 256 and 512 bytes. Larger page sizes can be supported in software.
- Capability of releasing external bus interface pins during long accesses.
- Support for internal bus requests of 16 bits.
- DMA engine to transfer data between internal memory and NAND flash device.

**One-Time Programmable Memory**

The processor has 64K bits of one-time programmable non-volatile memory that can be programmed by the developer only one time. It includes the array and logic to support read access and programming. Additionally, its pages can be write protected.

OTP enables developers to store both public and private data on-chip. In addition to storing public and private key data for applications requiring security, it also allows developers to store completely user-definable data such as customer ID, product ID, MAC address, etc. Hence, generic parts can be shipped, which are then programmed and protected by the developer within this non-volatile memory.

**I/O Memory Space**

The processor does not define a separate I/O space. All resources are mapped through the flat 32-bit address space. On-chip I/O devices have their control registers mapped into memory-mapped registers (MMRs) at addresses near the top of the 4G byte address space. These are separated into two smaller blocks, one which contains the control MMRs for all core functions, and the other which contains the registers needed for setup and control of the on-chip peripherals outside of the core. The MMRs are accessible only in supervisor mode and appear as reserved space to on-chip peripherals.

**Booting**

The processor contains a small on-chip boot kernel, which configures the appropriate peripheral for booting. If the processor is configured to boot from boot ROM memory space, the processor starts executing from the on-chip boot ROM. For more information, see Booting Modes on Page 18.

**Event Handling**

The event controller on the processor handles all asynchronous and synchronous events to the processor. The processor provides event handling that supports both nesting and prioritization. Nesting allows multiple event service routines to be active simultaneously. Prioritization ensures that servicing of a higher-priority event takes precedence over servicing of a lower-priority event. The controller provides support for five different types of events:

- **Emulation** — An emulation event causes the processor to enter emulation mode, allowing command and control of the processor via the JTAG interface.
- **RESET** — This event resets the processor.
- **Nonmaskable Interrupt (NMI)** — The NMI event can be generated by the software watchdog timer or by the NMI input signal to the processor. The NMI event is frequently used as a power-down indicator to initiate an orderly shutdown of the system.
- **Exceptions** — Events that occur synchronously to program flow (in other words, the exception is taken before the instruction is allowed to complete). Conditions such as data alignment violations and undefined instructions cause exceptions.
- **Interrupts** — Events that occur asynchronously to program flow. They are caused by input signals, timers, and other peripherals, as well as by an explicit software instruction.

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 processor 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.

**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 processor provides 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 2. Core Event Controller (CEC)

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

### Table 3. System Interrupt Controller (SIC)

<table>
<thead>
<tr>
<th>Peripheral Interrupt Event</th>
<th>General Purpose Interrupt (at RESET)</th>
<th>Peripheral Interrupt ID</th>
<th>Default Core Interrupt ID</th>
<th>SIC Registers</th>
</tr>
</thead>
<tbody>
<tr>
<td>PLL Wakeup Interrupt</td>
<td>IVG7</td>
<td>0</td>
<td>0</td>
<td>IAR0</td>
</tr>
<tr>
<td>DMA Error 0 (generic)</td>
<td>IVG7</td>
<td>1</td>
<td>0</td>
<td>IAR0</td>
</tr>
<tr>
<td>DMAR0 Block Interrupt</td>
<td>IVG7</td>
<td>2</td>
<td>0</td>
<td>IAR0</td>
</tr>
<tr>
<td>DMAR1 Block Interrupt</td>
<td>IVG7</td>
<td>3</td>
<td>0</td>
<td>IAR0</td>
</tr>
<tr>
<td>DMAR0 Overflow Error</td>
<td>IVG7</td>
<td>4</td>
<td>0</td>
<td>IAR0</td>
</tr>
<tr>
<td>DMAR1 Overflow Error</td>
<td>IVG7</td>
<td>5</td>
<td>0</td>
<td>IAR0</td>
</tr>
<tr>
<td>PPI Error</td>
<td>IVG7</td>
<td>6</td>
<td>0</td>
<td>IAR0</td>
</tr>
<tr>
<td>MAC Status</td>
<td>IVG7</td>
<td>7</td>
<td>0</td>
<td>IAR0</td>
</tr>
<tr>
<td>SPORT0 Status</td>
<td>IVG7</td>
<td>8</td>
<td>0</td>
<td>IAR1</td>
</tr>
<tr>
<td>SPORT1 Status</td>
<td>IVG7</td>
<td>9</td>
<td>0</td>
<td>IAR1</td>
</tr>
<tr>
<td>Reserved</td>
<td>IVG7</td>
<td>10</td>
<td>0</td>
<td>IAR1</td>
</tr>
<tr>
<td>Reserved</td>
<td>IVG7</td>
<td>11</td>
<td>0</td>
<td>IAR1</td>
</tr>
<tr>
<td>UART0 Status</td>
<td>IVG7</td>
<td>12</td>
<td>0</td>
<td>IAR1</td>
</tr>
<tr>
<td>UART1 Status</td>
<td>IVG7</td>
<td>13</td>
<td>0</td>
<td>IAR1</td>
</tr>
<tr>
<td>RTC</td>
<td>IVG8</td>
<td>14</td>
<td>1</td>
<td>IAR1</td>
</tr>
<tr>
<td>DMA Channel 0 (PPI/NFC)</td>
<td>IVG8</td>
<td>15</td>
<td>1</td>
<td>IAR1</td>
</tr>
<tr>
<td>DMA Channel 3 (SPORT0 RX)</td>
<td>IVG9</td>
<td>16</td>
<td>2</td>
<td>IAR2</td>
</tr>
<tr>
<td>DMA Channel 4 (SPORT0 TX)</td>
<td>IVG9</td>
<td>17</td>
<td>2</td>
<td>IAR2</td>
</tr>
<tr>
<td>DMA Channel 5 (SPORT1 RX)</td>
<td>IVG9</td>
<td>18</td>
<td>2</td>
<td>IAR2</td>
</tr>
<tr>
<td>DMA Channel 6 (SPORT1 TX)</td>
<td>IVG9</td>
<td>19</td>
<td>2</td>
<td>IAR2</td>
</tr>
<tr>
<td>TWI</td>
<td>IVG10</td>
<td>20</td>
<td>3</td>
<td>IAR2</td>
</tr>
<tr>
<td>DMA Channel 7 (SPI)</td>
<td>IVG10</td>
<td>21</td>
<td>3</td>
<td>IAR2</td>
</tr>
<tr>
<td>DMA Channel 8 (UART0 RX)</td>
<td>IVG10</td>
<td>22</td>
<td>3</td>
<td>IAR2</td>
</tr>
<tr>
<td>DMA Channel 9 (UART0 TX)</td>
<td>IVG10</td>
<td>23</td>
<td>3</td>
<td>IAR2</td>
</tr>
<tr>
<td>DMA Channel 10 (UART1 RX)</td>
<td>IVG10</td>
<td>24</td>
<td>3</td>
<td>IAR3</td>
</tr>
<tr>
<td>DMA Channel 11 (UART1 TX)</td>
<td>IVG10</td>
<td>25</td>
<td>3</td>
<td>IAR3</td>
</tr>
</tbody>
</table>
Event Control

The processor provides 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 16 bits wide.

- **CEC interrupt latch register (ILAT)** — 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 may be written only when its corresponding IMASK bit is cleared.

- **CEC interrupt mask register (IMASK)** — 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 may 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 may be read while in supervisor mode.

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

- **SIC interrupt mask registers (SIC_IMASKx)** — Control the masking and unmasking of each peripheral interrupt event. When a bit is set in these registers, that peripheral event is...
unmasked and is processed by the system when asserted. A cleared bit in the register masks the peripheral event, preventing the processor from servicing the event.

- SIC interrupt status registers (SIC_ISRx) — As multiple peripherals can be mapped to a single event, these registers allow 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 registers (SIC_IWRx) — By enabling the corresponding bit in these registers, a peripheral can be configured to wake up the processor, should the core be idled or in sleep mode when the event is generated. For more information see Dynamic Power Management on Page 14.

Because multiple interrupt sources can map to a single general-purpose 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 processor has 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 Ethernet MAC, NFC, HOSTDP, USB, SPORTs, SPI port, UARTs, and PPI. Each individual DMA-capable peripheral has at least one dedicated DMA channel.

The processor DMA controller supports both one-dimensional (1-D) and two-dimensional (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 ±32K 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 processor DMA controller include:

- A single, linear buffer that stops upon completion.
- A circular, auto-refreshing 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 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.

The processor also has an external DMA controller capability via dual external DMA request pins when used in conjunction with the external bus interface unit (EBIU). This functionality can be used when a high speed interface is required for external FIFOs and high bandwidth communications peripherals such as USB 2.0. It allows control of the number of data transfers for memory DMA. The number of transfers per edge is programmable. This feature can be programmed to allow memory DMA to have an increased priority on the external bus relative to the core.

**HOST DMA PORT**

The host port interface allows an external host to be a DMA master to transfer data in and out of the device. The host device masters the transactions and the Blackfin processor is the DMA slave.

The host port is enabled through the PAB interface. Once enabled, the DMA is controlled by the external host, which can then program the DMA to send/receive data to any valid internal or external memory location.

The host port interface controller has the following features.

- Allows external master to configure DMA read/write data transfers and read port status.
- Uses asynchronous memory protocol for external interface.
- 8-/16-bit external data interface to host device.
- Half duplex operation.
- Little-/big-endian data transfer.
- Acknowledge mode allows flow control on host transactions.
- Interrupt mode guarantees a burst of FIFO depth host transactions.

**REAL-TIME CLOCK**

The 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 Blackfin processor. Connect RTC pins RTXI and RTXO with external...
components as shown in Figure 4.

![Figure 4. External Components for RTC](image)

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 an 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. There are two alarms: The first alarm is for a time of day. The second alarm is for a day and time of that day.

The stopwatch function counts down from a programmed value, with one-second resolution. When the stopwatch is enabled and the counter underflows, an interrupt is generated. Like the other peripherals, the RTC can wake up the processor from sleep mode upon generation of any RTC wake-up event. Additionally, an RTC wake-up event can wake up the processor from deep sleep mode or cause a transition from the hibernate state.

**WATCHDOG TIMER**

The processor includes a 32-bit timer that can be used to implement a software watchdog function. A software watchdog can improve system availability by forcing the processor to a known state through generation of a hardware reset, nonmaskable interrupt (NMI), or general-purpose interrupt, if the timer expires before being reset by software. The programmer initializes the count value of the timer, enables the appropriate interrupt, then enables the timer. Thereafter, the software must reload the counter before it counts to zero from the programmed value. This protects the system from remaining in an unknown state where software, which would normally reset the timer, has stopped running due to an external noise condition or software error.

If configured to generate a hardware reset, the watchdog timer resets both the core and the processor peripherals. After a reset, software can determine if the watchdog was the source of the hardware reset by interrogating a status bit in the watchdog timer control register.

The timer is clocked by the system clock (SCLK), at a maximum frequency of $f_{SCLK}$.

**TIMERS**

There are nine general-purpose programmable timer units in the processors. Eight timers have an external pin that can be configured either as a pulse width modulator (PWM) or timer output, as an input to clock the timer, or as a mechanism for measuring pulse widths and periods of external events. These timers can be synchronized to an external clock input to the several other associated PF pins, an external clock input to the PPI_CLK input pin, or to the internal SCLK.

The timer units can be used in conjunction with the two UARTs to measure the width of the pulses in the data stream to provide a software auto-baud detect function for the respective serial channels.

The timers can generate interrupts to the processor core providing periodic events for synchronization, either to the system clock or to a count of external signals.

In addition to the eight general-purpose programmable timers, a ninth timer is also provided. This extra timer is clocked by the internal processor clock and is typically used as a system tick clock for generation of operating system periodic interrupts.

**UP/DOWN COUNTER AND THUMBWHEEL INTERFACE**

A 32-bit up/down counter is provided that can sense 2-bit quadrature or binary codes as typically emitted by industrial drives or manual thumb wheels. The counter can also operate in general-purpose up/down count modes. Then, count direction is either controlled by a level-sensitive input pin or by two edge detectors.

A third input can provide flexible zero marker support and can alternatively be used to input the push-button signal of thumb wheels. All three pins have a programmable debouncing circuit.

An internal signal forwarded to the timer unit enables one timer to measure the intervals between count events. Boundary registers enable auto-zero operation or simple system warning by interrupts when programmable count values are exceeded.

**SERIAL PORTS**

The processors incorporate two dual-channel synchronous serial ports (SPORT0 and SPORT1) for serial and multiprocessor communications. The SPORTs support the following features:

- 1S capable operation.
• Bidirectional operation — Each SPORT has two sets of independent transmit and receive pins, enabling eight channels of 16-channel stereo audio.

• Buffered (8-deep) transmit and receive ports — Each port has a data register for transferring data words to and from other processor components and shift registers for shifting data in and out of the data registers.

• Clocking — Each transmit and receive port can either use an external serial clock or generate its own, in frequencies ranging from \( (f_{SCLK}/131,070) \) Hz to \( (f_{SCLK}/2) \) Hz.

• Word length — Each SPORT supports serial data words from 3 to 32 bits in length, transferred most-significant-bit first or least-significant-bit first.

• Framing — Each transmit and receive port can run with or without frame sync signals for each data word. Frame sync signals can be generated internally or externally, active high or low, and with either of two pulse widths and early or late frame sync.

• Comping in hardware — Each SPORT can perform A-law or \( \mu \)-law companding according to ITU recommendation G.711. Comping can be selected on the transmit and/or receive channel of the SPORT without additional latencies.

• DMA operations with single-cycle overhead — Each SPORT can automatically receive and transmit multiple buffers of memory data. The processor can link or chain sequences of DMA transfers between a SPORT and memory.

• 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 1024-channel window and is compatible with the H.100, H.110, MVIP-90, and HMVIP standards.

SERIAL PERIPHERAL INTERFACE (SPI) PORT

The 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 SPI port's baud rate and clock phase/polarities are programmable, and it has an integrated DMA channel, configurable to support transmit or receive data streams. The SPI's DMA channel can only service unidirectional accesses at any given time.

The SPI port's clock rate is calculated as:

\[
\text{SPI Clock Rate} = \frac{f_{SCLK}}{2 \times \text{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 PORTS

The processors provide two full-duplex universal asynchronous receiver/transmitter (UART) ports, which are fully compatible with PC-standard UARTs. Each UART port provides a simplified UART interface to other peripherals or hosts, supporting full-duplex, DMA-supported, asynchronous transfers of serial data. A UART port includes support for five to eight data bits, one or two stop bits, and none, even, or odd parity. Each 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.

Each UART port's baud rate, serial data format, error code generation and status, and interrupts are programmable:

• Supporting bit rates ranging from \( (f_{SCLK}/1,048,576) \) to \( (f_{SCLK}/16) \) bits per second.

• Supporting data formats from seven 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:

\[
\text{UART Clock Rate} = \frac{f_{SCLK}}{16 \times \text{UART_Divisor}}
\]

Where the 16-bit UART_Divisor comes from the UART_DLH (most significant 8 bits) and UART_DLL (least significant 8 bits) registers.

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

The capabilities of the UARTs are further extended with support for the infrared data association (IrDA) serial infrared physical layer link specification (SIR) protocol.
TWI CONTROLLER INTERFACE

The processors include a 2-wire interface (TWI) module for providing a simple exchange method of control data between multiple devices. The TWI is compatible with the widely used I2C® bus standard. The TWI module offers the capabilities of simultaneous master and slave operation and support for both 7-bit addressing and multimedia data arbitration. The TWI interface utilizes two pins for transferring clock (SCL) and data (SDA) and supports the protocol at speeds up to 400k bits/sec. The TWI interface pins are compatible with 5 V logic levels.

Additionally, the TWI module is fully compatible with serial camera control bus (SCCB) functionality for easier control of various CMOS camera sensor devices.

10/100 ETHERNET MAC

The ADSP-BF526 and ADSP-BF527 processors offer the capability to directly connect to a network by way of an embedded Fast Ethernet Media Access Controller (MAC) that supports both 10-BaseT (10M bits/sec) and 100-BaseT (100M bits/sec) operation. The 10/100 Ethernet MAC peripheral on the processor is fully compliant to the IEEE 802.3-2002 standard and it provides programmable features designed to minimize supervision, bus use, or message processing by the rest of the processor system.

Some standard features are:

- Support of MII and RMII protocols for external PHYs.
- Full duplex and half duplex modes.
- Data framing and encapsulation: generation and detection of preamble, length padding, and FCS.
- Media access management (in half-duplex operation): collision and contention handling, including control of retransmission of collision frames and of back-off timing.
- Flow control (in full-duplex operation): generation and detection of PAUSE frames.
- Station management: generation of MDC/MDIO frames for read-write access to PHY registers.
- Operating range for active and sleep operating modes, see Table 58 on Page 68 and Table 59 on Page 68.
- Internal loopback from Tx to Rx.

Some advanced features are:

- Buffered crystal output to external PHY for support of a single crystal system.
- Automatic checksum computation of IP header and IP payload fields of Rx frames.
- Independent 32-bit descriptor-driven Rx and Tx DMA channels.
- Frame status delivery to memory via DMA, including frame completion semaphores, for efficient buffer queue management in software.
- Tx DMA support for separate descriptors for MAC header and payload to eliminate buffer copy operations.
- Convenient frame alignment modes support even 32-bit alignment of encapsulated Rx or Tx IP packet data in memory after the 14-byte MAC header.
- Programmable Ethernet event interrupt supports any combination of:
  - Any selected Rx or Tx frame status conditions.
  - PHY interrupt condition.
  - Wake-up frame detected.
  - Any selected MAC management counter(s) at half-full.
  - DMA descriptor error.
- 47 MAC management statistics counters with selectable clear-on-read behavior and programmable interrupts on half maximum value.
- Programmable Rx address filters, including a 64-bin address hash table for multicast and/or unicast frames, and programmable filter modes for broadcast, multicast, unicast, control, and damaged frames.
- Advanced power management supporting unattended transfer of Rx and Tx frames and status to/from external memory via DMA during low power sleep mode.
- System wakeup from sleep operating mode upon magic packet or any of four user-definable wakeup frame filters.
- Support for 802.3Q tagged VLAN frames.
- Programmable MDC clock rate and preamble suppression.
- In RMII operation, seven unused pins may be configured as GPIO pins for other purposes.

PORTS

Because of the rich set of peripherals, the processor groups the many peripheral signals to four ports—Port F, Port G, Port H, and Port J. Most of the associated pins are shared by multiple signals. The ports function as multiplexer controls.

General-Purpose I/O (GPIO)

The processor has 48 bidirectional, general-purpose I/O (GPIO) pins allocated across three separate GPIO modules—PORTFIO, PORTGIO, and PORTHIO, associated with Port F, Port G, and Port H, respectively. Port J does not provide GPIO functionality. Each GPIO-capable pin shares functionality with other processor peripherals via a multiplexing scheme; however, the GPIO functionality is the default state of the device upon power-up. Neither GPIO output nor input drivers are active by default.
Each general-purpose port pin can be individually controlled by manipulation of the port control, status, and interrupt registers:

- GPIO direction control register — Specifies the direction of each individual GPIO 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 pin values, one register is written in order to clear pin values, one register is written in order to toggle pin values, and one register is written in order to specify a pin value. Reading the GPIO status register allows software to interrogate the sense of the pins.
- GPIO interrupt mask registers — The two GPIO interrupt mask registers allow each individual GPIO pin to function as an interrupt to the processor. Similar to the two GPIO control registers that are used to set and clear individual 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. GPIO pins defined as inputs can be configured to generate hardware interrupts, while output pins can be triggered by software interrupts.
- GPIO interrupt sensitivity registers — The two GPIO interrupt sensitivity registers specify whether individual pins are level- or edge-sensitive and specify—if edge-sensitive—whether just the rising edge or both the rising and falling edges of the signal are significant. One register selects the type of sensitivity, and one register selects which edges are significant for edge-sensitivity.

**PARALLEL PERIPHERAL INTERFACE (PPI)**

The processor provides a parallel peripheral interface (PPI) that can connect directly to parallel analog-to-digital and digital-to-analog converters, video encoders and decoders, and other general-purpose peripherals. The PPI consists of a dedicated input clock pin, up to three frame synchronization pins, and up to 16 data pins. The input clock supports parallel data rates up to half the system clock rate, and the synchronization signals can be configured as either inputs or outputs.

The PPI supports a variety of general-purpose and ITU-R 656 modes of operation. In general-purpose mode, the PPI provides half-duplex, bidirectional data transfer with up to 16 bits of data. Up to three frame synchronization signals are also provided. In ITU-R 656 mode, the PPI provides half-duplex bidirectional transfer of 8- or 10-bit video data. Additionally, on-chip decode of embedded start-of-line (SOL) and start-of-field (SOF) preamble packets is supported.

**General-Purpose Mode Descriptions**

The general-purpose modes of the PPI are intended to suit a wide variety of video capture, processing, and transmission applications. Three distinct submodes are supported:

1. **Input mode** — Frame syncs and data are inputs into the PPI.
2. **Frame capture mode** — Frame syncs are outputs from the PPI, but data are inputs.
3. **Output mode** — Frame syncs and data are outputs from the PPI.

**Input Mode**

Input mode is intended for ADC applications, as well as video communication with hardware signaling. In its simplest form, PPI_FS1 is an external frame sync input that controls when to read data. The PPI_DELAY MMR allows for a delay (in PPI_CLK cycles) between reception of this frame sync and the initiation of data reads. The number of input data samples is user programmable and defined by the contents of the PPI_COUNT register. The PPI supports 8-bit and 10-bit through 16-bit data, programmable in the PPI_CONTROL register.

**Frame Capture Mode**

Frame capture mode allows the video source(s) to act as a slave (for frame capture for example). The ADSP-BF52x processors control when to read from the video source(s). PPI_FS1 is an HSYNC output, and PPI_FS2 is a VSYNC output.

**Output Mode**

Output mode is used for transmitting video or other data with up to three output frame syncs. Typically, a single frame sync is appropriate for data converter applications, whereas two or three frame syncs could be used for sending video with hardware signaling.

**ITU-R 656 Mode Descriptions**

The ITU-R 656 modes of the PPI are intended to suit a wide variety of video capture, processing, and transmission applications. Three distinct submodes are supported:

1. **Active video only mode**
2. **Vertical blanking only mode**
3. **Entire field mode**

**Active Video Mode**

Active video only mode is used when only the active video portion of a field is of interest and not any of the blanking intervals. The PPI does not read in any data between the end of active video (EAV) and start of active video (SAV) preamble symbols, or any data present during the vertical blanking intervals. In this mode, the control byte sequences are not stored to memory; they are filtered by the PPI. After synchronizing to the start of Field 1, the PPI ignores incoming samples until it sees an SAV code. The user specifies the number of active video lines per frame (in PPI_COUNT register).

**Vertical Blanking Interval Mode**

In this mode, the PPI only transfers vertical blanking interval (VBI) data.
Entire Field Mode
In this mode, the entire incoming bit stream is read in through the PPI. This includes active video, control preamble sequences, and ancillary data that may be embedded in horizontal and vertical blanking intervals. Data transfer starts immediately after synchronization to Field 1. Data is transferred to or from the synchronous channels through eight DMA engines that work autonomously from the processor core.

USB ON-THE-GO DUAL-ROLE DEVICE CONTROLLER
The USB OTG dual-role device controller (USBDRC) provides a low-cost connectivity solution for consumer mobile devices such as cell phones, digital still cameras, and MP3 players, allowing these devices to transfer data using a point-to-point USB connection without the need for a PC host. The USBDRC module can operate in a traditional USB peripheral-only mode as well as the host mode presented in the On-the-Go (OTG) supplement to the USB 2.0 specification. In host mode, the USB module supports transfers at high speed (480 Mbps), full speed (12 Mbps), and low speed (1.5 Mbps) rates. Peripheral-only mode supports the high- and full-speed transfer rates.

The USB clock (USB_XI) is provided through a dedicated external crystal or crystal oscillator. See Universal Serial Bus (USB) On-The-Go—Receive and Transmit Timing on Page 60 for related timing requirements. If using a crystal to provide the USB clock, use a parallel-resonant, fundamental mode, microprocessor-grade crystal.

The USB on-the-go dual-role device controller includes a phase locked loop with programmable multipliers to generate the necessary internal clocking frequency for USB. The multiplier value should be programmed based on the USB_XI frequency to achieve the necessary 480 MHz internal clock for USB high speed operation. For example, for a USB_XI crystal frequency of 24 MHz, the USB_PLLOSC_CTRL register should be programmed with a multiplier value of 20 to generate a 480 MHz internal clock.

CODE SECURITY WITH LOCKBOX SECURE TECHNOLOGY
A security system consisting of a blend of hardware and software provides customers with a flexible and rich set of code security features with Lockbox™ Secure Technology. Key features include:
• OTP memory
• Unique chip ID
• Code authentication
• Secure mode of operation

The security scheme is based upon the concept of authentication of digital signatures using standards-based algorithms and provides a secure processing environment in which to execute code and protect assets. See Lockbox Secure Technology Disclaimer on Page 22.

DYNAMIC POWER MANAGEMENT
The processor provides five operating modes, each with a different performance/power profile. In addition, dynamic power management provides the control functions to dynamically alter the processor core supply voltage, further reducing power dissipation. When configured for a 0 V core supply voltage, the processor enters the hibernate state. Control of clocking to each of the processor peripherals also reduces power consumption. See Table 4 for a summary of the power settings for each mode.

Table 4. Power Settings

<table>
<thead>
<tr>
<th>Mode/State</th>
<th>PLL Bypassed</th>
<th>Core Clock (CCLK)</th>
<th>System Clock (SCLK)</th>
<th>Core Power</th>
</tr>
</thead>
<tbody>
<tr>
<td>Full-On</td>
<td>Enabled</td>
<td>No</td>
<td>Enabled</td>
<td>On</td>
</tr>
<tr>
<td>Active</td>
<td>Enabled/</td>
<td>Yes</td>
<td>Enabled</td>
<td>On</td>
</tr>
<tr>
<td>Sleep</td>
<td>Enabled</td>
<td>—</td>
<td>Disabled</td>
<td>On</td>
</tr>
<tr>
<td>Deep Sleep</td>
<td>Disabled</td>
<td>—</td>
<td>Disabled</td>
<td>Off</td>
</tr>
<tr>
<td>Hibernate</td>
<td>Disabled</td>
<td>—</td>
<td>Disabled</td>
<td>—</td>
</tr>
</tbody>
</table>

Full-On Operating Mode—Maximum Performance
In the full-on mode, the PLL is enabled and is not bypassed, providing capability for maximum operational frequency. This is the power-up default execution state in which maximum performance can be achieved. The processor core and all enabled peripherals run at full speed.

Active Operating Mode—Moderate Dynamic Power Savings
In the active mode, the PLL is enabled but bypassed. Because the PLL is bypassed, the processor’s core clock (CCLK) and system clock (SCLK) run at the input clock (CLKIN) frequency. DMA access is available to appropriately configured L1 memories.

In the active mode, it is possible to disable the control input to the PLL by setting the PLL_OFF bit in the PLL control register. This register can be accessed with a user-callable routine in the on-chip ROM called bfrom_SysControl(). If disabled, the PLL control input must be re-enabled before transitioning to the full-on or sleep modes.

For more information about PLL controls, see the “Dynamic Power Management” chapter in the ADSP-BF52x Blackfin Processor Hardware Reference.

Sleep Operating Mode—High Dynamic Power Savings
The sleep mode reduces dynamic power dissipation by disabling the clock to the processor core (CCLK). The PLL and system clock (SCLK), however, continue to operate in this mode. Typically, an external event or RTC activity wakes up the processor. When in the sleep mode, asserting a wakeup enabled in the SIC_IWRx registers causes the processor to sense the value of the BYPASS bit in the PLL control register (PLL_CTL). If BYPASS is disabled, the processor transitions to the full-on mode. If BYPASS is enabled, the processor transitions to the active mode.
System DMA access to L1 memory is not supported in sleep mode.

**Deep Sleep Operating Mode—Maximum Dynamic Power Savings**

The deep sleep mode maximizes dynamic power savings by disabling the clocks to the processor core (CCLK) and to all synchronous peripherals (SCLK). Asynchronous peripherals, such as the RTC, may still be running but cannot access internal resources or external memory. This powered-down mode can only be exited by assertion of the reset interrupt (RESET) or by an asynchronous interrupt generated by the RTC. When in deep sleep mode, an RTC asynchronous interrupt causes the processor to transition to the Active mode. Assertion of RESET while in deep sleep mode causes the processor to transition to the full on mode.

**Hibernate State—Maximum Static Power Savings**

The hibernate state maximizes static power savings by disabling the voltage and clocks to the processor core (CCLK) and to all of the synchronous peripherals (SCLK). The internal voltage regulator (ADSP-BF523/ADSP-BF525/ADSP-BF527 only) for the processor can be shut off by writing b#00 to the FREQ bits of the VR_CTL register, using the bfrom_SysControl() function. This setting sets the internal power supply voltage (VDDINT) to 0 V to provide the lowest static power dissipation. Any critical information stored internally (for example, memory contents, register contents, and other information) must be written to a non volatile storage device prior to removing power if the processor state is to be preserved. Writing b#00 to the FREQ bits also causes EXT_WAKE0 and EXT_WAKE1 to transition low, which can be used to signal an external voltage regulator to shut down.

Since VDDEXT and VDDMEM can still be supplied in this mode, all of the external pins three-state, unless otherwise specified. This allows other devices that may be connected to the processor to still have power applied without drawing unwanted current.

The Ethernet or USB modules can wake up the internal supply regulator (ADSP-BF525 and ADSP-BF527 only) or signal an external regulator to wake up using EXT_WAKE0 or EXT_WAKE1. If PG15 does not connect as a PHYINT signal to an external PHY device, PG15 can be pulled low by any other device to wake the processor up. The processor can also be woken up by a real-time clock wakeup event or by asserting the reset pin. All hibernate wake-up events initiate the hardware reset sequence. Individual sources are enabled by the VR_CTL register. The EXT_WAKE0 signals are provided to indicate the occurrence of wake-up events.

As long as VDDEXT is applied, the VR_CTL register maintains its state during hibernation. All other internal registers and memories, however, lose their content in the hibernate state. State variables may be held in external SRAM or SDRAM. The SCKELOW bit in the VR_CTL register controls whether or not SDRAM operates in self-refresh mode, which allows it to retain its content while the processor is in hibernate and through the subsequent reset sequence.

---

### Power Savings

As shown in Table 5, the processor supports six different power domains, which maximizes flexibility while maintaining compliance with industry standards and conventions. By isolating the internal logic of the processor into its own power domain, separate from the RTC and other I/O, the processor can take advantage of dynamic power management without affecting the RTC or other I/O devices. There are no sequencing requirements for the various power domains, but all domains must be powered according to the appropriate specifications table for processor Operating Conditions; even if the feature/peripheral is not used.

<table>
<thead>
<tr>
<th>Table 5. Power Domains</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Power Domain</strong></td>
</tr>
<tr>
<td>All internal logic, except RTC, Memory, USB, OTP</td>
</tr>
<tr>
<td>RTC internal logic and crystal I/O</td>
</tr>
<tr>
<td>Memory logic</td>
</tr>
<tr>
<td>USB PHY logic</td>
</tr>
<tr>
<td>OTP logic</td>
</tr>
<tr>
<td>All other I/O</td>
</tr>
</tbody>
</table>

The dynamic power management feature of the processor allows both the processor’s input voltage (VDDINT) and clock frequency (fCCLK) to be dynamically controlled.

The power dissipated by a processor is largely a function of its clock frequency and the square of the operating voltage. For example, reducing the clock frequency by 25% results in a 25% reduction in dynamic power dissipation, while reducing the voltage by 25% reduces dynamic power dissipation by more than 40%. Further, these power savings are additive, in that if the clock frequency and supply voltage are both reduced, the power savings can be dramatic, as shown in the following equations.

### Power Savings Factor

\[
\% \text{ Power Savings} = (1 - \text{Power Savings Factor}) \times 100\%
\]

\[
\text{Power Savings Factor} = \frac{f_{\text{CCLKNOM}}}{f_{\text{CCLKRED}}} \times \left(\frac{V_{\text{DDINTNOM}}}{V_{\text{DDINTRED}}}\right)^2 \times \left(\frac{T_{\text{RED}}}{T_{\text{NOM}}}\right)
\]

where the variables in the equations are:

- \(f_{\text{CCLKNOM}}\) is the nominal core clock frequency
- \(f_{\text{CCLKRED}}\) is the reduced core clock frequency
- \(V_{\text{DDINTNOM}}\) is the nominal internal supply voltage
- \(V_{\text{DDINTRED}}\) is the reduced internal supply voltage
- \(T_{\text{NOM}}\) is the duration running at \(f_{\text{CCLKNOM}}\)
- \(T_{\text{RED}}\) is the duration running at \(f_{\text{CCLKRED}}\)
ADSP-BF523/ADSP-BF525/ADSP-BF527 VOLTAGE REGULATION

The ADSP-BF523/ADSP-BF525/ADSP-BF527 provides an on-chip voltage regulator that can generate processor core voltage levels from an external supply. Figure 5 shows the typical external components required to complete the power management system.

The regulator controls the internal logic voltage levels and is programmable with the voltage regulator control register (VR_CTL) in increments of 50 mV. This register can be accessed using the bfrom_SYSControl() function in the on-chip ROM. To reduce standby power consumption, the internal voltage regulator can be programmed to remove power to the processor core while keeping I/O power supplied. While in the hibernate state, all external supplies (VDDINT, VDDMEM, VDDUSB, VDDOTP) can still be applied, eliminating the need for external buffers. VDDINT must be applied at all times for correct hibernate operation. The external voltage regulator can be activated from this power down state either through an RTC wakeup, a USB wakeup, an Ethernet wakeup, or by asserting the RESET pin, each of which then initiates a boot sequence. EXT_WAKE0 or EXT_WAKE1 indicate a wakeup to the external voltage regulator. The Power Good (PG) input signal allows the processor to start only after the internal voltage has reached a chosen level. In this way, the startup time of the external regulator is detected after hibernation. For a complete description of Soft Start and Power Good functionality, refer to the ADSP-BF52x Blackfin Processor Hardware Reference.

ADSP-BF522/ADSP-BF524/ADSP-BF526 VOLTAGE REGULATION

The ADSP-BF522/ADSP-BF524/ADSP-BF526 processor requires an external voltage regulator to power the VDDINT domain. To reduce standby power consumption, the external voltage regulator can be signaled through EXT_WAKE0 or EXT_WAKE1 to remove power from the processor core. These identical signals are high-true for power-up and may be connected directly to the low-true shut down input of many common regulators. While in the hibernate state, all external supplies (VDDINT, VDDMEM, VDDUSB, VDDOTP) can still be applied, eliminating the need for external buffers. VDDINT must be applied at all times for correct hibernate operation. The external voltage regulator can be activated from this power down state either through an RTC wakeup, a USB wakeup, an Ethernet wakeup, or by asserting the RESET pin, each of which then initiates a boot sequence. EXT_WAKE0 or EXT_WAKE1 indicate a wakeup to the external voltage regulator. The Power Good (PG) input signal allows the processor to start only after the internal voltage has reached a chosen level. In this way, the startup time of the external regulator is detected after hibernation. For a complete description of the Power Good functionality, refer to the ADSP-BF52x Blackfin Processor Hardware Reference.

CLOCK SIGNALS

The processor can be clocked by an external crystal, a sine wave input, or a buffered, shaped clock derived from an external clock oscillator.

If an external clock is used, it should be a TTL compatible signal and must not be halted, changed, or operated below the specified frequency during normal operation. This signal is connected to the processor's CLKIN pin. When an external clock is used, the XTAL pin must be left unconnected. Alternatively, because the processor includes an on-chip oscillator circuit, an external crystal may be used. For fundamental frequency operation, use the circuit shown in Figure 6. A parallel-resonant, fundamental frequency, microprocessor-grade crystal is connected across the CLKIN and XTAL pins. The on-chip resistance between CLKIN and the XTAL pin is in the 500 kΩ range. Further parallel resistors are typically not recommended. The two capacitors and the series resistor shown in Figure 6 fine tune phase and amplitude of the sine frequency.

The capacitor and resistor values shown in Figure 6 are typical values only. The capacitor values are dependent upon the crystal manufacturers' load capacitance recommendations and the PCB physical layout. The resistor value depends on the drive level.
specified by the crystal manufacturer. The user should verify the customized values based on careful investigations on multiple devices over temperature range.

A third-overtone crystal can be used for frequencies above 25 MHz. The circuit is then modified to ensure crystal operation only at the third overtone by adding a tuned inductor circuit as shown in Figure 6. A design procedure for third-overtone operation is discussed in detail in application note (EE-168) Using Third Overtone Crystals with the ADSP-218x DSP on the Analog Devices website (www.analog.com)—use site search on “EE-168.”

The CLKBUF pin is an output pin, which is a buffered version of the input clock. This pin is particularly useful in Ethernet applications to limit the number of required clock sources in the system. In this type of application, a single 25 MHz or 50 MHz crystal may be applied directly to the processor. The 25 MHz or 50 MHz output of CLKBUF can then be connected to an external Ethernet MII or RMII PHY device. If, instead of a crystal, an external oscillator is used at CLKIN, CLKBUF will not have the 40/60 duty cycle required by some devices. The CLKBUF output is active by default and can be disabled for power savings reasons using the VR_CTL register.

The Blackfin core runs at a different clock rate than the on-chip peripherals. As shown in Figure 7, 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 programmable multiplication factor (bounded by specified minimum and maximum VCO frequencies). The default multiplier can be modified by a software instruction sequence. This sequence is managed by the bfrom_SysControl() function in the on-chip ROM.

On-the-fly CCLK and SCLK frequency changes can be applied by using the bfrom_SysControl() function in the on-chip ROM. The maximum allowed CCLK and SCLK rates depend on the applied voltages VDDINT, VDDRXT, and VDDMEM; the VCO is always permitted to run up to the frequency specified by the part’s maximum instruction rate. The CLKOUT pin reflects the SCLK frequency to the off-chip world. It is part of the SDRAM interface, but it functions as a reference signal in other timing specifications as well. While active by default, it can be disabled using the EBIU_SDGCTL and EBIU_AMGCTL registers.

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.

Note that the divisor ratio must be chosen to limit the system clock frequency to its maximum of $f_{SCLK}$. The SSEL value can be dynamically changed without any PLL lock latencies by writing the appropriate values to the PLL divisor register (PLL_DIV) using the bfrom_SysControl() function in the on-chip ROM.

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 6. Example System Clock Ratios

<table>
<thead>
<tr>
<th>Signal Name SSEL3–0</th>
<th>Divider Ratio VCO/SCLK</th>
<th>Example Frequency Ratios (MHz)</th>
</tr>
</thead>
<tbody>
<tr>
<td>0001</td>
<td>1:1</td>
<td>VCO 100</td>
</tr>
<tr>
<td>0110</td>
<td>6:1</td>
<td>SCLK 50</td>
</tr>
<tr>
<td>1010</td>
<td>10:1</td>
<td>SCLK 50</td>
</tr>
</tbody>
</table>

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

<table>
<thead>
<tr>
<th>Signal Name CSEL1–0</th>
<th>Divider Ratio VCO/CCLK</th>
<th>Example Frequency Ratios (MHz)</th>
</tr>
</thead>
<tbody>
<tr>
<td>00</td>
<td>1:1</td>
<td>VCO 300</td>
</tr>
<tr>
<td>01</td>
<td>2:1</td>
<td>CCLK 300</td>
</tr>
<tr>
<td>10</td>
<td>4:1</td>
<td>SCLK 125</td>
</tr>
<tr>
<td>11</td>
<td>8:1</td>
<td>CCLK 25</td>
</tr>
</tbody>
</table>
The maximum CCLK frequency not only depends on the part’s maximum instruction rate (see Page 88). This frequency also depends on the applied $V_{DDINT}$ voltage. See Table 12 and Table 15 for details. The maximal system clock rate (SCLK) depends on the chip package and the applied $V_{DDINT}$, $V_{DDEXT}$, and $V_{DGMEM}$ voltages (see Table 14 and Table 17).

### Booting Modes

The processor has several mechanisms (listed in Table 8) for automatically loading internal and external memory after a reset. The boot mode is defined by four BMODE input pins dedicated to this purpose. There are two categories of boot modes. In master boot modes the processor actively loads data from external host devices. In slave boot modes the processor receives data from external host devices.

The boot modes listed in Table 8 provide a number of mechanisms for automatically loading the processor’s internal and external memories after a reset. By default, all boot modes use the slowest meaningful configuration settings. Default settings can be altered via the initialization code feature at boot time or by proper OTP programming at pre-boot time. The BMODE pins of the reset configuration register, sampled during power-up, determine the boot mode.

![Table 8: Booting Modes](image)

- **Idle/no boot mode (BMODE = 0x0)** — In this mode, the processor goes into idle. The idle boot mode helps recover from illegal operating modes, such as when the OTP memory has been misconfigured.
- **Boot from 8- or 16-bit external flash memory (BMODE = 0x1)** — In this mode, the boot kernel loads the first block header from address $0x2000 0000$, and (depending on instructions contained in the header) the boot kernel performs an 8- or 16-bit boot or starts program execution at the address provided by the header. By default, all configuration settings are set for the slowest device possible (3-cycle hold time, 15-cycle R/W access times, 4-cycle setup).

The ARDY is not enabled by default, but it can be enabled through OTP programming. Similarly, all interface behavior and timings can be customized through OTP programming. This includes activation of burst-mode or page-mode operation. In this mode, all asynchronous interface signals are enabled at the port muxing level.

- **Boot from 16-bit asynchronous FIFO (BMODE = 0x2)** — In this mode, the boot kernel starts booting from address $0x2030 0000$. Every 16-bit word that the boot kernel has to read from the FIFO must be requested by placing a low pulse on the DMAR1 pin.

- **Boot from serial SPI memory, EEPROM or flash (BMODE = 0x3)** — 8-, 16-, 24-, or 32-bit addressable devices are supported. The processor uses the PG1 GPIO pin to select a SPI EEPROM/flash device and submits a read command and successive address bytes (0x00) until a valid 8-, 16-, 24-, or 32-bit addressable device is detected. Pull-up resistors are required on the SPISEL1 and MISO pins. By default, a value of 0x85 is written to the SPI_BAUD register.

- **Boot from serial SPI memory, EEPROM or flash (BMODE = 0x4)** — The processor operates in SPI slave mode and is configured to receive the bytes of the LDR file from an SPI host (master) agent. The HWAIT signal must be interrogated by the host before every transmitted byte. A pull-up resistor is required on the SPISS input. A pull-down on the serial clock (SCK) may improve signal quality and booting robustness.

- **Boot from serial TWI memory, EEPROM/flash (BMODE = 0x5)** — The processor operates in master mode and selects the TWI slave connected to the TWI with the unique ID 0xA0. The processor submits successive read commands to the memory device starting at internal address $0x0000$ and begins clocking data into the processor. The TWI memory device should comply with the Philips I²C® Bus Specification version 2.1 and should be able to auto-increment its internal address counter such that the contents of the memory device can be read sequentially. By default, a PRESCALE value of 0x4 and a TWI_CLKDIV value of 0x0811 are used. Unless altered by OTP settings, an I²C memory that takes two address bytes is assumed. The development tools ensure that data booted to memories that cannot be accessed by the Blackfin core is written to an intermediate storage location and then copied to the final destination via memory DMA.

- **Boot from SPI host device (BMODE = 0x6)** — The TWI host agent selects the slave with the unique ID 0x5F. The processor replies with an acknowledgement and the host then downloads the boot stream. The TWI host agent should comply with the Philips I²C Bus Specification.
version 2.1. An I²C multiplexer can be used to select one processor at a time when booting multiple processors from a single TWI.

- Boot from UART0 host on Port G (BMODE = 0x7) — Using an autobaud handshake sequence, a boot-stream formatted program is downloaded by the host. The host selects a bit rate within the UART’s clocking capabilities.

When performing the autobaud, the UART expects a “@” (0x40) character (eight bits data, one start bit, one stop bit, no parity bit) on the UART0RX pin to determine the bit rate. The UART then replies with an acknowledgement composed of 4 bytes (0xBF, the value of UART0_DLL, the value of UART0_DLH, then 0x00). The host can then download the boot stream. To hold off the host the Blackfin processor signals the host with the boot host wait (HWAIT) signal. Therefore, the host must monitor HWAIT before every transmitted byte.

- Boot from UART1 host on Port F (BMODE = 0x8). Same as BMODE = 0x7 except that the UART1 port is used.

- Boot from SDRAM (BMODE = 0xA) This is a warm boot scenario, where the boot kernel starts booting from address 0x0000 0010. The SDRAM is expected to contain a valid boot stream and the SDRAM controller must be configured by the OTP settings.

- Boot from OTP memory (BMODE = 0xB) — This provides a stand-alone booting method. The boot stream is loaded from on-chip OTP memory. By default, the boot stream is expected to start from OTP page 0x40 and can occupy all public OTP memory up to page 0xDF. This is 2560 bytes. Since the start page is programmable, the maximum size of the boot stream can be extended to 3072 bytes.

- Boot from 8-bit external NAND flash memory (BMODE = 0xC and BMODE = 0xD) — In this mode, auto detection of the NAND flash device is performed.

BMODE = 0xC, the processor configures PORTF GPIO pins PF7:0 for the NAND data pins and PORTH pins PH15:10 for the NAND control signals.

BMODE = 0xD, the processor configures PORTH GPIO pins PH7:0 for the NAND data pins and PORTH pins PH15:10 for the NAND control signals.

For correct device operation pull-up resistors are required on both ND_CE (PH10) and ND_BUSY (PH13) signals. By default, a value of 0x0033 is written to the NFC_CTL register. The booting procedure always starts by booting from byte 0 of block 0 of the NAND flash device.

NAND flash boot supports the following features:

- Device Auto Detection
- Error Detection & Correction for maximum reliability
- No boot stream size limitation
- Peripheral DMA providing efficient transfer of all data (excluding the ECC parity data)

—Software-configurable boot mode for booting from boot streams spanning multiple blocks, including bad blocks
—Software-configurable boot mode for booting from multiple copies of the boot stream, allowing for handling of bad blocks and uncorrectable errors
—Configurable timing via OTP memory

Small page NAND flash devices must have a 512-byte page size, 32 pages per block, a 16-byte spare area size, and a bus configuration of 8 bits. By default, all read requests from the NAND flash are followed by four address cycles. If the NAND flash device requires only three address cycles, the device must be capable of ignoring the additional address cycles.

The small page NAND flash device must comply with the following command set:

- Reset: 0xFF
- Read lower half of page: 0x00
- Read upper half of page: 0x01
- Read spare area: 0x50

For large-page NAND-flash devices, the four-byte electronic signature is read in order to configure the kernel for booting, which allows support for multiple large-page devices. The fourth byte of the electronic signature must comply with the specification in Table 9 on Page 20.

Any NAND flash array configuration from Table 9, excluding 16-bit devices, that also complies with the command set listed below are directly supported by the boot kernel.

There are no restrictions on the page size or block size as imposed by the small-page boot kernel.

For devices consisting of a five-byte signature, only four are read. The fourth must comply as outlined above.

Large page devices must support the following command set:

- Reset: 0xFF
- Read Electronic Signature: 0x90
- Read: 0x00, 0x30 (confirm command)

Large-page devices must not support or react to NAND flash command 0x50. This is a small-page NAND flash command used for device auto detection.

By default, the boot kernel will always issue five address cycles; therefore, if a large page device requires only four cycles, the device must be capable of ignoring the additional address cycles.

- Boot from 16-Bit Host DMA (BMODE = 0xE) — In this mode, the host DMA port is configured in 16-bit Acknowledge mode, with little endian data formatting. Unlike other modes, the host is responsible for interpreting the boot stream. It writes data blocks individually into the Host DMA port. Before configuring the DMA settings for each block, the host may either poll the ALLOW_CONFIG bit in HOST_STATUS or wait to be interrupted by the HWAIT
signal. When using HWAIT, the host must still check ALLOW_CONFIG at least once before beginning to configure the Host DMA Port. After completing the configuration, the host is required to poll the READY bit in HOST_STATUS before beginning to transfer data. When the host sends an HIRQ control command, the boot kernel issues a CALL instruction to address 0xFFA0 0000. It is the host’s responsibility to ensure that valid code has been placed at this address. The routine at 0xFFA0 0000 can be a simple initialization routine to configure internal resources, such as the SDRAM controller, which then returns using an RTS instruction. The routine may also be by the final application, which will never return to the boot kernel.

- Boot from 8-Bit Host DMA (BMODE = 0xF) — In this mode, the Host DMA port is configured in 8-bit interrupt mode, with little endian data formatting. Unlike other modes, the host is responsible for interpreting the boot stream. It writes data blocks individually into the Host DMA port. Before configuring the DMA settings for each block, the host may either poll the ALLOW_CONFIG bit in HOST_STATUS or wait to be interrupted by the HWAIT signal. When using HWAIT, the host must still check ALLOW_CONFIG at least once before beginning to configure the Host DMA Port. The host will receive an interrupt from the HOST_ACK signal every time it is allowed to send the next FIFO depths worth (sixteen 32-bit words) of information. When the host sends an HIRQ control command, the boot kernel issues a CALL instruction to address 0xFFA0 0000. It is the host’s responsibility to ensure valid code has been placed at this address. The routine at 0xFFA0 0000 can be a simple initialization routine to configure internal resources, such as the SDRAM controller, which then returns using an RTS instruction. The routine may also be by the final application, which will never return to the boot kernel.

### Table 9. Fourth Byte for Large Page Devices

<table>
<thead>
<tr>
<th>Bit</th>
<th>Parameter</th>
<th>Value</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>D1:D0</td>
<td>Page Size (excluding spare area)</td>
<td>00</td>
<td>1K byte</td>
</tr>
<tr>
<td></td>
<td></td>
<td>01</td>
<td>2K byte</td>
</tr>
<tr>
<td></td>
<td></td>
<td>10</td>
<td>4K byte</td>
</tr>
<tr>
<td></td>
<td></td>
<td>11</td>
<td>8K byte</td>
</tr>
<tr>
<td>D2</td>
<td>Spare Area Size</td>
<td>00</td>
<td>8 byte/512 byte</td>
</tr>
<tr>
<td></td>
<td></td>
<td>01</td>
<td>16 byte/512 byte</td>
</tr>
<tr>
<td>D5:D4</td>
<td>Block Size (excluding spare area)</td>
<td>00</td>
<td>64K byte</td>
</tr>
<tr>
<td></td>
<td></td>
<td>01</td>
<td>128K byte</td>
</tr>
<tr>
<td></td>
<td></td>
<td>10</td>
<td>256K byte</td>
</tr>
<tr>
<td></td>
<td></td>
<td>11</td>
<td>512K byte</td>
</tr>
<tr>
<td>D6</td>
<td>Bus width</td>
<td>00</td>
<td>x8</td>
</tr>
<tr>
<td></td>
<td></td>
<td>01</td>
<td>not supported</td>
</tr>
<tr>
<td>D3, D7</td>
<td>Not Used for configuration</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

### 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/MCU 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® Embedded Studio and/or VisualDSP++®, 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™ 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](http://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 a wide range of EZ-KIT Lite® 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®, 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 offers 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 CrossCore 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.

**Board Support Packages for Evaluation Hardware**

Software support for the EZ-KIT Lite evaluation boards and EZ-Extender daughter cards is provided by software add-ins called Board Support Packages (BSPs). The BSPs contain the required drivers, pertinent release notes, and select example code for the given evaluation hardware. A download link for a specific BSP is located on the web page for the associated EZ-KIT or EZ-Extender product. The link is found in the Product Download area of the product web page.

**Middleware Packages**

Analog Devices separately offers middleware add-ins such as real time operating systems, file systems, USB stacks, and TCP/IP stacks. For more information see the following web pages:

- www.analog.com/ucos3
- www.analog.com/ucfs
- www.analog.com/ucusbd
- www.analog.com/lwip

**Algorithmic Modules**

To speed development, Analog Devices offers add-ins that perform popular audio and video processing algorithms. These are available for use with both CrossCore Embedded Studio and VisualDSP++. For more information visit www.analog.com and search on “Blackfin software modules” or “SHARC software modules”.

**Designing an Emulator-Compatible DSP Board (Target)**

For embedded system test and debug, Analog Devices provides a family of emulators. On each JTAG DSP, Analog Devices supplies an IEEE 1149.1 JTAG Test Access Port (TAP). In-circuit emulation is facilitated by use of this JTAG interface. The emulator accesses the processor’s internal features via the processor’s TAP, allowing the developer to load code, set breakpoints, and view variables, memory, and registers. The processor must be halted to send data and commands, but once an operation is completed by the emulator, the DSP system is set to run at full speed with no impact on system timing. The emulators require the target board to include a header that supports connection of the DSP’s JTAG port to the emulator.

For details on target board design issues including mechanical layout, single processor connections, signal buffering, signal termination, and emulator pod logic, see the Engineer-to-Engineer Note “Analog Devices JTAG Emulation Technical Reference” (EE-68) on the Analog Devices website (www.analog.com)—use site search on “EE-68.” This document is updated regularly to keep pace with improvements to emulator support.

**ADDITIONAL INFORMATION**

The following publications that describe the ADSP-BF52x processors (and related processors) can be ordered from any Analog Devices sales office or accessed electronically on our website:

- Getting Started With Blackfin Processors
- ADSP-BF52x Blackfin Processor Hardware Reference (volumes 1 and 2)
- Blackfin Processor Programming Reference
- ADSP-BF522/ADSP-BF524/ADSP-BF526 Blackfin Processor Anomaly List
- ADSP-BF523/ADSP-BF525/ADSP-BF527 Blackfin Processor Anomaly List
RELATED SIGNAL CHAINS

A *signal chain* is a series of signal-conditioning electronic components that receive input (data acquired from sampling either real-time phenomena or from stored data) in tandem, with the output of one portion of the chain supplying input to the next. Signal chains are often used in signal processing applications to gather and process data or to apply system controls based on analysis of real-time phenomena. For more information about this term and related topics, see the "signal chain" entry in *Wikipedia* or the *Glossary of EE Terms* on the Analog Devices website.

Analog Devices eases signal processing system development by providing signal processing components that are designed to work together well. A tool for viewing relationships between specific applications and related components is available on the [www.analog.com](http://www.analog.com) website.

The Application Signal Chains page in the Circuits from the Lab™ site ([http://www.analog.com/signalchains](http://www.analog.com/signalchains)) provides:

- Graphical circuit block diagram presentation of signal chains for a variety of circuit types and applications
- Drill down links for components in each chain to selection guides and application information
- Reference designs applying best practice design techniques

LOCKBOX SECURE TECHNOLOGY DISCLAIMER

Analog Devices products containing Lockbox Secure Technology are warranted by Analog Devices as detailed in the Analog Devices Standard Terms and Conditions of Sale. To our knowledge, the Lockbox Secure Technology, when used in accordance with the data sheet and hardware reference manual specifications, provides a secure method of implementing code and data safeguards. However, Analog Devices does not guarantee that this technology provides absolute security.

**ACCORDINGLY, ANALOG DEVICES HEREBY DISCLAIMS ANY AND ALL EXPRESS AND IMPLIED WARRANTIES THAT THE LOCKBOX SECURE TECHNOLOGY CANNOT BE BREACHED, COMPROMISED, OR OTHERWISE CIRCUMVENTED AND IN NO EVENT SHALL ANALOG DEVICES BE LIABLE FOR ANY LOSS, DAMAGE, DESTRUCTION, OR RELEASE OF DATA, INFORMATION, PHYSICAL PROPERTY, OR INTELLECTUAL PROPERTY.**
SIGNAL DESCRIPTIONS

Signal definitions for the ADSP-BF52x processors are listed in Table 10. In order to maintain maximum function and reduce package size and ball count, some balls have dual, multiplexed functions. In cases where ball function is reconfigurable, the default state is shown in plain text, while the alternate function is shown in italics.

All pins are three-stated during and immediately after reset, with the exception of the external memory interface, asynchronous and synchronous memory control, and the buffered XTAL output pin (CLKBUF). On the external memory interface, the control and address lines are driven high, with the exception of CLKOUT, which toggles at the system clock rate. During hibernate, all outputs are three-stated unless otherwise noted in Table 10.

It is strongly advised to use the available IBIS models to ensure that a given board design meets overshoot/undershoot and signal integrity requirements. If no IBIS simulation is performed, it is strongly recommended to add series resistor terminations for all Driver Types A, C and D.

The termination resistors should be placed near the processor to reduce transients and improve signal integrity. The resistance value, typically 33 Ω or 47 Ω, should be chosen to match the average board trace impedance.

Additionally, adding a parallel termination to CLKOUT may prove useful in further enhancing signal integrity. Be sure to verify overshoot/undershoot and signal integrity specifications on actual hardware.

Table 10. Signal Descriptions

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Type</th>
<th>Function</th>
<th>Driver Type¹</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADDR19–1</td>
<td>O</td>
<td>Address Bus</td>
<td>A</td>
</tr>
<tr>
<td>DATA15–0</td>
<td>I/O</td>
<td>Data Bus</td>
<td>A</td>
</tr>
<tr>
<td>ABF1–0/SDQM1–0</td>
<td>O</td>
<td>Byte Enables/Data Mask</td>
<td>A</td>
</tr>
<tr>
<td>AMS3–0</td>
<td>O</td>
<td>Asynchronous Memory Bank Selects (Require pull-ups if hibernate is used.)</td>
<td>A</td>
</tr>
<tr>
<td>ARDY</td>
<td>I</td>
<td>Hardware Ready Control</td>
<td>A</td>
</tr>
<tr>
<td>AOE</td>
<td>O</td>
<td>Asynchronous Output Enable</td>
<td>A</td>
</tr>
<tr>
<td>ARE</td>
<td>O</td>
<td>Asynchronous Read Enable</td>
<td>A</td>
</tr>
<tr>
<td>AWE</td>
<td>O</td>
<td>Asynchronous Write Enable</td>
<td>A</td>
</tr>
<tr>
<td>SRAS</td>
<td>O</td>
<td>SDRAM Row Address Strobe</td>
<td>A</td>
</tr>
<tr>
<td>SCAS</td>
<td>O</td>
<td>SDRAM Column Address Strobe</td>
<td>A</td>
</tr>
<tr>
<td>SWE</td>
<td>O</td>
<td>SDRAM Write Enable</td>
<td>A</td>
</tr>
<tr>
<td>SCE</td>
<td>O</td>
<td>SDRAM Clock Enable (Requires a pull-down if hibernate with SDRAM self-refresh is used.)</td>
<td>A</td>
</tr>
<tr>
<td>CLKOUT</td>
<td>O</td>
<td>SDRAM Clock Output</td>
<td>B</td>
</tr>
<tr>
<td>SA10</td>
<td>O</td>
<td>SDRAM A10 Signal</td>
<td>A</td>
</tr>
<tr>
<td>SMS</td>
<td>O</td>
<td>SDRAM Bank Select</td>
<td>A</td>
</tr>
</tbody>
</table>

All I/O pins have their input buffers disabled with the exception of the pins that need pull-ups or pull-downs, as noted in Table 10.
Table 10. Signal Descriptions (Continued)

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Type</th>
<th>Function</th>
<th>Driver Type</th>
</tr>
</thead>
<tbody>
<tr>
<td>USB 2.0 HS OTG</td>
<td>I/O</td>
<td>Data + (This ball should be pulled low when USB is unused or not present.)</td>
<td>F</td>
</tr>
<tr>
<td>USB_DP</td>
<td>I/O</td>
<td>Data – (This ball should be pulled low when USB is unused or not present.)</td>
<td>F</td>
</tr>
<tr>
<td>USB_DM</td>
<td>I</td>
<td>USB Crystal Input (This ball should be pulled low when USB is unused or not present.)</td>
<td>F</td>
</tr>
<tr>
<td>USB_XI</td>
<td>O</td>
<td>USB Crystal Output (This ball should be left unconnected when USB is unused or not present.)</td>
<td>F</td>
</tr>
<tr>
<td>USB_XO</td>
<td>O</td>
<td>USB Crystal Output (This ball should be left unconnected when USB is unused or not present.)</td>
<td>F</td>
</tr>
<tr>
<td>USB_ID</td>
<td>I</td>
<td>USB OTG mode (This ball should be pulled low when USB is unused or not present.)</td>
<td>F</td>
</tr>
<tr>
<td>USB_VREF</td>
<td>A</td>
<td>USB voltage reference (Connect to GND through a 0.1 μF capacitor or leave unconnected when not used.)</td>
<td>F</td>
</tr>
<tr>
<td>USB_RSET</td>
<td>A</td>
<td>USB resistance set. (This ball should be left unconnected.)</td>
<td>F</td>
</tr>
<tr>
<td>USB_VBUS</td>
<td>I/O 5V</td>
<td>USB VBUS. USB_VBUS is an output only in peripheral mode during SRP signaling. Host mode requires that an external voltage source of 5 V at 8 mA or more (per the OTG specification) be applied to VBUS. The voltage source needs to be able to charge and discharge VBUS, thus an ON/OFF switch is required to control the voltage source. A GPIO can be used for this purpose (This ball should be pulled low when USB is unused or not present.)</td>
<td>F</td>
</tr>
</tbody>
</table>

Port F: GPIO and Multiplexed Peripherals

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Type</th>
<th>Function</th>
<th>Driver Type</th>
</tr>
</thead>
<tbody>
<tr>
<td>PF0/PPID0/DR0PRI/ND_D0A</td>
<td>I/O</td>
<td>GPIO/PPID0/DR0PRI Data 0/SPORT0 Primary Receive Data/NAND Alternate Data 0</td>
<td>C</td>
</tr>
<tr>
<td>PF1/PPID1/RFS0/ND_D1A</td>
<td>I/O</td>
<td>GPIO/PPID1/RFS0 Data 1/SPORT0 Receive Frame Sync/NAND Alternate Data 1</td>
<td>C</td>
</tr>
<tr>
<td>PF2/PPID2/RCLK0/ND_D2A</td>
<td>I/O</td>
<td>GPIO/PPID2/RCLK0 Data 2/SPORT0 Receive Serial Clock/NAND Alternate Data 2/A</td>
<td>D</td>
</tr>
<tr>
<td>PF3/PPID3/DT0PRI/ND_D3A</td>
<td>I/O</td>
<td>GPIO/PPID3/DT0PRI Data 3/SPORT0 Transmit Primary Data/NAND Alternate Data 3</td>
<td>C</td>
</tr>
<tr>
<td>PF4/PPID4/TS0/ND_D4A/TACLK0</td>
<td>I/O</td>
<td>GPIO/PPID4/TS0 Data 4/SPORT0 Transmit Frame Sync/NAND Alternate Data 4/A</td>
<td>C</td>
</tr>
<tr>
<td>PF5/PPID5/TCLK0/ND_D5A/TACLK1</td>
<td>I/O</td>
<td>GPIO/PPID5/TCLK0 Data 5/SPORT0 Transmit Serial Clock/NAND Alternate Data 5/A</td>
<td>D</td>
</tr>
<tr>
<td>PF6/PPID6/DT0SEC/ND_D6A/TACI0</td>
<td>I/O</td>
<td>GPIO/PPID6/DT0SEC Data 6/SPORT0 Transmit Secondary Data/NAND Alternate Data 6/A</td>
<td>C</td>
</tr>
<tr>
<td>PF7/PPID7/DR0SEC/ND_D7A/TACI1</td>
<td>I/O</td>
<td>GPIO/PPID7/DR0SEC Data 7/SPORT0 Receive Secondary Data/NAND Alternate Data 7/A</td>
<td>C</td>
</tr>
<tr>
<td>PF8/PPID8/DR1PRI</td>
<td>I/O</td>
<td>GPIO/PPID8/DR1PRI Data 8/SPORT1 Primary Receive Data</td>
<td>C</td>
</tr>
<tr>
<td>PF9/PPID9/RCLK1/SPISEC</td>
<td>I/O</td>
<td>GPIO/PPID9/RCLK1 Data 9/SPORT1 Receive Serial Clock/SPI Slave Select 6</td>
<td>D</td>
</tr>
<tr>
<td>PF10/PPID10/RFS1/SPISEC</td>
<td>I/O</td>
<td>GPIO/PPID10/RFS1 Data 10/SPORT1 Receive Frame Sync/SPI Slave Select 7</td>
<td>C</td>
</tr>
<tr>
<td>PF11/PPID11/TFS1/CZM</td>
<td>I/O</td>
<td>GPIO/PPID11/TFS1 Data 11/SPORT1 Transmit Frame Sync/Counter Zero Marker</td>
<td>C</td>
</tr>
<tr>
<td>PF12/PPID12/DT1PRI/SPISEC/CDG</td>
<td>I/O</td>
<td>GPIO/PPID12/DT1PRI Data 12/SPORT1 Transmit Primary Data/SPI Slave Select 2/Counter Down Gate</td>
<td>C</td>
</tr>
<tr>
<td>PF13/PPID13/TCLK1/SPISEC/CDG</td>
<td>I/O</td>
<td>GPIO/PPID13/TCLK1 Data 13/SPORT1 Transmit Serial Clock/SPI Slave Select 3/Counter Up Direction</td>
<td>D</td>
</tr>
<tr>
<td>PF14/PPID14/DT1SEC/UART1TX</td>
<td>I/O</td>
<td>GPIO/PPID14/DT1SEC Data 14/SPORT1 Transmit Secondary Data/UART1 Transmit</td>
<td>C</td>
</tr>
<tr>
<td>PF15/PPID15/DR1SEC/UART1RX/TACI3</td>
<td>I/O</td>
<td>GPIO/PPID15/DR1SEC Data 15/SPORT1 Receive Secondary Data/UART1 Receive Alternate Capture Input 3</td>
<td>C</td>
</tr>
</tbody>
</table>
### Table 10. Signal Descriptions (Continued)

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Type</th>
<th>Function</th>
<th>Driver Type</th>
</tr>
</thead>
<tbody>
<tr>
<td>Port G: GPIO and Multiplexed Peripherals</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PG0/HWAIT</td>
<td>I/O</td>
<td>GPIO/Boot Host Wait2</td>
<td>C</td>
</tr>
<tr>
<td>PG1/SPIS1/SPISEL1</td>
<td>I/O</td>
<td>GPIO/SPI Slave Select Input/SPI Slave Select 1</td>
<td>C</td>
</tr>
<tr>
<td>PG2/SCK</td>
<td>I/O</td>
<td>GPIO/SPI Clock</td>
<td>D</td>
</tr>
<tr>
<td>PG3/MISO/DR0/SECA</td>
<td>I/O</td>
<td>GPIO/SPI Master In Slave Out/Sport 0 Alternate Receive Data Secondary</td>
<td>C</td>
</tr>
<tr>
<td>PG4/MOSI/DT0/SECA</td>
<td>I/O</td>
<td>GPIO/SPI Master Out Slave In/Sport 0 Alternate Transmit Data Secondary</td>
<td>C</td>
</tr>
<tr>
<td>PG5/TMR1/PP1_F52</td>
<td>I/O</td>
<td>GPIO/Timer1/PP1 Frame Sync2</td>
<td>C</td>
</tr>
<tr>
<td>PG6/DTOPR1/TMR2/PP1_F53</td>
<td>I/O</td>
<td>GPIO/SPORT0 Alternate Primary Transmit Data / Timer2 / PPI Frame Sync3</td>
<td>C</td>
</tr>
<tr>
<td>PG7/TMR3/DTOPR1/UART0TX</td>
<td>I/O</td>
<td>GPIO/Timer3/Sport 0 Alternate Receive Data Primary/UART0 Transmit</td>
<td>C</td>
</tr>
<tr>
<td>PG8/TMR4/RF50A/UART0RX/TACI4</td>
<td>I/O</td>
<td>GPIO/Timer 4/Sport 0 Alternate Receive Clock/Frame Sync</td>
<td>C</td>
</tr>
<tr>
<td>PG9/TMR5/RSCLK0A/TACI5</td>
<td>I/O</td>
<td>GPIO/Timer5/Sport 0 Alternate Receive Clock</td>
<td>D</td>
</tr>
<tr>
<td>PG10/TMR6/TSCLK0A/TACI6</td>
<td>I/O</td>
<td>GPIO/Timer 6 /Sport 0 Alternate Transmit</td>
<td>D</td>
</tr>
<tr>
<td>PG11/TMR7/HOST_WR</td>
<td>I/O</td>
<td>GPIO/Timer7/Host DMA Write Enable</td>
<td>C</td>
</tr>
<tr>
<td>PG12/DMAR1/UART1TXA/HOST_ACK</td>
<td>I/O</td>
<td>GPIO/DMA Request 1 /Alternate UART1 Transmit /Host DMA Acknowledge</td>
<td>C</td>
</tr>
<tr>
<td>PG13/DMAR0/UART1RXA/HOST_ADDR/TACI2</td>
<td>I/O</td>
<td>GPIO/DMA Request 0 /Alternate UART1 Receive /Host DMA Address /Alternate</td>
<td>C</td>
</tr>
<tr>
<td>Capture Input 2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PG14/TSCLK0A1/MDC/HOST_RD</td>
<td>I/O</td>
<td>GPIO/SPORT0 Alternate 1 Transmit/Ethernet Management Channel Clock</td>
<td>D</td>
</tr>
<tr>
<td>PG15+/TF50A/MII_PHYINT/RMII MDINT/HOST_CE</td>
<td></td>
<td>GPIO/SPORT0 Alternate Transmit Frame Sync/Ethernet/MII PHY Interrupt/RMI</td>
<td>C</td>
</tr>
</tbody>
</table>

### Port H: GPIO and Multiplexed Peripherals

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Type</th>
<th>Function</th>
<th>Driver Type</th>
</tr>
</thead>
<tbody>
<tr>
<td>PH0/ND_D0/MMICS/RMIICRSDV/HOST_D0</td>
<td>I/O</td>
<td>GPIO/NAND D0/Ethernet MII or RMII Carrier Sense /Host DMA D0</td>
<td>C</td>
</tr>
<tr>
<td>PH1/ND_D1/ERxER/HOST_D1</td>
<td>I/O</td>
<td>GPIO/NAND D1/Ethernet MII or RMII Receive Error /Host DMA D1</td>
<td>C</td>
</tr>
<tr>
<td>PH2/ND_D2/MDIO/HOST_D2</td>
<td>I/O</td>
<td>GPIO/NAND D2/Ethernet Management Channel Serial Data /Host DMA D2</td>
<td>C</td>
</tr>
<tr>
<td>PH3/ND_D3/ETxEN/HOST_D3</td>
<td>I/O</td>
<td>GPIO/NAND D3/Ethernet MII Transmit Enable /Host DMA D3</td>
<td>C</td>
</tr>
<tr>
<td>PH4/ND_D4/MMITxCLK/RMIREF_CLK/HOST_D4</td>
<td>I/O</td>
<td>GPIO/NAND D4/Ethernet MII or RMII Reference Clock /Host D4</td>
<td>C</td>
</tr>
<tr>
<td>PH5/ND_D5/ETxD0/HOST_D5</td>
<td>I/O</td>
<td>GPIO/NAND D5/Ethernet MII or RMII Transmit D0 /Host DMA D5</td>
<td>C</td>
</tr>
<tr>
<td>PH6/ND_D6/ERxD0/HOST_D6</td>
<td>I/O</td>
<td>GPIO/NAND D6/Ethernet MII or RMII Receive D0 /Host DMA D6</td>
<td>C</td>
</tr>
<tr>
<td>PH7/ND_D7/ETxD1/HOST_D7</td>
<td>I/O</td>
<td>GPIO/NAND D7/Ethernet MII or RMII Transmit D1 /Host DMA D7</td>
<td>C</td>
</tr>
<tr>
<td>PH8/SPIS1/ERxD1/HOST_D8/TACLK2</td>
<td>I/O</td>
<td>GPIO/AIternate Timer Clock 2/Ethernet MII or RMII Receive D1 /Host DMA D</td>
<td>C</td>
</tr>
<tr>
<td>PH9/SPIS3/ETxD2/HOST_D9/TACLK3</td>
<td>I/O</td>
<td>GPIO/SP1 Slave Select 5/Ethernet MII Transmit D2 /Host DMA D9</td>
<td>C</td>
</tr>
<tr>
<td>PH10/ND_CE/ERxD2/HOST_D10</td>
<td>I/O</td>
<td>GPIO/NAND Chip Enable /Ethernet MII Receive D2 /Host DMA D10</td>
<td>C</td>
</tr>
<tr>
<td>PH11/ND_WE/ETxD3/HOST_D11</td>
<td>I/O</td>
<td>GPIO/NAND Write Enable /Ethernet MII Transmit D3 /Host DMA D11</td>
<td>C</td>
</tr>
<tr>
<td>PH12/ND_RE/ERxD3/HOST_D12</td>
<td>I/O</td>
<td>GPIO/NAND Read Enable /Ethernet MII Receive D3 /Host DMA D12</td>
<td>C</td>
</tr>
<tr>
<td>PH13/ND_BUSY/ERxCLK/HOST_D13</td>
<td>I/O</td>
<td>GPIO/NAND Busy /Ethernet MII Receive Clock /Host DMA D13</td>
<td>C</td>
</tr>
<tr>
<td>PH14/ND_CLE/ERxDV/HOST_D14</td>
<td>I/O</td>
<td>GPIO/NAND Command Latch Enable /Ethernet MII or RMII Receive Data Valid /</td>
<td>C</td>
</tr>
<tr>
<td>PH15/ND_ALE/COL/HOST_D15</td>
<td>I/O</td>
<td>GPIO/NAND Address Latch Enable /Ethernet MII Collision /Host DMA Data 15</td>
<td>C</td>
</tr>
</tbody>
</table>
Table 10. Signal Descriptions (Continued)

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Type</th>
<th>Function</th>
<th>Driver Type</th>
<th>Notes</th>
</tr>
</thead>
<tbody>
<tr>
<td>Port J: Multiplexed Peripherals</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>PJ0: PPI_FS1/TMR0</td>
<td>I/O</td>
<td>PPI Frame Sync1/Timer0</td>
<td>C</td>
<td></td>
</tr>
<tr>
<td>PJ1: PPI_CLK/TMRCLK</td>
<td>I</td>
<td>PPI Clock/Timer Clock</td>
<td>E</td>
<td></td>
</tr>
<tr>
<td>PJ2: SCL</td>
<td>I/O 5V</td>
<td>TWI Serial Clock (This pin is an open-drain output and requires a pull-up</td>
<td>E</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>resistor.)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>PJ3: SDA</td>
<td>I/O 5V</td>
<td>TWI Serial Data (This pin is an open-drain output and requires a pull-up</td>
<td>E</td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td>resistor.)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Real Time Clock</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RTXI</td>
<td>I</td>
<td>RTC Crystal Input (This ball should be pulled low when not used.)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>RTXO</td>
<td>O</td>
<td>RTC Crystal Output (Does not three-state during hibernate.)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>JTAG Port</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>TCK</td>
<td>I</td>
<td>JTAG Clock</td>
<td></td>
<td></td>
</tr>
<tr>
<td>TDO</td>
<td>O</td>
<td>JTAG Serial Data Out</td>
<td>C</td>
<td></td>
</tr>
<tr>
<td>TDI</td>
<td>I</td>
<td>JTAG Serial Data In</td>
<td></td>
<td></td>
</tr>
<tr>
<td>TMS</td>
<td>I</td>
<td>JTAG Mode Select</td>
<td></td>
<td></td>
</tr>
<tr>
<td>TRST</td>
<td>I</td>
<td>JTAG Reset (This ball should be pulled low if the JTAG port is not used.)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>EMU</td>
<td>O</td>
<td>Emulation Output</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Clock</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLKIN</td>
<td>I</td>
<td>Clock/Crystal Input</td>
<td></td>
<td></td>
</tr>
<tr>
<td>XTAL</td>
<td>O</td>
<td>Crystal Output (If CLKBUF is enabled, does not three-state during hibernate.)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLKBUF</td>
<td>O</td>
<td>Buffered XTAL Output (If enabled, does not three-state during hibernate.)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Mode Controls</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RESET</td>
<td>I</td>
<td>Reset</td>
<td></td>
<td></td>
</tr>
<tr>
<td>NMI</td>
<td>I</td>
<td>Nonmaskable Interrupt (This ball should be pulled high when not used.)</td>
<td></td>
<td></td>
</tr>
<tr>
<td>BMODE3–0</td>
<td>I</td>
<td>Boot Mode Strap 3-0</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADSP-BF523/ADSP-BF525/ADSP-BF527 Voltage Regulation I/F</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>VRSEL</td>
<td>I</td>
<td>Internal/External Voltage Regulator Select</td>
<td></td>
<td></td>
</tr>
<tr>
<td>VROUT/EXT_WAKE1</td>
<td>O</td>
<td>External FET Drive/Wake up Indication 1 (Does not three-state during hibernate.)</td>
<td>G</td>
<td></td>
</tr>
<tr>
<td>EXT_WAKE0</td>
<td>O</td>
<td>Wake up Indication 0 (Does not three-state during hibernate.)</td>
<td>C</td>
<td></td>
</tr>
<tr>
<td>SS/PG</td>
<td>A</td>
<td>Soft Start/Power Good</td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADSP-BF522/ADSP-BF524/ADSP-BF526 Voltage Regulation I/F</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>EXT_WAKE1</td>
<td>O</td>
<td>Wake up Indication 1 (Does not three-state during hibernate.)</td>
<td>C</td>
<td></td>
</tr>
<tr>
<td>EXT_WAKE0</td>
<td>O</td>
<td>Wake up Indication 0 (Does not three-state during hibernate.)</td>
<td>C</td>
<td></td>
</tr>
<tr>
<td>PG</td>
<td>A</td>
<td>Power Good (This signal should be pulled low when not used.)</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>
Table 10. Signal Descriptions (Continued)

<table>
<thead>
<tr>
<th>Signal Name</th>
<th>Type</th>
<th>Function</th>
</tr>
</thead>
<tbody>
<tr>
<td>VDDEXT</td>
<td>P</td>
<td>I/O Power Supply</td>
</tr>
<tr>
<td>VDDINT</td>
<td>P</td>
<td>Internal Power Supply</td>
</tr>
<tr>
<td>VDDRTC</td>
<td>P</td>
<td>Real Time Clock Power Supply</td>
</tr>
<tr>
<td>VDDUSB</td>
<td>P</td>
<td>3.3 V USB Phy Power Supply</td>
</tr>
<tr>
<td>VDDMEM</td>
<td>P</td>
<td>MEM Power Supply</td>
</tr>
<tr>
<td>VDDOTP</td>
<td>P</td>
<td>OTP Power Supply</td>
</tr>
<tr>
<td>VPPOTP</td>
<td>P</td>
<td>OTP Programming Voltage</td>
</tr>
<tr>
<td>GND</td>
<td>G</td>
<td>Ground for All Supplies</td>
</tr>
</tbody>
</table>

1 See Output Drive Currents on Page 73 for more information about each driver type.
2 HWAIT must be pulled high or low to configure polarity. It is driven as an output and toggle during processor boot. See Booting Modes on Page 18.
3 When driven low, this ball can be used to wake up the processor from the hibernate state, either in normal GPIO mode or in Ethernet mode as MII PHYINT. If the ball is used for wake up, enable the feature with the PHYWE bit in the VR_CTL register, and pull-up the ball with a resistor.
4 Consult version 2.1 of the I2C specification for the proper resistor value.
## OPERATING CONDITIONS

### FOR ADSP-BF522/ADSP-BF524/ADSP-BF526 PROCESSORS

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Conditions</th>
<th>Min</th>
<th>Nominal</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>VDDINT</td>
<td>Internal Supply Voltage</td>
<td>1.235</td>
<td>1.47</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>VDDEXT</td>
<td>External Supply Voltage&lt;sup&gt;1&lt;/sup&gt;</td>
<td>1.7</td>
<td>1.9</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>VDDMEM</td>
<td>MEM Supply Voltage&lt;sup&gt;1, 3&lt;/sup&gt;</td>
<td>3</td>
<td>3.6</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>VDDRTC</td>
<td>RTC Power Supply Voltage&lt;sup&gt;2&lt;/sup&gt;</td>
<td>2.25</td>
<td>3.6</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>VPPOTP</td>
<td>OTP Programming Voltage&lt;sup&gt;1&lt;/sup&gt;</td>
<td>2.25</td>
<td>2.75</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>VDDUSB</td>
<td>USB Supply Voltage&lt;sup&gt;5&lt;/sup&gt;</td>
<td>3.0</td>
<td>3.6</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>VIH</td>
<td>High Level Input Voltage&lt;sup&gt;6, 7&lt;/sup&gt;</td>
<td>1.90</td>
<td>3.6</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>VIL</td>
<td>Low Level Input Voltage&lt;sup&gt;6, 7&lt;/sup&gt;</td>
<td>1.7</td>
<td>0.6</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>VILTWI</td>
<td>Low Level Input Voltage&lt;sup&gt;9&lt;/sup&gt;</td>
<td>0.7 × V&lt;sub&gt;BUSTWI&lt;/sub&gt;</td>
<td>V&lt;sub&gt;BUSTWI&lt;/sub&gt;</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>T&lt;sub&gt;J&lt;/sub&gt;</td>
<td>Junction Temperature @ T&lt;sub&gt;AV&lt;/sub&gt; = 0°C to +70°C</td>
<td>0</td>
<td>+105</td>
<td>°C</td>
<td></td>
</tr>
<tr>
<td>T&lt;sub&gt;J&lt;/sub&gt;</td>
<td>Junction Temperature @ T&lt;sub&gt;AV&lt;/sub&gt; = 0°C to +70°C</td>
<td>0</td>
<td>+105</td>
<td>°C</td>
<td></td>
</tr>
<tr>
<td>T&lt;sub&gt;J&lt;/sub&gt;</td>
<td>Junction Temperature @ T&lt;sub&gt;AV&lt;/sub&gt; = -40°C to +85°C</td>
<td>0</td>
<td>+105</td>
<td>°C</td>
<td></td>
</tr>
</tbody>
</table>

<sup>1</sup> Must remain powered (even if the associated function is not used).

<sup>2</sup> If not used, power with V<sub>DDMEM</sub>.

<sup>3</sup> Balls that use V<sub>DDMEM</sub> are DATA15–0, ADDR19–1, ADET, ARE, AWE, AOE, AMST–0, ARDY, SA10, SWE, SCAS, CLKOUT, SEAS, SKI, SCKE. These balls are not tolerant to voltages higher than V<sub>DDMEM</sub>.

<sup>4</sup> The V<sub>PPOTP</sub> voltage for writes must only be applied when programming OTP memory. There is a finite amount of cumulative time that this voltage may be applied (dependent on voltage and junction temperature) over the lifetime of the part. Please see Table 30 on Page 38 for details.

<sup>5</sup> When not using the USB peripheral on the ADSP-BF524/ADSP-BF526 or terminating V<sub>DDUSB</sub> on the ADSP-BF522, V<sub>DDUSB</sub> must be powered by V<sub>DDEXT</sub>.

<sup>6</sup> Parameter value applies to all input and bidirectional balls, except USB_DP, USB_DM, USB_VBUS, SDA, and SCL.

<sup>7</sup> Bidirectional balls (PF15–0, PG15–0, PH15–0) and input balls (RTXI, TCK, TDI, TMS, TRST, CLKIN, RESET, NMI, and BMODE3–0) of the ADSP-BF52x processors are 2.5 V tolerant (always accept up to 2.7 V maximum V<sub>DD</sub>). Voltage compliance (on outputs, V<sub>DD</sub>) is limited by the V<sub>DDEXT</sub> supply voltage.

<sup>8</sup> Bidirectional balls (PF15–0, PG15–0, PH15–0) and input balls (RTXI, TCK, TDI, TMS, TRST, CLKIN, RESET, NMI, and BMODE3–0) of the ADSP-BF52x processors are 3.3 V tolerant (always accept up to 3.6 V maximum V<sub>DD</sub>). Voltage compliance (on outputs, V<sub>DD</sub>) is limited by the V<sub>DDEXT</sub> supply voltage.

<sup>9</sup> The V<sub>IL</sub> min and max value vary with the selection in the TWI_DT field of the NONGPIO_DRIVE register. See Table 30 on Page 38 for details.

<sup>10</sup> SDA and SCL are pulled up to V<sub>BUSTWI</sub>. See Table 11.
Table 11 shows settings for TWI_DT in the NONGPIO_DRIVE register. Set this register prior to using the TWI port.

<table>
<thead>
<tr>
<th>TWI_DT</th>
<th>V_DDEXT/Nominal</th>
<th>V_BUSTWI/Min</th>
<th>V_BUSTWI/Nominal</th>
<th>V_BUSTWI/Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>000 (default)</td>
<td>3.3</td>
<td>2.97</td>
<td>3.3</td>
<td>3.63</td>
<td>V</td>
</tr>
<tr>
<td>001</td>
<td>1.8</td>
<td>1.7</td>
<td>1.8</td>
<td>1.98</td>
<td>V</td>
</tr>
<tr>
<td>010</td>
<td>2.5</td>
<td>2.97</td>
<td>3.3</td>
<td>3.63</td>
<td>V</td>
</tr>
<tr>
<td>011</td>
<td>1.8</td>
<td>2.97</td>
<td>3.3</td>
<td>3.63</td>
<td>V</td>
</tr>
<tr>
<td>100</td>
<td>3.3</td>
<td>4.5</td>
<td>5</td>
<td>5.5</td>
<td>V</td>
</tr>
<tr>
<td>101</td>
<td>1.8</td>
<td>2.25</td>
<td>2.5</td>
<td>2.75</td>
<td>V</td>
</tr>
<tr>
<td>110</td>
<td>2.5</td>
<td>2.25</td>
<td>2.5</td>
<td>2.75</td>
<td>V</td>
</tr>
<tr>
<td>111 (reserved)</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>–</td>
<td>–</td>
</tr>
</tbody>
</table>

Table 11. TWI_DT Field Selections and V_DDEXT/V_BUSTWI

1 Designs must comply with the V_DDEXT and V_BUSTWI voltages specified for the default TWI_DT setting for correct JTAG boundary scan operation during reset.

**Clock Related Operating Conditions**

**for ADSP-BF522/ADSP-BF524/ADSP-BF526 Processors**

Table 12 describes the core clock timing requirements for the ADSP-BF522/ADSP-BF524/ADSP-BF526 processors. Take care in selecting MSEL, SSEL, and CSEL ratios so as not to exceed the maximum core clock and system clock (see Table 14). Table 13 describes phase-locked loop operating conditions.

**Table 12. Core Clock (CCLK) Requirements (All Instruction Rates)** for ADSP-BF522/ADSP-BF524/ADSP-BF526 Processors

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Nominal Voltage Setting</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>f_CCLK</td>
<td>Core Clock Frequency (V_DDINT = 1.33 V minimum)</td>
<td>1.40 V</td>
<td>400 MHz</td>
</tr>
<tr>
<td>f_CCLK</td>
<td>Core Clock Frequency (V_DDINT = 1.235 V minimum)</td>
<td>1.30 V</td>
<td>300 MHz</td>
</tr>
</tbody>
</table>

1 See the Ordering Guide on Page 88.

**Table 13. Phase-Locked Loop Operating Conditions for ADSP-BF522/ADSP-BF524/ADSP-BF526 Processors**

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>f_VCO</td>
<td>Voltage Controlled Oscillator (VCO) Frequency</td>
<td>70 Instruction Rate</td>
<td>MHz</td>
</tr>
</tbody>
</table>

1 See the Ordering Guide on Page 88.

**Table 14. SCLK Conditions for ADSP-BF522/ADSP-BF524/ADSP-BF526 Processors**

<table>
<thead>
<tr>
<th>Parameter</th>
<th>V_DDEXT/V_DDMEM 1.8 V Nominal</th>
<th>V_DDEXT/V_DDMEM 2.5 V or 3.3 V Nominal</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>f_SCLK</td>
<td>CLKOUT/SCLK Frequency (V_DDINT ≥ 1.33 V)</td>
<td>80 Max</td>
<td>100 Max</td>
</tr>
<tr>
<td>f_SCLK</td>
<td>CLKOUT/SCLK Frequency (V_DDINT &lt; 1.33 V)</td>
<td>80 Max</td>
<td>80 Max</td>
</tr>
</tbody>
</table>

1 If either V_DDEXT or V_DDMEM are operating at 1.8 V nominal, f_SCLK is constrained to 80 MHz.

2 f_SCLK must be less than or equal to f_CCLK and is subject to additional restrictions for SDRAM interface operation. See Table 37 on Page 47.
### OPERATING CONDITIONS FOR ADSP-BF523/ADSP-BF525/ADSP-BF527 PROCESSORS

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Conditions</th>
<th>Min</th>
<th>Nominal</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>VDDINT</td>
<td>Internal Supply Voltage&lt;sup&gt;1&lt;/sup&gt;</td>
<td>Nonautomotive models&lt;sup&gt;2&lt;/sup&gt;</td>
<td>0.95</td>
<td>1.26</td>
<td>V</td>
</tr>
<tr>
<td>VDDINT</td>
<td>Internal Supply Voltage&lt;sup&gt;1&lt;/sup&gt;</td>
<td>Automotive 533 MHz models&lt;sup&gt;3&lt;/sup&gt;</td>
<td>1.093</td>
<td>1.15</td>
<td>V</td>
</tr>
<tr>
<td>VDDINT</td>
<td>Internal Supply Voltage&lt;sup&gt;1&lt;/sup&gt;</td>
<td>Automotive 400 MHz models&lt;sup&gt;3&lt;/sup&gt;</td>
<td>1.045</td>
<td>1.10</td>
<td>V</td>
</tr>
<tr>
<td>VDDINT</td>
<td>Internal Supply Voltage&lt;sup&gt;1&lt;/sup&gt;</td>
<td>Nonautomotive models, Internal Voltage Regulator Disabled</td>
<td>1.7</td>
<td>1.8</td>
<td>V</td>
</tr>
<tr>
<td>VDDINT</td>
<td>Nonautomotive models</td>
<td>2.25</td>
<td>2.5</td>
<td>2.75</td>
<td>V</td>
</tr>
<tr>
<td>VDDINT</td>
<td>Automotive models</td>
<td>3</td>
<td>3.3</td>
<td>3.6</td>
<td>V</td>
</tr>
<tr>
<td>VDDINT</td>
<td>Automotive models</td>
<td>2.7</td>
<td>3.3</td>
<td>3.6</td>
<td>V</td>
</tr>
<tr>
<td>VDDRTC</td>
<td>RTC Power Supply Voltage&lt;sup&gt;4&lt;/sup&gt;</td>
<td>Nonautomotive models</td>
<td>2.25</td>
<td>3.3</td>
<td>V</td>
</tr>
<tr>
<td>VDDRTC</td>
<td>Automotive models</td>
<td>2.7</td>
<td>3.3</td>
<td>3.6</td>
<td>V</td>
</tr>
<tr>
<td>VDDMEM</td>
<td>MEM Supply Voltage&lt;sup&gt;4, 7&lt;/sup&gt;</td>
<td>Nonautomotive models</td>
<td>1.7</td>
<td>1.8</td>
<td>V</td>
</tr>
<tr>
<td>VDDMEM</td>
<td>Automotive models</td>
<td>2.25</td>
<td>2.5</td>
<td>2.75</td>
<td>V</td>
</tr>
<tr>
<td>VDDMEM</td>
<td>Automotive models</td>
<td>3</td>
<td>3.3</td>
<td>3.6</td>
<td>V</td>
</tr>
<tr>
<td>VDDMEM</td>
<td>Automotive models</td>
<td>2.7</td>
<td>3.3</td>
<td>3.6</td>
<td>V</td>
</tr>
<tr>
<td>VDDMEM</td>
<td>Nonautomotive models</td>
<td>2.25</td>
<td>2.5</td>
<td>2.75</td>
<td>V</td>
</tr>
<tr>
<td>VDDMEM</td>
<td>Automotive models</td>
<td>3.0</td>
<td>3.3</td>
<td>3.6</td>
<td>V</td>
</tr>
<tr>
<td>VDDUSB</td>
<td>USB Supply Voltage&lt;sup&gt;8&lt;/sup&gt;</td>
<td>3.0</td>
<td>3.3</td>
<td>3.6</td>
<td>V</td>
</tr>
<tr>
<td>VIH</td>
<td>High Level Input Voltage&lt;sup&gt;9, 10&lt;/sup&gt;</td>
<td>VDDINT/VDDMEM = 1.90 V</td>
<td>1.1</td>
<td>1.4</td>
<td>V</td>
</tr>
<tr>
<td>VIH</td>
<td>High Level Input Voltage&lt;sup&gt;10, 11&lt;/sup&gt;</td>
<td>VDDINT/VDDMEM = 2.75 V</td>
<td>1.7</td>
<td>2.0</td>
<td>V</td>
</tr>
<tr>
<td>VIH</td>
<td>High Level Input Voltage&lt;sup&gt;10, 11&lt;/sup&gt;</td>
<td>VDDINT/VDDMEM = 3.6 V</td>
<td>2.0</td>
<td>2.0</td>
<td>V</td>
</tr>
<tr>
<td>VIHTWI</td>
<td>High Level Input Voltage&lt;sup&gt;12&lt;/sup&gt;</td>
<td>VDDINT = 1.90 V/2.75 V/3.6 V 0.7 × V_BUSTWI</td>
<td>V_BUSTWI</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>VIH</td>
<td>Low Level Input Voltage&lt;sup&gt;6, 10&lt;/sup&gt;</td>
<td>VDDINT/VDDMEM = 1.7 V</td>
<td>0.6</td>
<td>0.6</td>
<td>V</td>
</tr>
<tr>
<td>VIH</td>
<td>Low Level Input Voltage&lt;sup&gt;6, 11&lt;/sup&gt;</td>
<td>VDDINT/VDDMEM = 2.25 V</td>
<td>0.7</td>
<td>0.7</td>
<td>V</td>
</tr>
<tr>
<td>VIH</td>
<td>Low Level Input Voltage&lt;sup&gt;6, 11&lt;/sup&gt;</td>
<td>VDDINT/VDDMEM = 3.0 V</td>
<td>0.8</td>
<td>0.8</td>
<td>V</td>
</tr>
<tr>
<td>VIHTWI</td>
<td>Low Level Input Voltage</td>
<td>VDDINT = Minimum</td>
<td>0.3 × V_BUSTWI</td>
<td>V</td>
<td></td>
</tr>
<tr>
<td>TJ</td>
<td>Junction Temperature</td>
<td>289-Ball CSP_BGA</td>
<td>0</td>
<td>+105</td>
<td>°C</td>
</tr>
<tr>
<td>TJ</td>
<td>Junction Temperature</td>
<td>289-Ball CSP_BGA</td>
<td>–40</td>
<td>+105</td>
<td>°C</td>
</tr>
<tr>
<td>TJ</td>
<td>Junction Temperature</td>
<td>208-Ball CSP_BGA</td>
<td>0</td>
<td>+105</td>
<td>°C</td>
</tr>
<tr>
<td>TJ</td>
<td>Junction Temperature</td>
<td>208-Ball CSP_BGA</td>
<td>–40</td>
<td>+105</td>
<td>°C</td>
</tr>
</tbody>
</table>

<sup>1</sup>The voltage regulator can generate VDDINT at levels of 1.00 V to 1.20 V with –5% to +5% tolerance when VRCTL is programmed with the bfrom_SysControl() API. This specification is only guaranteed when the API is used.

<sup>2</sup>See Ordering Guide on Page 88.

<sup>3</sup>See Automotive Products on Page 87.

<sup>4</sup>Must remain powered (even if the associated function is not used).

<sup>5</sup>VDDINT is the supply to the voltage regulator and GPIO.

<sup>6</sup>When not using the USB peripheral on the ADSP-BF525/ADSP-BF527 or terminating VDDUSB on the ADSP-BF523, VDDUSB must be powered by VDDEXT.

<sup>7</sup>Parameter value applies to all input and bidirectional balls, except USB_DP, USB_DM, USB_VBUS, SDA, and SCL.

<sup>8</sup>Bidirectional balls (PF15–0, PG15–0, PH15–0) and input balls (RTXI, TCK, TDI, TMS, TEST, CLKIN, RESET, NMI, and BMODE3–0) of the ADSP-BF52x processors are 2.5 V tolerant (always accept up to 2.7 V maximum VIH). Voltage compliance (on outputs, VOH) is limited by the VDDEXT supply voltage.

<sup>9</sup>The VIHTWI min and max value vary with the selection in the TWI_DT field of the NONGPIO_DRIVE register. See V_BUSTWI min and max values in Table 11 on Page 29.

<sup>10</sup>SDA and SCL are pulled up to V_BUSTWI. See Table 11 on Page 29.
Clock Related Operating Conditions for ADSP-BF523/ADSP-BF525/ADSP-BF527 Processors

Table 15 describes the core clock timing requirements for the ADSP-BF523/ADSP-BF525/ADSP-BF527 processors. Take care in selecting MSEL, SSEL, and CSEL ratios so as not to exceed the maximum core clock and system clock (see Table 17). Table 16 describes phase-locked loop operating conditions.

Use the nominal voltage setting (Table 15) for internal and external regulators.

Table 15. Core Clock (CCLK) Requirements (All Instruction Rates) for ADSP-BF523/ADSP-BF525/ADSP-BF527 Processors

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Nominal Voltage Setting</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>fCCLK</td>
<td>Core Clock Frequency (VDDINT = 1.14 V minimum)</td>
<td>1.20 V</td>
<td>600</td>
</tr>
<tr>
<td>fCCLK</td>
<td>Core Clock Frequency (VDDINT = 1.093 V minimum)</td>
<td>1.15 V</td>
<td>533</td>
</tr>
<tr>
<td>fCCLK</td>
<td>Core Clock Frequency (VDDINT = 1.045 V minimum)</td>
<td>1.10 V</td>
<td>400</td>
</tr>
<tr>
<td>fCCLK</td>
<td>Core Clock Frequency (VDDINT = 0.95 V minimum)</td>
<td>1.0 V</td>
<td>400</td>
</tr>
</tbody>
</table>

1 See the Ordering Guide on Page 88.
2 Applies to 600 MHz models only. See the Ordering Guide on Page 88.
3 Applies to 533 MHz and 600 MHz models only. See the Ordering Guide on Page 88.
4 Applies only to automotive products. See Automotive Products on Page 87.

Table 16. Phase-Locked Loop Operating Conditions for ADSP-BF523/ADSP-BF525/ADSP-BF527 Processors

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min</th>
<th>Max</th>
</tr>
</thead>
<tbody>
<tr>
<td>fVCO</td>
<td>60 Instruction Rate 1 MHz</td>
<td>Instruction Rate 1 MHz</td>
</tr>
<tr>
<td>fVCO</td>
<td>70 Instruction Rate 1 MHz</td>
<td>Instruction Rate 1 MHz</td>
</tr>
</tbody>
</table>

1 See the Ordering Guide on Page 88.

Table 17. SCLK Conditions for ADSP-BF523/ADSP-BF525/ADSP-BF527 Processors

<table>
<thead>
<tr>
<th>Parameter</th>
<th>VDDINT/VDDMEM 1.8 V Nominal</th>
<th>VDDINT/VDDMEM 2.5 V or 3.3 V Nominal</th>
</tr>
</thead>
<tbody>
<tr>
<td>fSCLK</td>
<td>Max</td>
<td>Max</td>
</tr>
<tr>
<td>fSCLK</td>
<td>100</td>
<td>133</td>
</tr>
<tr>
<td>fSCLK</td>
<td>100</td>
<td>100</td>
</tr>
</tbody>
</table>

1 If either VDDINT or VDDMEM are operating at 1.8 V nominal, fSCLK is constrained to 100 MHz.
2 fSCLK must be less than or equal to fCCLK and is subject to additional restrictions for SDRAM interface operation. See Table 38 on Page 47.
3 Rounded number. Actual test specification is SCLK period of 7.5 ns. See Table 38 on Page 47.
# Electrical Characteristics

**Table 18. Common Electrical Characteristics for All ADSP-BF52x Processors**

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Test Conditions</th>
<th>Min</th>
<th>Typical</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>$V_{OH}$</td>
<td>$V_{DDEXT}/V_{DDMEM}=1.7,V$, $I_{OH}=-0.5,mA$</td>
<td>1.35</td>
<td></td>
<td></td>
<td>V</td>
</tr>
<tr>
<td>$V_{OH}$</td>
<td>$V_{DDEXT}/V_{DDMEM}=2.25,V$, $I_{OH}=-0.5,mA$</td>
<td>2.0</td>
<td></td>
<td></td>
<td>V</td>
</tr>
<tr>
<td>$V_{OH}$</td>
<td>$V_{DDEXT}/V_{DDMEM}=3.0,V$, $I_{OH}=-0.5,mA$</td>
<td>2.4</td>
<td></td>
<td></td>
<td>V</td>
</tr>
<tr>
<td>$V_{OL}$</td>
<td>$V_{DDEXT}/V_{DDMEM}=1.7,V/2.25,V/3.0,V$, $I_{OL}=2.0,mA$</td>
<td>0.4</td>
<td></td>
<td></td>
<td>V</td>
</tr>
<tr>
<td>$I_{IH}$</td>
<td>$V_{DDEXT}/V_{DDMEM}=3.6,V$, $V_{IN}=3.6,V$</td>
<td>0</td>
<td>10.0</td>
<td></td>
<td>μA</td>
</tr>
<tr>
<td>$I_{IL}$</td>
<td>$V_{DDEXT}/V_{DDMEM}=3.6,V$, $V_{IN}=0,V$</td>
<td>0</td>
<td>10.0</td>
<td></td>
<td>μA</td>
</tr>
<tr>
<td>$I_{IH}$</td>
<td>$V_{DDEXT}/V_{DDMEM}=3.6,V$, $V_{IN}=3.6,V$</td>
<td>0</td>
<td>75.0</td>
<td></td>
<td>μA</td>
</tr>
<tr>
<td>$I_{OZH}$</td>
<td>$V_{DDEXT}/V_{DDMEM}=3.6,V$, $V_{IN}=3.6,V$</td>
<td>0</td>
<td>10.0</td>
<td></td>
<td>μA</td>
</tr>
<tr>
<td>$I_{OZL}$</td>
<td>$V_{DDEXT}=3.0,V$, $V_{IN}=5.5,V$</td>
<td>0</td>
<td>10.0</td>
<td></td>
<td>μA</td>
</tr>
<tr>
<td>$I_{OZH}$</td>
<td>$V_{DDEXT}/V_{DDMEM}=3.6,V$, $V_{IN}=0,V$</td>
<td>0</td>
<td>10.0</td>
<td></td>
<td>μA</td>
</tr>
<tr>
<td>$C_{IN}$</td>
<td>$f_{IN}=1,MHz$, $T_{AMBIENT}=25^\circ C$, $V_{IN}=2.5,V$</td>
<td>5</td>
<td>8</td>
<td></td>
<td>pF</td>
</tr>
<tr>
<td>$C_{INTWI}$</td>
<td>$f_{IN}=1,MHz$, $T_{AMBIENT}=25^\circ C$, $V_{IN}=2.5,V$</td>
<td>15</td>
<td></td>
<td></td>
<td>pF</td>
</tr>
</tbody>
</table>

1. Applies to input balls.
2. Applies to JTAG input balls (TCK, TDI, TMS, TRST).
3. Applies to three-stateable balls.
4. Applies to bidirectional balls SCL and SDA.
5. Applies to all signal balls, except SCL and SDA.
6. Guaranteed, but not tested.
### Table 19. Electrical Characteristics for ADSP-BF522/ADSP-BF524/ADSP-BF526 Processors

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Test Conditions</th>
<th>Min</th>
<th>Typical</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>IDDDEEPSLEEP</td>
<td>V_DDINT Current in Deep Sleep Mode V_DDINT = 1.3 V, f_CCLK = 0 MHz, f_SCLK = 0 MHz, T_J = 25°C, ASF = 0.00</td>
<td>2 mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IDDSLEEP</td>
<td>V_DDINT Current in Sleep Mode V_DDINT = 1.3 V, f_SCLK = 25 MHz, T_J = 25°C</td>
<td>13 mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IIDDLE</td>
<td>V_DDINT Current in Idle V_DDINT = 1.3 V, f_CCLK = 300 MHz, f_SCLK = 25 MHz, T_J = 25°C, ASF = 0.4</td>
<td>44 mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IIDD-TYP</td>
<td>V_DDINT Current V_DDINT = 1.4 V, f_CCLK = 400 MHz, f_SCLK = 25 MHz, T_J = 25°C, ASF = 1.00</td>
<td>83 mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IIDD-TYP</td>
<td>V_DDINT Current V_DDINT = 1.4 V, f_CCLK = 400 MHz, f_SCLK = 25 MHz, T_J = 25°C, ASF = 1.00</td>
<td>114 mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IDDHBERNATE</td>
<td>Hibernate State Current V_DDINT = V_DDMEG = V_DDRTC = V_DDUSB = 3.30 V, V_DDOTP = V_PPOTP = 2.5 V, T_J = 25°C, CLKIN = 0 MHz with voltage regulator off (V_DDINT = 0 V)</td>
<td>40 μA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IDDRTC</td>
<td>V_DDRTC Current V_DDRTC = 3.3 V, T_J = 25°C</td>
<td>20 μA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IDDUSB-FS</td>
<td>V_DDUSB Current in Full/Low Speed Mode V_DDUSB = 3.3 V, T_J = 25°C, Full Speed USB Transmit</td>
<td>9 mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IDDUSB-HS</td>
<td>V_DDUSB Current in High Speed Mode V_DDUSB = 3.3 V, T_J = 25°C, High Speed USB Transmit</td>
<td>25 mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IDDDEEPSLEEP</td>
<td>V_DDINT Current in Deep Sleep Mode V_DDINT = 1.3 V, f_CCLK = 0 MHz, f_SCLK &gt; 0 MHz</td>
<td></td>
<td>Table 22 + (0.52 × V_DDINT × f_SCLK)^4</td>
<td></td>
<td>mA</td>
</tr>
<tr>
<td>IDDDEEPSLEEP</td>
<td>V_DDINT Current in Deep Sleep Mode V_DDINT = 1.3 V, f_CCLK = 0 MHz, f_SCLK ≥ 0 MHz</td>
<td></td>
<td>Table 22 + (Table 23 × ASF) + (0.52 × V_DDINT × f_SCLK)</td>
<td></td>
<td>mA</td>
</tr>
<tr>
<td>IDDOTP</td>
<td>V_DDOTP Current V_DDOTP = 2.5 V, T_J = 25°C, OTP Memory Read</td>
<td>2 mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IDDOTP</td>
<td>V_DDOTP Current V_DDOTP = 2.5 V, T_J = 25°C, OTP Memory Write</td>
<td>2 mA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IPPOTP</td>
<td>V_PPOTP Current V_PPOTP = 2.5 V, T_J = 25°C, OTP Memory Read</td>
<td>100 μA</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>IPPOTP</td>
<td>V_PPOTP Current V_PPOTP = see Table 30, T_J = 25°C, OTP Memory Write</td>
<td>3 mA</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

1 See the ADSP-BF52x Blackfin Processor Hardware Reference Manual for definition of sleep, deep sleep, and hibernate operating modes.
2 Includes current on V_DDEXT, V_DDUSB, V_DDMEG, V_DDRTC, and V_DDOTP supplies. Clock inputs are tied high or low.
3 Guaranteed maximum specifications.
4 Unit for V_DDINT is V (Volts). Unit for f_SCLK is MHz. Example: 1.4 V, 75 MHz would be 0.52 × 1.4 × 75 = 54.6 mA adder.
5 See Table 21 for the list of IDDINT power vectors covered.
Table 20. Electrical Characteristics for ADSP-BF523/ADSP-BF525/ADSP-BF527 Processors

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Test Conditions</th>
<th>Min</th>
<th>Typical</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>( i_{DDDEEPSLEEP} )</td>
<td>( V_{DDINT} ) Current in Deep Sleep Mode</td>
<td>10</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDSLEEP} )</td>
<td>( V_{DDINT} ) Current in Sleep Mode</td>
<td>20</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DD-IDLE} )</td>
<td>( V_{DDINT} ) Current in Idle</td>
<td>53</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DD-TYP} )</td>
<td>( V_{DDINT} ) Current</td>
<td>94</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DD-TYP} )</td>
<td>( V_{DDINT} ) Current</td>
<td>144</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DD-TYP} )</td>
<td>( V_{DDINT} ) Current</td>
<td>170</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDBERNATE} )</td>
<td>Hibernation State Current</td>
<td>40</td>
<td>( \mu A )</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDRTC} )</td>
<td>( V_{DDBRTC} ) Current</td>
<td>20</td>
<td>( \mu A )</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDUSB-FS} )</td>
<td>( V_{DDUSB} ) Current in Full/Low Speed Mode</td>
<td>9</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDUSB-HS} )</td>
<td>( V_{DDUSB} ) Current in High Speed Mode</td>
<td>25</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDBERNATE} )</td>
<td>Hibernation State Current</td>
<td>40</td>
<td>( \mu A )</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDRTC} )</td>
<td>( V_{DDBRTC} ) Current</td>
<td>20</td>
<td>( \mu A )</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDUSB-FS} )</td>
<td>( V_{DDUSB} ) Current in Full/Low Speed Mode</td>
<td>9</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDUSB-HS} )</td>
<td>( V_{DDUSB} ) Current in High Speed Mode</td>
<td>25</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDBERNATE} )</td>
<td>Hibernation State Current</td>
<td>40</td>
<td>( \mu A )</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDRTC} )</td>
<td>( V_{DDBRTC} ) Current</td>
<td>20</td>
<td>( \mu A )</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDUSB-FS} )</td>
<td>( V_{DDUSB} ) Current in Full/Low Speed Mode</td>
<td>9</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDUSB-HS} )</td>
<td>( V_{DDUSB} ) Current in High Speed Mode</td>
<td>25</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDBERNATE} )</td>
<td>Hibernation State Current</td>
<td>40</td>
<td>( \mu A )</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDRTC} )</td>
<td>( V_{DDBRTC} ) Current</td>
<td>20</td>
<td>( \mu A )</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDUSB-FS} )</td>
<td>( V_{DDUSB} ) Current in Full/Low Speed Mode</td>
<td>9</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDUSB-HS} )</td>
<td>( V_{DDUSB} ) Current in High Speed Mode</td>
<td>25</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDDEEPSLEEP} )</td>
<td>( V_{DDINT} ) Current in Deep Sleep Mode</td>
<td>10</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDDEEPSLEEP} )</td>
<td>( V_{DDINT} ) Current in Deep Sleep Mode</td>
<td>10</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDDEEPSLEEP} )</td>
<td>( V_{DDINT} ) Current in Deep Sleep Mode</td>
<td>10</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( i_{DDDEEPSLEEP} )</td>
<td>( V_{DDINT} ) Current in Deep Sleep Mode</td>
<td>10</td>
<td>mA</td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

1 See the ADSP-BF52x Blackfin Processor Hardware Reference Manual for definition of sleep, deep sleep, and hibernate operating modes.
2 Includes current on \( V_{DDEXT} \), \( V_{DDUSB} \), \( V_{DDMEM} \), \( V_{DDOTP} \), and \( V_{PPOTP} \) supplies. Clock inputs are tied high or low.
3 Guaranteed maximum specifications.
4 Unit for \( V_{DDINT} \) is V (Volts). Unit for \( f_{SCLK} \) is MHz. Example: 1.2 V, 75 MHz would be \( 0.61 \times 1.2 \times 75 = 54.9 \) mA adder.
5 See Table 21 for the list of \( i_{DDINT} \) power vectors covered.
Total Power Dissipation

Total power dissipation has two components:
1. Static, including leakage current
2. Dynamic, due to transistor switching characteristics

Many operating conditions can also affect power dissipation, including temperature, voltage, operating frequency, and processor activity. Electrical Characteristics on Page 32 shows the current dissipation for internal circuitry (VDDINT). IDDDEEPSLEEP specifies static power dissipation as a function of voltage (VDDINT) and temperature (see Table 22 or Table 24), and IIDDINT specifies the total power specification for the listed test conditions, including the dynamic component as a function of voltage (VDDINT) and frequency (Table 23 or Table 25).

There are two parts to the dynamic component. The first part is due to transistor switching in the core clock (CCLK) domain. This part is subject to an Activity Scaling Factor (ASF) which represents application code running on the processor core and L1 memories (Table 21).

The ASF is combined with the CCLK Frequency and VDDINT dependent data in Table 23 or Table 25 to calculate this part. The second part is due to transistor switching in the system clock (SCLK) domain, which is included in the IIDDINT specification equation.

Table 21. Activity Scaling Factors (ASF)¹

<table>
<thead>
<tr>
<th>IDDINT Power Vector</th>
<th>Activity Scaling Factor (ASF)</th>
</tr>
</thead>
<tbody>
<tr>
<td>IDD-PEAK</td>
<td>1.29</td>
</tr>
<tr>
<td>IDD-HIGH</td>
<td>1.26</td>
</tr>
<tr>
<td>IDD-TYP</td>
<td>1.00</td>
</tr>
<tr>
<td>IDD-APP</td>
<td>0.88</td>
</tr>
<tr>
<td>IDD-NOP</td>
<td>0.72</td>
</tr>
<tr>
<td>IDD-IDLE</td>
<td>0.44</td>
</tr>
</tbody>
</table>

¹See Estimating Power for ASDP-BF534/BF536/BF537 Blackfin Processors (EE-297). The power vector information also applies to the ADSP-BF52x processors.

Table 22. Static Current — IIDDDEEPSLEEP (mA) for ADSP-BF522/ADSP-BF524/ADSP-BF526 Processors

<table>
<thead>
<tr>
<th>Tj (°C)¹</th>
<th>Voltage (VDDINT)¹</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>1.2 V</td>
</tr>
<tr>
<td>−40</td>
<td>1.47</td>
</tr>
<tr>
<td>−20</td>
<td>1.67</td>
</tr>
<tr>
<td>0</td>
<td>1.97</td>
</tr>
<tr>
<td>25</td>
<td>2.49</td>
</tr>
<tr>
<td>40</td>
<td>3.12</td>
</tr>
<tr>
<td>55</td>
<td>4.07</td>
</tr>
<tr>
<td>70</td>
<td>5.77</td>
</tr>
<tr>
<td>85</td>
<td>8.32</td>
</tr>
<tr>
<td>100</td>
<td>12.11</td>
</tr>
<tr>
<td>105</td>
<td>13.78</td>
</tr>
</tbody>
</table>


Table 23. Dynamic Current in CCLK Domain (mA, with ASF = 1.0)¹ for ADSP-BF522/ADSP-BF524/ADSP-BF526 Processors

<table>
<thead>
<tr>
<th>fCCLK (MHz)²</th>
<th>Voltage (VDDINT)²</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>1.2 V</td>
</tr>
<tr>
<td>400</td>
<td>N/A</td>
</tr>
<tr>
<td>350</td>
<td>N/A</td>
</tr>
<tr>
<td>300</td>
<td>63.31</td>
</tr>
<tr>
<td>250</td>
<td>53.36</td>
</tr>
<tr>
<td>200</td>
<td>43.49</td>
</tr>
<tr>
<td>100</td>
<td>23.6</td>
</tr>
</tbody>
</table>

¹The values are not guaranteed as standalone maximum specifications. They must be combined with static current per the equations of Electrical Characteristics on Page 32.
### Table 24. Static Current — $I_{DD-DEEPSLEEP}$ (mA) for ADSP-BF523/ADSP-BF525/ADSP-BF527 Processors

<table>
<thead>
<tr>
<th>$T_j$ ($^\circ$C)</th>
<th>0.95 V</th>
<th>1.00 V</th>
<th>1.05 V</th>
<th>1.10 V</th>
<th>1.15 V</th>
<th>1.20 V</th>
<th>1.25 V</th>
<th>1.30 V</th>
</tr>
</thead>
<tbody>
<tr>
<td>–40</td>
<td>6.5</td>
<td>7.8</td>
<td>9.3</td>
<td>11.1</td>
<td>13.1</td>
<td>15.4</td>
<td>18.0</td>
<td>21.0</td>
</tr>
<tr>
<td>–20</td>
<td>9.0</td>
<td>10.6</td>
<td>12.4</td>
<td>14.6</td>
<td>17.0</td>
<td>19.8</td>
<td>22.9</td>
<td>26.4</td>
</tr>
<tr>
<td>0</td>
<td>13.2</td>
<td>15.2</td>
<td>17.7</td>
<td>20.4</td>
<td>23.5</td>
<td>27.0</td>
<td>30.9</td>
<td>35.3</td>
</tr>
<tr>
<td>25</td>
<td>22.3</td>
<td>25.4</td>
<td>28.9</td>
<td>32.8</td>
<td>37.2</td>
<td>42.1</td>
<td>47.6</td>
<td>53.7</td>
</tr>
<tr>
<td>40</td>
<td>30.8</td>
<td>34.8</td>
<td>39.2</td>
<td>44.1</td>
<td>49.6</td>
<td>55.7</td>
<td>62.5</td>
<td>70.0</td>
</tr>
<tr>
<td>55</td>
<td>42.9</td>
<td>47.9</td>
<td>53.6</td>
<td>59.9</td>
<td>66.9</td>
<td>74.6</td>
<td>83.2</td>
<td>92.6</td>
</tr>
<tr>
<td>70</td>
<td>59.1</td>
<td>65.6</td>
<td>72.9</td>
<td>80.8</td>
<td>89.7</td>
<td>99.4</td>
<td>110.2</td>
<td>122.0</td>
</tr>
<tr>
<td>85</td>
<td>80.4</td>
<td>88.6</td>
<td>97.9</td>
<td>107.8</td>
<td>119.2</td>
<td>131.5</td>
<td>145.1</td>
<td>159.8</td>
</tr>
<tr>
<td>100</td>
<td>109.3</td>
<td>118.7</td>
<td>130.5</td>
<td>143.2</td>
<td>157.4</td>
<td>172.8</td>
<td>189.7</td>
<td>208.1</td>
</tr>
<tr>
<td>105</td>
<td>120.8</td>
<td>132.1</td>
<td>144.7</td>
<td>158.8</td>
<td>174.2</td>
<td>190.9</td>
<td>209.3</td>
<td>229.2</td>
</tr>
<tr>
<td>115</td>
<td>144.4</td>
<td>157.5</td>
<td>172.3</td>
<td>188.4</td>
<td>206.0</td>
<td>225.3</td>
<td>246.4</td>
<td>269.2</td>
</tr>
<tr>
<td>125</td>
<td>173.9</td>
<td>189.1</td>
<td>206.4</td>
<td>224.9</td>
<td>245.4</td>
<td>267.8</td>
<td>292.2</td>
<td>318.7</td>
</tr>
</tbody>
</table>


### Table 25. Dynamic Current in CCLK Domain (mA, with ASF = 1.0)¹ for ADSP-BF523/ADSP-BF525/ADSP-BF527 Processors

<table>
<thead>
<tr>
<th>$f_{CCLK}$ (MHz)²</th>
<th>0.95 V</th>
<th>1.00 V</th>
<th>1.05 V</th>
<th>1.10 V</th>
<th>1.15 V</th>
<th>1.20 V</th>
<th>1.25 V</th>
<th>1.30 V</th>
</tr>
</thead>
<tbody>
<tr>
<td>600</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
<td>130.4</td>
<td>137.6</td>
<td>145.1</td>
<td>152.5</td>
</tr>
<tr>
<td>533</td>
<td>N/A</td>
<td>N/A</td>
<td>N/A</td>
<td>110.3</td>
<td>116.7</td>
<td>123.3</td>
<td>129.8</td>
<td>136.4</td>
</tr>
<tr>
<td>500</td>
<td>N/A</td>
<td>N/A</td>
<td>97.3</td>
<td>103.1</td>
<td>109.1</td>
<td>115.0</td>
<td>121.3</td>
<td>127.7</td>
</tr>
<tr>
<td>400</td>
<td>69.8</td>
<td>74.3</td>
<td>78.9</td>
<td>83.6</td>
<td>88.5</td>
<td>93.5</td>
<td>98.6</td>
<td>103.9</td>
</tr>
<tr>
<td>300</td>
<td>53.4</td>
<td>56.9</td>
<td>60.4</td>
<td>64.1</td>
<td>68.0</td>
<td>71.8</td>
<td>75.8</td>
<td>80.0</td>
</tr>
<tr>
<td>200</td>
<td>36.9</td>
<td>39.4</td>
<td>41.9</td>
<td>44.6</td>
<td>47.4</td>
<td>50.1</td>
<td>53.0</td>
<td>56.0</td>
</tr>
<tr>
<td>100</td>
<td>20.5</td>
<td>22.0</td>
<td>23.6</td>
<td>25.3</td>
<td>27.0</td>
<td>28.8</td>
<td>30.6</td>
<td>32.5</td>
</tr>
</tbody>
</table>

¹ The values are not guaranteed as standalone maximum specifications. They must be combined with static current per the equations of Electrical Characteristics on Page 32.

ABSOLUTE MAXIMUM RATINGS

Stresses greater than those listed in Table 26 may cause permanent damage to the device. These are stress ratings only. Functional operation of the device at these or any other conditions greater than those indicated in the operational sections of this specification is not implied. Exposure to absolute maximum rating conditions for extended periods may affect device reliability.

Table 26. Absolute Maximum Ratings

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Rating</th>
</tr>
</thead>
<tbody>
<tr>
<td>Internal Supply Voltage (V_{DDINT}) for ADSP-BF523/ADSP-BF525/ADSP-BF527 processors</td>
<td>–0.3 V to +1.26 V</td>
</tr>
<tr>
<td>Internal Supply Voltage (V_{DDINT}) for ADSP-BF522/ADSP-BF524/ADSP-BF526 processors</td>
<td>–0.3 V to +1.47 V</td>
</tr>
<tr>
<td>External (I/O) Supply Voltage (V_{DDEXT/VDDMEM})</td>
<td>–0.3 V to +3.8 V</td>
</tr>
<tr>
<td>Real-Time Clock Supply Voltage (V_{DDRTC})</td>
<td>–0.5 V to +3.8 V</td>
</tr>
<tr>
<td>OTP Supply Voltage (V_{DDOTP})</td>
<td>–0.5 V to +3.0 V</td>
</tr>
<tr>
<td>OTP Programming Voltage (V_{VPPOTP})</td>
<td>–0.5 V to +3.0 V</td>
</tr>
<tr>
<td>OTP Programming Voltage (V_{VPPOTP})</td>
<td>–0.5 V to +7.1 V</td>
</tr>
<tr>
<td>USB PHY Supply Voltage (V_{DDUSB})</td>
<td>–0.5 V to +3.8 V</td>
</tr>
<tr>
<td>Input Voltage</td>
<td>–0.5 V to +3.8 V</td>
</tr>
<tr>
<td>Input Voltage</td>
<td>–0.5 V to +5.5 V</td>
</tr>
<tr>
<td>Input Voltage</td>
<td>–0.5 V to +5.25 V</td>
</tr>
<tr>
<td>Output Voltage Swing</td>
<td>–0.5 V to V_{DDEXT}/V_{DDMEM} ±0.5 V</td>
</tr>
<tr>
<td>I_{OH}/I_{OL} Current per Pin Group</td>
<td>82 mA (max)</td>
</tr>
<tr>
<td>Storage Temperature Range</td>
<td>–65°C to +150°C</td>
</tr>
<tr>
<td>Junction Temperature While Biased</td>
<td>+110°C</td>
</tr>
</tbody>
</table>

1 Applies to OTP memory reads and writes for ADSP-BF523/ADSP-BF525/ADSP-BF527 processors and to OTP memory reads for ADSP-BF522/ADSP-BF524/ADSP-BF526 processors.
2 Applies only to OTP memory writes for ADSP-BF522/ADSP-BF524/ADSP-BF526 processors.
3 Applies to 100% transient duty cycle.
4 Applies only when V_{DDEXT} is within specifications. When V_{DDEXT} is outside specifications, the range is V_{DDEXT} ±0.2 V.
5 For other duty cycles see Table 27.
6 Applies to balls SCL and SDA.
7 Applies to balls USB_DP, USB_DM, and USB_VBUS.
8 For pin group information, see Table 28. For other duty cycles see Table 29.

Table 27. Maximum Duty Cycle for Input Transient Voltage

<table>
<thead>
<tr>
<th>Maximum Duty Cycle</th>
<th>V_{IN} Min (V)</th>
<th>V_{IN} Max (V)</th>
</tr>
</thead>
<tbody>
<tr>
<td>100%</td>
<td>–0.50</td>
<td>+3.80</td>
</tr>
<tr>
<td>40%</td>
<td>–0.70</td>
<td>+4.00</td>
</tr>
<tr>
<td>25%</td>
<td>–0.80</td>
<td>+4.10</td>
</tr>
<tr>
<td>15%</td>
<td>–0.90</td>
<td>+4.20</td>
</tr>
<tr>
<td>10%</td>
<td>–1.00</td>
<td>+4.30</td>
</tr>
</tbody>
</table>

1 Applies to all signal balls with the exception of CLKIN, XTAL, VREXT/EXT_WAKE1, SCL, SDA, USB_DP, USB_DM, and USB_VBUS.
2 Applies only when V_{DDEXT} is within specifications. When V_{DDEXT} is outside specifications, the range is V_{DDEXT} ±0.2 V.
3 Duty cycle refers to the percentage of time the signal exceeds the value for the 100% case. This is equivalent to the measured duration of a single instance of overshoot or undershoot as a percentage of the period of occurrence.
4 The individual values cannot be combined for analysis of a single instance of overshoot or undershoot. The worst case observed value must fall within one of the voltages specified, and the total duration of the overshoot or undershoot (exceeding the 100% case) must be less than or equal to the corresponding duty cycle.

Table 26 specifies the maximum total source/sink (I_{OH}/I_{OL}) current for a group of pins. Permanent damage can occur if this value is exceeded. To understand this specification, if pins PH4, PH3, PH2, PH1, and PH0 from group 1 in Table 28 were sourcing or sinking 2 mA each, the total current for those pins would be 10 mA. This would allow up to 72 mA total that could be sourced or sunk by the remaining pins in the group without damaging the device. For a list of all groups and their pins, see the Table 28 table. For duty cycles that are less than 100%, see Table 29. Note that the V_{OH} and V_{OL} specifications have separate per-pin maximum current requirements (see Table 19 on Page 33 and Table 20 on Page 34).

Table 28. Total Current Pin Groups

<table>
<thead>
<tr>
<th>Group</th>
<th>Pins in Group</th>
</tr>
</thead>
<tbody>
<tr>
<td>1</td>
<td>PH4, PH3, PH2, PH1, PH0, PF15, PF14, PF13</td>
</tr>
<tr>
<td>2</td>
<td>PF12, SDA, SCL, PF11, PF10, PF9, PF8, PF7</td>
</tr>
<tr>
<td>3</td>
<td>PF6, PF5, PF4, PF3, PF2, PF1, F0, PPL_F1</td>
</tr>
<tr>
<td>4</td>
<td>PPI_CLK, PG15, PG14, PG13, PG12, PG11, PG10, PG9</td>
</tr>
<tr>
<td>5</td>
<td>PG8, PG7, PG6, PG5, PG4, BMODE3, BMODE2, BMODE1</td>
</tr>
</tbody>
</table>
When programming OTP memory on the ADSP-BF522/ADSP-BF524/ADSP-BF526 processors, the VPPOTP ball must be set to the write value specified in the Operating Conditions for ADSP-BF522/ADSP-BF524 Processors on Page 28. There is a finite amount of cumulative time that the write voltage may be applied (dependent on voltage and junction temperature) to VPPOTP over the lifetime of the part. Therefore, maximum OTP memory programming time for the ADSP-BF522/ADSP-BF524 processors is shown in Table 30. The ADSP-BF523/ADSP-BF525 processors do not have a similar restriction.

Table 28. Total Current Pin Groups (Continued)

<table>
<thead>
<tr>
<th>Group</th>
<th>Pins in Group</th>
</tr>
</thead>
<tbody>
<tr>
<td>6</td>
<td>BMODE0, PG3, PG2, PG1, PG0, TDI, TDO, EMU</td>
</tr>
<tr>
<td>7</td>
<td>TCK, TRST, TMS</td>
</tr>
<tr>
<td>8</td>
<td>PH12, PH11, PH10, PH9, PH8, PH7, PH6, PH5</td>
</tr>
<tr>
<td>9</td>
<td>PH15, PH14, PH13, CLKBUF, NMI, RESET</td>
</tr>
<tr>
<td>10</td>
<td>DATA15, DATA14, DATA13, DATA12, DATA11, DATA10</td>
</tr>
<tr>
<td>11</td>
<td>DATA9, DATA8, DATA7, DATA6, DATA5, DATA4</td>
</tr>
<tr>
<td>12</td>
<td>DATA3, DATA2, DATA1, DATA0, ADDR19, ADDR18</td>
</tr>
<tr>
<td>13</td>
<td>ADDR17, ADDR16, ADDR15, ADDR14, ADDR13</td>
</tr>
<tr>
<td>14</td>
<td>ADDR12, ADDR11, ADDR10, ADDR9, ADDR8, ADDR7</td>
</tr>
<tr>
<td>15</td>
<td>ADDR6, ADDR5, ADDR4, ADDR3, ADDR2, ADDR1</td>
</tr>
<tr>
<td>16</td>
<td>ABET, ABE0, SA0, SWE, SCAS, SRAS</td>
</tr>
<tr>
<td>17</td>
<td>SMS, SCKE, ARDY, AWE, ARE, AOE</td>
</tr>
<tr>
<td>18</td>
<td>AM53, AM52, AM51, AM50, CLKOUT</td>
</tr>
</tbody>
</table>

Table 29. Maximum Duty Cycle for \(I_{OH}/I_{OL}\) Current Per Pin Group

<table>
<thead>
<tr>
<th>Maximum Duty Cycle</th>
<th>RMS Current (mA)</th>
</tr>
</thead>
<tbody>
<tr>
<td>100%</td>
<td>82</td>
</tr>
<tr>
<td>80%</td>
<td>92</td>
</tr>
<tr>
<td>60%</td>
<td>106</td>
</tr>
<tr>
<td>40%</td>
<td>130</td>
</tr>
<tr>
<td>25%</td>
<td>165</td>
</tr>
<tr>
<td>10%</td>
<td>261</td>
</tr>
</tbody>
</table>

When programming OTP memory on the ADSP-BF522/ADSP-BF524/ADSP-BF526 processors, the VPPOTP ball must be set to the write value specified in the Operating Conditions for ADSP-BF522/ADSP-BF524/ADSP-BF526 Processors on Page 28. There is a finite amount of cumulative time that the write voltage may be applied (dependent on voltage and junction temperature) to VPPOTP over the lifetime of the part. Therefore, maximum OTP memory programming time for the ADSP-BF522/ADSP-BF524/ADSP-BF526 processors is shown in Table 30. The ADSP-BF523/ADSP-BF525/ADSP-BF527 processors do not have a similar restriction.

Table 30. Maximum OTP Memory Programming Time for ADSP-BF522/ADSP-BF524/ADSP-BF526 Processors

<table>
<thead>
<tr>
<th>(V_{PPOTP}) Voltage (V)</th>
<th>25°C</th>
<th>85°C</th>
<th>105°C</th>
</tr>
</thead>
<tbody>
<tr>
<td>6.9</td>
<td>6000 sec</td>
<td>100 sec</td>
<td>25 sec</td>
</tr>
<tr>
<td>7.0</td>
<td>2400 sec</td>
<td>44 sec</td>
<td>12 sec</td>
</tr>
<tr>
<td>7.1</td>
<td>1000 sec</td>
<td>18 sec</td>
<td>4.5 sec</td>
</tr>
</tbody>
</table>

Table 31. Package Brand Information

<table>
<thead>
<tr>
<th>Brand Key</th>
<th>Field Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADSP-BF52x</td>
<td>Product Name¹</td>
</tr>
<tr>
<td>t</td>
<td>Temperature Range</td>
</tr>
<tr>
<td>pp</td>
<td>Package Type</td>
</tr>
<tr>
<td>Z</td>
<td>Lead Free Option</td>
</tr>
<tr>
<td>ccc</td>
<td>See Ordering Guide</td>
</tr>
<tr>
<td>vvvvv.x</td>
<td>Assembly Lot Code</td>
</tr>
<tr>
<td>n.n</td>
<td>Silicon Revision</td>
</tr>
<tr>
<td>#</td>
<td>RoHS Compliance Designator</td>
</tr>
<tr>
<td>yyyy</td>
<td>Date Code</td>
</tr>
</tbody>
</table>

¹ Non Automotive only. For branding information specific to Automotive products, contact Analog Devices Inc.

² See product names in the Ordering Guide on Page 88.

ESD SENSITIVITY

ESD (electrostatic discharge) sensitive device. Charged devices and circuit boards can discharge without detection. Although this product features patented or proprietary protection circuitry, damage may occur on devices subjected to high energy ESD. Therefore, proper ESD precautions should be taken to avoid performance degradation or loss of functionality.
TIMING SPECIFICATIONS

Specifications are subject to change without notice.

Clock and Reset Timing

Table 32 and Figure 9 describe clock and reset operations. Per the CCLK and SCLK timing specifications in Table 12 to Table 17, combinations of CLKIN and clock multipliers must not select core/peripheral clocks in excess of the processor's maximum instruction rate.

Table 32. Clock and Reset Timing

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>Timing Requirements</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$f_{\text{CLKIN}}$</td>
<td>12 MHz</td>
<td>50 MHz</td>
<td></td>
</tr>
<tr>
<td>$f_{\text{CLKIN}}$</td>
<td>Combination of the CLKIN frequency and the PLL clock multiplier must not exceed the allowed $f_{\text{VCO}}$, $f_{\text{CCLK}}$, and $f_{\text{SCLK}}$ settings discussed in Table 12 on Page 29 through Table 14 on Page 29 and Table 15 on Page 31 through Table 17 on Page 31.</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{\text{CKINL}}$</td>
<td>10 ns</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>$t_{\text{CKINH}}$</td>
<td>10 ns</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>$t_{\text{WRST}}$</td>
<td>$11 \times t_{\text{CKIN}}$, ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Switching Characteristic</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{\text{BUFDLAY}}$</td>
<td>10 ns</td>
<td>ns</td>
<td></td>
</tr>
</tbody>
</table>

1 Applies to PLL bypass mode and PLL nonbypass mode.
2 Combinations of the CLKIN frequency and the PLL clock multiplier must not exceed the allowed $f_{\text{VCO}}$, $f_{\text{CCLK}}$, and $f_{\text{SCLK}}$ settings discussed in Table 12 on Page 29 through Table 14 on Page 29 and Table 15 on Page 31 through Table 17 on Page 31.
3 The $t_{\text{CKIN}}$ period (see Figure 9) equals $1/f_{\text{CKIN}}$.
4 If the DF bit in the PLL_CTL register is set, the minimum $f_{\text{CKIN}}$ specification is 24 MHz for commercial/industrial models and 28 MHz for automotive models.
5 Applies after power-up sequence is complete. See Table 33 and Figure 10 for power-up reset timing.

Figure 9. Clock and Reset Timing
Table 33. Power-Up Reset Timing

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Min</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>Timing Requirement</td>
<td><strong>RESET</strong> Deasserted after the $V_{DDINT}$, $V_{DDEXT}$, $V_{DDRTC}$, $V_{DDUSB}$, $V_{DDMEM}$, $V_{DDOTP}$, and CLKin Pins are Stable and Within Specification</td>
<td>3500 × $t_{CLKIN}$</td>
<td>ns</td>
</tr>
</tbody>
</table>

In **Figure 10**, $V_{DD\_SUPPLIES}$ is $V_{DDINT}$, $V_{DDEXT}$, $V_{DDRTC}$, $V_{DDUSB}$, $V_{DDMEM}$, and $V_{DDOTP}$.

**Figure 10. Power-Up Reset Timing**
Asynchronous Memory Read Cycle Timing

Table 34. Asynchronous Memory Read Cycle Timing

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>( V_{\text{DOMEM}} ) 1.8 V Nominal</td>
<td>( V_{\text{DOMEM}} ) 2.5 V or 3.3 V Nominal</td>
</tr>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
</tr>
<tr>
<td>Timing Requirements</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{\text{SDAT}} ) DATA15–0 Setup Before CLKOUT</td>
<td>2.1</td>
<td>2.1</td>
</tr>
<tr>
<td>( t_{\text{HDAT}} ) DATA15–0 Hold After CLKOUT</td>
<td>1.2</td>
<td>0.8</td>
</tr>
<tr>
<td>( t_{\text{SARDY}} ) ARDY Setup Before CLKOUT</td>
<td>4.0</td>
<td>4.0</td>
</tr>
<tr>
<td>( t_{\text{HARDY}} ) ARDY Hold After CLKOUT</td>
<td>0.2</td>
<td>0.2</td>
</tr>
<tr>
<td>Switching Characteristics</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{\text{DO}} ) Output Delay After CLKOUT(^1)</td>
<td>6.0</td>
<td>6.0</td>
</tr>
<tr>
<td>( t_{\text{HO}} ) Output Hold After CLKOUT(^1)</td>
<td>0.8</td>
<td>0.8</td>
</tr>
</tbody>
</table>

\(^1\) Output balls include AMS3–0, ABE1–0, ADDR19–1, AOE, ARE.

---

Figure 11. Asynchronous Memory Read Cycle Timing
Asynchronous Memory Write Cycle Timing

Table 35. Asynchronous Memory Write Cycle Timing

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>$V_{DDMEM}$ 1.8 V Nominal</td>
<td>$V_{DDMEM}$ 2.5 V or 3.3 V Nominal</td>
<td>$V_{DDMEM}$ 1.8 V Nominal</td>
<td>$V_{DDMEM}$ 2.5 V or 3.3 V Nominal</td>
<td></td>
</tr>
<tr>
<td>Timing Requirements</td>
<td>Min</td>
<td>Max</td>
<td>Min</td>
<td>Max</td>
<td>Min</td>
</tr>
<tr>
<td>$t_{SARDY}$ ARDY Setup Before CLKOUT</td>
<td>4.0</td>
<td>4.0</td>
<td>4.0</td>
<td>4.0</td>
<td>0.2</td>
</tr>
<tr>
<td>$t_{HARDY}$ ARDY Hold After CLKOUT</td>
<td>0.2</td>
<td>0.2</td>
<td>0.2</td>
<td>0.2</td>
<td>ns</td>
</tr>
<tr>
<td>Switching Characteristics</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{DDAT}$ DATA15–0 Disable After CLKOUT</td>
<td>6.0</td>
<td>6.0</td>
<td>6.0</td>
<td>6.0</td>
<td>6.0</td>
</tr>
<tr>
<td>$t_{ENDAT}$ DATA15–0 Enable After CLKOUT</td>
<td>0.0</td>
<td>0.0</td>
<td>0.0</td>
<td>0.0</td>
<td>ns</td>
</tr>
<tr>
<td>$t_{DO}$ Output Delay After CLKOUT$^1$</td>
<td>6.0</td>
<td>6.0</td>
<td>6.0</td>
<td>6.0</td>
<td>ns</td>
</tr>
<tr>
<td>$t_{HO}$ Output Hold After CLKOUT$^1$</td>
<td>0.8</td>
<td>0.8</td>
<td>0.8</td>
<td>0.8</td>
<td>ns</td>
</tr>
</tbody>
</table>

$^1$ Output balls include AMS3–0, ABE1–0, ADDR19–1, DATA15–0, AWE.

![Asynchronous Memory Write Cycle Timing Diagram](image-url)
**NAND Flash Controller Interface Timing**

Table 36 and Figure 13 on Page 44 through Figure 17 on Page 46 describe NAND Flash Controller Interface operations.

Table 36. NAND Flash Controller Interface Timing

<table>
<thead>
<tr>
<th>Parameter</th>
<th>1.8 V Nominal</th>
<th>2.5 V or 3.3 V Nominal</th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Write Cycle</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{CW}$</td>
<td>ND_CE Setup Time to AWE Low</td>
<td>$1.0 \times t_{SCLK} - 4$</td>
</tr>
<tr>
<td>$t_{CH}$</td>
<td>ND_CE Hold Time From AWE High</td>
<td>$3.0 \times t_{SCLK} - 4$</td>
</tr>
<tr>
<td>$t_{CLEW}$</td>
<td>ND_CLE Setup Time to AWE Low</td>
<td>0.0</td>
</tr>
<tr>
<td>$t_{CLEH}$</td>
<td>ND_CLE Hold Time From AWE high</td>
<td>$2.5 \times t_{SCLK} - 4$</td>
</tr>
<tr>
<td>$t_{AEWL}$</td>
<td>ND_ALE Setup Time to AWE Low</td>
<td>0.0</td>
</tr>
<tr>
<td>$t_{ALH}$</td>
<td>ND_ALE Hold Time From AWE High</td>
<td>$2.5 \times t_{SCLK} - 4$</td>
</tr>
<tr>
<td>$t_{W}$</td>
<td>AWE Low to AWE high</td>
<td>(WR_DLY +1.0) $\times t_{SCLK}$</td>
</tr>
<tr>
<td>$t_{WHL}$</td>
<td>AWE High to AWE Low</td>
<td>$4.0 \times t_{SCLK} - 4$</td>
</tr>
<tr>
<td>$t_{WLC}$</td>
<td>AWE Low to AWE Low</td>
<td>(WR_DLY +5.0) $\times t_{SCLK} - 4$</td>
</tr>
<tr>
<td>$t_{WS}$</td>
<td>Data Setup Time for a Write Access</td>
<td>(WR_DLY +1.5) $\times t_{SCLK} - 4$</td>
</tr>
<tr>
<td>$t_{WH}$</td>
<td>Data Hold Time for a Write Access</td>
<td>$2.5 \times t_{SCLK} - 4$</td>
</tr>
<tr>
<td><strong>Read Cycle</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{CRL}$</td>
<td>ND_CE Setup Time to ARE Low</td>
<td>$1.0 \times t_{SCLK} - 4$</td>
</tr>
<tr>
<td>$t_{CHR}$</td>
<td>ND_CE Hold Time From ARE High</td>
<td>$3.0 \times t_{SCLK} - 4$</td>
</tr>
<tr>
<td>$t_{RP}$</td>
<td>ARE Low to ARE High</td>
<td>(RD_DLY +1.0) $\times t_{SCLK} - 4$</td>
</tr>
<tr>
<td>$t_{RHL}$</td>
<td>ARE High to ARE Low</td>
<td>$4.0 \times t_{SCLK} - 4$</td>
</tr>
<tr>
<td>$t_{RC}$</td>
<td>ARE Low to ARE Low</td>
<td>(RD_DLY +5.0) $\times t_{SCLK} - 4$</td>
</tr>
<tr>
<td><strong>Timing Requirements (ADSP-BF522/ADSP-BF524/ADSP-BF526)</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{RDS}$</td>
<td>Data Setup Time for a Read Transaction</td>
<td>14.0</td>
</tr>
<tr>
<td>$t_{RDH}$</td>
<td>Data Hold Time for a Read Transaction</td>
<td>0.0</td>
</tr>
<tr>
<td><strong>Timing Requirements (ADSP-BF523/ADSP-BF525/ADSP-BF527)</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{RDS}$</td>
<td>Data Setup Time for a Read Transaction</td>
<td>11.0</td>
</tr>
<tr>
<td>$t_{RDH}$</td>
<td>Data Hold Time for a Read Transaction</td>
<td>0.0</td>
</tr>
<tr>
<td><strong>Write Followed by Read</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{WHLR}$</td>
<td>AWE High to ARE Low</td>
<td>$5.0 \times t_{SCLK} - 4$</td>
</tr>
</tbody>
</table>

1. WR_DLY and RD_DLY are defined in the NFC_CTL register.
In Figure 13, ND_DATA is ND_D0–D7.

Figure 13. NAND Flash Controller Interface Timing — Command Write Cycle

In Figure 14, ND_DATA is ND_D0–D7.

Figure 14. NAND Flash Controller Interface Timing — Address Write Cycle
In Figure 15, ND_DATA is ND_D0–D7.

*Figure 15. NAND Flash Controller Interface Timing — Data Write Operation*

In Figure 16, ND_DATA is ND_D0–D7.

*Figure 16. NAND Flash Controller Interface Timing — Data Read Operation*
In Figure 17, ND_DATA is ND_D0–D7.

Figure 17. NAND Flash Controller Interface Timing — Write Followed by Read Operation
**SDRAM Interface Timing**

Table 37. SDRAM Interface Timing for ADSP-BF522/ADSP-BF524/ADSP-BF526 Processors

<table>
<thead>
<tr>
<th>Parameter</th>
<th>( V_{D_{D_{MEM}}} )</th>
<th>( V_{D_{D_{MEM}}} )</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
<td>Min</td>
</tr>
<tr>
<td><strong>Timing Requirements</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{SSDAT} )</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Data Setup Before CLKOUT</td>
<td>1.5</td>
<td>1.5</td>
<td></td>
</tr>
<tr>
<td>( t_{HS_DAT} )</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Data Hold After CLKOUT</td>
<td>1.3</td>
<td>0.8</td>
<td></td>
</tr>
<tr>
<td><strong>Switching Characteristics</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{S_CLK} )</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLKOUT Period(^1)</td>
<td>12.5</td>
<td>10</td>
<td></td>
</tr>
<tr>
<td>( t_{S_CLKH} )</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLKOUT Width High</td>
<td>5.0</td>
<td>4.0</td>
<td></td>
</tr>
<tr>
<td>( t_{S_CLKL} )</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLKOUT Width Low</td>
<td>5.0</td>
<td>4.0</td>
<td></td>
</tr>
<tr>
<td>( t_{DC_AD} )</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Command, Address, Data Delay After CLKOUT(^2)</td>
<td>5.0</td>
<td>4.0</td>
<td></td>
</tr>
<tr>
<td>( t_{HC_AD} )</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Command, Address, Data Hold After CLKOUT(^2)</td>
<td>1.0</td>
<td>1.0</td>
<td></td>
</tr>
<tr>
<td>( t_{DS_DAT} )</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Data Disable After CLKOUT</td>
<td>5.5</td>
<td>5.0</td>
<td></td>
</tr>
<tr>
<td>( t_{ENS_DAT} )</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Data Enable After CLKOUT</td>
<td>0.0</td>
<td>0.0</td>
<td></td>
</tr>
</tbody>
</table>

\(^1\)The \( t_{S\_CLK} \) value is the inverse of the \( f_{S\_CLK} \) specification discussed in Table 14 and Table 17. Package type and reduced supply voltages affect the best-case values listed here.

\(^2\)Command balls include: SRAS, SCAS, SWE, SDQM, SMS, SA10, SCKE.

Table 38. SDRAM Interface Timing for ADSP-BF523/ADSP-BF525/ADSP-BF527 Processors

<table>
<thead>
<tr>
<th>Parameter</th>
<th>( V_{D_{D_{MEM}}} )</th>
<th>( V_{D_{D_{MEM}}} )</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
<td>Min</td>
</tr>
<tr>
<td><strong>Timing Requirements</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{SSDAT} )</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Data Setup Before CLKOUT</td>
<td>1.5</td>
<td>1.5</td>
<td></td>
</tr>
<tr>
<td>( t_{HS_DAT} )</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Data Hold After CLKOUT</td>
<td>1.0</td>
<td>0.8</td>
<td></td>
</tr>
<tr>
<td><strong>Switching Characteristics</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{S_CLK} )</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLKOUT Period(^1)</td>
<td>10</td>
<td>7.5</td>
<td></td>
</tr>
<tr>
<td>( t_{S_CLKH} )</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLKOUT Width High</td>
<td>2.5</td>
<td>2.5</td>
<td></td>
</tr>
<tr>
<td>( t_{S_CLKL} )</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLKOUT Width Low</td>
<td>2.5</td>
<td>2.5</td>
<td></td>
</tr>
<tr>
<td>( t_{DC_AD} )</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Command, Address, Data Delay After CLKOUT(^2)</td>
<td>4.0</td>
<td>4.0</td>
<td></td>
</tr>
<tr>
<td>( t_{HC_AD} )</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Command, Address, Data Hold After CLKOUT(^2)</td>
<td>1.0</td>
<td>1.0</td>
<td></td>
</tr>
<tr>
<td>( t_{DS_DAT} )</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Data Disable After CLKOUT</td>
<td>5.0</td>
<td>4.0</td>
<td></td>
</tr>
<tr>
<td>( t_{ENS_DAT} )</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Data Enable After CLKOUT</td>
<td>0.0</td>
<td>0.0</td>
<td></td>
</tr>
</tbody>
</table>

\(^1\)The \( t_{S\_CLK} \) value is the inverse of the \( f_{S\_CLK} \) specification discussed in Table 14 and Table 17. Package type and reduced supply voltages affect the best-case values listed here.

\(^2\)Command balls include: SRAS, SCAS, SWE, SDQM, SMS, SA10, SCKE.
Figure 18. SDRAM Interface Timing

NOTE: COMMAND = SRAS, SCAS, SWE, SDQM, SMS, SA10, SCKE.
### External DMA Request Timing

Table 39, Table 40, and Figure 19 describe the External DMA Request operations.

**Table 39. External DMA Request Timing for ADSP-BF522/ADSP-BF524/ADSP-BF526 Processors**

<table>
<thead>
<tr>
<th>Parameter</th>
<th>$V_{DDEXT}/V_{DDMEM}$</th>
<th>$V_{DDEXT}/V_{DDMEM}$</th>
<th>Min</th>
<th>Max</th>
<th>Min</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>1.8 V Nominal</td>
<td>2.5 V or 3.3 V Nominal</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Timing Requirements</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>tDS</td>
<td>DMARx Asserted to CLKOUT High Setup</td>
<td>9.0</td>
<td>6.0</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>tDH</td>
<td>CLKOUT High to DMARx Deasserted Hold Time</td>
<td>0.0</td>
<td>0.0</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>tDMARACT</td>
<td>DMARx Active Pulse Width</td>
<td>1.0 × tSCLK</td>
<td>1.0 × tSCLK</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>tDMARINACT</td>
<td>DMARx Inactive Pulse Width</td>
<td>1.75 × tSCLK</td>
<td>1.75 × tSCLK</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

1 Because the external DMA control pins are part of the $V_{DDEXT}$ power domain and the CLKOUT signal is part of the $V_{DDMEM}$ power domain, systems in which $V_{DDEXT}$ and $V_{DDMEM}$ are NOT equal may require level shifting logic for correct operation.

**Table 40. External DMA Request Timing for ADSP-BF523/ADSP-BF525/ADSP-BF527 Processors**

<table>
<thead>
<tr>
<th>Parameter</th>
<th>$V_{DDEXT}/V_{DDMEM}$</th>
<th>$V_{DDEXT}/V_{DDMEM}$</th>
<th>Min</th>
<th>Max</th>
<th>Min</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>1.8 V Nominal</td>
<td>2.5 V or 3.3 V Nominal</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Timing Requirements</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>tDS</td>
<td>DMARx Asserted to CLKOUT High Setup</td>
<td>8.0</td>
<td>6.0</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>tDH</td>
<td>CLKOUT High to DMARx Deasserted Hold Time</td>
<td>0.0</td>
<td>0.0</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>tDMARACT</td>
<td>DMARx Active Pulse Width</td>
<td>1.0 × tSCLK</td>
<td>1.0 × tSCLK</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>tDMARINACT</td>
<td>DMARx Inactive Pulse Width</td>
<td>1.75 × tSCLK</td>
<td>1.75 × tSCLK</td>
<td>ns</td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

1 Because the external DMA control pins are part of the $V_{DDEXT}$ power domain and the CLKOUT signal is part of the $V_{DDMEM}$ power domain, systems in which $V_{DDEXT}$ and $V_{DDMEM}$ are NOT equal may require level shifting logic for correct operation.

**Figure 19. External DMA Request Timing**
Parallel Peripheral Interface Timing

Table 41 and Figure 20 on Page 51, Figure 24 on Page 55, and Figure 27 on Page 57 describe parallel peripheral interface operations.

Table 41. Parallel Peripheral Interface Timing for ADSP-BF522/ADSP-BF524/ADSP-BF526 Processors

<table>
<thead>
<tr>
<th>Parameter</th>
<th>V_{DDEXT} 1.8 V Nominal</th>
<th>V_{DDEXT} 2.5 V or 3.3 V Nominal</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
<td>Min</td>
</tr>
<tr>
<td><strong>Timing Requirements</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{PCLKW} ) PPI_CLK Width(^1)</td>
<td>6.4</td>
<td>6.4</td>
<td>6.4</td>
</tr>
<tr>
<td>( t_{PCLK} ) PPI_CLK Period(^1)</td>
<td>25.0</td>
<td>20.0</td>
<td>25.0</td>
</tr>
<tr>
<td><strong>Timing Requirements - GP Input and Frame Capture Modes</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{SFSPE} ) External Frame Sync Setup Before PPI_CLK (Nonsampling Edge for Rx, Sampling Edge for Tx)</td>
<td>6.7</td>
<td>6.7</td>
<td>6.7</td>
</tr>
<tr>
<td>( t_{HFSPE} ) External Frame Sync Hold After PPI_CLK</td>
<td>1.2</td>
<td>1.2</td>
<td>1.2</td>
</tr>
<tr>
<td>( t_{SDRPE} ) Receive Data Setup Before PPI_CLK</td>
<td>4.1</td>
<td>3.5</td>
<td>4.1</td>
</tr>
<tr>
<td>( t_{HDRPE} ) Receive Data Hold After PPI_CLK</td>
<td>2.0</td>
<td>1.6</td>
<td>2.0</td>
</tr>
<tr>
<td><strong>Switching Characteristics - GP Output and Frame Capture Modes</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{DFSPE} ) Internal Frame Sync Delay After PPI_CLK</td>
<td>8.0</td>
<td>8.0</td>
<td>8.0</td>
</tr>
<tr>
<td>( t_{HOFSPE} ) Internal Frame Sync Hold After PPI_CLK</td>
<td>1.7</td>
<td>1.7</td>
<td>1.7</td>
</tr>
<tr>
<td>( t_{DDTPE} ) Transmit Data Delay After PPI_CLK</td>
<td>8.2</td>
<td>8.0</td>
<td>8.2</td>
</tr>
<tr>
<td>( t_{HDTPE} ) Transmit Data Hold After PPI_CLK</td>
<td>2.3</td>
<td>1.9</td>
<td>2.3</td>
</tr>
</tbody>
</table>

\(^1\) PPI_CLK frequency cannot exceed \( f_{SCLK}/2 \).

Table 42. Parallel Peripheral Interface Timing for ADSP-BF523/ADSP-BF525/ADSP-BF527 Processors

<table>
<thead>
<tr>
<th>Parameter</th>
<th>V_{DDEXT} 1.8 V Nominal</th>
<th>V_{DDEXT} 2.5 V or 3.3 V Nominal</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
<td>Min</td>
</tr>
<tr>
<td><strong>Timing Requirements</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{PCLKW} ) PPI_CLK Width(^1)</td>
<td>6.0</td>
<td>6.0</td>
<td>6.0</td>
</tr>
<tr>
<td>( t_{PCLK} ) PPI_CLK Period(^1)</td>
<td>20.0</td>
<td>15.0</td>
<td>20.0</td>
</tr>
<tr>
<td><strong>Timing Requirements - GP Input and Frame Capture Modes</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{SFSPE} ) External Frame Sync Setup Before PPI_CLK (Nonsampling Edge for Rx, Sampling Edge for Tx)</td>
<td>6.7</td>
<td>6.7</td>
<td>6.7</td>
</tr>
<tr>
<td>( t_{HFSPE} ) External Frame Sync Hold After PPI_CLK</td>
<td>1.0</td>
<td>1.0</td>
<td>1.0</td>
</tr>
<tr>
<td>( t_{SDRPE} ) Receive Data Setup Before PPI_CLK</td>
<td>3.5</td>
<td>3.5</td>
<td>3.5</td>
</tr>
<tr>
<td>( t_{HDRPE} ) Receive Data Hold After PPI_CLK</td>
<td>2.0</td>
<td>1.6</td>
<td>2.0</td>
</tr>
<tr>
<td><strong>Switching Characteristics - GP Output and Frame Capture Modes</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{DFSPE} ) Internal Frame Sync Delay After PPI_CLK</td>
<td>8.0</td>
<td>8.0</td>
<td>8.0</td>
</tr>
<tr>
<td>( t_{HOFSPE} ) Internal Frame Sync Hold After PPI_CLK</td>
<td>1.7</td>
<td>1.7</td>
<td>1.7</td>
</tr>
<tr>
<td>( t_{DDTPE} ) Transmit Data Delay After PPI_CLK</td>
<td>8.0</td>
<td>8.0</td>
<td>8.0</td>
</tr>
<tr>
<td>( t_{HDTPE} ) Transmit Data Hold After PPI_CLK</td>
<td>2.3</td>
<td>1.9</td>
<td>2.3</td>
</tr>
</tbody>
</table>

\(^1\) PPI_CLK frequency cannot exceed \( f_{SCLK}/2 \).
Figure 20. PPI GP Rx Mode with External Frame Sync Timing

Figure 21. PPI GP Tx Mode with External Frame Sync Timing

Figure 22. PPI GP Rx Mode with Internal Frame Sync Timing
Figure 23. PPI GP Tx Mode with Internal Frame Sync Timing
Serial Ports
Table 43 through Table 47 on Page 57 and Figure 24 on Page 55 through Figure 27 on Page 57 describe serial port operations.

Table 43. Serial Ports—External Clock

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>$V_{DDEXT}$ 1.8 V Nominal</td>
<td>$V_{DDEXT}$ 2.5 V or 3.3 V Nominal</td>
</tr>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
</tr>
<tr>
<td><strong>Timing Requirements</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{SFSE}$ TFSx/RFSx Setup Before TSCLKx/RSCLKx$^1$</td>
<td>3.0</td>
<td>3.0</td>
</tr>
<tr>
<td>$t_{HFSE}$ TFSx/RFSx Hold After TSCLKx/RSCLKx$^1$</td>
<td>3.0</td>
<td>3.0</td>
</tr>
<tr>
<td>$t_{SDRE}$ Receive Data Setup Before RSCLKx$^1$</td>
<td>3.0</td>
<td>3.0</td>
</tr>
<tr>
<td>$t_{HDRE}$ Receive Data Hold After RSCLKx$^1$</td>
<td>3.5</td>
<td>3.0</td>
</tr>
<tr>
<td>$t_{SCLKEW}$ TSCLKx/RSCLKx Width</td>
<td>7.0</td>
<td>4.5</td>
</tr>
<tr>
<td>$t_{SCLKE}$ TSCLKx/RSCLKx Period</td>
<td>2.0 × $t_{SCLK}$</td>
<td>2.0 × $t_{SCLK}$</td>
</tr>
<tr>
<td>$t_{SUDE}$ Start-Up Delay From SPORT Enable To First External TFSx$^2$</td>
<td>4.0 × $t_{SCLKE}$</td>
<td>4.0 × $t_{SCLKE}$</td>
</tr>
<tr>
<td>$t_{SUDE}$ Start-Up Delay From SPORT Enable To First External RFSx$^2$</td>
<td>4.0 × $t_{SCLKE}$</td>
<td>4.0 × $t_{SCLKE}$</td>
</tr>
<tr>
<td><strong>Switching Characteristics</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{DFSE}$ TFSx/RFSx Delay After TSCLKx/RSCLKx (Internally Generated TFSx/RFSx)$^3$</td>
<td>10.0</td>
<td>10.0</td>
</tr>
<tr>
<td>$t_{HDFSE}$ TFSx/RFSx Hold After TSCLKx/RSCLKx (Internally Generated TFSx/RFSx)$^3$</td>
<td>0.0</td>
<td>0.0</td>
</tr>
<tr>
<td>$t_{DDTE}$ Transmit Data Delay After TSCLKx$^3$</td>
<td>10.0</td>
<td>10.0</td>
</tr>
<tr>
<td>$t_{HDTE}$ Transmit Data Hold After TSCLKx$^3$</td>
<td>0.0</td>
<td>0.0</td>
</tr>
</tbody>
</table>

$^1$ Referenced to sample edge.

$^2$ Verified in design but untested.

$^3$ Referenced to drive edge.
Table 44. Serial Ports—Internal Clock for ADSP-BF522/ADSP-BF524/ADSP-BF526 Processors

<table>
<thead>
<tr>
<th>Parameter</th>
<th>$V_{DDEXT}$ 1.8 V Nominal</th>
<th>$V_{DDEXT}$ 2.5 V or 3.3 V Nominal</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
<td>Min</td>
</tr>
<tr>
<td><strong>Timing Requirements</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{SFSI}$</td>
<td>TFSx/RFSx Setup Before TSCLKx/RSCLKx$^1$</td>
<td>11.0</td>
<td>9.6</td>
</tr>
<tr>
<td>$t_{HFSI}$</td>
<td>TFSx/RFSx Hold After TSCLKx/RSCLKx$^1$</td>
<td>-1.5</td>
<td>-1.5</td>
</tr>
<tr>
<td>$t_{SDRI}$</td>
<td>Receive Data Setup Before RSCLKx$^1$</td>
<td>11.0</td>
<td>9.6</td>
</tr>
<tr>
<td>$t_{HDRI}$</td>
<td>Receive Data Hold After RSCLKx$^1$</td>
<td>-1.5</td>
<td>-1.5</td>
</tr>
<tr>
<td><strong>Switching Characteristics</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{SCLKIW}$</td>
<td>TSCLKx/RSCLKx Width</td>
<td>10.0</td>
<td>8.0</td>
</tr>
<tr>
<td>$t_{DFS}$</td>
<td>TFSx/RFSx Delay After TSCLKx/RSCLKx (Internally Generated TFSx/RFSx)$^2$</td>
<td>3.0</td>
<td>3.0</td>
</tr>
<tr>
<td>$t_{HDFS}$</td>
<td>TFSx/RFSx Hold After TSCLKx/RSCLKx (Internally Generated TFSx/RFSx)$^2$</td>
<td>-2.0</td>
<td>-1.0</td>
</tr>
<tr>
<td>$t_{DDTI}$</td>
<td>Transmit Data Delay After TSCLKx$^2$</td>
<td>3.0</td>
<td>3.0</td>
</tr>
<tr>
<td>$t_{HDTI}$</td>
<td>Transmit Data Hold After TSCLKx$^2$</td>
<td>-1.8</td>
<td>-1.5</td>
</tr>
</tbody>
</table>

$^1$ Referenced to sample edge.
$^2$ Referenced to drive edge.

Table 45. Serial Ports—Internal Clock for ADSP-BF523/ADSP-BF525/ADSP-BF527 Processors

<table>
<thead>
<tr>
<th>Parameter</th>
<th>$V_{DDEXT}$ 1.8 V Nominal</th>
<th>$V_{DDEXT}$ 2.5 V or 3.3 V Nominal</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
<td>Min</td>
</tr>
<tr>
<td><strong>Timing Requirements</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{SFSI}$</td>
<td>TFSx/RFSx Setup Before TSCLKx/RSCLKx$^1$</td>
<td>11.0</td>
<td>9.6</td>
</tr>
<tr>
<td>$t_{HFSI}$</td>
<td>TFSx/RFSx Hold After TSCLKx/RSCLKx$^1$</td>
<td>-1.5</td>
<td>-1.5</td>
</tr>
<tr>
<td>$t_{SDRI}$</td>
<td>Receive Data Setup Before RSCLKx$^1$</td>
<td>11.0</td>
<td>9.6</td>
</tr>
<tr>
<td>$t_{HDRI}$</td>
<td>Receive Data Hold After RSCLKx$^1$</td>
<td>-1.5</td>
<td>-1.5</td>
</tr>
<tr>
<td><strong>Switching Characteristics</strong></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{SCLKIW}$</td>
<td>TSCLKx/RSCLKx Width</td>
<td>4.5</td>
<td>4.5</td>
</tr>
<tr>
<td>$t_{DFS}$</td>
<td>TFSx/RFSx Delay After TSCLKx/RSCLKx (Internally Generated TFSx/RFSx)$^2$</td>
<td>3.0</td>
<td>3.0</td>
</tr>
<tr>
<td>$t_{HDFS}$</td>
<td>TFSx/RFSx Hold After TSCLKx/RSCLKx (Internally Generated TFSx/RFSx)$^2$</td>
<td>-1.0</td>
<td>-1.0</td>
</tr>
<tr>
<td>$t_{DDTI}$</td>
<td>Transmit Data Delay After TSCLKx$^2$</td>
<td>3.0</td>
<td>3.0</td>
</tr>
<tr>
<td>$t_{HDTI}$</td>
<td>Transmit Data Hold After TSCLKx$^2$</td>
<td>-1.8</td>
<td>-1.5</td>
</tr>
</tbody>
</table>

$^1$ Referenced to sample edge.
$^2$ Referenced to drive edge.
Figure 24. Serial Ports

Figure 25. Serial Port Start Up with External Clock and Frame Sync
Table 46. Serial Ports—Enable and Three-State

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>( V_{\text{DDEXT}} ) 1.8 V Nominal</td>
<td>( V_{\text{DDEXT}} ) 2.5 V or 3.3 V Nominal</td>
</tr>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
</tr>
<tr>
<td>Switching Characteristics</td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{\text{DTENE}} ) Data Enable Delay from External TSCLK( x )(^1)</td>
<td>0.0</td>
<td>0.0</td>
</tr>
<tr>
<td>( t_{\text{DDTTE}} ) Data Disable Delay from External TSCLK( x )(^1)</td>
<td>( t_{\text{SCLK}} +1 )</td>
<td>( t_{\text{SCLK}} +1 )</td>
</tr>
<tr>
<td>( t_{\text{DTENI}} ) Data Enable Delay from Internal TSCLK( x )(^1)</td>
<td>( t_{\text{SCLK}} +1 )</td>
<td>( t_{\text{SCLK}} +1 )</td>
</tr>
</tbody>
</table>

\(^1\) Referenced to drive edge.

---

Figure 26. Serial Ports — Enable and Three-State
### Table 47. Serial Ports — External Late Frame Sync

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>( V_{DD_{EXT}} ) 1.8 V Nominal</td>
<td>( V_{DD_{EXT}} ) 2.5 V or 3.3 V Nominal</td>
</tr>
<tr>
<td>Min</td>
<td>Max</td>
<td>Min</td>
</tr>
<tr>
<td><strong>Switching Characteristics</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>( t_{DDTLFSE} )</td>
<td>Data Delay from Late External TFSx or External RFSx in multi-channel mode with MFD = 0&lt;sup&gt;1,2&lt;/sup&gt;</td>
<td>12.0</td>
</tr>
<tr>
<td>( t_{DTENLFSE} )</td>
<td>Data Enable from External RFSx in multi-channel mode with MFD = 0&lt;sup&gt;1,2&lt;/sup&gt;</td>
<td>0.0</td>
</tr>
</tbody>
</table>

<sup>1</sup> When in multi-channel mode, TFSx enable and TFSx valid follow \( t_{DTENLFSE} \) and \( t_{DDTLFSE} \).

<sup>2</sup> If external RFSx/TFSx setup to RSCLKx/TSCLKx \( > t_{SCLKE}/2 \) then \( t_{DDTLE/I} \) and \( t_{DTENE/I} \) apply, otherwise \( t_{DDTLFSE} \) and \( t_{DTENLFSE} \) apply.

---

**Figure 27. Serial Ports — External Late Frame Sync**

[Diagram of external late frame sync connections]
Table 48 and Figure 28 describe SPI port master operations.

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>$V_{DDEXT}$ 1.8 V Nominal</td>
<td>$V_{DDEXT}$ 2.5 V or 3.3 V Nominal</td>
</tr>
<tr>
<td>Min</td>
<td>Max</td>
<td>Min</td>
</tr>
<tr>
<td>$t_{SSPIDM}$ Data Input Valid to SCK Edge (Data Input Setup)</td>
<td>11.6</td>
<td>9.6</td>
</tr>
<tr>
<td>$t_{HS PIDM}$ SCK Sampling Edge to Data Input Invalid</td>
<td>–1.5</td>
<td>–1.5</td>
</tr>
<tr>
<td><strong>Switching Characteristics</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{SDSCIM}$ SPISELx low to First SCK Edge</td>
<td>$2 \times t_{SCLK} – 1.5$</td>
<td>$2 \times t_{SCLK} – 1.5$</td>
</tr>
<tr>
<td>$t_{SPICLM}$ Serial Clock High Period</td>
<td>$2 \times t_{SCLK} – 1.5$</td>
<td>$2 \times t_{SCLK} – 1.5$</td>
</tr>
<tr>
<td>$t_{SPICLM}$ Serial Clock Low Period</td>
<td>$2 \times t_{SCLK} – 1.5$</td>
<td>$2 \times t_{SCLK} – 1.5$</td>
</tr>
<tr>
<td>$t_{SPICLK}$ Serial Clock Period</td>
<td>$4 \times t_{SCLK} – 1.5$</td>
<td>$4 \times t_{SCLK} – 1.5$</td>
</tr>
<tr>
<td>$t_{HDSM}$ Last SCK Edge to SPISELx High</td>
<td>$2 \times t_{SCLK} – 1.5$</td>
<td>$2 \times t_{SCLK} – 1.5$</td>
</tr>
<tr>
<td>$t_{SPITDM}$ Sequential Transfer Delay</td>
<td>$2 \times t_{SCLK} – 1.5$</td>
<td>$2 \times t_{SCLK} – 1.5$</td>
</tr>
<tr>
<td>$t_{DDSPIDM}$ SCK Edge to Data Out Valid (Data Out Delay)</td>
<td>6</td>
<td>6</td>
</tr>
<tr>
<td>$t_{HDSPIDM}$ SCK Edge to Data Out Invalid (Data Out Hold)</td>
<td>–1.0</td>
<td>–1.0</td>
</tr>
</tbody>
</table>

Figure 28. Serial Peripheral Interface (SPI) Port—Master Timing
Serial Peripheral Interface (SPI) Port—Slave Timing

Table 49 and Figure 29 describe SPI port slave operations.

Table 49. Serial Peripheral Interface (SPI) Port—Slave Timing

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>$V_{DDEXT}$ 1.8 V Nominal</td>
<td>$V_{DDEXT}$ 2.5 V or 3.3 V Nominal</td>
</tr>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
</tr>
<tr>
<td>Timing Requirements</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{SPICHS}$  Serial Clock High Period</td>
<td>2 × $t_{SCLK}$ – 1.5 ns</td>
<td>2 × $t_{SCLK}$ – 1.5 ns</td>
</tr>
<tr>
<td>$t_{SPICLS}$  Serial Clock Low Period</td>
<td>2 × $t_{SCLK}$ – 1.5 ns</td>
<td>2 × $t_{SCLK}$ – 1.5 ns</td>
</tr>
<tr>
<td>$t_{SPICLK}$  Serial Clock Period</td>
<td>4 × $t_{SCLK}$ – 1.5 ns</td>
<td>4 × $t_{SCLK}$ – 1.5 ns</td>
</tr>
<tr>
<td>$t_{HDS}$  Last SCK Edge to SPISS Not Asserted</td>
<td>2 × $t_{SCLK}$ – 1.5 ns</td>
<td>2 × $t_{SCLK}$ – 1.5 ns</td>
</tr>
<tr>
<td>$t_{SPITDS}$  Sequential Transfer Delay</td>
<td>2 × $t_{SCLK}$ – 1.5 ns</td>
<td>2 × $t_{SCLK}$ – 1.5 ns</td>
</tr>
<tr>
<td>$t_{SDSCI}$  SPISS Assertion to First SCK Edge</td>
<td>2 × $t_{SCLK}$ – 1.5 ns</td>
<td>2 × $t_{SCLK}$ – 1.5 ns</td>
</tr>
<tr>
<td>$t_{SSPID}$  Data Input Valid to SCK Edge (Data Input Setup)</td>
<td>1.6 ns</td>
<td>1.6 ns</td>
</tr>
<tr>
<td>$t_{HSPI}$  SCK Sampling Edge to Data Input Invalid</td>
<td>2.0 ns</td>
<td>1.6 ns</td>
</tr>
</tbody>
</table>

Switching Characteristics

|                                                        | Min     | Max    | Min     | Max    | Min     | Max     |
| $t_{DSOE}$  SPISS Assertion to Data Out Active         | 0 ns    | 12.0 ns| 0 ns    | 10.3 ns| 0 ns    | 12.0 ns |
| $t_{DSDHI}$ SPISS Deassertion to Data High Impedance   | 0 ns    | 11.0 ns| 0 ns    | 8.5 ns | 0 ns    | 8 ns    |
| $t_{ODSID}$  SCK Edge to Data Out Valid (Data Out Delay) | 10 ns   | 10 ns  | 10 ns   | 10 ns  |
| $t_{OSPID}$  SCK Edge to Data Out Invalid (Data Out Hold) | 0 ns    | 0 ns   | 0 ns    | 0 ns   |

Figure 29. Serial Peripheral Interface (SPI) Port—Slave Timing
Universal Serial Bus (USB) On-The-Go—Receive and Transmit Timing

Table 50 describes the USB On-The-Go receive and transmit operations.

Table 50. USB On-The-Go—Receive and Transmit Timing

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>V_{DDEXT} 1.8 V Nominal</td>
<td>V_{DDEXT} 2.5 V or 3.3 V Nominal</td>
</tr>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
</tr>
<tr>
<td>Timing Requirements</td>
<td></td>
<td></td>
</tr>
<tr>
<td>f_{USB}</td>
<td>USB_XI Frequency</td>
<td>12</td>
</tr>
<tr>
<td>FS_{USB}</td>
<td>USB_XI Clock Frequency Stability</td>
<td>-50</td>
</tr>
<tr>
<td></td>
<td>Unit</td>
<td></td>
</tr>
<tr>
<td></td>
<td>MHz</td>
<td></td>
</tr>
<tr>
<td></td>
<td>ppm</td>
<td></td>
</tr>
</tbody>
</table>
Universal Asynchronous Receiver-Transmitter
(UART) Ports—Receive and Transmit Timing

For information on the UART port receive and transmit operations, see the ADSP-BF52x Hardware Reference Manual.

General-Purpose Port Timing

Table 51 and Figure 30 describe general-purpose port operations.

Table 51. General-Purpose Port Timing for ADSP-BF522/ADSP-BF524/ADSP-BF526 Processors

<table>
<thead>
<tr>
<th>Parameter</th>
<th>$V_{DD}^{EXT}$</th>
<th>$V_{DD}^{EXT}$</th>
<th>$V_{DD}^{EXT}$</th>
<th>$V_{DD}^{EXT}$</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>1.8 V Nominal</td>
<td>2.5 V or 3.3 V Nominal</td>
<td>1.8 V Nominal</td>
<td>2.5 V or 3.3 V Nominal</td>
<td></td>
</tr>
<tr>
<td>Timing Requirement</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{WFI}$ General-Purpose Port Ball Input Pulse Width</td>
<td>$t_{CLK}$ + 1</td>
<td>$t_{CLK}$ + 1</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Switching Characteristic</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{GPOD}$ General-Purpose Port Ball Output Delay from CLKOUT Low</td>
<td>0</td>
<td>11.0</td>
<td>0</td>
<td>8.2</td>
<td>ns</td>
</tr>
</tbody>
</table>

Table 52. General-Purpose Port Timing for ADSP-BF523/ADSP-BF525/ADSP-BF527 Processors

<table>
<thead>
<tr>
<th>Parameter</th>
<th>$V_{DD}^{EXT}$</th>
<th>$V_{DD}^{EXT}$</th>
<th>$V_{DD}^{EXT}$</th>
<th>$V_{DD}^{EXT}$</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>1.8 V Nominal</td>
<td>2.5 V or 3.3 V Nominal</td>
<td>1.8 V Nominal</td>
<td>2.5 V or 3.3 V Nominal</td>
<td></td>
</tr>
<tr>
<td>Timing Requirement</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{WFI}$ General-Purpose Port Ball Input Pulse Width</td>
<td>$t_{CLK}$ + 1</td>
<td>$t_{CLK}$ + 1</td>
<td>ns</td>
<td></td>
<td></td>
</tr>
<tr>
<td>Switching Characteristic</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{GPOD}$ General-Purpose Port Ball Output Delay from CLKOUT Low</td>
<td>0</td>
<td>8.2</td>
<td>0</td>
<td>6.5</td>
<td>ns</td>
</tr>
</tbody>
</table>

Figure 30. General-Purpose Port Timing
**Timer Cycle Timing**

Table 53 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 53. Timer Cycle Timing**

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>(V_{DD_{EXT}}) 1.8 V Nominal</td>
<td>(V_{DD_{EXT}}) 2.5 V or 3.3 V Nominal</td>
</tr>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
</tr>
<tr>
<td><strong>Timing Requirements</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>(t_{WL}) Timer Pulse Width Input Low (Measured In SCLK Cycles)(^1)</td>
<td>(t_{SCLK})</td>
<td>(t_{SCLK})</td>
</tr>
<tr>
<td>(t_{WH}) Timer Pulse Width Input High (Measured In SCLK Cycles)(^1)</td>
<td>(t_{SCLK})</td>
<td>(t_{SCLK})</td>
</tr>
<tr>
<td>(t_{TIS}) Timer Input Setup Time Before CLKOUT Low(^2)</td>
<td>10</td>
<td>7</td>
</tr>
<tr>
<td>(t_{TIH}) Timer Input Hold Time After CLKOUT Low(^2)</td>
<td>–2</td>
<td>–2</td>
</tr>
<tr>
<td><strong>Switching Characteristics</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>(t_{HTO}) Timer Pulse Width Output (Measured In SCLK Cycles)</td>
<td>(t_{SCLK} - 1.5(2^{32} - 1)t_{SCLK})</td>
<td>(t_{SCLK} - 1(2^{32} - 1)t_{SCLK})</td>
</tr>
<tr>
<td>(t_{TOD}) Timer Output Update Delay After CLKOUT High</td>
<td>6</td>
<td>6</td>
</tr>
</tbody>
</table>

\(^1\)The minimum pulse widths apply for TMRx signals in width capture and external clock modes. They also apply to the PF15 or PPI_CLK signals in PWM output mode.

\(^2\)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 Cycle Timing](image-url)
**Timer Clock Timing**

Table 54 and Figure 32 describe timer clock timing.

**Table 54. Timer Clock Timing**

<table>
<thead>
<tr>
<th>Parameter</th>
<th>$V_{DD_{EXT}}$ 1.8 V Nominal</th>
<th>$V_{DD_{EXT}}$ 2.5 V or 3.3 V Nominal</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
</tr>
<tr>
<td><strong>Switching Characteristic</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{TODP}$ Timer Output Update Delay After PPI_CLK High</td>
<td>12.0</td>
<td></td>
</tr>
</tbody>
</table>

![Figure 32. Timer Clock Timing](image)

**Up/Down Counter/Rotary Encoder Timing**

**Table 55. Up/Down Counter/Rotary Encoder Timing**

<table>
<thead>
<tr>
<th>Parameter</th>
<th>$V_{DD_{EXT}}$ 1.8 V Nominal</th>
<th>$V_{DD_{EXT}}$ 2.5 V or 3.3 V Nominal</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
</tr>
<tr>
<td><strong>Timing Requirements</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{WCOUNT}$ Up/Down Counter/Rotary Encoder Input Pulse Width</td>
<td>$t_{SCLK} + 1$</td>
<td>$t_{SCLK} + 1$</td>
</tr>
<tr>
<td>$t_{CIS}$ Counter Input Setup Time Before CLKOUT High</td>
<td>9.0</td>
<td></td>
</tr>
<tr>
<td>$t_{CIH}$ Counter Input Hold Time After CLKOUT High</td>
<td>0</td>
<td></td>
</tr>
</tbody>
</table>

1 Either a valid setup and hold time or a valid pulse width is sufficient. There is no need to resynchronize counter inputs.

![Figure 33. Up/Down Counter/Rotary Encoder Timing](image)
**HOSTDP A/C Timing - Host Read Cycle**

Table 56 describes the HOSTDP A/C Host Read Cycle timing requirements.

Table 56. Host Read Cycle Timing Requirements

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>$V_{DD EXT}$ 1.8 V Nominal</td>
<td>$V_{DD EXT}$ 2.5 V or 3.3 V Nominal</td>
</tr>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
</tr>
<tr>
<td>Timing Requirements</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{SADRDL}$ HOST_ADDR and HOST_CE Setup before HOST_RD falling edge</td>
<td>4</td>
<td>4</td>
</tr>
<tr>
<td>$t_{HADRH}$ HOST_ADDR and HOST_CE Hold after HOST_RD rising edge</td>
<td>2.5</td>
<td>2.5</td>
</tr>
<tr>
<td>$t_{RDWL}$ HOST_RD pulse width low (ACK mode)</td>
<td>$t_{RDYRDL} + t_{RDYPRD}$</td>
<td>$t_{RDYRDL} + t_{RDYPRD}$</td>
</tr>
<tr>
<td>$t_{RDWL}$ HOST_RD pulse width low (INT mode)</td>
<td>$1.5 \times t_{SCLK} + 8.7$</td>
<td>$1.5 \times t_{SCLK} + 8.7$</td>
</tr>
<tr>
<td>$t_{RDWH}$ HOST_RD pulse width high or time between HOST_RD rising edge and HOST_WR falling edge</td>
<td>$2 \times t_{SCLK}$</td>
<td>$2 \times t_{SCLK}$</td>
</tr>
<tr>
<td>$t_{RDHRD}$ HOST_RD rising edge delay after HOST_ACK rising edge (ACK mode)</td>
<td>2.0</td>
<td>2.0</td>
</tr>
<tr>
<td>$t_{SDATRD}$ Data valid prior HOST_ACK rising edge (ACK mode)</td>
<td>4.5</td>
<td>3.5</td>
</tr>
<tr>
<td>$t_{DROVF}$ HOST_ACK falling edge after HOST_CE (ACK mode)</td>
<td>12.5</td>
<td>11.25</td>
</tr>
<tr>
<td>$t_{DROVF}$ HOST_ACK low pulse-width for Read access (ACK mode)</td>
<td>NM$^1$</td>
<td>NM$^1$</td>
</tr>
<tr>
<td>$t_{DWARH}$ Data disable after HOST_RD</td>
<td>11.0</td>
<td>9.0</td>
</tr>
<tr>
<td>$t_{ACC}$ Data valid after HOST_RD falling edge (INT mode)</td>
<td>$1.5 \times t_{SCLK}$</td>
<td>$1.5 \times t_{SCLK}$</td>
</tr>
<tr>
<td>$t_{DWARH}$ Data hold after HOST_RD rising edge</td>
<td>1.0</td>
<td>1.0</td>
</tr>
</tbody>
</table>

$^1$ NM (Not Measured) — This parameter is based on $t_{SCLK}$. It is not measured because the number of SCLK cycles for which HOST_ACK is low depends on the Host DMA FIFO status and is system design dependent.
In Figure 34, HOST_DATA is HOST_D0–D15.

Figure 34. HOSTDP A/C- Host Read Cycle
HOSTDP A/C Timing- Host Write Cycle

Table 57 describes the HOSTDP A/C Host Write Cycle timing requirements.

Table 57. Host Write Cycle Timing Requirements

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>$V_{DDEXT}$ 1.8V Nominal</td>
<td>$V_{DDEXT}$ 2.5 V or 3.3 V Nominal</td>
</tr>
<tr>
<td>Timing Requirements</td>
<td>Min</td>
<td>Max</td>
</tr>
<tr>
<td>$t_{SADWRL}$ HOST_ADDR/HOST_CE Setup before HOST_WR falling edge</td>
<td>2.5</td>
<td>2.5</td>
</tr>
<tr>
<td>$t_{HADWRH}$ HOST_ADDR/HOST_CE Hold after HOST_WR rising edge</td>
<td>4</td>
<td>4</td>
</tr>
<tr>
<td>$t_{WRWL}$ HOST_WR pulse width low (ACK mode)</td>
<td>$t_{DRDYWRL} + t_{DRDYWRL} + t_{DRDYWRL} + t_{DRDYWRL}$</td>
<td>$t_{DRDYWRL} + t_{DRDYWRL} + t_{DRDYWRL} + t_{DRDYWRL}$</td>
</tr>
<tr>
<td>$t_{WRWH}$ HOST_WR pulse width high or time between HOST_WR rising edge and HOST_RD falling edge</td>
<td>2.5×$t_{SCLK}$</td>
<td>2.5×$t_{SCLK}$</td>
</tr>
<tr>
<td>$t_{DWRHRDY}$ HOST_WR rising edge delay after HOST_ACK rising edge (ACK mode)</td>
<td>2.0</td>
<td>2.0</td>
</tr>
<tr>
<td>$t_{DATWH}$ Data Hold after HOST_WR rising edge</td>
<td>2.5</td>
<td>2.5</td>
</tr>
<tr>
<td>$t_{SDATWH}$ Data Setup before HOST_WR rising edge</td>
<td>3.5</td>
<td>2.5</td>
</tr>
<tr>
<td>Switching Characteristics</td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{DRDYWRL}$ HOST_ACK falling edge after HOST_CE asserted (ACK mode)</td>
<td>12.5</td>
<td>11.5</td>
</tr>
<tr>
<td>$t_{RDYPWR}$ HOST_ACK low pulse-width for Write access (ACK mode)</td>
<td>NM$^1$</td>
<td>NM$^1$</td>
</tr>
</tbody>
</table>

$^1$ NM (Not Measured) — This parameter is based on $t_{SCLK}$. It is not measured because the number of SCLK cycles for which HOST_ACK is low depends on the Host DMA FIFO status and is system design dependent.
In Figure 35, HOST_DATA is HOST_D0–D15.

*Figure 35. HOSTDP A/C- Host Write Cycle*
10/100 Ethernet MAC Controller Timing

Table 58 through Table 63 and Figure 36 through Figure 41 describe the 10/100 Ethernet MAC Controller operations.

Table 58. 10/100 Ethernet MAC Controller Timing: MII Receive Signal

<table>
<thead>
<tr>
<th>Parameter</th>
<th>$V_{DDEXT}$ 1.8 V Nominal</th>
<th>$V_{DDEXT}$ 2.5 V or 3.3 V Nominal</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
</tr>
<tr>
<td><strong>Timing Requirements</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{ERXCLKF}$ ERxCLK Frequency ($f_{SCLK} = SCLK Frequency$)</td>
<td>None</td>
<td>25 + 1%</td>
</tr>
<tr>
<td>$t_{ERXCLKW}$ ERxCLK Width ($t_{ERXCLK} = ERxCLK Period$)</td>
<td>$t_{ERXCLK} \times 40%$</td>
<td>$t_{ERXCLK} \times 60%$</td>
</tr>
<tr>
<td>$t_{ERXCLKS}$ Rx Input Valid to ERxCLK Rising Edge (Data In Setup)</td>
<td>7.5</td>
<td>7.5 ns</td>
</tr>
<tr>
<td>$t_{ERXCLKIH}$ ERxCLK Rising Edge to Rx Input Invalid (Data In Hold)</td>
<td>7.5</td>
<td>7.5 ns</td>
</tr>
</tbody>
</table>

1 MII inputs synchronous to ERxCLK are ERxD3–0, ERxDV, and ERxER.

Figure 36. 10/100 Ethernet MAC Controller Timing: MII Receive Signal

Table 59. 10/100 Ethernet MAC Controller Timing: MII Transmit Signal

<table>
<thead>
<tr>
<th>Parameter</th>
<th>$V_{DDEXT}$ 1.8 V Nominal</th>
<th>$V_{DDEXT}$ 2.5 V or 3.3 V Nominal</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
</tr>
<tr>
<td><strong>Switching Characteristics</strong></td>
<td></td>
<td></td>
</tr>
<tr>
<td>$t_{ETXCLKF}$ ETxCLK Frequency ($f_{SCLK} = SCLK Frequency$)</td>
<td>None</td>
<td>25 + 1%</td>
</tr>
<tr>
<td>$t_{ETXCLKW}$ ETxCLK Width ($t_{ETXCLK} = ETxCLK Period$)</td>
<td>$t_{ETXCLK} \times 40%$</td>
<td>$t_{ETXCLK} \times 60%$</td>
</tr>
<tr>
<td>$t_{ETXCLKOV}$ ETxCLK Rising Edge to Tx Output Valid (Data Out Valid)</td>
<td>0</td>
<td>20</td>
</tr>
<tr>
<td>$t_{ETXCLKOH}$ ETxCLK Rising Edge to Tx Output Invalid (Data Out Hold)</td>
<td>0</td>
<td>20</td>
</tr>
</tbody>
</table>

1 MII outputs synchronous to ETxCLK are ETxD3–0.

Figure 37. 10/100 Ethernet MAC Controller Timing: MII Transmit Signal
Table 60. 10/100 Ethernet MAC Controller Timing: RMII Receive Signal

<table>
<thead>
<tr>
<th>Parameter</th>
<th>VDD&lt;sub&gt;EXT&lt;/sub&gt; 1.8 V Nominal</th>
<th></th>
<th>VDD&lt;sub&gt;EXT&lt;/sub&gt; 2.5 V or 3.3 V Nominal</th>
<th></th>
<th></th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
<td>Min</td>
<td>Max</td>
<td>Min</td>
<td>Max</td>
</tr>
<tr>
<td>Timing Requirements</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>t&lt;sub&gt;EREFCLKF&lt;/sub&gt;</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>REF_CLK Frequency (f&lt;sub&gt;SCLK&lt;/sub&gt; = SCLK Frequency)</td>
<td>None</td>
<td>50 + 1%</td>
<td>None</td>
<td>50 + 1%</td>
<td>MHz</td>
<td></td>
</tr>
<tr>
<td>t&lt;sub&gt;EREFCLKW&lt;/sub&gt;</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>EREF_CLK Width (t&lt;sub&gt;EREFCLK&lt;/sub&gt; = EREFCLK Period)</td>
<td>t&lt;sub&gt;EREFCLK&lt;/sub&gt; × 40%</td>
<td>t&lt;sub&gt;EREFCLK&lt;/sub&gt; × 60%</td>
<td>t&lt;sub&gt;EREFCLK&lt;/sub&gt; × 35%</td>
<td>t&lt;sub&gt;EREFCLK&lt;/sub&gt; × 65%</td>
<td>ns</td>
<td></td>
</tr>
<tr>
<td>t&lt;sub&gt;EREFCLKIS&lt;/sub&gt;</td>
<td></td>
<td></td>
<td>2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>Rx Input Valid to RMII REF_CLK Rising Edge (Data In Setup)</td>
<td>4</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>t&lt;sub&gt;EREFCLKIH&lt;/sub&gt;</td>
<td></td>
<td></td>
<td>2</td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>RMII REF_CLK Rising Edge to Rx Input Invalid (Data In Hold)</td>
<td>2</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

1 RMII inputs synchronous to RMII REF_CLK are ERxD1–0, RMII CRS_DV, and ERxER.

Figure 38. 10/100 Ethernet MAC Controller Timing: RMII Receive Signal

Table 61. 10/100 Ethernet MAC Controller Timing: RMII Transmit Signal

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>VDD&lt;sub&gt;EXT&lt;/sub&gt; 1.8 V Nominal</td>
<td>VDD&lt;sub&gt;EXT&lt;/sub&gt; 2.5 V or 3.3 V Nominal</td>
</tr>
<tr>
<td></td>
<td>Min</td>
<td>Max</td>
</tr>
<tr>
<td>t&lt;sub&gt;EREFCLKOV&lt;/sub&gt;</td>
<td>RMII REF_CLK Rising Edge to Tx Output Valid (Data Out Valid)</td>
<td>8.1</td>
</tr>
<tr>
<td>t&lt;sub&gt;EREFCLKOH&lt;/sub&gt;</td>
<td>RMII REF_CLK Rising Edge to Tx Output Invalid (Data Out Hold)</td>
<td>2</td>
</tr>
</tbody>
</table>

1 RMII outputs synchronous to RMII REFCLK are ETxD1–0.

Figure 39. 10/100 Ethernet MAC Controller Timing: RMII Transmit Signal
Table 62. 10/100 Ethernet MAC Controller Timing: MII/RMII Asynchronous Signal

<table>
<thead>
<tr>
<th>Parameter</th>
<th>( V_{DDEXT} ) 1.8 V Nominal</th>
<th>( V_{DDEXT} ) 2.5 V or 3.3 V Nominal</th>
</tr>
</thead>
<tbody>
<tr>
<td>( t_{ECOLH} )</td>
<td>( \frac{t_{ETxCLK} \times 1.5}{2} )</td>
<td>( \frac{t_{ERxCLK} \times 1.5}{2} )</td>
</tr>
<tr>
<td>( t_{ECOLL} )</td>
<td>( \frac{t_{ETxCLK} \times 1.5}{2} )</td>
<td>( \frac{t_{ERxCLK} \times 1.5}{2} )</td>
</tr>
<tr>
<td>( t_{ECRSH} )</td>
<td>( \frac{t_{ETxCLK} \times 1.5}{2} )</td>
<td>( \frac{t_{ETxCLK} \times 1.5}{2} )</td>
</tr>
<tr>
<td>( t_{ECRSL} )</td>
<td>( \frac{t_{ETxCLK} \times 1.5}{2} )</td>
<td>( \frac{t_{ETxCLK} \times 1.5}{2} )</td>
</tr>
</tbody>
</table>

1 MII/RMII asynchronous signals are COL and CRS. These signals are applicable in both MII and RMII modes. The asynchronous COL input is synchronized separately to both the ETxCLK and ERxCLK, and the COL input must have a minimum pulse width high or low at least 1.5 times the period of the slower of the two clocks.

2 The asynchronous CRS input is synchronized to the ETxCLK, and the CRS input must have a minimum pulse width high or low at least 1.5 times the period of ETxCLK.

![Figure 40. 10/100 Ethernet MAC Controller Timing: Asynchronous Signal](image)

Table 63. 10/100 Ethernet MAC Controller Timing: MII Station Management

<table>
<thead>
<tr>
<th>Parameter</th>
<th>( V_{DDEXT} ) 1.8 V Nominal</th>
<th>( V_{DDEXT} ) 2.5 V or 3.3 V Nominal</th>
</tr>
</thead>
<tbody>
<tr>
<td>( t_{MDIOS} )</td>
<td>11.5</td>
<td>11.5</td>
</tr>
<tr>
<td>( t_{MDIOH} )</td>
<td>11.5</td>
<td>11.5</td>
</tr>
</tbody>
</table>

![Figure 41. 10/100 Ethernet MAC Controller Timing: Station Management](image)

1 MDC/MDIO is a 2-wire serial bidirectional port for controlling one or more external PHYs. MDC is an output clock whose minimum period is programmable as a multiple of the system clock SCLK. MDIO is a bidirectional data line.
Figure 41. 10/100 Ethernet MAC Controller Timing: MII Station Management
Table 64 and Figure 42 describe JTAG port operations.

### Table 64. JTAG Port Timing

<table>
<thead>
<tr>
<th>Parameter</th>
<th>( V_{DDEXT} )</th>
<th>Min</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>( t_{TCK} )</td>
<td>1.8 V Nominal</td>
<td>20</td>
<td>20</td>
<td>ns</td>
</tr>
<tr>
<td>( t_{TCK} )</td>
<td>2.5 V or 3.3 V Nominal</td>
<td>20</td>
<td>20</td>
<td>ns</td>
</tr>
<tr>
<td>( t_{STAP} )</td>
<td>TDI, TMS Setup Before TCK High</td>
<td>4</td>
<td>4</td>
<td>ns</td>
</tr>
<tr>
<td>( t_{HTAP} )</td>
<td>TDI, TMS Hold After TCK High</td>
<td>4</td>
<td>4</td>
<td>ns</td>
</tr>
<tr>
<td>( t_{SSYS} )</td>
<td>System Inputs Setup Before TCK High</td>
<td>12</td>
<td>12</td>
<td>ns</td>
</tr>
<tr>
<td>( t_{HSYS} )</td>
<td>System Inputs Hold After TCK High</td>
<td>5</td>
<td>5</td>
<td>ns</td>
</tr>
<tr>
<td>( t_{TRSTW} )</td>
<td>TRST Pulse Width (measured in TCK cycles)</td>
<td>4</td>
<td>4</td>
<td>TCK</td>
</tr>
</tbody>
</table>

### Switching Characteristics

<table>
<thead>
<tr>
<th>Parameter</th>
<th>( V_{DDEXT} )</th>
<th>Min</th>
<th>Max</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>( t_{TDO} )</td>
<td>TDO Delay from TCK Low</td>
<td>10</td>
<td>10</td>
<td>ns</td>
</tr>
<tr>
<td>( t_{SYS} )</td>
<td>System Outputs Delay After TCK Low</td>
<td>12</td>
<td>12</td>
<td>ns</td>
</tr>
</tbody>
</table>

1 System Inputs = DATA15–0, ARDY, SCL, SDA, PF15–0, PG15–0, PH15–0, RESET, NMI, BMODE3–0.
2 50 MHz Maximum.
3 System Outputs = DATA15–0, ADDR19–1, ABET–0, AOE, ARE, AWE, AMS3–0, SRAS, SCAS, SWE, SCKE, CLKOUT, SA10, SMS, SCL, SDA, PF15–0, PG15–0, PH15–0.
OUTPUT DRIVE CURRENTS

Figure 43 through Figure 57 show typical current-voltage characteristics for the output drivers of the ADSP-BF52x processors.

The curves represent the current drive capability of the output drivers. See Table 10 on Page 23 for information about which driver type corresponds to a particular ball.
Figure 49. Driver Type C Current (3.3V $V_{DDEXT}/V_{DDMEM}$)

Figure 50. Drive Type C Current (2.5V $V_{DDEXT}/V_{DDMEM}$)

Figure 51. Driver Type C Current (1.8V $V_{DDEXT}/V_{DDMEM}$)

Figure 52. Driver Type D Current (3.3V $V_{DDEXT}/V_{DDMEM}$)

Figure 53. Driver Type D Current (2.5V $V_{DDEXT}/V_{DDMEM}$)

Figure 54. Driver Type D Current (1.8V $V_{DDEXT}/V_{DDMEM}$)
**TEST CONDITIONS**

All Timing Requirements appearing in this data sheet were measured under the conditions described in this section. Figure 58 shows the measurement point for AC measurements (except output enable/disable). The measurement point \( V_{\text{MEAS}} \) is \( V_{\text{DDEXT}}/2 \) or \( V_{\text{DDMEM}}/2 \) for \( V_{\text{DDEXT}}/V_{\text{DDMEM}} \) (nominal) = 1.8 V/2.5 V/3.3 V.

**Output Enable Time Measurement**

Output balls 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_{\text{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 59.

The time \( t_{\text{ENA, MEASURED}} \) is the interval from when the reference signal switches to when the output voltage reaches \( V_{\text{TRIP}} \) (high) or \( V_{\text{TRIP}} \) (low). For \( V_{\text{DDEXT}}/V_{\text{DDMEM}} \) (nominal) = 1.8 V, \( V_{\text{TRIP}} \) (high) is 1.05 V, and \( V_{\text{TRIP}} \) (low) is 0.75 V. For \( V_{\text{DDEXT}}/V_{\text{DDMEM}} \) (nominal) = 2.5 V, \( V_{\text{TRIP}} \) (high) is 1.5 V and \( V_{\text{TRIP}} \) (low) is 1.0 V. For \( V_{\text{DDEXT}}/V_{\text{DDMEM}} \) (nominal) = 3.3 V, \( V_{\text{TRIP}} \) (high) is 1.9 V, and \( V_{\text{TRIP}} \) (low) is 1.4 V. Time \( t_{\text{TRIP}} \) is the interval from when the output starts driving to when the output reaches the \( V_{\text{TRIP}} \) (high) or \( V_{\text{TRIP}} \) (low) trip voltage.

Time \( t_{\text{ENA}} \) is calculated as shown in the equation:

\[
 t_{\text{ENA}} = t_{\text{ENA, MEASURED}} - t_{\text{TRIP}}
\]

If multiple balls (such as the data bus) are enabled, the measurement value is that of the first ball to start driving.
**Output Disable Time Measurement**

Output balls 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 59.

$$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_L$. This decay time can be approximated by the equation:

$$t_{DECAY} = \frac{(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.25 V for $V_{DD\text{EXT}}/V_{DD\text{MEM}}$ (nominal) = 2.5 V/3.3 V and 0.15 V for $V_{DD\text{EXT}}/V_{DD\text{MEM}}$ (nominal) = 1.8V.

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.

**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 will be $t_{DECAY}$ plus the various output disable times as specified in the Timing Specifications on Page 39 (for example $t_{DSDAT}$ for an SDRAM write cycle as shown in SDRAM Interface Timing on Page 47).

**Capacitive Loading**

Output delays and holds are based on standard capacitive loads of an average of 6 pF on all balls (see Figure 60). $V_{LOAD}$ is equal to $(V_{DD\text{EXT}}/V_{DD\text{MEM}})/2$. The graphs of Figure 61 through Figure 72 show how output rise time varies with capacitance. The delay and hold specifications given should be derated by a factor derived from these figures. The graphs in these figures may not be linear outside the ranges shown.
Figure 62. Driver Type A Typical Rise and Fall Times (10%–90%) vs. Load Capacitance (2.5V VDDEXT/VDDMEM)

Figure 63. Driver Type A Typical Rise and Fall Times (10%–90%) vs. Load Capacitance (3.3V VDDEXT/VDDMEM)

Figure 64. Driver Type B Typical Rise and Fall Times (10%–90%) vs. Load Capacitance (1.8V VDDEXT/VDDMEM)

Figure 65. Driver Type B Typical Rise and Fall Times (10%–90%) vs. Load Capacitance (2.5V VDDEXT/VDDMEM)

Figure 66. Driver Type B Typical Rise and Fall Times (10%–90%) vs. Load Capacitance (3.3V VDDEXT/VDDMEM)

Figure 67. Driver Type C Typical Rise and Fall Times (10%–90%) vs. Load Capacitance (1.8V VDDEXT/VDDMEM)
Figure 68. Driver Type C Typical Rise and Fall Times (10%–90%) vs. Load Capacitance (2.5V VDDEXT/VDDMEM)

Figure 69. Driver Type C Typical Rise and Fall Times (10%–90%) vs. Load Capacitance (3.3V VDDEXT/VDDMEM)

Figure 70. Driver Type D Typical Rise and Fall Times (10%–90%) vs. Load Capacitance (1.8V VDDEXT/VDDMEM)

Figure 71. Driver Type D Typical Rise and Fall Times (10%–90%) vs. Load Capacitance (2.5V VDDEXT/VDDMEM)

Figure 72. Driver Type D Typical Rise and Fall Times (10%–90%) vs. Load Capacitance (3.3V VDDEXT/VDDMEM)

Figure 73. Driver Type G Typical Rise and Fall Times (10%–90%) vs. Load Capacitance (1.8V VDDEXT/VDDMEM)
ENVIRONMENTAL CONDITIONS

To determine the junction temperature on the application printed circuit board use:

\[ T_J = T_{CASE} + (\theta_J T \times P_D) \]

where:
- \( T_J \) = Junction temperature (°C)
- \( T_{CASE} \) = Case temperature (°C) measured by customer at top center of package.
- \( \theta_J T \) = From Table 66
- \( P_D \) = Power dissipation — For a description, see Total Power Dissipation on Page 35.

Values of \( \theta_J A \) are provided for package comparison and printed circuit board design considerations. \( \theta_J A \) can be used for a first order approximation of \( T_J \) by the equation:

\[ T_J = T_A + (\theta_J A \times P_D) \]

where:
- \( T_A \) = Ambient temperature (°C)

Values of \( \theta_J C \) are provided for package comparison and printed circuit board design considerations when an external heat sink is required.

Values of \( \theta_J B \) are provided for package comparison and printed circuit board design considerations.

In Table 66, airflow measurements comply with JEDEC standards JESD51-2 and JESD51-6, and the junction-to-board measurement complies with JESD51-8. The junction-to-case measurement complies with MIL-STD-883 (Method 1012.1). All measurements use a 2S2P JEDEC test board.

### Table 65. Thermal Characteristics for BC-208-1 Package

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Condition</th>
<th>Typical Unit</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>( \theta_J A )</td>
<td>0 linear m/s air flow</td>
<td>23.20</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \theta_J M A )</td>
<td>1 linear m/s air flow</td>
<td>20.20</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \theta_J M A )</td>
<td>2 linear m/s air flow</td>
<td>19.20</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \theta_J B )</td>
<td></td>
<td>13.05</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \theta_J C )</td>
<td></td>
<td>6.92</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \psi_J T )</td>
<td>0 linear m/s air flow</td>
<td>0.18</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \psi_J T )</td>
<td>1 linear m/s air flow</td>
<td>0.27</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \psi_J T )</td>
<td>2 linear m/s air flow</td>
<td>0.32</td>
<td>°C/W</td>
</tr>
</tbody>
</table>

### Table 66. Thermal Characteristics for BC-289-2 Package

<table>
<thead>
<tr>
<th>Parameter</th>
<th>Condition</th>
<th>Typical Unit</th>
<th>Unit</th>
</tr>
</thead>
<tbody>
<tr>
<td>( \theta_J A )</td>
<td>0 linear m/s air flow</td>
<td>34.5</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \theta_J M A )</td>
<td>1 linear m/s air flow</td>
<td>31.1</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \theta_J M A )</td>
<td>2 linear m/s air flow</td>
<td>29.8</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \theta_J B )</td>
<td></td>
<td>20.3</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \theta_J C )</td>
<td></td>
<td>8.8</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \psi_J T )</td>
<td>0 linear m/s air flow</td>
<td>0.24</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \psi_J T )</td>
<td>1 linear m/s air flow</td>
<td>0.44</td>
<td>°C/W</td>
</tr>
<tr>
<td>( \psi_J T )</td>
<td>2 linear m/s air flow</td>
<td>0.53</td>
<td>°C/W</td>
</tr>
</tbody>
</table>
### 289-Ball CSP_BGA Ball Assignment

Table 67 lists the CSP_BGA balls by signal mnemonic. Table 68 on Page 81 lists the CSP_BGA by ball number.

#### Table 67. 289-Ball CSP_BGA Ball Assignment (Alphabetically by Signal)

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>ABE0/SDQM0</td>
<td>AB9</td>
<td>DATA6</td>
<td>T2</td>
<td>GND</td>
<td>M10</td>
<td>NC</td>
<td>D23</td>
<td>PH0</td>
<td>A11</td>
<td>USB_XO</td>
<td>AA23</td>
</tr>
<tr>
<td>ABE1/SDQM1</td>
<td>AC9</td>
<td>DATA7</td>
<td>T1</td>
<td>GND</td>
<td>M11</td>
<td>NC</td>
<td>E22</td>
<td>PH1</td>
<td>A12</td>
<td>VDD</td>
<td>G7</td>
</tr>
<tr>
<td>ADDR1</td>
<td>A88</td>
<td>DATA8</td>
<td>R1</td>
<td>GND</td>
<td>M12</td>
<td>NC</td>
<td>E23</td>
<td>PH2</td>
<td>A13</td>
<td>VDD</td>
<td>G8</td>
</tr>
<tr>
<td>ADDR2</td>
<td>A8C</td>
<td>DATA9</td>
<td>P1</td>
<td>GND</td>
<td>M13</td>
<td>NC</td>
<td>F22</td>
<td>PH3</td>
<td>B14</td>
<td>VDD</td>
<td>G9</td>
</tr>
<tr>
<td>ADDR3</td>
<td>A87</td>
<td>DATA10</td>
<td>P2</td>
<td>GND</td>
<td>M14</td>
<td>NC</td>
<td>F23</td>
<td>PH4</td>
<td>A14</td>
<td>VDD</td>
<td>G10</td>
</tr>
<tr>
<td>ADDR4</td>
<td>AC7</td>
<td>DATA11</td>
<td>R2</td>
<td>GND</td>
<td>M15</td>
<td>NC</td>
<td>G22</td>
<td>PH5</td>
<td>K23</td>
<td>VDD</td>
<td>G11</td>
</tr>
<tr>
<td>ADDR5</td>
<td>AC6</td>
<td>DATA12</td>
<td>N1</td>
<td>GND</td>
<td>N9</td>
<td>NC</td>
<td>H23</td>
<td>PH6</td>
<td>K22</td>
<td>VDD</td>
<td>G12</td>
</tr>
<tr>
<td>ADDR6</td>
<td>AB6</td>
<td>DATA13</td>
<td>N2</td>
<td>GND</td>
<td>N10</td>
<td>NC</td>
<td>J23</td>
<td>PH7</td>
<td>L23</td>
<td>VDD</td>
<td>G13</td>
</tr>
<tr>
<td>ADDR7</td>
<td>AB4</td>
<td>DATA14</td>
<td>M2</td>
<td>GND</td>
<td>N11</td>
<td>NMI</td>
<td>U22</td>
<td>PH8</td>
<td>L22</td>
<td>VDD</td>
<td>G14</td>
</tr>
<tr>
<td>ADDR8</td>
<td>AB5</td>
<td>DATA15</td>
<td>M1</td>
<td>GND</td>
<td>N12</td>
<td>VPPOTP</td>
<td>AB11</td>
<td>PH9</td>
<td>T23</td>
<td>VDD</td>
<td>G15</td>
</tr>
<tr>
<td>ADDR9</td>
<td>AC5</td>
<td>EMU</td>
<td>J2</td>
<td>GND</td>
<td>N13</td>
<td>PF0</td>
<td>A7</td>
<td>PH10</td>
<td>M22</td>
<td>VDD</td>
<td>H7</td>
</tr>
<tr>
<td>ADDR10</td>
<td>AC4</td>
<td>EXT_WAKE0</td>
<td>AC19</td>
<td>GND</td>
<td>M14</td>
<td>PF1</td>
<td>B8</td>
<td>PH11</td>
<td>R22</td>
<td>VDD</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>ADDR11</td>
<td>AB3</td>
<td>GND</td>
<td>A1</td>
<td>GND</td>
<td>M15</td>
<td>PF2</td>
<td>A8</td>
<td>PH12</td>
<td>M23</td>
<td>VDD</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>ADDR12</td>
<td>AC3</td>
<td>GND</td>
<td>A23</td>
<td>GND</td>
<td>M16</td>
<td>PF9</td>
<td>B1</td>
<td>PH13</td>
<td>N22</td>
<td>VDD</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>ADDR13</td>
<td>AB2</td>
<td>GND</td>
<td>B6</td>
<td>GND</td>
<td>M17</td>
<td>PF4</td>
<td>B11</td>
<td>PH14</td>
<td>N23</td>
<td>VDD</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>ADDR14</td>
<td>AC2</td>
<td>GND</td>
<td>G16</td>
<td>GND</td>
<td>M18</td>
<td>PF5</td>
<td>B10</td>
<td>PH15</td>
<td>P22</td>
<td>VDD</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>ADDR15</td>
<td>AA2</td>
<td>GND</td>
<td>G17</td>
<td>GND</td>
<td>N12</td>
<td>PF6</td>
<td>B12</td>
<td>PPL_CLK/TMRCLK</td>
<td>A6</td>
<td>VDD</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>ADDR16</td>
<td>W2</td>
<td>GND</td>
<td>H17</td>
<td>GND</td>
<td>M19</td>
<td>PF7</td>
<td>B13</td>
<td>PPL_F51/TMR0</td>
<td>B7</td>
<td>VDD</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>ADDR17</td>
<td>Y2</td>
<td>GND</td>
<td>H22</td>
<td>GND</td>
<td>M20</td>
<td>PF8</td>
<td>B16</td>
<td>RESET</td>
<td>V22</td>
<td>VDD</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>ADDR18</td>
<td>AA1</td>
<td>GND</td>
<td>J22</td>
<td>GND</td>
<td>M21</td>
<td>PF9</td>
<td>A20</td>
<td>RTXI</td>
<td>U23</td>
<td>VDD</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>ADDR19</td>
<td>AB1</td>
<td>GND</td>
<td>J9</td>
<td>GND</td>
<td>M22</td>
<td>PF10</td>
<td>B15</td>
<td>RTXO</td>
<td>V23</td>
<td>VDD</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>AMS0</td>
<td>AC17</td>
<td>GND</td>
<td>J10</td>
<td>GND</td>
<td>M23</td>
<td>PF11</td>
<td>B17</td>
<td>SA10</td>
<td>AC10</td>
<td>VDD</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>AMS1</td>
<td>AB16</td>
<td>GND</td>
<td>J11</td>
<td>GND</td>
<td>M24</td>
<td>PF12</td>
<td>B18</td>
<td>SCAS</td>
<td>AC11</td>
<td>VDD</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>AMS2</td>
<td>AC16</td>
<td>GND</td>
<td>J12</td>
<td>GND</td>
<td>M25</td>
<td>PF13</td>
<td>B19</td>
<td>SCKE</td>
<td>AB13</td>
<td>VDD</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>AMS3</td>
<td>AB15</td>
<td>GND</td>
<td>J13</td>
<td>GND</td>
<td>M26</td>
<td>PF14</td>
<td>A9</td>
<td>SCL</td>
<td>B22</td>
<td>VDD</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>AOE</td>
<td>AC15</td>
<td>GND</td>
<td>J14</td>
<td>GND</td>
<td>M27</td>
<td>PF15</td>
<td>A10</td>
<td>SDA</td>
<td>C22</td>
<td>VDD</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>ARDY</td>
<td>AC14</td>
<td>GND</td>
<td>J15</td>
<td>GND</td>
<td>M28</td>
<td>PG0</td>
<td>H2</td>
<td>SMS</td>
<td>AC13</td>
<td>VDD</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>ARE</td>
<td>AB17</td>
<td>GND</td>
<td>K9</td>
<td>GND</td>
<td>M29</td>
<td>PG1</td>
<td>G1</td>
<td>SRS</td>
<td>AB12</td>
<td>VDD</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>AWE</td>
<td>AB14</td>
<td>GND</td>
<td>K10</td>
<td>GND</td>
<td>M30</td>
<td>PG2</td>
<td>H1</td>
<td>SS/PG</td>
<td>AC20</td>
<td>VDD</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>BMODE0</td>
<td>G2</td>
<td>GND</td>
<td>K11</td>
<td>GND</td>
<td>M31</td>
<td>AC23</td>
<td>PG3</td>
<td>F1</td>
<td>SWE</td>
<td>AB10</td>
<td>VDD</td>
</tr>
<tr>
<td>BMODE1</td>
<td>F2</td>
<td>GND</td>
<td>K12</td>
<td>NC</td>
<td>M32</td>
<td>A15</td>
<td>PG4</td>
<td>D1</td>
<td>TCK</td>
<td>L1</td>
<td>VDD</td>
</tr>
<tr>
<td>BMODE2</td>
<td>E1</td>
<td>GND</td>
<td>K13</td>
<td>NC</td>
<td>M33</td>
<td>A16</td>
<td>PG5</td>
<td>D2</td>
<td>TDI</td>
<td>J1</td>
<td>VDD</td>
</tr>
<tr>
<td>BMODE3</td>
<td>E2</td>
<td>GND</td>
<td>K14</td>
<td>NC</td>
<td>M34</td>
<td>A17</td>
<td>PG6</td>
<td>C2</td>
<td>TDO</td>
<td>K1</td>
<td>VDD</td>
</tr>
<tr>
<td>CLKBUF</td>
<td>AB19</td>
<td>GND</td>
<td>K15</td>
<td>NC</td>
<td>M35</td>
<td>A18</td>
<td>PG7</td>
<td>B1</td>
<td>TMS</td>
<td>L2</td>
<td>VDD</td>
</tr>
<tr>
<td>CLKIN</td>
<td>R23</td>
<td>GND</td>
<td>L9</td>
<td>NC</td>
<td>M36</td>
<td>A19</td>
<td>PG8</td>
<td>C1</td>
<td>TRST</td>
<td>K2</td>
<td>VDD</td>
</tr>
<tr>
<td>CLKOUT</td>
<td>AB18</td>
<td>GND</td>
<td>L10</td>
<td>NC</td>
<td>M37</td>
<td>A21</td>
<td>PG9</td>
<td>B2</td>
<td>USB_DM</td>
<td>AB21</td>
<td>VDD</td>
</tr>
<tr>
<td>DATA0</td>
<td>Y1</td>
<td>GND</td>
<td>L11</td>
<td>NC</td>
<td>M38</td>
<td>A22</td>
<td>PG10</td>
<td>B4</td>
<td>USB_DP</td>
<td>AA22</td>
<td>VDD</td>
</tr>
<tr>
<td>DATA1</td>
<td>V2</td>
<td>GND</td>
<td>L12</td>
<td>NC</td>
<td>M39</td>
<td>B20</td>
<td>PG11</td>
<td>B3</td>
<td>USB_ID</td>
<td>Y22</td>
<td>VDD</td>
</tr>
<tr>
<td>DATA2</td>
<td>W1</td>
<td>GND</td>
<td>L13</td>
<td>NC</td>
<td>M40</td>
<td>B21</td>
<td>PG12</td>
<td>A2</td>
<td>USB_RESET</td>
<td>AC21</td>
<td>VDD</td>
</tr>
<tr>
<td>DATA3</td>
<td>U2</td>
<td>GND</td>
<td>L14</td>
<td>NC</td>
<td>M41</td>
<td>B23</td>
<td>PG13</td>
<td>A3</td>
<td>USB_VBUS</td>
<td>AB20</td>
<td>VDD</td>
</tr>
<tr>
<td>DATA4</td>
<td>V1</td>
<td>GND</td>
<td>L15</td>
<td>NC</td>
<td>M42</td>
<td>C23</td>
<td>PG14</td>
<td>A4</td>
<td>USB_VREF</td>
<td>AC22</td>
<td>VDD</td>
</tr>
<tr>
<td>DATA5</td>
<td>U1</td>
<td>GND</td>
<td>M9</td>
<td>NC</td>
<td>M43</td>
<td>D22</td>
<td>PG15</td>
<td>A5</td>
<td>USB_XI</td>
<td>AB23</td>
<td>VDD</td>
</tr>
</tbody>
</table>

**NOTE:** In this table, **BOLD TYPE** indicates the sole signal/function for that ball on ADSP-BF522/ADSP-BF524/ADSP-BF526 processors.

1 For ADSP-BF52xC compatibility, connect this ball to VDD.
### Table 68. 289-Ball CSP_BGA Ball Assignment (Numerically by Ball Number)

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>A1</td>
<td>GND</td>
<td>B20</td>
<td>NC</td>
<td>H12</td>
<td>VDDINT</td>
<td>L9</td>
<td>GND</td>
<td>P2</td>
<td>DATA10</td>
<td>T22</td>
<td>GND</td>
</tr>
<tr>
<td>A2</td>
<td>PG12</td>
<td>B21</td>
<td>NC</td>
<td>H13</td>
<td>VDDINT</td>
<td>L10</td>
<td>GND</td>
<td>P7</td>
<td>VDDMEM</td>
<td>T23</td>
<td>PH9</td>
</tr>
<tr>
<td>A3</td>
<td>PG13</td>
<td>B22</td>
<td>SCL</td>
<td>H14</td>
<td>VDDINT</td>
<td>L11</td>
<td>GND</td>
<td>P8</td>
<td>VDDINT</td>
<td>U1</td>
<td>DATA5</td>
</tr>
<tr>
<td>A4</td>
<td>PG14</td>
<td>B23</td>
<td>NC</td>
<td>H15</td>
<td>VDDMEM</td>
<td>L12</td>
<td>GND</td>
<td>P9</td>
<td>GND</td>
<td>U2</td>
<td>DATA3</td>
</tr>
<tr>
<td>A5</td>
<td>PG15</td>
<td>C1</td>
<td>PG8</td>
<td>H16</td>
<td>VDDMEM</td>
<td>L13</td>
<td>GND</td>
<td>P10</td>
<td>GND</td>
<td>U7</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>A6</td>
<td>PPI_CLK/TMRCLK</td>
<td>C2</td>
<td>PG6</td>
<td>H17</td>
<td>GND</td>
<td>L14</td>
<td>GND</td>
<td>P11</td>
<td>GND</td>
<td>U8</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>A7</td>
<td>PF0</td>
<td>C22</td>
<td>SDA</td>
<td>H22</td>
<td>GND</td>
<td>L15</td>
<td>GND</td>
<td>P12</td>
<td>GND</td>
<td>U9</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>A8</td>
<td>PF2</td>
<td>C23</td>
<td>NC</td>
<td>H23</td>
<td>VDDINT</td>
<td>L16</td>
<td>VDDINT</td>
<td>P13</td>
<td>GND</td>
<td>U10</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>A9</td>
<td>PF14</td>
<td>D1</td>
<td>PG4</td>
<td>J1</td>
<td>TDI</td>
<td>L17</td>
<td>VDDINT</td>
<td>P14</td>
<td>GND</td>
<td>U11</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>A10</td>
<td>PF15</td>
<td>D2</td>
<td>PG5</td>
<td>J2</td>
<td>EMU</td>
<td>L22</td>
<td>PH8</td>
<td>P15</td>
<td>GND</td>
<td>U12</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>A11</td>
<td>PH0</td>
<td>D22</td>
<td>NC</td>
<td>J7</td>
<td>VDDMEM</td>
<td>L23</td>
<td>PH7</td>
<td>P16</td>
<td>VDDINT</td>
<td>U13</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>A12</td>
<td>PH1</td>
<td>D23</td>
<td>NC</td>
<td>J8</td>
<td>VDDINT</td>
<td>M1</td>
<td>DATA15</td>
<td>P17</td>
<td>VDDEXT</td>
<td>U14</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>A13</td>
<td>PH2</td>
<td>E1</td>
<td>BMODE2</td>
<td>J9</td>
<td>GND</td>
<td>M2</td>
<td>DATA14</td>
<td>P22</td>
<td>PH15</td>
<td>U15</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>A14</td>
<td>PH4</td>
<td>E2</td>
<td>BMODE3</td>
<td>J10</td>
<td>GND</td>
<td>M7</td>
<td>VDDMEM</td>
<td>P23</td>
<td>XTAL</td>
<td>U16</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>A15</td>
<td>NC</td>
<td>E22</td>
<td>NC</td>
<td>J11</td>
<td>GND</td>
<td>M8</td>
<td>VDDINT</td>
<td>R1</td>
<td>DATA8</td>
<td>U17</td>
<td>VDDINT</td>
</tr>
<tr>
<td>A16</td>
<td>NC</td>
<td>E23</td>
<td>NC</td>
<td>J12</td>
<td>GND</td>
<td>M9</td>
<td>GND</td>
<td>R2</td>
<td>DATA11</td>
<td>U12</td>
<td>NMI</td>
</tr>
<tr>
<td>A17</td>
<td>NC</td>
<td>F1</td>
<td>PG3</td>
<td>J13</td>
<td>GND</td>
<td>M10</td>
<td>GND</td>
<td>R7</td>
<td>VDDMEM</td>
<td>U13</td>
<td>RTC</td>
</tr>
<tr>
<td>A18</td>
<td>NC</td>
<td>F2</td>
<td>BMODE1</td>
<td>J14</td>
<td>GND</td>
<td>M11</td>
<td>GND</td>
<td>R8</td>
<td>VDDINT</td>
<td>V1</td>
<td>DATA4</td>
</tr>
<tr>
<td>A19</td>
<td>NC</td>
<td>F22</td>
<td>NC</td>
<td>J15</td>
<td>GND</td>
<td>M12</td>
<td>GND</td>
<td>R9</td>
<td>GND</td>
<td>V2</td>
<td>DATA1</td>
</tr>
<tr>
<td>A20</td>
<td>PF9</td>
<td>F23</td>
<td>NC</td>
<td>J16</td>
<td>VDDINT</td>
<td>M13</td>
<td>GND</td>
<td>R10</td>
<td>GND</td>
<td>V22</td>
<td>RESET</td>
</tr>
<tr>
<td>A21</td>
<td>NC</td>
<td>G1</td>
<td>PG1</td>
<td>J17</td>
<td>VDDINT</td>
<td>M14</td>
<td>GND</td>
<td>R11</td>
<td>GND</td>
<td>V23</td>
<td>RTXO</td>
</tr>
<tr>
<td>A22</td>
<td>NC</td>
<td>G2</td>
<td>BMODE0</td>
<td>J22</td>
<td>GND</td>
<td>M15</td>
<td>GND</td>
<td>R12</td>
<td>GND</td>
<td>W1</td>
<td>DATA2</td>
</tr>
<tr>
<td>A23</td>
<td>GND</td>
<td>G7</td>
<td>VDDINT</td>
<td>J23</td>
<td>NC</td>
<td>M16</td>
<td>VDDINT</td>
<td>R13</td>
<td>GND</td>
<td>W2</td>
<td>ADDR16</td>
</tr>
<tr>
<td>B1</td>
<td>PG7</td>
<td>G8</td>
<td>VDDINT</td>
<td>K1</td>
<td>TDO</td>
<td>M17</td>
<td>VDDINT</td>
<td>R14</td>
<td>GND</td>
<td>W22</td>
<td>VDDDBS</td>
</tr>
<tr>
<td>B2</td>
<td>PG9</td>
<td>G9</td>
<td>VDDINT</td>
<td>K2</td>
<td>TRST</td>
<td>M22</td>
<td>PH10</td>
<td>R15</td>
<td>GND</td>
<td>W23</td>
<td>VDDINT</td>
</tr>
<tr>
<td>B3</td>
<td>PG11</td>
<td>G10</td>
<td>VDDINT</td>
<td>K7</td>
<td>VDDMEM</td>
<td>M23</td>
<td>PH12</td>
<td>R16</td>
<td>VDDINT</td>
<td>Y1</td>
<td>DATA0</td>
</tr>
<tr>
<td>B4</td>
<td>PG10</td>
<td>G11</td>
<td>VDDINT</td>
<td>K8</td>
<td>VDDMEM</td>
<td>N1</td>
<td>DATA12</td>
<td>R17</td>
<td>VDDINT</td>
<td>Y2</td>
<td>ADDR17</td>
</tr>
<tr>
<td>B5</td>
<td>VDDINT</td>
<td>G12</td>
<td>VDDINT</td>
<td>K9</td>
<td>GND</td>
<td>N2</td>
<td>DATA13</td>
<td>R22</td>
<td>PH11</td>
<td>Y22</td>
<td>USB_ID</td>
</tr>
<tr>
<td>B6</td>
<td>GND</td>
<td>G13</td>
<td>VDDINT</td>
<td>K10</td>
<td>GND</td>
<td>N7</td>
<td>VDDMEM</td>
<td>R23</td>
<td>CLKIN</td>
<td>Y23</td>
<td>VDDUSB</td>
</tr>
<tr>
<td>B7</td>
<td>PPI_FS1/TMR0</td>
<td>G14</td>
<td>VDDINT</td>
<td>K11</td>
<td>GND</td>
<td>N8</td>
<td>VDDINT</td>
<td>T1</td>
<td>DATA7</td>
<td>AA1</td>
<td>ADDR18</td>
</tr>
<tr>
<td>B8</td>
<td>PF1</td>
<td>G15</td>
<td>VDDINT</td>
<td>K12</td>
<td>GND</td>
<td>N9</td>
<td>GND</td>
<td>T2</td>
<td>DATA6</td>
<td>AA2</td>
<td>ADDR15</td>
</tr>
<tr>
<td>B9</td>
<td>PF3</td>
<td>G16</td>
<td>GND</td>
<td>K13</td>
<td>GND</td>
<td>N10</td>
<td>GND</td>
<td>T7</td>
<td>VDDMEM</td>
<td>AA22</td>
<td>USB_DP</td>
</tr>
<tr>
<td>B10</td>
<td>PF5</td>
<td>G17</td>
<td>GND</td>
<td>K14</td>
<td>GND</td>
<td>N11</td>
<td>GND</td>
<td>T8</td>
<td>VDDINT</td>
<td>AA23</td>
<td>USB_XO</td>
</tr>
<tr>
<td>B11</td>
<td>PF4</td>
<td>G22</td>
<td>NC</td>
<td>K15</td>
<td>GND</td>
<td>N12</td>
<td>GND</td>
<td>T9</td>
<td>VDDINT</td>
<td>AB1</td>
<td>ADDR19</td>
</tr>
<tr>
<td>B12</td>
<td>PF6</td>
<td>G23</td>
<td>NC</td>
<td>K16</td>
<td>VDDINT</td>
<td>N13</td>
<td>GND</td>
<td>T10</td>
<td>VDDINT</td>
<td>AB2</td>
<td>ADDR13</td>
</tr>
<tr>
<td>B13</td>
<td>PF7</td>
<td>H1</td>
<td>PG2</td>
<td>K17</td>
<td>VDDINT</td>
<td>N14</td>
<td>GND</td>
<td>T11</td>
<td>VDDINT</td>
<td>AB3</td>
<td>ADDR11</td>
</tr>
<tr>
<td>B14</td>
<td>PH3</td>
<td>H2</td>
<td>PG0</td>
<td>K22</td>
<td>PH6</td>
<td>N15</td>
<td>GND</td>
<td>T12</td>
<td>VDDINT</td>
<td>AB4</td>
<td>ADDR7</td>
</tr>
<tr>
<td>B15</td>
<td>PF10</td>
<td>H7</td>
<td>VDDINT</td>
<td>K23</td>
<td>PH5</td>
<td>N16</td>
<td>VDDINT</td>
<td>T13</td>
<td>VDDINT</td>
<td>AB5</td>
<td>ADDR8</td>
</tr>
<tr>
<td>B16</td>
<td>PF8</td>
<td>H8</td>
<td>VDDINT</td>
<td>L1</td>
<td>TCK</td>
<td>N17</td>
<td>VDDINT</td>
<td>T14</td>
<td>VDDINT</td>
<td>AB6</td>
<td>ADDR6</td>
</tr>
<tr>
<td>B17</td>
<td>PF11</td>
<td>H9</td>
<td>VDDINT</td>
<td>L2</td>
<td>TMS</td>
<td>N22</td>
<td>PH13</td>
<td>T15</td>
<td>VDDINT</td>
<td>AB7</td>
<td>ADDR3</td>
</tr>
<tr>
<td>B18</td>
<td>PF12</td>
<td>H10</td>
<td>VDDMEM</td>
<td>L7</td>
<td>VDDMEM</td>
<td>N23</td>
<td>PH14</td>
<td>T16</td>
<td>VDDINT</td>
<td>AB8</td>
<td>ADDR1</td>
</tr>
<tr>
<td>B19</td>
<td>PF13</td>
<td>H11</td>
<td>VDDINT</td>
<td>L8</td>
<td>VDDINT</td>
<td>P1</td>
<td>DATA9</td>
<td>T17</td>
<td>VDDINT</td>
<td>AB9</td>
<td>ABE0/SDQM0</td>
</tr>
</tbody>
</table>

**NOTE:** In this table, **BOLD TYPE** indicates the sole signal/function for that ball on ADSP-BF522/ADSP-BF524/ADSP-BF526 processors.

1For ADSP-BF52xC compatibility, connect this ball to VDDINT.
Figure 76 shows the top view of the BC-289-2 CSP_BGA ball configuration. Figure 77 shows the bottom view of the BC-289-2 CSP_BGA ball configuration.
## 208-Ball CSP_BGA Ball Assignment

Table 69 lists the CSP_BGA balls by signal mnemonic. Table 70 on Page 84 lists the CSP_BGA by ball number.

### Table 69. 208-Ball CSP_BGA Ball Assignment (Alphabetically by Signal)

<table>
<thead>
<tr>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
<th></th>
</tr>
</thead>
<tbody>
<tr>
<td>ABE0/SDQM0 V19</td>
<td>CLKOUT</td>
<td>K20 GND</td>
<td>K11 PF13</td>
<td>A5 PPI_CLK/TMRCLK</td>
<td>G2 VDDCTRL</td>
<td>J8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ABE1/SDQM1 V20</td>
<td>DATA0</td>
<td>Y8 GND</td>
<td>K12 PF14</td>
<td>B6 PPI_F51/TMR0</td>
<td>F2 VDDCTRL</td>
<td>K7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR1 W20</td>
<td>DATA1</td>
<td>W8 GND</td>
<td>K13 PF15</td>
<td>A6 RESET</td>
<td>B18 VDDCTRL</td>
<td>K8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR2 W19</td>
<td>DATA2</td>
<td>Y7 GND</td>
<td>L9 PG0</td>
<td>R2 RTXI</td>
<td>A14 VDDCTRL</td>
<td>L7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR3 Y19</td>
<td>DATA3</td>
<td>W7 GND</td>
<td>L10 PG1</td>
<td>P1 RTXO</td>
<td>A15 VDDCTRL</td>
<td>G12</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR4 W18</td>
<td>DATA4</td>
<td>Y6 GND</td>
<td>L11 PG2</td>
<td>P2 SA10</td>
<td>U19 VDDCTRL</td>
<td>G13</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR5 Y18</td>
<td>DATA5</td>
<td>W6 GND</td>
<td>L12 PG3</td>
<td>N1 SCAS</td>
<td>U20 VDDCTRL</td>
<td>G14</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR6 W17</td>
<td>DATA6</td>
<td>Y5 GND</td>
<td>L13 PG4</td>
<td>N2 SCKE</td>
<td>P20 VDDCTRL</td>
<td>H14</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR7 Y17</td>
<td>DATA7</td>
<td>W5 GND</td>
<td>M9 PG5</td>
<td>L2 SRA5</td>
<td>T19 VDDCTRL</td>
<td>M14</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR8 W16</td>
<td>DATA8</td>
<td>Y4 GND</td>
<td>M10 PG6</td>
<td>M2 SDA</td>
<td>B4 VDDCTRL</td>
<td>K14</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR9 Y16</td>
<td>DATA9</td>
<td>W4 GND</td>
<td>M11 PG7</td>
<td>L1 SMS</td>
<td>R19 VDDCTRL</td>
<td>L14</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR10 W15</td>
<td>DATA10</td>
<td>Y3 GND</td>
<td>M12 PG8</td>
<td>L2 SRA5</td>
<td>T19 VDDCTRL</td>
<td>M14</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR11 Y15</td>
<td>DATA11</td>
<td>W3 GND</td>
<td>M13 PG9</td>
<td>K1 SS/PG</td>
<td>G19 VDDCTRL</td>
<td>N14</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR12 W14</td>
<td>DATA12</td>
<td>Y2 GND</td>
<td>N9 PG10</td>
<td>K2 SWE</td>
<td>T20 VDDCTRL</td>
<td>P12</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR13 Y14</td>
<td>DATA13</td>
<td>W2 GND</td>
<td>N10 PG11</td>
<td>J1 TCK</td>
<td>V2 VDDCTRL</td>
<td>P13</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR14 W13</td>
<td>DATA14</td>
<td>W1 GND</td>
<td>N11 PG12</td>
<td>J2 TDI</td>
<td>R1 VDDCTRL</td>
<td>P14</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR15 Y13</td>
<td>DATA15</td>
<td>V1 GND</td>
<td>N12 PG13</td>
<td>H1 TDO</td>
<td>T1 VDDMEM</td>
<td>L8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR16 W12</td>
<td>EMU</td>
<td>T2 GND</td>
<td>N13 PG14</td>
<td>H2 TMS</td>
<td>U2 VDDMEM</td>
<td>M7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR17 Y12</td>
<td>EXT_WAKE0</td>
<td>J20 GND</td>
<td>Y1 PG15</td>
<td>G1 TRST</td>
<td>U1 VDDMEM</td>
<td>M8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR18 W11</td>
<td>GND</td>
<td>A1 GND</td>
<td>Y20 PH0</td>
<td>A7 USB_DM</td>
<td>F20 VDDMEM</td>
<td>N7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ADDR19 Y11</td>
<td>GND</td>
<td>A17 NMI</td>
<td>B19 PH1</td>
<td>B7 USB_DP</td>
<td>E20 VDDMEM</td>
<td>N8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>AMS0 J19</td>
<td>GND</td>
<td>A20 VPPOTP</td>
<td>L19 PH2</td>
<td>A8 USB_ID</td>
<td>C20 VDDMEM</td>
<td>P7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>AMS1 K19</td>
<td>GND</td>
<td>B20 PF0</td>
<td>F1 PH3</td>
<td>B8 USB_RSET</td>
<td>D20 VDDMEM</td>
<td>P8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>AMS2 M19</td>
<td>GND</td>
<td>H9 PF1</td>
<td>E1 PH4</td>
<td>A9 USB_VBUS</td>
<td>E19 VDDMEM</td>
<td>P9</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>AMS3 L20</td>
<td>GND</td>
<td>H10 PF2</td>
<td>E2 PH5</td>
<td>B9 USB_VREF</td>
<td>H19 VDDMEM</td>
<td>P10</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>AOE N20</td>
<td>GND</td>
<td>H11 PF3</td>
<td>D1 PH6</td>
<td>B10 USB_XI</td>
<td>A19 VDDMEM</td>
<td>P11</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ARDY P19</td>
<td>GND</td>
<td>H12 PF4</td>
<td>D2 PH7</td>
<td>B11 USB_XO</td>
<td>A18 VDDCTRL</td>
<td>R20</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ARE M20</td>
<td>GND</td>
<td>H13 PF5</td>
<td>C1 PH8</td>
<td>A12 VDDCTRL</td>
<td>G7 VDDCTRL</td>
<td>A16</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>AWE N19</td>
<td>GND</td>
<td>J9 PF6</td>
<td>C2 PH9</td>
<td>B12 VDDCTRL</td>
<td>G8 VDDCTRL</td>
<td>D19</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>BMODE0 Y10</td>
<td>GND</td>
<td>J10 PF7</td>
<td>B1 PH10</td>
<td>A13 VDDCTRL</td>
<td>G9 VDDCTRL</td>
<td>G20</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>BMODE1 W10</td>
<td>GND</td>
<td>J11 PF8</td>
<td>B2 PH11</td>
<td>B13 VDDCTRL</td>
<td>G10 VROUT/EXT_WAKE1</td>
<td>H20</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>BMODE2 Y9</td>
<td>GND</td>
<td>J12 PF9</td>
<td>A2 PH12</td>
<td>B14 VDDCTRL</td>
<td>G11 VRSEL/VDDCTRL</td>
<td>F19</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>BMODE3 W9</td>
<td>GND</td>
<td>J13 PF10</td>
<td>B3 PH13</td>
<td>B15 VDDCTRL</td>
<td>H7 XTAL</td>
<td>A10</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLKBUF C19</td>
<td>GND</td>
<td>K9 PF11</td>
<td>A3 PH14</td>
<td>B16 VDDCTRL</td>
<td>H8</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>CLKIN A11</td>
<td>GND</td>
<td>K10 PF12</td>
<td>B5 PH15</td>
<td>B17 VDDCTRL</td>
<td>J7</td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

**NOTE:** In this table, **BOLD TYPE** indicates the sole signal/function for that ball on ADSP-BF522/ADSP-BF524/ADSP-BF526 processors.
### Table 70. 208-Ball CSP_BGA Ball Assignment (Numerically by Ball Number)

<table>
<thead>
<tr>
<th>Ball No.</th>
<th>Signal</th>
<th>Ball No.</th>
<th>Signal</th>
<th>Ball No.</th>
<th>Signal</th>
<th>Ball No.</th>
<th>Signal</th>
<th>Ball No.</th>
<th>Signal</th>
</tr>
</thead>
<tbody>
<tr>
<td>A1</td>
<td>GND</td>
<td>B16</td>
<td>PH14</td>
<td>H7</td>
<td>VDEXT</td>
<td>L2</td>
<td>PG8</td>
<td>P1</td>
<td>PG1</td>
</tr>
<tr>
<td>A2</td>
<td>PF9</td>
<td>B17</td>
<td>PH15</td>
<td>H8</td>
<td>VDEXT</td>
<td>L7</td>
<td>VDEXT</td>
<td>P2</td>
<td>PG2</td>
</tr>
<tr>
<td>A3</td>
<td>PF11</td>
<td>B18</td>
<td>RESET</td>
<td>H9</td>
<td>GND</td>
<td>L8</td>
<td>VDDMEM</td>
<td>P7</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>A4</td>
<td>SCL</td>
<td>B19</td>
<td>NMII</td>
<td>H10</td>
<td>GND</td>
<td>L9</td>
<td>VDDMEM</td>
<td>P8</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>A5</td>
<td>PF13</td>
<td>B20</td>
<td>GND</td>
<td>H11</td>
<td>GND</td>
<td>L10</td>
<td>GND</td>
<td>P9</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>A6</td>
<td>PF15</td>
<td>C1</td>
<td>PF5</td>
<td>H12</td>
<td>GND</td>
<td>L11</td>
<td>GND</td>
<td>P10</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>A7</td>
<td>PH0</td>
<td>C2</td>
<td>PF6</td>
<td>H13</td>
<td>GND</td>
<td>L12</td>
<td>GND</td>
<td>P11</td>
<td>VDDMEM</td>
</tr>
<tr>
<td>A8</td>
<td>PH2</td>
<td>C19</td>
<td>CLKBUF</td>
<td>H14</td>
<td>VDDINT</td>
<td>L13</td>
<td>GND</td>
<td>P12</td>
<td>VDDINT</td>
</tr>
<tr>
<td>A9</td>
<td>PH4</td>
<td>C20</td>
<td>USB_ID</td>
<td>H19</td>
<td>USB_VREF</td>
<td>L14</td>
<td>VDDINT</td>
<td>P13</td>
<td>VDDINT</td>
</tr>
<tr>
<td>A10</td>
<td>XTAL</td>
<td>D1</td>
<td>PF3</td>
<td>H20</td>
<td>VRDEXT</td>
<td>L19</td>
<td>VPPOTP</td>
<td>P14</td>
<td>VDDINT</td>
</tr>
<tr>
<td>A11</td>
<td>CLKIN</td>
<td>D2</td>
<td>PF4</td>
<td>J1</td>
<td>PG11</td>
<td>L20</td>
<td>AMS3</td>
<td>P19</td>
<td>ARDY</td>
</tr>
<tr>
<td>A12</td>
<td>PH8</td>
<td>D19</td>
<td>VDDUSB</td>
<td>J2</td>
<td>PG12</td>
<td>M1</td>
<td>PG5</td>
<td>P20</td>
<td>SCKE</td>
</tr>
<tr>
<td>A13</td>
<td>PH10</td>
<td>D20</td>
<td>USB_RESET</td>
<td>J7</td>
<td>VDEXT</td>
<td>M2</td>
<td>PG6</td>
<td>R1</td>
<td>TDI</td>
</tr>
<tr>
<td>A14</td>
<td>RTXI</td>
<td>E1</td>
<td>PF1</td>
<td>J8</td>
<td>VDEXT</td>
<td>M7</td>
<td>VDDMEM</td>
<td>R2</td>
<td>PG0</td>
</tr>
<tr>
<td>A15</td>
<td>RTXO</td>
<td>E2</td>
<td>PF2</td>
<td>J9</td>
<td>GND</td>
<td>M8</td>
<td>VDDMEM</td>
<td>R19</td>
<td>SMS</td>
</tr>
<tr>
<td>A16</td>
<td>VDDRTC</td>
<td>E19</td>
<td>USB_VBUS</td>
<td>J10</td>
<td>GND</td>
<td>M9</td>
<td>GND</td>
<td>R20</td>
<td>VDDOTP</td>
</tr>
<tr>
<td>A17</td>
<td>GND</td>
<td>E20</td>
<td>USB_DP</td>
<td>J11</td>
<td>GND</td>
<td>M10</td>
<td>GND</td>
<td>T1</td>
<td>TDO</td>
</tr>
<tr>
<td>A18</td>
<td>USB_XO</td>
<td>F1</td>
<td>PF0</td>
<td>J12</td>
<td>GND</td>
<td>M11</td>
<td>GND</td>
<td>T2</td>
<td>EMU</td>
</tr>
<tr>
<td>A19</td>
<td>USB_XI</td>
<td>F2</td>
<td>PPI_FS1/TMR0</td>
<td>J13</td>
<td>GND</td>
<td>M12</td>
<td>GND</td>
<td>T19</td>
<td>SRA0</td>
</tr>
<tr>
<td>A20</td>
<td>GND</td>
<td>F19</td>
<td>VRSEL/VDEXT</td>
<td>J14</td>
<td>VDDINT</td>
<td>M13</td>
<td>GND</td>
<td>T20</td>
<td>SWF</td>
</tr>
<tr>
<td>B1</td>
<td>PF7</td>
<td>F20</td>
<td>USB_DM</td>
<td>J19</td>
<td>AMS50</td>
<td>M14</td>
<td>VDDINT</td>
<td>U1</td>
<td>TRST</td>
</tr>
<tr>
<td>B2</td>
<td>PF8</td>
<td>G1</td>
<td>PG15</td>
<td>J20</td>
<td>EXT_WAKE0</td>
<td>M19</td>
<td>AMS2</td>
<td>U2</td>
<td>TMS</td>
</tr>
<tr>
<td>B3</td>
<td>PF10</td>
<td>G2</td>
<td>PPI_CLK/TMRCLK</td>
<td>K1</td>
<td>PG9</td>
<td>M20</td>
<td>ARE</td>
<td>U19</td>
<td>SA10</td>
</tr>
<tr>
<td>B4</td>
<td>SDA</td>
<td>G7</td>
<td>VDEXT</td>
<td>K2</td>
<td>PG10</td>
<td>N1</td>
<td>PG3</td>
<td>U20</td>
<td>SCAS</td>
</tr>
<tr>
<td>B5</td>
<td>PF12</td>
<td>G8</td>
<td>VDEXT</td>
<td>K7</td>
<td>VDEXT</td>
<td>N2</td>
<td>PG4</td>
<td>V1</td>
<td>DATA15</td>
</tr>
<tr>
<td>B6</td>
<td>PF14</td>
<td>G9</td>
<td>VDEXT</td>
<td>K8</td>
<td>VDEXT</td>
<td>N7</td>
<td>VDDMEM</td>
<td>V2</td>
<td>TCK</td>
</tr>
<tr>
<td>B7</td>
<td>PH1</td>
<td>G10</td>
<td>VDEXT</td>
<td>K9</td>
<td>GND</td>
<td>N8</td>
<td>VDDMEM</td>
<td>V19</td>
<td>ABE0/SDQM0</td>
</tr>
<tr>
<td>B8</td>
<td>PH3</td>
<td>G11</td>
<td>VDEXT</td>
<td>K10</td>
<td>GND</td>
<td>N9</td>
<td>VDDMEM</td>
<td>V19</td>
<td>ABET/SDQM1</td>
</tr>
<tr>
<td>B9</td>
<td>PH5</td>
<td>G12</td>
<td>VDDINT</td>
<td>K11</td>
<td>GND</td>
<td>N10</td>
<td>GND</td>
<td>W1</td>
<td>DATA14</td>
</tr>
<tr>
<td>B10</td>
<td>PH6</td>
<td>G13</td>
<td>VDDINT</td>
<td>K12</td>
<td>GND</td>
<td>N11</td>
<td>GND</td>
<td>W2</td>
<td>DATA13</td>
</tr>
<tr>
<td>B11</td>
<td>PH7</td>
<td>G14</td>
<td>VDDINT</td>
<td>K13</td>
<td>GND</td>
<td>N12</td>
<td>GND</td>
<td>W3</td>
<td>DATA11</td>
</tr>
<tr>
<td>B12</td>
<td>PH9</td>
<td>G19</td>
<td>SS/PG</td>
<td>K14</td>
<td>VDDINT</td>
<td>N13</td>
<td>GND</td>
<td>W4</td>
<td>DATA9</td>
</tr>
<tr>
<td>B13</td>
<td>PH11</td>
<td>G20</td>
<td>VDDUSB</td>
<td>K19</td>
<td>AMS5</td>
<td>N14</td>
<td>VDDINT</td>
<td>W5</td>
<td>DATA7</td>
</tr>
<tr>
<td>B14</td>
<td>PH12</td>
<td>H1</td>
<td>PG13</td>
<td>K20</td>
<td>CLKOUT</td>
<td>N19</td>
<td>AWE</td>
<td>W6</td>
<td>DATA5</td>
</tr>
<tr>
<td>B15</td>
<td>PH13</td>
<td>H2</td>
<td>PG14</td>
<td>L1</td>
<td>PG7</td>
<td>N20</td>
<td>AOE</td>
<td>W7</td>
<td>DATA3</td>
</tr>
</tbody>
</table>

**NOTE:** In this table, **BOLD TYPE** indicates the sole signal/function for that ball on ADSP-BF522/ADSP-BF524/ADSP-BF526 processors.
Figure 78 shows the top view of the CSP_BGA ball configuration. Figure 79 shows the bottom view of the CSP_BGA ball configuration.
OUTLINE DIMENSIONS

Dimensions in the outline dimension figures (Figure 80 and Figure 81) are shown in millimeters.

---

*COMPLIANT WITH JEDEC STANDARD MO-275-GGCE-1

---

*COMPLIANT TO JEDEC STANDARDS MO-275-MMAB-1 WITH EXCEPTION TO PACKAGE HEIGHT AND THICKNESS.

---

Rev. D | Page 86 of 88 | July 2013
SURFACE-MOUNT DESIGN

Table 71 is provided as an aid to PCB design. For industry-standard design recommendations, refer to IPC-7351, Generic Requirements for Surface Mount Design and Land Pattern Standard.

Table 71. Surface-Mount Design Supplement

<table>
<thead>
<tr>
<th>Package</th>
<th>Package Ball Attach Type</th>
<th>Package Solder Mask Opening</th>
<th>Package Ball Pad Size</th>
</tr>
</thead>
<tbody>
<tr>
<td>289-Ball CSP_BGA</td>
<td>Solder Mask Defined</td>
<td>0.26 mm diameter</td>
<td>0.35 mm diameter</td>
</tr>
<tr>
<td>208-Ball CSP_BGA</td>
<td>Solder Mask Defined</td>
<td>0.40 mm diameter</td>
<td>0.50 mm diameter</td>
</tr>
</tbody>
</table>

AUTOMOTIVE PRODUCTS

The ADBF525W model is available with controlled manufacturing to support the quality and reliability requirements of automotive applications. Note that these automotive models may have specifications that differ from the commercial models and designers should review the product Specifications section of this data sheet carefully. Only the automotive grade products shown in Table 72 are available for use in automotive applications. Contact your local ADI account representative for specific product ordering information and to obtain the specific automotive Reliability reports for these models.

Table 72. Automotive Products

<table>
<thead>
<tr>
<th>Automotive Models1, 2</th>
<th>Temperature Range3</th>
<th>Package Description</th>
<th>Package Option</th>
<th>Instruction Rate (Max)</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADBF525WBBBCZ4xx</td>
<td>–40°C to +85°C</td>
<td>208-Ball CSP_BGA</td>
<td>BC-208-2</td>
<td>400 MHz</td>
</tr>
<tr>
<td>ADBF525WBBBCZ5xx</td>
<td>–40°C to +85°C</td>
<td>208-Ball CSP_BGA</td>
<td>BC-208-2</td>
<td>533 MHz</td>
</tr>
<tr>
<td>ADBF525WYBCZxxxx</td>
<td>–40°C to +105°C</td>
<td>208-Ball CSP_BGA</td>
<td>BC-208-2</td>
<td>For product details, please contact your ADI account representative.</td>
</tr>
</tbody>
</table>

1 Z = RoHS Compliant Part.
2 The information indicated by x in the model number will be provided by your ADI account representative.
3 Referenced temperature is ambient temperature. The ambient temperature is not a specification. Please see Operating Conditions for ADSP-BF523/ADSP-BF525/ADSP-BF527 Processors on Page 30 for junction temperature (Tj) specification which is the only temperature specification.
### ORDERING GUIDE

<table>
<thead>
<tr>
<th>Model</th>
<th>Temperature Range</th>
<th>Instruction Rate (Max)</th>
<th>Package Description</th>
<th>Package Option</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADSP-BF522BBCZ-3A</td>
<td>-40°C to +85°C</td>
<td>300 MHz</td>
<td>208-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-208-2</td>
</tr>
<tr>
<td>ADSP-BF522BBCZ-4A</td>
<td>-40°C to +85°C</td>
<td>400 MHz</td>
<td>208-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-208-2</td>
</tr>
<tr>
<td>ADSP-BF522KBCZ-3</td>
<td>0°C to +70°C</td>
<td>300 MHz</td>
<td>289-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-289-2</td>
</tr>
<tr>
<td>ADSP-BF522KBCZ-4</td>
<td>0°C to +70°C</td>
<td>400 MHz</td>
<td>289-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-289-2</td>
</tr>
<tr>
<td>ADSP-BF523BBCZ-5A</td>
<td>-40°C to +85°C</td>
<td>533 MHz</td>
<td>208-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-208-2</td>
</tr>
<tr>
<td>ADSP-BF523KBCZ-5</td>
<td>0°C to +70°C</td>
<td>533 MHz</td>
<td>289-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-289-2</td>
</tr>
<tr>
<td>ADSP-BF523KBCZ-6</td>
<td>0°C to +70°C</td>
<td>600 MHz</td>
<td>289-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-289-2</td>
</tr>
<tr>
<td>ADSP-BF523KBCZ-6A</td>
<td>0°C to +70°C</td>
<td>600 MHz</td>
<td>208-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-208-2</td>
</tr>
<tr>
<td>ADSP-BF524BBCZ-3A</td>
<td>-40°C to +85°C</td>
<td>300 MHz</td>
<td>208-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-208-2</td>
</tr>
<tr>
<td>ADSP-BF524BBCZ-4A</td>
<td>-40°C to +85°C</td>
<td>400 MHz</td>
<td>208-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-208-2</td>
</tr>
<tr>
<td>ADSP-BF525KBCZ-3</td>
<td>0°C to +70°C</td>
<td>300 MHz</td>
<td>289-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-289-2</td>
</tr>
<tr>
<td>ADSP-BF525KBCZ-4</td>
<td>0°C to +70°C</td>
<td>400 MHz</td>
<td>289-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-289-2</td>
</tr>
<tr>
<td>ADSP-BF525KBCZ-5</td>
<td>0°C to +70°C</td>
<td>600 MHz</td>
<td>289-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-289-2</td>
</tr>
<tr>
<td>ADSP-BF525KBCZ-6</td>
<td>0°C to +70°C</td>
<td>600 MHz</td>
<td>208-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-208-2</td>
</tr>
<tr>
<td>ADSP-BF526BBCZ-3A</td>
<td>-40°C to +85°C</td>
<td>300 MHz</td>
<td>208-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-208-2</td>
</tr>
<tr>
<td>ADSP-BF526BBCZ-4A</td>
<td>-40°C to +85°C</td>
<td>400 MHz</td>
<td>208-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-208-2</td>
</tr>
<tr>
<td>ADSP-BF527BBCZ-5A</td>
<td>-40°C to +85°C</td>
<td>533 MHz</td>
<td>208-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-208-2</td>
</tr>
<tr>
<td>ADSP-BF527KBCZ-5</td>
<td>0°C to +70°C</td>
<td>533 MHz</td>
<td>289-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-289-2</td>
</tr>
<tr>
<td>ADSP-BF527KBCZ-6</td>
<td>0°C to +70°C</td>
<td>600 MHz</td>
<td>289-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-289-2</td>
</tr>
<tr>
<td>ADSP-BF527KBCZ-6A</td>
<td>0°C to +70°C</td>
<td>600 MHz</td>
<td>208-Ball Chip Scale Package Ball Grid Array (CSP_BGA)</td>
<td>BC-208-2</td>
</tr>
</tbody>
</table>

1 Z = RoHS Compliant Part.

2 Referenced temperature is ambient temperature. The ambient temperature is not a specification. Please see Operating Conditions for ADSP-BF522/ADSP-BF524/ADSP-BF526 Processors on Page 28 and Operating Conditions for ADSP-BF523/ADSP-BF525/ADSP-BF527 Processors on Page 30 for junction temperature (TJ) specification which is the only temperature specification.