Welcome to **E-XFL.COM** # Understanding <u>Embedded - FPGAs (Field Programmable Gate Array)</u> Embedded - FPGAs, or Field Programmable Gate Arrays, are advanced integrated circuits that offer unparalleled flexibility and performance for digital systems. Unlike traditional fixed-function logic devices, FPGAs can be programmed and reprogrammed to execute a wide array of logical operations, enabling customized functionality tailored to specific applications. This reprogrammability allows developers to iterate designs quickly and implement complex functions without the need for custom hardware. ## **Applications of Embedded - FPGAs** The versatility of Embedded - FPGAs makes them indispensable in numerous fields. In telecommunications. | Details | | |--------------------------------|------------------------------------------------------------------------------| | Product Status | Obsolete | | Number of LABs/CLBs | 256 | | Number of Logic Elements/Cells | 2048 | | Total RAM Bits | 81920 | | Number of I/O | 12 | | Number of Gates | - | | Voltage - Supply | 1.14V ~ 1.26V | | Mounting Type | Surface Mount | | Operating Temperature | -40°C ~ 100°C (TJ) | | Package / Case | 20-UFBGA, WLCSP | | Supplier Device Package | 20-WLCSP (1.71x2.06) | | Purchase URL | https://www.e-xfl.com/product-detail/lattice-semiconductor/ice5lp2k-uwg20itr | Email: info@E-XFL.COM Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong ## iCE40 Ultra Family Data Sheet Architecture June 2016 Data Sheet DS1048 ## **Architecture Overview** The iCE40 Ultra family architecture contains an array of Programmable Logic Blocks (PLB), two Oscillator Generators, two user configurable I<sup>2</sup>C controllers, two user configurable SPI controllers, and blocks of sysMEM<sup>™</sup> Embedded Block RAM (EBR) surrounded by Programmable I/O (PIO). Figure 2-1shows the block diagram of the iCE5LP-4K device. Figure 2-1. iCE5LP-4K Device, Top View The Programmable Logic Blocks (PLB) and sysMEM EBR blocks, are arranged in a two-dimensional grid with rows and columns. Each column has either PLB or EBR blocks. The PIO cells are located at the top and bottom of the device, arranged in banks. The PLB contains the building blocks for logic, arithmetic, and register functions. The PIOs utilize a flexible I/O buffer referred to as a sysIO buffer that supports operation with a variety of interface standards. The blocks are connected with many vertical and horizontal routing channel resources. The place and route software tool automatically allocates these routing resources. In the iCE40 Ultra family, there are three sysIO banks, one on top and two at the bottom. User can connect some $V_{\text{CCIOS}}$ together, if all the I/Os are using the same voltage standard. Refer to the details in later sections of this document on Power Up Sequence. The sysMEM EBRs are large 4 kbit, dedicated fast memory blocks. These blocks can be configured as RAM, ROM or FIFO with user logic using PLBs. Every device in the family has two user SPI ports, one of these (right side) SPI port also supports programming and configuration of the device. The iCE40 Ultra also includes two user I<sup>2</sup>C ports, two Oscillators, and high current RGB and IR LED sinks. © 2016 Lattice Semiconductor Corp. All Lattice trademarks, registered trademarks, patents, and disclaimers are as listed at www.latticesemi.com/legal. All other brand or product names are trademarks or registered trademarks of their respective holders. The specifications and information herein are subject to change without notice. ## Routing There are many resources provided in the iCE40 Ultra devices to route signals individually with related control signals. The routing resources consist of switching circuitry, buffers and metal interconnect (routing) segments. The inter-PLB connections are made with three different types of routing resources: Adjacent (spans two PLBs), x4 (spans five PLBs) and x12 (spans thirteen PLBs). The Adjacent, x4 and x12 connections provide fast and efficient connections in the diagonal, horizontal and vertical directions. The design tool takes the output of the synthesis tool and places and routes the design. ### **Clock/Control Distribution Network** Each iCE40 Ultra device has six global inputs, two pins on the top bank and four pins on the bottom bank These global inputs can be used as high fanout nets, clock, reset or enable signals. The dedicated global pins are identified as Gxx and each drives one of the eight global buffers. The global buffers are identified as GBUF[7:0]. These six inputs may be used as general purpose I/O if they are not used to drive the clock nets. Table 2-2 lists the connections between a specific global buffer and the inputs on a PLB. All global buffers optionally connect to the PLB CLK input. Any four of the eight global buffers can drive logic inputs to a PLB. Even-numbered global buffers optionally drive the Set/Reset input to a PLB. Similarly, odd-numbered buffers optionally drive the PLB clock-enable input. GBUF[7:6, 3:0] can connect directly to G[7:6, 3:0] pins respectively. GBUF4 and GBUF5 can connect to the two on-chip Oscillator Generators (GBUF4 connects to LFOSC, GBUF5 connects to HFOSC). Table 2-2. Global Buffer (GBUF) Connections to Programmable Logic Blocks | Global Buffer | LUT Inputs | Clock | Clock Enable | Reset | |---------------|-----------------|-------|--------------|-------| | GBUF0 | | ✓ | ✓ | | | GBUF1 | | ✓ | | ✓ | | GBUF2 | | ✓ | ✓ | | | GBUF3 | Yes, any 4 of 8 | ✓ | | ✓ | | GBUF4 | GBUF Inputs | ✓ | ✓ | | | GBUF5 | | ✓ | | ✓ | | GBUF6 | | ✓ | ✓ | | | GBUF7 | | ✓ | | ✓ | The maximum frequency for the global buffers are shown in the iCE40 Ultra External Switching Characteristics tables later in this document. #### **Global Hi-Z Control** The global high-impedance control signal, GHIZ, connects to all I/O pins on the iCE40 Ultra device. This GHIZ signal is automatically asserted throughout the configuration process, forcing all user I/O pins into their high-impedance state. #### **Global Reset Control** The global reset control signal connects to all PLB and PIO flip-flops on the iCE40 Ultra device. The global reset signal is automatically asserted throughout the configuration process, forcing all flip-flops to their defined wake-up state. For PLB flip-flops, the wake-up state is always reset, regardless of the PLB flip-flop primitive used in the application. ## Table 2-3. PLL Signal Descriptions | Signal Name | Direction | Description | |-------------------|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | REFERENCECLK | Input | Input reference clock | | BYPASS | Input | The BYPASS control selects which clock signal connects to the PLL-OUT output. 0 = PLL generated signal 1 = REFERENCECLK | | EXTFEEDBACK | Input | External feedback input to PLL. Enabled when the FEEDBACK_PATH attribute is set to EXTERNAL. | | DYNAMICDELAY[7:0] | Input | Fine delay adjustment control inputs. Enabled when DELAY_ADJUSTMENT_MODE is set to DYNAMIC. | | LATCHINPUTVALUE | Input | When enabled, puts the PLL into low-power mode; PLL output is held static at the last input clock value. Set ENABLE ICEGATE_PORTA and PORTB to '1' to enable. | | PLLOUTGLOBAL | Output | Output from the Phase-Locked Loop (PLL). Drives a global clock network on the FPGA. The port has optimal connections to global clock buffers GBUF4 and GBUF5. | | PLLOUTCORE | Output | Output clock generated by the PLL, drives regular FPGA routing. The frequency generated on this output is the same as the frequency of the clock signal generated on the PLLOUTLGOBAL port. | | LOCK | Output | When High, indicates that the PLL output is phase aligned or locked to the input reference clock. | | RESET | Input | Active low reset. | | SCLK | Input | Input, Serial Clock used for re-programming PLL settings. | | SDI | Input | Input, Serial Data used for re-programming PLL settings. | ## sysMEM Embedded Block RAM Memory Larger iCE40 Ultra device includes multiple high-speed synchronous sysMEM Embedded Block RAMs (EBRs), each 4 kbit in size. This memory can be used for a wide variety of purposes including data buffering, and FIFO. ## sysMEM Memory Block The sysMEM block can implement single port, pseudo dual port, or FIFO memories with programmable logic resources. Each block can be used in a variety of depths and widths as shown in Table 2-4. ## Table 2-4. sysMEM Block Configurations<sup>1</sup> | Block RAM<br>Configuration | Block RAM<br>Configuration<br>and Size | WADDR Port<br>Size (Bits) | WDATA Port<br>Size (Bits) | RADDR Port<br>Size (Bits) | RDATA Port<br>Size (Bits) | MASK Port<br>Size (Bits) | |----------------------------------------------------------------------|----------------------------------------|---------------------------|---------------------------|---------------------------|---------------------------|--------------------------| | SB_RAM256x16<br>SB_RAM256x16NR<br>SB_RAM256x16NW<br>SB_RAM256x16NRNW | 256x16 (4 k) | 8 [7:0] | 16 [15:0] | 8 [7:0] | 16 [15:0] | 16 [15:0] | | SB_RAM512x8<br>SB_RAM512x8NR<br>SB_RAM512x8NW<br>SB_RAM512x8NRNW | 512x8 (4 k) | 9 [8:0] | 8 [7:0] | 9 [8:0] | 8 [7:0] | No Mask Port | | SB_RAM1024x4<br>SB_RAM1024x4NR<br>SB_RAM1024x4NW<br>SB_RAM1024x4NRNW | 1024x4 (4 k) | 10 [9:0] | 4 [3:0] | 10 [9:0] | 4 [3:0] | No Mask Port | | SB_RAM2048x2<br>SB_RAM2048x2NR<br>SB_RAM2048x2NW<br>SB_RAM2048x2NRNW | 2048x2 (4 k) | 11 [10:0] | 2 [1:0] | 11 [10:0] | 2 [1:0] | No Mask Port | <sup>1.</sup> For iCE40 Ultra, the primitive name without "Nxx" uses rising-edge Read and Write clocks. "NR" uses rising-edge Write clock, falling-edge Read clock. "NRW" uses falling-edge Write clock and rising-edge Read clock. "NRNW" uses falling-edge clocks on both Read and Write. #### RAM Initialization and ROM Operation If desired, the contents of the RAM can be pre-loaded during device configuration. By preloading the RAM block during the chip configuration cycle and disabling the write controls, the sysMEM block can also be utilized as a ROM. #### **Memory Cascading** Larger and deeper blocks of RAM can be created using multiple EBR sysMEM Blocks. #### **RAM4k Block** Figure 2-4 shows the 256x16 memory configurations and their input/output names. In all the sysMEM RAM modes, the input data and addresses for the ports are registered at the input of the memory array. Figure 2-4. sysMEM Memory Primitives Table 2-5. EBR Signal Descriptions | Signal Name | Direction | Description | |-------------|-----------|--------------------------------------------------------------------------------------------| | WDATA[15:0] | Input | Write Data input. | | MASK[15:0] | Input | Masks write operations for individual data bit-lines. 0 = write bit 1 = do not write bit | | WADDR[7:0] | Input | Write Address input. Selects one of 256 possible RAM locations. | | WE | Input | Write Enable input. | | WCLKE | Input | Write Clock Enable input. | | WCLK | Input | Write Clock input. Default rising-edge, but with falling-edge option. | | RDATA[15:0] | Output | Read Data output. | | RADDR[7:0] | Input | Read Address input. Selects one of 256 possible RAM locations. | | RE | Input | Read Enable input. | | RCLKE | Input | Read Clock Enable input. | | RCLK | Input | Read Clock input. Default rising-edge, but with falling-edge option. | For further information on the sysMEM EBR block, please refer to TN1250, Memory Usage Guide for iCE40 Devices. ## sysDSP The iCE40 Ultra family provides an efficient sysDSP architecture that is very suitable for low-cost Digital Signal Processing (DSP) functions for mobile applications. Typical functions used in these applications are Multiply, Accumulate, and Multiply-Accumulate. The block can also be used for simple Add and Subtract functions. #### iCE40 Ultra sysDSP Architecture Features The iCE40 Ultra sysDSP supports many functions that include the following: - Single 16-bit x 16-bit Multiplier, or two independent 8-bit x 8-bit Multipliers - Optional independent pipeline control on Input Register, Output Register, and Intermediate Reg faster clock performance - Single 32-bit Accumulator, or two independent 16-bit Accumulators - Single 32-bit, or two independent 16-bit Adder/Subtracter functions, registered or asynchronous - · Cascadable to create wider Accumulator blocks Figure 2-5 shows the block diagram of the sysDSP block. The block consists Multiplier section, with an bypassable Output register. The Input Register, Intermediate register between Multiplier and AC timing to achieve the highest performance. Figure 2-5. sysDSP Functional Block Diagram (16-bit x 16-bit Multiply-Accumulate) Figure 2-7. DSP 16-bit x 16-bit Multiplier #### Typical I/O Behavior During Power-up The internal power-on-reset (POR) signal is deactivated when $V_{CC}$ , $SPI\_V_{CCIO1}$ , and $V_{PP\_2V5}$ reach the level defined in the Power-On-Reset Voltage table in the DC and Switching Characteristics section of this data sheet. After the POR signal is deactivated, the FPGA core logic becomes active. You must ensure that all $V_{CCIO}$ banks are active with valid input logic levels to properly control the output logic states of all the I/O banks that are critical to the application. The default configuration of the I/O pins in a device prior to configuration is tri-stated with a weak pull-up to $V_{CCIO}$ . The I/O pins maintain the pre-configuration state until $V_{CC}$ , $SPI\_V_{CCIO1}$ , and $V_{PP\_2V5}$ reach the defined levels. The I/Os take on the software user-configured settings only after POR signal is deactivated and the device performs a proper download/configuration. Unused I/Os are automatically blocked and the pull-up termination is disabled. #### **Supported Standards** The iCE40 Ultra sysIO buffer supports both single-ended input/output standards, and used as differential comparators. The buffer supports the LVCMOS 1.8, 2.5, and 3.3 V standards. The buffer has individually configurable options for bus maintenance (weak pull-up or none). Table 2-8 and Table 2-9 show the I/O standards (together with their supply and reference voltages) supported by the iCE40 Ultra devices. #### **Differential Comparators** The iCE40 Ultra devices provide differential comparator on pairs of I/O pins. These comparators are useful in some mobile applications. Please refer to the Pin Information Summary section to locate the corresponding paired I/Os with differential comparators. Table 2-8. Supported Input Standards | Input Standard | V <sub>CCIO</sub> (Typical) | | | | | |-------------------------|-----------------------------|-------|-------|--|--| | input Standard | 3.3 V | 2.5 V | 1.8 V | | | | Single-Ended Interfaces | • | • | • | | | | LVCMOS33 | ✓ | | | | | | LVCMOS25 | | ✓ | | | | | LVCMOS18 | | | ✓ | | | Table 2-9. Supported Output Standards | Output Standard | V <sub>CCIO</sub> (Typical) | |-------------------------|-----------------------------| | Single-Ended Interfaces | | | LVCMOS33 | 3.3 V | | LVCMOS25 | 2.5 V | | LVCMOS18 | 1.8 V | ## **On-Chip Oscillator** The iCE40 Ultra devices feature two different frequency Oscillator. One is tailored for low-power operation that runs at low frequency (LFOSC). Both Oscillators are controlled with internally generated current. The LFOSC runs at nominal frequency of 10 kHz. The high frequency oscillator (HFOSC) runs at a nominal frequency of 48 MHz, divisible to 24 MHz, 12 MHz, or 6 MHz by user option. The LFOSC can be used to perform all always-on functions, with the lowest power possible. The HFOSC can be enabled when the always-on functions detect a condition that would need to wake up the system to perform higher frequency functions. ## User I<sup>2</sup>C IP The iCE40 Ultra devices have two I<sup>2</sup>C IP cores. Either of the two cores can be configured either as an I<sup>2</sup>C master or as an I<sup>2</sup>C slave. The pins for the I<sup>2</sup>C interface are not pre-assigned. User can use any General Purpose I/O pins. In each of the two cores, there are options to delay the either the input or the output, or both, by 50 ns nominal, using dedicated on-chip delay elements. This provides an easier interface with any external I<sup>2</sup>C components. When the IP core is configured as master, it will be able to control other devices on the I<sup>2</sup>C bus through the preassigned pin interface. When the core is configured as the slave, the device will be able to provide I/O expansion to an I<sup>2</sup>C Master. The I<sup>2</sup>C cores support the following functionality: - Master and Slave operation - · 7-bit and 10-bit addressing - Multi-master arbitration support - · Clock stretching - · Up to 400 kHz data transfer speed - · General Call support - Optionally delaying input or output data, or both For further information on the User I<sup>2</sup>C, please refer to TN1274, iCE40 SPI/I2C Hardened IP Usage Guide. #### **User SPI IP** The iCE40 Ultra devices have two SPI IP cores. The pins for the SPI interface are not pre-assigned. User can use any General Purpose I/O pins. Both SPI IP cores can be configured as a SPI master or as a slave. When the SPI IP core is configured as a master, it controls the other SPI enabled devices connected to the SPI Bus. When SPI IP core is configured as a slave, the device will be able to interface to an external SPI master. The SPI IP core supports the following functions: - · Configurable Master and Slave modes - Full-Duplex data transfer - Mode fault error flag with CPU interrupt capability - · Double-buffered data register - · Serial clock with programmable polarity and phase - · LSB First or MSB First Data Transfer For further information on the User SPI, please refer to TN1274, iCE40 SPI/I2C Hardened IP Usage Guide. ## **High Current LED Drive I/O Pins** The iCE40 Ultra family devices offer multiple high current LED drive outputs in each device in the family to allow the iCE40 Ultra product to drive LED signals directly on mobile applications. There are three outputs on each device that can sink up to 24 mA current. These outputs are open-drain outputs, and provides sinking current to an LED connecting to the positive supply. These three outputs are designed to drive the RBG LEDs, such as the service LED found in a lot of mobile devices. An embedded RGB PWM IP is also offered in the family. This RGB drive current is user programmable from 4 mA to 24 mA, in increments of 4 mA. This output functions as General Purpose I/O with open-drain when the high current LED drive is not needed. There is one output on each device that can sink up to 500 mA current. This output is open-drain, and provides sinking current to drive an external IR LED connecting to the positive supply. This IR drive current is user programmable from 50 mA to 500 mA in increments of 50 mA. This output functions as General Purpose I/O with open-drain when the high current LED drive is not needed. #### **Embedded PWM IP** To provide an easier usage of the RGB high current drivers to drive RGB LED, a Pulse-Width Modulator IP can be embedded into the user design. This PWM IP provides the flexibility for user to dynamically change the settings on the ON-time duration, OFF-time duration, and ability to turn the LED lights on and off gradually with user set breath-on and breath-off time. For additional information on the embedded PWM IP, please refer to TN1288, iCE40 LED Driver Usage Guide. ## **Non-Volatile Configuration Memory** All iCE40 Ultra devices provide a Non-Volatile Configuration Memory (NVCM) block which can be used to configure the device. For more information on the NVCM, please refer to TN1248, iCE40 Programming and Configuration. ## iCE40 Ultra Programming and Configuration This section describes the programming and configuration of the iCE40 Ultra family. ## **Device Programming** The NVCM memory can be programmed through the SPI port. The SPI port is located in Bank 1, using $SPI_{CCIO1}$ power supply. ## **Device Configuration** There are various ways to configure the Configuration RAM (CRAM), using SPI port, including: - From a SPI Flash (Master SPI mode) - System microprocessor to drive a Serial Slave SPI port (SSPI mode) For more details on configuring the iCE40 Ultra, please see TN1248, iCE40 Programming and Configuration. ## **Power Saving Options** The iCE40 Ultra devices feature iCEGate and PLL low power mode to allow users to meet the static and dynamic power requirements of their applications. Table 2-10 describes the function of these features. Table 2-10. iCE40 Ultra Power Saving Features Description | Device Subsystem | Feature Description | |------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | IPLI | When LATCHINPUTVALUE is enabled, puts the PLL into low-power mode; PLL output held static at last input clock value. | | iCEGate | To save power, the optional iCEGate latch can selectively freeze the state of individual, non-registered inputs within an I/O bank. Registered inputs are effectively frozen by their associated clock or clock-enable control. | # iCE40 Ultra Family Data Sheet DC and Switching Characteristics June 2016 Data Sheet DS1048 ## **Absolute Maximum Ratings**<sup>1, 2, 3</sup> | Supply Voltage V <sub>CC</sub> | V | |-------------------------------------------------------|---| | Output Supply Voltage V <sub>CCIO</sub> | V | | NVCM Supply Voltage V <sub>PP_2V5</sub> | ٧ | | PLL Supply Voltage V <sub>CCPLL</sub> 0.5 V to 1.42 \ | V | | I/O Tri-state Voltage Applied0.5 V to 3.60 \ | V | | Dedicated Input Voltage Applied | V | | Storage Temperature (Ambient)—65 °C to 150 °C | С | | Junction Temperature (T <sub>J</sub> ) | С | <sup>1.</sup> Stress above those listed under the "Absolute Maximum Ratings" may cause permanent damage to the device. Functional operation of the device at these or any other conditions above those indicated in the operational sections of this specification is not implied. ## Recommended Operating Conditions<sup>1</sup> | Symbol | Parameter | | Min. | Max. | Units | |--------------------------------------|-------------------------------------------|--------------------------------------------------------------------|--------|-------|-------| | V <sub>CC</sub> <sup>1</sup> | Core Supply Voltage | | 1.14 | 1.26 | V | | | | Slave SPI Configuration | 1.71 4 | 3.46 | V | | N/ | VPP_2V5 NVCM Programming and | Master SPI Configuration | 2.30 | 3.46 | V | | V <sub>PP_2V5</sub> | Operating Supply Voltage | Configuration from NVCM | 2.30 | 3.46 | V | | | | NVCM Programming | 2.30 | 3.00 | V | | V <sub>CCIO</sub> <sup>1, 2, 3</sup> | I/O Driver Supply Voltage | V <sub>CCIO_0</sub> , SPI_V <sub>CCIO1</sub> , V <sub>CCIO_2</sub> | 1.71 | 3.46 | V | | V <sub>CCPLL</sub> | PLL Supply Voltage | | 1.14 | 1.26 | V | | t <sub>JCOM</sub> | Junction Temperature Commercial Operation | | 0 | 85 | °C | | t <sub>JIND</sub> | Junction Temperature Industrial Operation | | -40 | 100 | °C | | t <sub>PROG</sub> | Junction Temperature N | VCM Programming | 10.00 | 30.00 | °C | Like power supplies must be tied together if they are at the same supply voltage and they meet the power up sequence requirement. Please refer to Power-Up Supply Sequencing section. V<sub>CC</sub> and V<sub>CCPLL</sub> are recommended to tie to same supply with an RC-based noise filter between them. Please refer to TN1252, iCE40 Hardware Checklist. ## Power Supply Ramp Rates<sup>1, 2</sup> | Symbol | Parameter | Min. | Max. | Units | |-------------------|-------------------------------------------------|------|------|-------| | t <sub>RAMP</sub> | Power supply ramp rates for all power supplies. | 0.6 | 10 | V/ms | <sup>1.</sup> Assumes monotonic ramp rates. <sup>2.</sup> Compliance with the Lattice Thermal Management document is required. <sup>3.</sup> All voltages referenced to GND. <sup>2.</sup> See recommended voltages by I/O standard in subsequent table. <sup>3.</sup> $V_{CCIO}$ pins of unused I/O banks should be connected to the $V_{CC}$ power supply on boards. V<sub>PP\_2V5</sub> can, optionally, be connected to a 1.8 V (+/-5%) power supply in Slave SPI Configuration mode subject to the condition that none of the HFOSC/LFOSC and RGB LED / IR LED driver features are used. Otherwise, V<sub>PP\_2V5</sub> must be connected to a power supply with a minimum 2.30 V level. <sup>2.</sup> Power up sequence must be followed. Please refer to Power-Up Supply Sequencing section. Figure 3-2. Power Up Sequence with All Supplies Connected Together ## Power-On-Reset Voltage Levels<sup>1</sup> | Symbol | Parameter | | Min. | Max. | Units | |-------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------|------------------------|------|------|-------| | V <sub>PORUP</sub> Power-On-Reset ramp-up trip point (circuit monitoring V <sub>CC</sub> , SPI_V <sub>CCIO1</sub> , V <sub>PP_2V5</sub> ) | | V <sub>CC</sub> | 0.62 | 0.92 | V | | | SPI_V <sub>CCIO1</sub> | 0.87 | 1.50 | V | | | | *CC; 0: 1_ *CCIO1, *PP_2V5/ | V <sub>PP_2V5</sub> | 0.90 | 1.53 | V | | V <sub>PORDN</sub> | Power-On-Reset ramp-down trip point (circuit monitoring $V_{CC}$ , $SPI\_V_{CCIO1}$ , $V_{PP\_2V5}$ ) | V <sub>CC</sub> | _ | 0.79 | V | | | | SPI_V <sub>CCIO1</sub> | _ | 1.50 | V | | | | V <sub>PP_2V5</sub> | _ | 1.53 | V | <sup>1.</sup> These POR trip points are only provided for guidance. Device operation is only characterized for power supply voltages specified under recommended operating conditions. ## **ESD Performance** Please contact Lattice Semiconductor for additional information. ## **DC Electrical Characteristics** #### **Over Recommended Operating Conditions** | Symbol | Parameter | Condition | Min. | Тур. | Max. | Units | |-----------------------------------------------------|-----------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|------|------|-------|-------| | I <sub>IL,</sub> I <sub>IH</sub> <sup>1, 3, 4</sup> | Input or I/O Leakage | $0V < V_{IN} < V_{CCIO} + 0.2 V$ | _ | _ | +/-10 | μΑ | | C <sub>1</sub> | I/O Capacitance, excluding LED Drivers <sup>2</sup> | $V_{CCIO} = 3.3 \text{ V}, 2.5 \text{ V}, 1.8 \text{ V}$<br>$V_{CC} = \text{Typ.}, V_{IO} = 0 \text{ to } V_{CCIO} + 0.2 \text{ V}$ | _ | 6 | _ | pF | | C <sub>2</sub> | Global Input Buffer<br>Capacitance <sup>2</sup> | $V_{CCIO} = 3.3 \text{ V}, 2.5 \text{ V}, 1.8 \text{ V}$<br>$V_{CC} = \text{Typ.}, V_{IO} = 0 \text{ to } V_{CCIO} + 0.2 \text{ V}$ | _ | 6 | _ | pF | | C <sub>3</sub> | RGB Pin Capacitance <sup>2</sup> | $V_{CC} = Typ., V_{IO} = 0 \text{ to } 3.5 \text{ V}$ | _ | 15 | _ | pF | | C <sub>4</sub> | IRLED Pin Capacitance <sup>2</sup> | $V_{CC} = Typ., V_{IO} = 0 \text{ to } 3.5 \text{ V}$ | _ | 53 | _ | pF | | V <sub>HYST</sub> | Input Hysteresis | V <sub>CCIO</sub> = 1.8 V, 2.5 V, 3.3 V | _ | 200 | _ | mV | | | Internal DIO Dull on | $V_{CCIO} = 1.8 \text{ V}, 0 = < V_{IN} < = 0.65 V_{CCIO}$ | -3 | _ | -31 | μΑ | | $I_{PU}$ | Internal PIO Pull-up<br>Current | $V_{CCIO} = 2.5 \text{ V}, 0 = < V_{IN} < = 0.65 V_{CCIO}$ | -8 | _ | -72 | μΑ | | | | $V_{CCIO} = 3.3 \text{ V}, 0 = < V_{IN} < = 0.65 V_{CCIO}$ | -11 | _ | -128 | μΑ | <sup>1.</sup> Input or I/O leakage current is measured with the pin configured as an input or as an I/O with the output driver tri-stated. It is not measured with the output driver active. Internal pull-up resistors are disabled. T<sub>J</sub> 25 °C, f = 1.0 MHz. <sup>3.</sup> Please refer to $V_{IL}$ and $V_{IH}$ in the sysIO Single-Ended DC Electrical Characteristics table of this document. <sup>4.</sup> Input pins are clamped to V<sub>CCIO</sub> and GND by a diode. When input is higher than V<sub>CCIO</sub> or lower than GND, the Input Leakage current will be higher than the I<sub>IL</sub> and I<sub>IH</sub>. ## iCE40 Ultra Family Timing Adders ## Over Recommended Commercial Operating Conditions<sup>1, 2, 3</sup> | Buffer Type Description | | Timing (Typ.) | Units | |-------------------------|-----------------------------------|---------------|-------| | Input Adjusters | · | | | | LVCMOS33 | LVCMOS, V <sub>CCIO</sub> = 3.3 V | 0.18 | ns | | LVCMOS25 | LVCMOS, V <sub>CCIO</sub> = 2.5 V | 0 | ns | | LVCMOS18 | LVCMOS, V <sub>CCIO</sub> = 1.8 V | 0.19 | ns | | Output Adjusters | · | | | | LVCMOS33 | LVCMOS, V <sub>CCIO</sub> = 3.3 V | -0.12 | ns | | LVCMOS25 | LVCMOS, V <sub>CCIO</sub> = 2.5 V | 0 | ns | | LVCMOS18 | LVCMOS, V <sub>CCIO</sub> = 1.8 V | 1.32 | ns | <sup>1.</sup> Timing adders are relative to LVCMOS25 and characterized but not tested on every device. ## iCE40 Ultra External Switching Characteristics ## **Over Recommended Commercial Operating Conditions** | Parameter | Description | Device | Min | Max | Units | |------------------------|-------------------------------------------------------|-------------|----------|-----|-------| | Clocks | | | | I | 1 | | Global Clocks | | | | | | | f <sub>MAX_GBUF</sub> | Frequency for Global Buffer Clock network | All devices | _ | 185 | MHz | | t <sub>W_GBUF</sub> | Clock Pulse Width for Global Buffer | All devices | 2 | _ | ns | | t <sub>SKEW_GBUF</sub> | Global Buffer Clock Skew Within a Device | All devices | _ | 500 | ps | | Pin-LUT-Pin Prop | agation Delay | | | | | | t <sub>PD</sub> | Best case propagation delay through one LUT logic All | | _ | 9.0 | ns | | General I/O Pin P | arameters (Using Global Buffer Clock without F | PLL)1 | <b>"</b> | • | | | t <sub>SKEW_IO</sub> | Data bus skew across a bank of IOs | All devices | _ | 410 | ps | | t <sub>CO</sub> | Clock to Output – PIO Output Register | All devices | _ | 9.0 | ns | | t <sub>SU</sub> | Clock to Data Setup - PIO Input Register | All devices | -0.5 | _ | ns | | t <sub>H</sub> | Clock to Data Hold – PIO Input Register | All devices | 5.55 | _ | ns | | General I/O Pin P | arameters (Using Global Buffer Clock with PLL) | ) | | | | | t <sub>COPLL</sub> | Clock to Output – PIO Output Register | All Devices | _ | 2.9 | ns | | t <sub>SUPLL</sub> | Clock to Data Setup - PIO Input Register | All Devices | 5.9 | _ | ns | | t <sub>HPLL</sub> | Clock to Data Hold – PIO Input Register | All Devices | -0.6 | _ | ns | <sup>1.</sup> All the data is from the worst case condition. <sup>2.</sup> LVCMOS timing measured with the load specified in Switching Test Condition table. <sup>3.</sup> Commercial timing numbers are shown. # SPI Master or NVCM Configuration Time<sup>1, 2</sup> | Symbol | Parameter | Conditions | Max. | Units | |---------------------|-----------------------------------|---------------------------------------|------|-------| | | | All devices – Low Frequency (Default) | 95 | ms | | t <sub>CONFIG</sub> | POR/CRESET_B to Device I/O Active | All devices – Medium frequency | 35 | ms | | | | All devices – High frequency | 18 | ms | <sup>1.</sup> Assumes sysMEM Block is initialized to an all zero pattern if they are used. ## sysCONFIG Port Timing Specifications | Symbol | Parameter | Min. | Тур. | Max. | Units | | |-------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|------|------|-------|-----------------| | All Configurat | tion Modes | | | l | | I | | t <sub>CRESET_B</sub> | Minimum CRESET_B LOW pulse width required to restart configuration, from falling edge to rising edge | | 200 | _ | _ | ns | | t <sub>DONE_IO</sub> | Number of configuration clock cycles after CDONE goes HIGH before the PIO pins are activated | | 49 | _ | _ | Clock<br>Cycles | | Slave SPI | , | | | l | | I | | <sup>t</sup> cr_sck | Minimum time from a rising edge on CRESET_B until the first SPI WRITE operation, first SPI_XCK clock. During this time, the iCE40 Ultra device is clearing its internal configuration memory | | 1200 | _ | _ | μѕ | | ſ | CCL K alask fragueray | Write | 1 | _ | 25 | MHz | | f <sub>MAX</sub> | CCLK clock frequency | Read <sup>1</sup> | _ | 15 | _ | MHz | | t <sub>CCLKH</sub> | CCLK clock pulsewidth HIGH | | 20 | _ | _ | ns | | t <sub>CCLKL</sub> | CCLK clock pulsewidth LOW | | 20 | _ | _ | ns | | t <sub>STSU</sub> | CCLK setup time | | 12 | _ | _ | ns | | t <sub>STH</sub> | CCLK hold time | | 12 | _ | _ | ns | | t <sub>STCO</sub> | CCLK falling edge to valid output | | 13 | _ | _ | ns | | Master SPI <sup>3</sup> | | | | | • | | | _ | | Low Frequency<br>(Default) | 7.0 | 12.0 | 17.0 | MHz | | f <sub>MCLK</sub> | MCLK clock frequency | Medium Frequency <sup>2</sup> | 21.0 | 33.0 | 45.0 | MHz | | | | High Frequency <sup>2</sup> | 33.0 | 53.0 | 71.0 | MHz | | t <sub>MCLK</sub> | CRESET_B HIGH to first MCLK edge | | 1200 | _ | _ | μs | | t <sub>SU</sub> | CCLK setup time <sup>4</sup> | | 9.9 | _ | _ | ns | | t <sub>HD</sub> | CCLK hold time | | 1 | _ | _ | ns | <sup>1.</sup> Supported with 1.2 V Vcc and at 25 °C. <sup>2.</sup> The NVCM download time is measured with a fast ramp rate starting from the maximum voltage of POR trip point. <sup>2.</sup> Extended range fMAX Write operations support up to 53 MHz with 1.2 V Vcc and at 25 °C. <sup>3.</sup> t<sub>SU</sub> and t<sub>HD</sub> timing must be met for all MCLK frequency choices. <sup>4.</sup> For considerations of SPI Master Configuration Mode, please refer to TN1248, iCE40 Programming and Configuration. # iCE40 Ultra Family Data Sheet Pinout Information June 2016 Data Sheet DS1048 # **Signal Descriptions** | Signal Name | | Function | I/O | Description | |---------------------|----------------|------------------------------------------------|--------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Power Supplie | s | 1 | | | | V <sub>CC</sub> | | Power | _ | Core Power Supply | | | CCIO1, VCCIO_2 | Power | _ | Power for I/Os in Bank 0, 1 and 2. | | V <sub>PP_2V5</sub> | _ | Power | _ | Power for NVCM programming and operations. | | V <sub>CCPLL</sub> | | Power | _ | Power for PLL | | GND | | GROUND | _ | Ground | | GND_LED | | GROUND | _ | Ground for LED drivers. Should connect to GND on board. | | Configuration | | <u>. </u> | | | | CRESETB | | Configuration | I | Configuration Reset, active LOW. No internal pull-up resistor. Either actively driven externally or connect an 10 kOhm pull-up to V <sub>CCIO_1</sub> . | | CDONE | | Configuration | I/O | Configuration Done. Includes a weak pull-up resistor to ${\rm SPI\_V_{CCIO1}}.$ | | | | General I/O | I/O | In user mode, after configuration, this pin can be programmed as general I/O in user function. | | Config SPI | | <u>. </u> | | | | Primary | Secondary | | | | | CRESETB | _ | Configuration | I | Configuration Reset, active LOW. No internal pull-up resistor. Either actively driven externally or connect an 10 kOhm pull-up to SPI_V <sub>CCIO1</sub> . | | PIOB_xx | CDONE | Configuration | I/O | Configuration Done. Includes a weak pull-up resistor to SPI_V <sub>CCIO1</sub> . | | | | General I/O | I/O | In user mode, after configuration, this pin can be programmed as general I/O in user function. | | Config SPI | | · | | | | Primary | Secondary | | | | | PIOB_34a | SPI_SCK | Configuration | I/O | This pin is shared with device configuration. During configuration: In Master SPI mode, this pin outputs the clock to external SPI memory. In Slave SPI mode, this pin inputs the clock from external processor. | | | | General I/O | I/O | In user mode, after configuration, this pin can be programmed as general I/O in user function | | PIOB_32a | SPI_SDO | Configuration | Output | This pin is shared with device configuration. During configuration: In Master SPI mode, this pin outputs the command data to external SPI memory. In Slave SPI mode, this pin connects to the MISO pin of the external processor. | | | | General I/O | I/O | In user mode, after configuration, this pin can be programmed as general I/O in user function. | # Pinout Information iCE40 Ultra Family Data Sheet | Signal Name | Function | I/O | Description | |-------------|-------------|----------------------|---------------------------------------------------------------------------------------------------------------------------| | RGB2 | General I/O | Open-Drain I/O | In user mode, with user's choice, this pin can be programmed as open drain I/O in user function | | | LED | Open-Drain<br>Output | In user mode, with user's choice, this pin can be programmed as open drain 24mA output to drive external LED | | IRLED | General I/O | Open-Drain I/O | In user mode, with user's choice, this pin can be programmed as open drain I/O in user function | | | LED | Open-Drain<br>Output | In user mode, with user's choice, this pin can be programmed as open drain 500mA output to drive external LED | | PIOT_xx | General I/O | I/O | In user mode, with user's choice, this pin can be programmed as I/O in user function in the top $(xx = I/O location)$ | | PIOB_xx | General I/O | I/O | In user mode, with user's choice, this pin can be programmed as I/O in user function in the bottom ( $xx = I/O$ location) | # **Ordering Part Numbers** ## Industrial | Part Number | LUTs | Supply Voltage | Package | Pins | Temp. | |---------------------|------|----------------|---------------------|------|-------| | iCE5LP1K-CM36ITR | 1100 | 1.2 V | Halogen-Free ucfBGA | 36 | IND | | iCE5LP1K-CM36ITR50 | 1100 | 1.2 V | Halogen-Free ucfBGA | 36 | IND | | iCE5LP1K-CM36ITR1K | 1100 | 1.2 V | Halogen-Free ucfBGA | 36 | IND | | iCE5LP1K-SWG36ITR | 1100 | 1.2 V | Halogen-Free WLCSP | 36 | IND | | iCE5LP1K-SWG36ITR50 | 1100 | 1.2 V | Halogen-Free WLCSP | 36 | IND | | iCE5LP1K-SWG36ITR1K | 1100 | 1.2 V | Halogen-Free WLCSP | 36 | IND | | iCE5LP1K-SG48ITR | 1100 | 1.2 V | Halogen-Free QFN | 48 | IND | | iCE5LP1K-SG48ITR50 | 1100 | 1.2 V | Halogen-Free QFN | 48 | IND | | iCE5LP2K-CM36ITR | 2048 | 1.2 V | Halogen-Free ucfBGA | 36 | IND | | iCE5LP2K-CM36ITR50 | 2048 | 1.2 V | Halogen-Free ucfBGA | 36 | IND | | iCE5LP2K-CM36ITR1K | 2048 | 1.2 V | Halogen-Free ucfBGA | 36 | IND | | iCE5LP2K-SWG36ITR | 2048 | 1.2 V | Halogen-Free WLCSP | 36 | IND | | iCE5LP2K-SWG36ITR50 | 2048 | 1.2 V | Halogen-Free WLCSP | 36 | IND | | iCE5LP2K-SWG36ITR1K | 2048 | 1.2 V | Halogen-Free WLCSP | 36 | IND | | iCE5LP2K-SG48ITR | 2048 | 1.2 V | Halogen-Free QFN | 48 | IND | | iCE5LP2K-SG48ITR50 | 2048 | 1.2 V | Halogen-Free QFN | 48 | IND | | iCE5LP4K-CM36ITR | 3520 | 1.2 V | Halogen-Free ucfBGA | 36 | IND | | iCE5LP4K-CM36ITR50 | 3520 | 1.2 V | Halogen-Free ucfBGA | 36 | IND | | iCE5LP4K-CM36ITR1K | 3520 | 1.2 V | Halogen-Free ucfBGA | 36 | IND | | iCE5LP4K-SWG36ITR | 3520 | 1.2 V | Halogen-Free WLCSP | 36 | IND | | iCE5LP4K-SWG36ITR50 | 3520 | 1.2 V | Halogen-Free WLCSP | 36 | IND | | iCE5LP4K-SWG36ITR1K | 3520 | 1.2 V | Halogen-Free WLCSP | 36 | IND | | iCE5LP4K-SG48ITR | 3520 | 1.2 V | Halogen-Free QFN | 48 | IND | | iCE5LP4K-SG48ITR50 | 3520 | 1.2 V | Halogen-Free QFN | 48 | IND | | Date | Version | Section | Change Summary | |-----------|---------|-------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | | | Updated Supply Current section. — Corrected I <sub>PP2V5STDBY</sub> parameter. — Added Typ. VCC = 1.2 V values for I <sub>CCPEAK</sub> , I <sub>PP_2V5PEAK</sub> , | | | | | I <sub>SPI_VCCIO1PEAK</sub> , and I <sub>CCIOPEAK</sub> . — Added footnote 5. — Corrected S <sub>PI_VCCIO1</sub> character format. | | | | | Updated User SPI Specifications section. Removed parameters and added footnotes. | | | | | Updated Internal Oscillators (HFOSC, LFOSC) section. Added Commercial and Industrial Temp values for DCH <sub>CLKHF</sub> | | | | | Updated sysIO Single-Ended DC Electrical Characteristics section. Removed footnote. | | | | | Updated Register-to-Register Performance section. Modified footnotes. | | | | | Updated iCE40 Ultra External Switching Characteristics section. Modified footnote. | | | | | Updated sysCLOCK PLL Timing section. Reversed t <sub>OPJIT</sub> conditions. | | | | | Updated sysCONFIG Port Timing Specifications section. — Modified t <sub>CR_SCK</sub> Min. value. — Added footnote 4 to t <sub>SU</sub> parameter. — Modified t <sub>SU</sub> Min. value. — Modified t <sub>HD</sub> parameter. | | | | | Updated section heading to RGB LED and IR LED Drive. Modified ILED_ACCURACY and IIR_ACCURACY parameters, Min. and Max. values. | | | | Pinout Information | Updated Signal Descriptions section. Changed V <sub>CCIO_1</sub> to SPI_V <sub>CCIO1</sub> in the CDONE, CRESETB and PIOB_xx descriptions. | | | | | Updated Pin Information Summary section. — Corrected symbol character format. — Corrected VCPP_2V5 to V <sub>PP_2V5</sub> . | | | 1.9 | Introduction | Updated Features section. Updated BGA package to ucfBGA. | | | | DC and Switching<br>Characteristics | Updated Differential Comparator Electrical Characteristics section. Corrected typo in $V_REF$ Max. value. | | | | Pinout Information | Updated Signal Descriptions section. — Changed PIOB_12a to PIOB_xx — Changed SPI_CSN to SPI_SS_B and revised description when in Slave SPI mode. — Corrected minor typo errors. | | | | | Updated Pin Information Summary section. Added footnote to SG48. | | | | Ordering Information | Updated iCE5LP Part Number Description section. Updated BGA package to ucfBGA. | | | | | Updated Ordering Part Numbers section. Updated BGA package to ucf-BGA. | | June 2015 | 1.8 | DC and Switching<br>Characteristics | Updated Internal Oscillators (HFOSC, LFOSC) section. Removed decimals. | | | | Ordering Information | Updated iCE5LP Part Number Description section. — Added TR items. — Corrected formatting errors. | | | | | Updated Ordering Part Numbers section. Updated CM36 and SG48 packages. | | Date | Version | Section | Change Summary | |-------------|---------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | August 2014 | 1.4 | All | Removed Preliminary document status. | | | | Introduction | Updated General Description section. Added information on high current driver. | | | | | Updated Features section. — Changed standby current typical to as low as 71 μA. — Changed feature to Embedded Memory. — Updated Table 1-1, iCE40 Ultra Family Selection Guide. Added NVCM and Embedded PWM IP rows. Added (MULT16 with 32-bit Accumulator) to DSP Block. Added Total I/O (Dedicated I/O) Count data. | | | | | General update to Introduction section. | | | | Architecture | Updated Architecture Overview section. — Revised and added information on sysIO banks. — Updated reference for embedded PWM IP. | | | | | Updated iCE40 Ultra Programming and Configuration section. — Changed SPI1 to SPI. — Changed VCCIO_1 to SPI_V <sub>CCIO1</sub> . | | | | DC and Switching<br>Characteristics | Updated Absolute Maximum Ratings section. Changed PLL Supply Voltage VCCPLL value. | | | | | Updated Recommended Operating Conditions section. Added footnote to VCCPLL. | | | | | Updated Power-up Sequence section. General update. | | | | | Updated Power-On-Reset Voltage Levels section. Changed the $V_{PORUP}$ $V_{CC}$ Max.value. | | | | | Updated DC Electrical Characteristics section. Added $C_3$ and $C_4$ information. | | | | | Updated Supply Current section. — Completed Typ. VCC =1.2 V4 data. — Changed symbols to I <sub>SPI_VCCIO1STDBY</sub> and I <sub>SPI_VCCIO1PEAK</sub> . — Added information to footnote 3. | | | | | Updated Internal Oscillators (HFOSC, LFOSC) section. General update. | | | | | Updated iCE40 Ultra External Switching Characteristics section. Added Max. value for t <sub>COPLL</sub> . Added Min. values for t <sub>SUPLL</sub> and t <sub>HPLL</sub> . | | | | | Updated sysCLOCK PLL Timing section.<br>Added Max. value for t <sub>OPJIT</sub> . | | | | | Updated sysCONFIG Port Timing Specifications section. — Added T <sub>SU</sub> and T <sub>HD</sub> information. — Added footnote 3 to Master SPI. | | | | | Updated High Current LED and IR LED Drive section. Updated Min. value. | | July 2014 | 1.3 | All | Changed document status from Advance to Preliminary. | | | | Introduction | Updated Features section. Adjusted Ultra-low Power Devices standby current. | | | | DC and Switching<br>Characteristics | Updated AC/DC specifications numbers. | | | | 0 1 | 010 | |------------|---------|-------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Date | Version | Section | Change Summary | | June 2014 | 1.2 | All | Product name changed to iCE40 Ultra. | | | | Introduction | Updated Table 1-1, iCE40 Ultra Family Selection Guide. Removed 30-ball WLCSP. | | | | DC and Switching<br>Characteristics | Updated values in the following sections: — Supply Current — Internal Oscillators (HFOSC, LFOSC) — Power Supply Ramp Rates — Power-On-Reset Voltage Levels — SPI Master or NVCM Configuration Time | | | | | Indicated TBD for values to be determined. | | | | Pinout Information | Updated Signal Descriptions section. Removed 30-pin WLCSP. | | | | | Updated Pin Information Summary section. Removed SWG30 values. | | | | Ordering Information | Updated iCE5LP Part Number Description section. Removed 30-ball WLCSP. | | | | | Updated Ordering Part Numbers section. Removed SWG30 and UWG30 part numbers. | | May 2014 | 01.1 | Introduction | Updated General Description, Features, and Introduction sections. Removed hardened RGB PWM IP information. | | | | Architecture | Updated Architecture Overview section. Removed the RGB IP block in Figure 2-1, iCE5LP-4K Device, Top View, Figure 2-8, I/O Bank and Programmable I/O, and in the text content. | | | | | Updated High Current Drive I/O Pins section. Removed hardened RGB PWM IP information. | | | | | Updated Power On Reset section. Removed content on Vccio_2 power down option. | | | | | Replaced RGB PWM Block section with Embedded PWM IP section. | | | | DC and Switching<br>Characteristics | Removed RGB PWM Block Timing section. | | April 2014 | 01.0 | All | Initial release. |