

# iCE40 Hardware Checklist

June 2016

**Technical Note TN1252** 

### Introduction

When designing complex hardware using the iCE40<sup>™</sup> device family (iCE40 LP/HX, iCE40LM, iCE40 Ultra<sup>™</sup>, iCE40 Ultra<sup>™</sup>, iCE40 Ultra<sup>™</sup>), designers must pay special attention to critical hardware configuration requirements. This technical note steps through these critical hardware requirements related to the iCE40 device. This document does not provide detailed step-by-step instructions but gives a high-level summary checklist to assist in the design process.

The iCE40 ultra-low power, non-volatile devices are available in four versions – LP series for low power applications, HX series for high performance applications, LM and Ultra/UltraLite/UltraPlus series for ultra-low power for mobile applications.

This technical note assumes that the reader is familiar with the iCE40 device features as described in DS1040, iCE40LP/HX Family Data Sheet, DS1045, iCE40LM Family Data Sheet, DS1048, iCE40 Ultra Family Data Sheet, DS1050, iCE40 UltraLite Family Data Sheet and DS1056, iCE40 UltraPlus Family Data Sheet. The critical hardware areas covered in this technical note include:

- Power supplies as they relate to the supply rails and how to connect them to the PCB and the associated system
- · Configuration and how to connect the configuration mode selection
- · Device I/O interface and critical signals

### **Power Supply**

The VCC (core supply voltage) VCCIO\_2, SPI\_VCC and VPP\_2V5 determine the iCE40 device's stable condition. These supplies need to be at a valid and stable level before the device can become operational. Refer to the family data sheets for voltage requirements.

| Supply <sup>3, 4</sup> | Voltage (Nominal Value) | Description                                      |
|------------------------|-------------------------|--------------------------------------------------|
| VCC                    | 1.20 V                  | Core supply voltage                              |
| VCCIO_X                | 1.5 V to 3.3 V          | Power supply for I/O banks                       |
| VPP_2V5                | 2.5 V                   | NVCM programming and operating supply voltage    |
| VPP_FAST⁵              | Leave unconnected       | Optional fast NVCM programming supply            |
| SPI_VCC                | 1.8 V to 3.3 V          | SPI interface supply voltage                     |
| VCCPLL <sup>1, 2</sup> | 1.2 V                   | Analog voltage supply to Phase Locked Loop (PLL) |

Table 1. Power Supply Description and Voltage Levels

1. VCCPLL must be tied to VCC when PLL is not used.

<sup>2.</sup> External power supply filter required for VCCPLL and GNDPLL.

<sup>3.</sup> iCE40LM family devices do not have VPP\_2V5 and VPP\_FAST supplies.

<sup>4.</sup> iCE40 Ultra/iCE40 UltraLite/iCE40 UltraPlus family devices do not have VPP\_FAST.

<sup>5.</sup> VPP\_FAST, used only for fast production programming, must be left floating or unconnected in applications, except CM36 and CM49 packages MUST have the VPP\_FAST ball connected to VCCIO\_0 ball externally.



## Analog Power Supply Filter for PLL

The iCE40 sysCLOCK<sup>™</sup> PLL contains analog blocks, so the PLL requires a separate power and ground that is quiet and stable to reduce the output clock jitter of the PLL on device with external VCCPLL supply pins (PLL is not offered in some device/package combinations without the VCCPLL ball. Please refer to the data sheet and the device family Pin List to check the availability of VCCPLL ball.) The sysCLOCK PLL has the DC ground connection made on the FPGA, so the external PLL ground connection (GNDPLL) must NOT be connected to the board's ground. Figure 1 also includes sample values for the components that make up the PLL power supply filter.

#### Figure 1. Isolating PLL Supplies



1. Note that GNDPLL should not be connected to the board's ground.

#### **Configuration Considerations**

The iCE40 LP/HX/Ultra/Ultra/UltraPlus devices contain two types of memory, CRAM (Configuration RAM) and NVCM (Non-volatile Configuration Memory). The iCE40LM device contains only the CRAM. CRAM memory contains the active configuration. The NVCM provides on-chip storage of configuration data. It is one-time programmable and is recommended for mass-production.

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

The configuration and programming of the iCE40 LP/HX/LM/Ultra/UltraLite/UltraPlus devices from external memory is using the SPI port, both in Master and Slave modes. In Master SPI mode, the device configures its CRAM from an external SPI Flash connected to it. In Slave mode, the device can be configured or programmed using the Lattice Diamond<sup>®</sup> Programmer or embedded processor.

On the iCE40LP/HX and iCE40 Ultra/UltraLite/UltraPlus family devices, the SPI\_SS\_B determines if the iCE40 CRAM is configured from an external SPI (SPI\_SS\_B=0) or from the NVCM (SPI\_SS\_B=1). This pin is sampled after Power-on-Reset (POR) is released or CRESET\_B is held low or toggled (High-Low-High).

| Pin Name | Function                                                                  | Direction | External<br>Termination                                                                                                       | Notes                                     |
|----------|---------------------------------------------------------------------------|-----------|-------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|
| CRESET_B | Configuration Reset input, active low.                                    | Input     | 10 kOhm pull-up to VCCIO_2.                                                                                                   | A low on CRESET_B delay's configuration.  |
| CDONE    | Configuration Done output from iCE40.                                     | Output    | Pull-up to VCCIO_2. The maximum Rpullup value is calculated as follows:<br><i>Rpullup=1/(2*ConfigFrequency*CDONETraceCap)</i> |                                           |
| SPI_VCC  | SPI interface supply voltage.                                             | Supply    |                                                                                                                               |                                           |
| SPI_SI   | SPI serial input to the<br>iCE40, in both Master<br>and Slave modes.      | Input     |                                                                                                                               | Released to user I/O after configuration. |
| SPI_SO   | SPI serial output from<br>the iCE40, in both Mas-<br>ter and Slave modes. | Output    |                                                                                                                               | Released to user I/O after configuration. |

Table 2. Configuration Pins



#### Table 2. Configuration Pins (Continued)

| Pin Name | Function    | Direction                                           | External<br>Termination                  | Notes                                                                                          |
|----------|-------------|-----------------------------------------------------|------------------------------------------|------------------------------------------------------------------------------------------------|
| SPI_SCK  | SPI clock   | Input/Output                                        | 10 kOhm pull-up to VCC_SPI recommended.  | Direction based on Mas-<br>ter or Slave modes.<br>Released to user I/O<br>after configuration. |
| SPI_SS_B | Chip select | Input (Slave<br>mode)/<br>Output (Mas-<br>ter mode) | and a 10 kOhm pull down in Slave mode is | Refer to TN1248, iCE40<br>Programming and Con-<br>figuration, for more<br>details.             |

#### SPI Flash Requirement in Master SPI Mode

Users are free to select any industry standard SPI Flash. The SPI Flash must support the 0x0B Fast Read command, using a 24-bit start address with eight dummy bits before the PROM provides first data. Refer to TN1248, iCE40 Programming and Configuration, for additional information.

## LVDS Pin Assignments (For iCE40LP/HX Devices Only)

The differential inputs are supported only by Bank 3; however, differential outputs are supported in all banks.

## Checklist

#### Table 3. iCE40 Hardware Checklist

|     | iCE40 Hardware Checklist Item                | ОК | N/A |  |
|-----|----------------------------------------------|----|-----|--|
| 1   | Power Supply                                 |    |     |  |
| 1.1 | Core supply VCC at 1.2 V                     |    |     |  |
| 1.2 | I/O power supply VCCIO 0-3 at 1.5 V to 3.3 V |    |     |  |
| 1.3 | SPI_VCC at 1.8 V to 3.3 V                    |    |     |  |
| 1.4 | VCCPLL pulled to VCC even if PLL not used    |    |     |  |
| 1.5 | Power supply filter for VCCPLL and GNDPLL    |    |     |  |
| 1.6 | GNDPLL must NOT be connected to the board    |    |     |  |
| 2   | Power-on-Reset (POR) inputs                  |    |     |  |
| 2.1 | VCC                                          |    |     |  |
| 2.2 | SPI_VCC                                      |    |     |  |
| 2.3 | VCCIO_0-3                                    |    |     |  |
| 2.4 | VPP_2V5                                      |    |     |  |
|     | VPP_FAST                                     |    |     |  |
| 3   | Configuration                                |    |     |  |
| 3.1 | Configuration mode based on SPI_SS_B         |    |     |  |
| 3.2 | Pull-up on CRESET_B,CDONE pin                | 1  |     |  |
| 3.3 | TRST_B is kept low for normal operation      |    |     |  |
| 4   | I/O pin assignment                           | 1  |     |  |
| 4.1 | LVDS pin assignment considerations           |    |     |  |



# **Technical Support Assistance**

Submit a technical support case through www.latticesemi.com/techsupport.

# **Revision History**

| Date           | Version | Change Summary                                                                                                                 |
|----------------|---------|--------------------------------------------------------------------------------------------------------------------------------|
| June 2016      | 1.6     | Added support for iCE40 UltraPlus.                                                                                             |
|                |         | Updated Introduction section. Added reference to DS1056, iCE40 Ultra-<br>Plus Family Data Sheet.                               |
|                |         | Updated Power Supply section. Revised Table 1, Power Supply Description and Voltage Levels. Added footnote 5 to VPP_FAST.      |
|                |         | Updated Analog Power Supply Filter for PLL section. Revised Figure 1, Isolating PLL Supplies. Changed 100W to 100 Ohms.        |
|                |         | Updated Configuration Considerations section. Revised Table 2, Con-<br>figuration Pins. Updated SPI_SS_B External Termination. |
|                |         | Updated Technical Support Assistance section.                                                                                  |
| January 2015   | 1.5     | Added support for iCE40 UltraLite.                                                                                             |
| June 2014      | 1.4     | Added support for iCE40 Ultra.                                                                                                 |
|                |         | Updated Analog Power Supply Filter for PLL section.                                                                            |
|                |         | Updated Table 2, Configuration Pins. Changed VCCIO_2 to VCC_SPI in SPI_SCK and SPI_SS_B.                                       |
| October 2013   | 01.3    | Updated the Configuration Pins table.                                                                                          |
|                |         | Updated Technical Support Assistance information.                                                                              |
| December 2012  | 01.2    | Power Supply Description and Voltage Levels table – corrected VCC nominal voltage.                                             |
| September 2012 | 01.1    | LVDS Pin Assignments text section – corrected description of differen-<br>tial input and output support.                       |
|                | 01.0    | Initial release.                                                                                                               |