# E.) (Fealtice Semiconductor Corporation - ICE40UP3K-UWG30ITR1K Datasheet



Welcome to E-XFL.COM

#### Understanding <u>Embedded - FPGAs (Field</u> <u>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                 | Active                                                                          |
|--------------------------------|---------------------------------------------------------------------------------|
| Number of LABs/CLBs            | 350                                                                             |
| Number of Logic Elements/Cells | 2800                                                                            |
| Total RAM Bits                 | 1130496                                                                         |
| Number of I/O                  | 21                                                                              |
| Number of Gates                | -                                                                               |
| Voltage - Supply               | 1.14V ~ 1.26V                                                                   |
| Mounting Type                  | Surface Mount                                                                   |
| Operating Temperature          | -40°C ~ 100°C (TJ)                                                              |
| Package / Case                 | 30-UFBGA, WLCSP                                                                 |
| Supplier Device Package        | 30-WLCSP (2.54x2.12)                                                            |
| Purchase URL                   | https://www.e-xfl.com/product-detail/lattice-semiconductor/ice40up3k-uwg30itr1k |
|                                |                                                                                 |

Email: info@E-XFL.COM

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



## Contents

| •              | in This Document                                   |    |
|----------------|----------------------------------------------------|----|
| 1. Gene        | ral Description                                    | 7  |
| 1.1.           | Features                                           |    |
| 2. Produ       | Jct Family                                         | 8  |
| 2.1.           | Overview                                           | 8  |
| 3. Archi       | tecture                                            | 10 |
| 3.1.           | Architecture Overview                              | 10 |
| 3.1.1          | PLB Blocks                                         | 11 |
| 3.1.2          | Routing                                            | 12 |
| 3.1.3          | Clock/Control Distribution Network                 | 12 |
| 3.1.4          | sysCLOCK Phase Locked Loops (PLLs)                 | 13 |
| 3.1.5          | sysMEM Embedded Block RAM Memory                   | 14 |
| 3.1.6          | sysMEM Single Port RAM Memory (SPRAM)              | 16 |
| 3.1.7          | sysDSP                                             | 17 |
| 3.1.8          | sysIO Buffer Banks                                 | 22 |
| 3.1.9          | sysIO Buffer                                       | 25 |
| 3.1.1          | 0. On-Chip Oscillator                              | 25 |
| 3.1.1          | 1. User I <sup>2</sup> C IP                        | 26 |
| 3.1.1          |                                                    |    |
| 3.1.1          | 3. RGB High Current Drive I/O Pins                 | 26 |
| 3.1.1          |                                                    |    |
| 3.1.1          |                                                    |    |
| 3.2.           | iCE40 UltraPlus Programming and Configuration      |    |
| 3.2.1          |                                                    |    |
| 3.2.2          |                                                    |    |
| 3.2.3          | 5                                                  |    |
| 0.10           | nd Switching Characteristics                       |    |
| 4.1.           | Absolute Maximum Ratings                           |    |
| 4.2.           | Recommended Operating Conditions                   |    |
| 4.3.           | Power Supply Ramp Rates                            |    |
| 4.4.           | Power-On Reset                                     |    |
| 4.5.           | Power-up Supply Sequence                           |    |
| 4.5.           | External Reset                                     |    |
| 4.0.           | Power-On-Reset Voltage Levels                      |    |
| 4.7.<br>4.8.   | ESD Performance                                    |    |
| 4.8.<br>4.9.   | DC Electrical Characteristics                      |    |
| 4.9.<br>4.10.  | Supply Current                                     |    |
| 4.10.<br>4.11. | User I <sup>2</sup> C Specifications               |    |
| 4.11.<br>4.12. | $l^2C$ 50 ns Delay                                 |    |
| 4.12.<br>4.13. | •                                                  |    |
| -              | I <sup>2</sup> C 50 ns Filter                      |    |
| 4.14.          | User SPI Specifications <sup>1, 2</sup>            |    |
| 4.15.          | Internal Oscillators (HFOSC, LFOSC)                |    |
| 4.16.          | sysI/O Recommended Operating Conditions            |    |
| 4.17.          | sysI/O Single-Ended DC Electrical Characteristics  |    |
| 4.18.          | Differential Comparator Electrical Characteristics |    |
| 4.19.          | Typical Building Block Function Performance        |    |
| 4.19.          |                                                    |    |
| 4.19.3         |                                                    |    |
| 4.20.          | sysDSP Timing                                      |    |
| 4.21.          | SPRAM Timing                                       |    |
| 4.22.          | Derating Logic Timing                              |    |
| 4.23.          | Maximum sysIO Buffer Performance                   | 36 |



Lattice, or they can use the design to create their own unique required functions. For more information regarding Lattice's reference designs or fully-verified bitstreams, contact your local Lattice representative.

<sup>© 2017</sup> 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.



# 3. Architecture

## **3.1.** Architecture Overview

The iCE40 UltraPlus 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, blocks of sysMEM<sup>™</sup> Embedded Block RAM (EBR) and Single Port RAM (SPRAM) surrounded by Programmable I/O (PIO). Figure 3.1 shows the block diagram of the iCE40UP5K device.



Figure 3.1. iCE40UP5K 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 UltraPlus family, there are three sysIO banks, one on top and two at the bottom. User can connect some  $V_{CCIOS}$  together, if all the I/Os are using the same voltage standard. See the Power-up Supply Sequence section. The sysMEM EBRs are large 4 kb, dedicated fast memory blocks. These blocks can be configured as RAM, ROM or FIFO with user logic using PLBs.

In addition to the EBR, the iCE40 UltraPlus devices also feature four 256 kb SPRAM blocks that can be cascaded to create up to 1 Mb block. It is useful for temporary storage of large quantities of information.

<sup>© 2017</sup> 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.



### Table 3.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 PLLOUT output.<br>0 – PLL generated signal<br>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.                                                                                                                                    |

## 3.1.5. sysMEM Embedded Block RAM Memory

Larger iCE40 UltraPlus 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 listed in Table 3.4.

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

Table 3.4. sysMEM Block Configurations



**Note**: For iCE40 UltraPlus, the primitive name without "Nxx" uses rising-edge Read and Write clocks. "NR" uses rising-edge Write clock and falling-edge Read clock. "NRW" uses falling-edge Write clock and rising-edge Read clock. "NRNW" uses failing-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 3.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 3.4. sysMEM Memory Primitives

#### Table 3.5 lists the EBR signals.

| Table 3.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.<br>0 – Write bit<br>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, refer to TN1250, Memory Usage Guide for iCE40 Devices.

## 3.1.6. sysMEM Single Port RAM Memory (SPRAM)

The SPRAM block is implemented to be accessed only as single port. Each block of SPRAM is designed to be 16K x 16 (256 kbits) in size. See Figure 3.5.

#### SPRAM Data Width

The SPRAM is designed with fixed 16-bit data width. However, the block contains nibble mask control on the write input that allows the user logic to operate the SPRAM as x4 or x8 with this control on the write side, and user logic to select which nible/byte in the read side.

### **SPRAM Initialization and ROM Operation**

There is no pre-load into the SPRAM during device configuration, therefore, the SPRAM is not initialized after configuration.

#### SPRAM Cascading

Deeper SPRAM can be created using multiple SPRAM blocks, up to four blocks (64K x 16)

#### **SPRAM Power Modes**

There are three power modes in the SPRAM that the users can select during normal operation. This reduces the SPRAM block power when it Is not needed, allow lower power consumption in an always-on application. These modes are:

- Standby Mode: SPRAM stops all activity, and SPRAM freezes in its current state. Memory contents are retained, memory outputs are retained, and all register contents are retained.
- Sleep Mode: SPRAM block is shut down on all peripheral circuit, except the memory core. Memory contents are retained, memory outputs and register contents are clear and become unknown.
- **Power Off Mode**: Power source to the SPRAM is disconnected. This is the lowest power state. Memory contents are lost. Memory outputs are unknown.



Figure 3.5. SPRAM Primitive





Figure 3.7. sysDSP 8-bit x 8-bit Multiplier

Figure 3.8 shows the path for an 16-bit x 16-bit Multiplier using the upper half of sysDSP block.

<sup>© 2017</sup> 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.





) = Statically defined by configuration program.



### Table 3.8. PIO Signal List

| Pin Name          | I/О Туре | Description                   |
|-------------------|----------|-------------------------------|
| OUTPUT_CLK        | Input    | Output register clock         |
| CLOCK_ENABLE      | Input    | Clock enable                  |
| INPUT_CLK         | Input    | Input register clock          |
| OUTPUT_ENABLE     | Input    | Output enable                 |
| D_OUT_0/1         | Input    | Data from the core            |
| D_IN_0/1          | Output   | Data to the core              |
| LATCH_INPUT_VALUE | Input    | Latches/holds the Input Value |



## 3.1.9. sysIO Buffer

Each I/O is associated with a flexible buffer referred to as a sysIO buffer. These buffers are arranged around the periphery of the device in groups referred to as banks. The sysIO buffers allow users to implement a wide variety of standards that are found in today's systems with LVCMOS interfaces.

### 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 Table 4.4. 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 UltraPlus sysIO buffer supports both single-ended input/output standards, and used as differential comparators. The buffer supports the LVCMOS 1.8 V, 2.5 V, and 3.3 V standards. The buffer has individually configurable options for bus maintenance (weak pull-up or none).

Table 3.9 and Table 3.10 show the I/O standards (together with their supply and reference voltages) supported by the iCE40 UltraPlus devices.

### **Differential Comparators**

The iCE40 UltraPlus devices provide differential comparator on pairs of I/O pins. These comparators are useful in some mobile applications. See the Pin Information Summary section on page 44 to locate the corresponding paired I/Os with differential comparators.

### Table 3.9. Supported Input Standards

| I/O Standard            | V <sub>CCIO</sub> (Typical) |       |       |  |  |
|-------------------------|-----------------------------|-------|-------|--|--|
| i/O Standard            | 3.3 V                       | 2.5 V | 1.8 V |  |  |
| Single-Ended Interfaces |                             |       |       |  |  |
| LVCMOS33                | Yes                         | —     | —     |  |  |
| LVCMOS25                | —                           | Yes   | —     |  |  |
| LVCMOS18                | _                           | _     | Yes   |  |  |

#### Table 3.10. Supported Output Standards

| I/O Standard            | V <sub>CCIO</sub> (Typical) |
|-------------------------|-----------------------------|
| Single-Ended Interfaces |                             |
| LVCMOS33                | 3.3 V                       |
| LVCMOS25                | 2.5 V                       |
| LVCMOS18                | 1.8 V                       |

## 3.1.10. On-Chip Oscillator

The iCE40 UltraPlus 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.

<sup>© 2017</sup> 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.



## 3.1.15. Non-Volatile Configuration Memory

All iCE40 UltraPlus devices provide a Non-Volatile Configuration Memory (NVCM) block which can be used to configure the device.

For more information on the NVCM, refer to TN1248, iCE40 Programming and Configuration.

## 3.2. iCE40 UltraPlus Programming and Configuration

This section describes the programming and configuration of the iCE40 UltraPlus family.

## 3.2.1. Device Programming

The NVCM memory can be programmed through the SPI port. The SPI port is located in Bank 1, using SPI\_V<sub>CCIO1</sub> power supply.

## 3.2.2. 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 UltraPlus, refer to TN1248, iCE40 Programming and Configuration.

## 3.2.3. Power Saving Options

The iCE40 UltraPlus devices feature iCEGate and PLL low power mode to allow users to meet the static and dynamic power requirements of their applications. Table 3.11 describes the function of these features.

|                  | ins rower saving reactives bescription                                                                                                                                                                                          |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Device Subsystem | Feature Description                                                                                                                                                                                                             |
| PLL              | 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. |

Table 3.11. iCE40 UltraPlus Power Saving Features Description



## 4.3. Power Supply Ramp Rates

### Table 4.3. Power Supply Ramp Rates

| Symbol            | Parameter                                      | Min | Max | Unit |
|-------------------|------------------------------------------------|-----|-----|------|
| t <sub>RAMP</sub> | Power supply ramp rates for all power supplies | 0.6 | 10  | V/ms |

Notes:

1. Assumes monotonic ramp rates.

2. Power up sequence must be followed. See the Power-up Supply Sequence section below.

## 4.4. Power-On Reset

All iCE40 UltraPlus devices have on-chip Power-On-Reset (POR) circuitry to ensure proper initialization of the device. Only three supply rails are monitored by the POR circuitry as follows: (1) Vcc, (2) SPI\_Vccio1 and (3) VPP\_2v5. All other supply pins have no effect on the power-on reset feature of the device. Note that all supply voltage pins must be connected to power supplies for normal operation (including device configuration).

## 4.5. Power-up Supply Sequence

It is recommended to bring up the power supplies in the following order. Note that there is no specified timing delay between the power supplies, however, there is a requirement for each supply to reach a level of 0.5 V, or higher, before any subsequent power supplies in the sequence are applied.

- 1. Vcc and VccPLL should be the first two supplies to be applied. Note that these two supplies can be tied together subject to the recommendation to include a RC-based noise filter on the VccPLL. Refer to TN1252, iCE40 Hardware Checklist.
- 2. **SPI\_Vccio1** should be the next supply, and can be applied any time after the previous supplies (Vcc and VccPLL) have reached as level of 0.5 V or higher.
- 3. **VPP\_2v5** should be the next supply, and can be applied any time after previous supplies (VCC, VCCPLL and SPI\_VCCIO1) have reached a level of 0.5 V or higher.
- 4. **Other Supplies** (Vccioo and Vccio2) do not affect device power-up functionality, and they can be applied any time after the initial power supplies (Vcc and VccPLL) have reached a level of 0.5 V or greater. There is no power down sequence required. However, when partial power supplies are powered down, it is required the above sequence to be followed when these supplies are re-powered up again.

## 4.6. External Reset

When all power supplies have reached their minimum operating voltage defined in the Minimum Operation Condition Table, it is required to either keep CRESET\_B LOW, or toggle CRESET\_B from HIGH to LOW, for a duration of tCRESET\_B, and release it to go HIGH, to start configuration download from either the internal NVCM or the external Flash memory. Figure 4.1 shows Power-Up sequence when SPI\_Vccio1 and VPP\_2v5 are not connected together, and the CRESET\_B signal triggers configuration download. shows when SPI\_Vccio1 and VPP\_2v5 connected together. All power supplies should be powered up during configuration. Before and during configuration, the I/Os are held in tri-state. I/Os are released to user functionality once the device has finished configuration.

<sup>© 2017</sup> 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.



## 4.20. sysDSP Timing

Over recommended operating conditions.

### Table 4.17. sysDSP Timing

| Parameter                  | Description                                                | Min | Max | Unit |
|----------------------------|------------------------------------------------------------|-----|-----|------|
| f <sub>MAX8x8SMULT</sub>   | Max frequency signed MULT8x8 bypassing pipeline register   | 50  | —   | MHz  |
| f <sub>MAX16x16SMULT</sub> | Max frequency signed MULT16x16 bypassing pipeline register | 50  | _   | MHz  |

## 4.21. SPRAM Timing

Over recommended operating conditions.

### Table 4.18. Single Port RAM Timing

| Parameter            | Description                                     | Min | Max | Unit |
|----------------------|-------------------------------------------------|-----|-----|------|
| f <sub>MAXSRAM</sub> | Max frequency SPRAM (4/8/16-bit Read and Write) | 70  | —   | MHz  |

## 4.22. Derating Logic Timing

Logic timing provided in the following sections of the data sheet and the Lattice design tools are worst case numbers in the operating range. Actual delays may be much faster. Lattice design tools can provide logic timing numbers at a particular temperature and voltage.



## 4.23. Maximum sysIO Buffer Performance

### Table 4.19. Maximum sysIO Buffer Performance

| I/O Standard | Max Speed | Unit |
|--------------|-----------|------|
| Inputs       |           |      |
| LVCMOS33     | 250       | MHz  |
| LVCMOS25     | 250       | MHz  |
| LVCMOS18     | 250       | MHz  |
| Outputs      |           |      |
| LVCMOS33     | 250       | MHz  |
| LVCMOS25     | 250       | MHz  |
| LVCMOS18     | 155       | MHz  |
| LVCMOS12     | 70        | MHz  |

Note: Measured with a toggling pattern.

## 4.24. iCE40 UltraPlus Family Timing Adders

Over recommended commercial operating conditions.

### Table 4.20. iCE40 UltraPlus Family Timing Adders

| 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    |
| LVCMOS12         | LVCMOS, V <sub>CCIO</sub> = 1.2 V | 5.38         | ns    |

Notes:

- 1. Timing adders are relative to LVCMOS25 and characterized but not tested on every device.
- 2. LVCMOS timing measured with the load specified in Switching Test Condition table.
- 3. Commercial timing numbers are shown.



## 4.25. iCE40 UltraPlus External Switching Characteristics

Over recommended commercial operating conditions.

### Table 4.21. iCE40 UltraPlus External Switching Characteristics

| Parameter                                                       | Description                                          | Device      | Min  | Max  | Unit |  |
|-----------------------------------------------------------------|------------------------------------------------------|-------------|------|------|------|--|
| Clocks                                                          |                                                      |             |      |      |      |  |
| Global Clock                                                    |                                                      |             |      |      |      |  |
| f <sub>MAX_GBUF</sub>                                           | Frequency for Global Buffer Clock network            | All Devices | _    | 185  | MHz  |  |
| tw_gbuf                                                         | Clock Pulse Width for Global Buffer                  | All Devices | 2    | -    | ns   |  |
| t <sub>ISKEW_GBUF</sub>                                         | Global Buffer Clock Skew Within a Device             | All Devices | _    | 530  | ps   |  |
| Pin-LUT-Pin Pro                                                 | ppagation Delay                                      |             |      |      |      |  |
| t <sub>PD</sub>                                                 | Best case propagation delay through one<br>LUT logic | All Devices | -    | 9.0  | ns   |  |
| General I/O Pin                                                 | Parameters (Using Global Buffer Clock without PL     | L)*         |      |      |      |  |
| t <sub>skew_io</sub>                                            | Data bus skew across a bank of IOs                   | All Devices | _    | 510  | ps   |  |
| t <sub>co</sub>                                                 | Clock to Output – PIO Output Register                | All Devices | _    | 10.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 Parameters (Using Global Buffer Clock with PLL) |                                                      |             |      |      |      |  |
| t <sub>copll</sub>                                              | Clock to Output – PIO Output Register                | All Devices | _    | 2.4  | ns   |  |
| t <sub>supll</sub>                                              | Clock to Data Setup – PIO Input Register             | All Devices | 7.3  | -    | ns   |  |
| t <sub>HPLL</sub>                                               | Clock to Data Hold – PIO Input Register              | All Devices | -1.1 | _    | ns   |  |

\*Note: All the data is from the worst case.



## 4.28. sysCONFIG Port Timing Specifications

Over recommended operating conditions.

#### Table 4.24. sysCONFIG Port Timing Specifications

| Symbol                  | Parameter                                                                                                                                                                                                    | Conditions                    | Min  | Тур  | Max  | Unit            |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|------|------|------|-----------------|
| All Configura           | ation Mode                                                                                                                                                                                                   |                               |      |      |      |                 |
| tCRESET_B               | 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<br>CDONE goes HIGH before the PIO pins are<br>activated                                                                                                           |                               | 49   | -    | -    | Clock<br>Cycles |
| Slave SPI               |                                                                                                                                                                                                              |                               |      |      |      |                 |
| t <sub>cr_sck</sub>     | Minimum time from a rising edge on<br>CRESET_B until the first SPI WRITE<br>operation, first SPI_XCK clock. During this<br>time, the iCE40 UltraPlus device is clearing<br>its internal configuration memory |                               | 1200 | _    | _    | μs              |
| f <sub>MAX</sub>        |                                                                                                                                                                                                              | Write                         | 1    | —    | 25   | MHz             |
| CCLK clock frequency    | 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>sтсо</sub>       | CCLK falling edge to valid output                                                                                                                                                                            |                               | 13   | _    | -    | ns              |
| Master SPI <sup>3</sup> |                                                                                                                                                                                                              |                               |      |      |      |                 |
| f <sub>MCLK</sub>       | MCLK clock frequency                                                                                                                                                                                         | Low Frequency                 | 7.0  | 12.0 | 17.0 | MHz             |
|                         |                                                                                                                                                                                                              | 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                                                                                                                                                                                              |                               | 6.16 |      | _    | ns              |
| t <sub>HD</sub>         | CCLK hold time                                                                                                                                                                                               |                               | 1    | _    | -    | ns              |

Notes:

1. Supported with 1.2 V V\_{CC} and at 25  $^\circ\text{C}.$ 

2. Extended range  $f_{MAX}$  Write operations support up to 53 MHz with 1.2 V V\_{CC} and at 25  $^\circ C.$ 

3.  $t_{SU}$  and  $t_{HD}$  timing must be met for all MCLK frequency choices.

<sup>© 2017</sup> 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.



# 5. Pinout Information

## 5.1. Signal Descriptions

## 5.1.1. Power Supply Pins

| Signal Name                                                        | Function | I/O | Description                                             |
|--------------------------------------------------------------------|----------|-----|---------------------------------------------------------|
| V <sub>cc</sub>                                                    | Power    | —   | Core Power Supply                                       |
| V <sub>CCIO_0</sub> , SPI_V <sub>CCIO1</sub> , V <sub>CCIO_2</sub> | 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. |

## 5.1.2. Configuration Pins

| Signal Name |                    |               |     |                                                                                                                                                                                                               |
|-------------|--------------------|---------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| General I/O | Shared<br>Function | Function      | I/O | Description                                                                                                                                                                                                   |
| CRESET_B    | _                  | Configuration | Ι   | Configuration Reset, active LOW. No internal pull-up resistor. Either actively driven externally or connect an 10 k $\Omega$ pull-up to SPI_V <sub>CCI01</sub> .                                              |
| IOB_xxx     | CDONE              | Configuration | I/O | Configuration Done. Includes a weak pull-up resistor to $\ensuremath{SPI_V}\xspace_CCIO1$                                                                                                                     |
|             |                    | General I/O   | I/O | In user mode, after configuration, this pin can be programmed<br>as general I/O in user function. In 30-pin WLCSP, this pin<br>connects to IOB_12a, which also is shared as global signal G4<br>in user mode. |

## 5.1.3. Configuration SPI Pins

| Signal      | Name               |               |        |                                                                                                                                                                                                                           |
|-------------|--------------------|---------------|--------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| General I/O | Shared<br>Function | Function      | I/O    | Description                                                                                                                                                                                                               |
| IOB_34a     | SPI_SCK            | Configuration | I/O    | This pin is shared with device configuration. During<br>configuration:<br>In Master SPI mode, this pin outputs the clock to external SPI<br>memory.<br>In Slave SPI mode, this pin inputs the clock from external         |
|             |                    | General I/O   | I/O    | In user mode, after configuration, this pin can be programmed as general I/O in user function.                                                                                                                            |
| IOB_32a     | SPI_SO             | Configuration | Output | This pin is shared with device configuration. During<br>configuration:<br>In Master SPI mode, this pin outputs the command data to<br>external SPI memory.<br>In Slave SPI mode, this pin connects to the MISO pin of the |
|             |                    | General I/O   | I/O    | In user mode, after configuration, this pin can be programmed as general I/O in user function.                                                                                                                            |

<sup>© 2017</sup> 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.



| RGB1    | - | General I/O | Open-<br>Drain I/O       | In user mode, when RGB function is not used, this pin can<br>be connected to any user logic and used as open-drain I/O.<br>This pin is located in Bank 0.                                                      |
|---------|---|-------------|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|         |   | LED         | Open-<br>Drain<br>Output | In user mode, when using RGB function, this pin can be programmed as open drain 24 mA output to drive external LED.                                                                                            |
| RGB2    | _ | General I/O | Open-<br>Drain I/O       | In user mode, when RGB function is not used, this pin can<br>be connected to any user logic and used as open-drain I/O.<br>This pin is located in Bank 0.                                                      |
|         |   | LED         | Open-<br>Drain<br>Output | In user mode, when using RGB function, this pin can be programmed as open drain 24 mA output to drive external LED.                                                                                            |
| PIOT_xx | _ | General I/O | 1/0                      | 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). These pins are located in Bank 0.                                                         |
| PIOB_xx | _ | General I/O | I/O                      | In user mode, with user's choice, this pin can be<br>programmed as I/O in user function in the bottom (xx = I/O<br>location). Pins with xx <= 9 are located in Bank 2, pins with<br>xx> are located in Bank 1. |

<sup>© 2017</sup> 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.



## 5.2. Pin Information Summary

|                     |          | iCE40UP3K | iCE40 | UP5K |
|---------------------|----------|-----------|-------|------|
| Pin Type            |          | UWG30     | UWG30 | SG48 |
| General Purpose     | Bank 0   | 7         | 7     | 17   |
| I/O Per Bank        | Bank 1   | 10        | 10    | 14   |
|                     | Bank 2   | 4         | 4     | 8    |
| Total General Purp  | ose I/Os | 21        | 21    | 39   |
| V <sub>cc</sub>     |          | 1         | 1     | 2    |
| V <sub>CCIO</sub>   | Bank 0   | 1         | 1     | 1    |
|                     | Bank 1   | 1         | 1     | 1    |
|                     | Bank 2   | 1         | 1     | 1    |
| V <sub>CCPLL</sub>  |          | 1         | 1     | 1    |
| V <sub>PP_2V5</sub> |          | 1         | 1     | 1    |
| Dedicated Config P  | ins      | 1         | 1     | 2    |
| GND                 |          | 2         | 2     | 01   |
| Total Balls         |          | 30        | 30    | 48   |

#### Note:

1. 48-pin QFN package (SG48) requires the package paddle to be connected to GND.



# **Technical Support**

For assistance, submit a technical support case at <u>www.latticesemi.com/techsupport</u>.

<sup>© 2017</sup> 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.



|                |     | DC and<br>Switching<br>Characteristics | <ul> <li>Added the following figures:         <ul> <li>Figure 4.1. Power Up Sequence with SPE_VCCIO1 and VPP_2V5 Not Connected Together.</li> <li>Figure 4.2. Power Up Sequence with All Supplies Connected Together to 1.8 V.</li> <li>Updated note in Table 4.5. DC Electrical Characteristics.</li> <li>Added note in Table 4.6. Supply Current.</li> <li>Revised User SPI Specifications 1, 2 section.</li> <li>Redded notes.</li> <li>Revised Table 4.11. Internal Oscillators (HFOSC, LFOSC).</li> </ul> </li> </ul> |
|----------------|-----|----------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                |     |                                        | <ul> <li>Removed note in Table 4.13. sysI/O Single-Ended DC Electrical<br/>Characteristics.</li> <li>Changed to Lattice Design Software tool in Table 4.15. Pin-to-Pin<br/>Performance (LVCMOS25).</li> <li>Changed to Lattice Design Software tool and revised note in Table</li> </ul>                                                                                                                                                                                                                                   |
|                |     |                                        | <ul> <li>4.16. Register-to-Register Performance.</li> <li>Added sysDSP Timing section.</li> <li>Added SPRAM Timing section.</li> <li>Removed LVCMOS12 and added timing values in Table 4.19.</li> </ul>                                                                                                                                                                                                                                                                                                                    |
|                |     |                                        | <ul> <li>Maximum IO Buffer Performance.</li> <li>Removed LVCMOS12 and added timing values in Table 4.20. iCE40</li> <li>UltraPlus Family Timing Adders.</li> <li>Revised max values in Table 4.23. SPI Master or NVCM Configuration</li> <li>Time.</li> </ul>                                                                                                                                                                                                                                                              |
|                |     |                                        | <ul> <li>Removed TBD conditions in Table 4.24. sysCONFIG Port Timing Specifications. Revised t<sub>HD</sub> parameter.</li> <li>Revised Table 4.25. High Current RGB LED and IR LED Drive.</li> </ul>                                                                                                                                                                                                                                                                                                                      |
|                |     | Pinout<br>Information                  | <ul> <li>General update to Signal Descriptions section.</li> <li>Updated the iCE40UP Part Number Description section. Added</li> <li>FGW49 package.</li> <li>Added OPNs.</li> </ul>                                                                                                                                                                                                                                                                                                                                        |
|                |     | Supplemental<br>Information            | Added reference to TN1314, iCE40 SPRAM Usage Guide.                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| September 2015 | 1.1 | Architecture<br>Pinout<br>Information  | Updated Architecture section. Replaced iCE5UP with iCE40UP.<br>Updated Pin Information Summary section.<br>— Replaced iCE5UP with iCE40UP.<br>— Replaced SWG30 with UWG30.                                                                                                                                                                                                                                                                                                                                                 |
|                |     | Ordering<br>Information                | Updated iCE40UP Part Number Description section.<br>— Replaced iCE5UP with iCE40UP.<br>— Replaced SWG30 with UWG30.<br>Updated Ordering Part Numbers section. Replaced the table of part                                                                                                                                                                                                                                                                                                                                   |
|                |     | Further<br>Information                 | Removed reference to Schematic Symbols.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| August 2015    | 1.0 | All                                    | Initial release.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |

<sup>© 2017</sup> 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.