## \#LATTICE

## Lattice ECP3 Family Data Sheet

## Data Sheet

## Disclaimers

Lattice makes no warranty, representation, or guarantee regarding the accuracy of information contained in this document or the suitability of its products for any particular purpose. All information herein is provided AS IS and with all faults, and all risk associated with such information is entirely with Buyer. Buyer shall not rely on any data and performance specifications or parameters provided herein. Products sold by Lattice have been subject to limited testing and it is the Buyer's responsibility to independently determine the suitability of any products and to test and verify the same. No Lattice products should be used in conjunction with mission- or safety-critical or any other application in which the failure of Lattice's product could create a situation where personal injury, death, severe property or environmental damage may occur. The information provided in this document is proprietary to Lattice Semiconductor, and Lattice reserves the right to make any changes to the information in this document or to any products at any time without notice.

## Contents

1. Introduction ..... 9
1.1. Features ..... 9
1.2. Introduction ..... 10
2. Architecture ..... 11
2.1. Architecture Overview ..... 11
2.2. PFU Blocks ..... 12
2.2.1. Slice ..... 13
2.2.2. Modes of Operation ..... 15
2.3. Routing ..... 16
2.4. sysCLOCK PLLs and DLLs ..... 16
2.4.1. General Purpose PLL ..... 16
2.4.2. Delay Locked Loops (DLL) ..... 17
2.4.3. PLL/DLL Cascading ..... 19
2.4.4. PLL/DLL PIO Input Pin Connections ..... 19
2.5. Clock Dividers ..... 20
2.6. Clock Distribution Network ..... 20
2.6.1. Primary Clock Sources ..... 20
2.6.2. Primary Clock Routing ..... 22
2.6.3. Dynamic Clock Control (DCC) ..... 23
2.6.4. Dynamic Clock Select (DCS) ..... 23
2.6.5. Secondary Clock/Control Sources ..... 23
2.6.6. Secondary Clock/Control Routing ..... 24
2.6.7. Slice Clock Selection ..... 26
2.6.8. Edge Clock Sources ..... 26
2.6.9. Edge Clock Routing ..... 27
2.7. sysMEM Memory ..... 29
2.7.1. sysMEM Memory Block ..... 29
2.7.2. Bus Size Matching ..... 29
2.7.3. RAM Initialization and ROM Operation ..... 29
2.7.4. Memory Cascading ..... 29
2.7.5. Single, Dual and Pseudo-Dual Port Modes. ..... 30
2.7.6. Memory Core Reset. ..... 30
2.8. $\quad$ sysDSP ${ }^{\text {TM }}$ Slice ..... 30
2.8.1. $\quad$ sysDSP Slice Approach Compared to General DSP ..... 30
2.9. LatticeECP3 sysDSP Slice Architecture Features ..... 31
2.9.1. MULT DSP Element ..... 33
2.9.2. MAC DSP Element ..... 34
2.9.3. MMAC DSP Element ..... 35
2.9.4. MULTADDSUB DSP Element ..... 36
2.9.5. MULTADDSUBSUM DSP Element ..... 37
2.10. Advanced sysDSP Slice Features ..... 38
2.10.1. Cascading ..... 38
2.10.2. Addition ..... 38
2.10.3. Rounding ..... 38
2.10.4. ALU Flags ..... 38
2.10.5. Clock, Clock Enable and Reset Resources ..... 38
2.10.6. Resources Available in the LatticeECP3 Family ..... 38
3. Programmable I/O Cells (PIC) ..... 40
3.1. PIO ..... 42
3.1.1. Input Register Block ..... 42
3.1.2. Output Register Block ..... 43
3.1.3. Tristate Register Block ..... 44
3.1.4. ISI Calibration ..... 44
3.1.5. Control Logic Block ..... 44
3.2. DDR Memory Support ..... 45
3.2.1. Left and Right Edges ..... 45
3.2.2. Bottom Edge ..... 45
3.2.3. Top Edge ..... 45
3.2.4. DLL Calibrated DQS Delay Block ..... 46
3.2.5. Polarity Control Logic ..... 48
3.2.6. DDR3 Memory Support ..... 49
3.3. sysl/O Buffer ..... 49
3.3.1. sysl/O Buffer Banks ..... 49
3.3.2. Typical sysl/O I/O Behavior During Power-up ..... 51
3.3.3. Supported sysl/O Standards ..... 51
3.3.4. On-Chip Programmable Termination ..... 51
3.3.5. Equalization Filter ..... 53
3.3.6. Hot Socketing ..... 53
3.4. SERDES and PCS (Physical Coding Sublayer). ..... 53
3.4.1. SERDES Block ..... 55
3.4.2. PCS ..... 55
3.4.3. SCI (SERDES Client Interface) Bus ..... 55
3.5. Flexible Quad SERDES Architecture ..... 56
3.6. IEEE 1149.1-Compliant Boundary Scan Testability. ..... 56
3.7. Device Configuration ..... 57
3.7.1. Enhanced Configuration Options ..... 57
3.7.2. Soft Error Detect (SED) Support ..... 57
3.7.3. External Resistor ..... 57
3.7.4. On-Chip Oscillator ..... 58
3.8. Density Shifting ..... 58
4. DC and Switching Characteristics ..... 59
4.1. Absolute Maximum Ratings ${ }^{1,2,3}$ ..... 59
4.2. Recommended Operating Conditions ${ }^{1}$ ..... 59
4.3. Hot Socketing Specifications ${ }^{1,2,3}$ ..... 60
4.4. Hot Socketing Requirements ..... 60
4.5. ESD Performance ..... 60
4.6. DC Electrical Characteristics ..... 61
4.7. LatticeECP3 Supply Current (Standby) ..... 62
4.8. SERDES Power Supply Requirements ..... 63
4.9. sysI/O Recommended Operating Conditions ..... 64
4.10. sysI/O Single-Ended DC Electrical Characteristics ..... 65
4.11. sys//O Differential Electrical Characteristics ..... 66
4.11.1. Differential HSTL and SSTL ..... 66
4.11.2. LVDS25E ..... 67
4.11.3. LVCMOS33D ..... 67
4.11.4. BLVDS25 ..... 68
4.12. LVPECL33 ..... 69
4.13. RSDS25E ..... 70
4.13.1. MLVDS25 ..... 71
4.14. Typical Building Block Function Performance ..... 72
4.14.1. Pin-to-Pin Performance (LVCMOS25 12 mA Drive) ${ }^{1,2}$ ..... 72
4.14.2. Register-to-Register Performance ${ }^{1,2,3}$ ..... 72
4.14.3. Register-to-Register Performance ${ }^{1,2,3}$ ..... 73
4.15. Derating Timing Tables ..... 73
4.16. LatticeECP3 External Switching Characteristics ${ }^{1,2,3,13}$ ..... 74
4.17. LatticeECP3 Internal Switching Characteristics ${ }^{1,2,5}$ ..... 88
4.18. Timing Diagrams ..... 90
4.19. LatticeECP3 Family Timing Adders ${ }^{1,2,3,4,5,7}$ ..... 92
4.20. LatticeECP3 Maximum I/O Buffer Speed ${ }^{1,2,3,4,5,6}$ ..... 95
4.21. sysCLOCK PLL Timing ..... 96
4.22. DLL Timing ..... 97
4.23. SERDES High-Speed Data Transmitter ${ }^{1}$ ..... 98
4.24. SERDES/PCS Block Latency ..... 100
4.25. SERDES High Speed Data Receiver ..... 101
4.25.1. Input Data Jitter Tolerance ..... 101
4.25.2. SERDES External Reference Clock ..... 102
4.26. PCI Express Electrical and Timing Characteristics ..... 105
4.26.1. AC and DC Characteristics ..... 105
4.27. XAUI/Serial Rapid I/O Type 3/CPRI LV E. 30 Electrical and Timing Characteristics ..... 106
4.27.1. AC and DC Characteristics ..... 106
4.28. Serial Rapid I/O Type 2/CPRI LV E. 24 Electrical and Timing Characteristics ..... 107
4.28.1. AC and DC Characteristics ..... 107
4.29. Gigabit Ethernet/Serial Rapid I/O Type 1/SGMII/CPRI LV E. 12 Electrical and Timing Characteristics ..... 108
4.29.1. AC and DC Characteristics ..... 108
4.30. SMPTE SD/HD-SDI/3G-SDI (Serial Digital Interface) Electrical and Timing Characteristics ..... 109
4.30.1. AC and DC Characteristics ..... 109
4.31. HDMI (High-Definition Multimedia Interface) Electrical and Timing Characteristics ..... 110
4.31.1. AC and DC Characteristics ..... 110
4.32. LatticeECP3 sysCONFIG Port Timing Specifications ..... 112
4.33. JTAG Port Timing Specifications ..... 118
4.34. Switching Test Conditions ..... 119
4.35. sysl/O Differential Electrical Characteristics ..... 119
4.35.1. Transition Reduced LVDS (TRLVDS DC Specification) ..... 119
4.35.2. Mini LVDS ..... 120
4.35.3. Point-to-Point LVDS (PPLVDS) ..... 120
4.35.4. RSDS ..... 121
5. Pinout Information ..... 122
5.1. Signal Descriptions ..... 122
5.2. PICs and DDR Data (DQ) Pins Associated with the DDR Strobe (DQS) Pin ..... 124
5.3. Pin Information Summary ..... 125
Pin Information Summary (Cont.) ..... 126
Pin Information Summary (Cont.) ..... 127
Pin Information Summary (Cont.) ..... 128
5.3.1. Package Pinout Information ..... 129
5.4. Thermal Management ..... 130
5.4.1. For Further Information ..... 130
6. Ordering Information ..... 131
6.1. LatticeECP3 Part Number Description ..... 131
6.2. Ordering Information ..... 131
6.2.1. LatticeECP3 Devices, Green and Lead-Free Packaging ..... 132
7. Supplemental Information ..... 138
7.1. For Further Information ..... 138
Technical Support Assistance ..... 139
Revision History ..... 140

## Figures

Figure 2.1. Simplified Block Diagram, LatticeECP3-35 Device (Top Level) ..... 12
Figure 2.2. PFU Diagram ..... 13
Figure 2.3. Slice Diagram ..... 14
Figure 2.4. General Purpose PLL Diagram ..... 17
Figure 2.5. Delay Locked Loop Diagram (DLL) ..... 18
Figure 2.6. Top-Level Block Diagram, High-Speed DLL and Slave Delay Line ..... 19
Figure 2.7. Sharing of PIO Pins by PLLs and DLLs in LatticeECP3 Devices ..... 19
Figure 2.8. Clock Divider Connections ..... 20
Figure 2.9. Primary Clock Sources for LatticeECP3-17 ..... 21
Figure 2.10. Primary Clock Sources for LatticeECP3-35 ..... 21
Figure 2.11. Primary Clock Sources for LatticeECP3-70, -95, -150 ..... 22
Figure 2.12. Per Quadrant Primary Clock Selection ..... 22
Figure 2.13. DCS Waveforms ..... 23
Figure 2.14. Secondary Clock Sources ..... 24
Figure 2.15. LatticeECP3-70 and LatticeECP3-95 Secondary Clock Regions ..... 25
Figure 2.16. Per Region Secondary Clock Selection ..... 25
Figure 2.17. Slice0 through Slice2 Clock Selection. ..... 26
Figure 2.18. Slice0 through Slice2 Control Selection ..... 26
Figure 2.19. Edge Clock Sources ..... 27
Figure 2.20. Sources of Edge Clock (Left and Right Edges) ..... 28
Figure 2.21. Sources of Edge Clock (Top Edge) ..... 28
Figure 2.22. Memory Core Reset ..... 30
Figure 2.23. Comparison of General DSP and LatticeECP3 Approaches ..... 31
Figure 2.24. Simplified sysDSP Slice Block Diagram ..... 32
Figure 2.25. Detailed sysDSP Slice Diagram ..... 32
Figure 2.26. MULT sysDSP Element ..... 33
Figure 2.27. MAC DSP Element ..... 34
Figure 2.28. MMAC sysDSP Element ..... 35
Figure 2.29. MULTADDSUB ..... 36
Figure 2.30. MULTADDSUBSUM Slice 0 ..... 37
Figure 2.31. MULTADDSUBSUM Slice 1 ..... 37
Figure 3.1. PIC Diagram ..... 40
Figure 3.2. Input Register Block for Left, Right and Top Edges ..... 43
Figure 3.3. Output and Tristate Block for Left and Right Edges ..... 44
Figure 3.4. DQS Grouping on the Left, Right and Top Edges ..... 45
Figure 3.5. Edge Clock, DLL Calibration and DQS Local Bus Distribution ..... 47
Figure 3.6. DQS Local Bus ..... 48
Figure 3.7. LatticeECP3 Banks ..... 50
Figure 3.8. On-Chip Termination ..... 52
Figure 3.9. SERDES/PCS Quads (LatticeECP3-150) ..... 54
Figure 3.10. Simplified Channel Block Diagram for SERDES/PCS Block ..... 55
Figure 4.1. LVDS25E Output Termination Example ..... 67
Figure 4.2. BLVDS25 Multi-point Output Example. ..... 68
Figure 4.3. Differential LVPECL33 ..... 69
Figure 4.4. RSDS25E (Reduced Swing Differential Signaling) ..... 70
Figure 4.5. MLVDS25 (Multipoint Low Voltage Differential Signaling) ..... 71
Figure 4.6. Generic DDRX1/DDRX2 (With Clock and Data Edges Aligned) ..... 86
Figure 4.7. DDR/DDR2/DDR3 Parameters ..... 86
Figure 4.8. Generic DDRX1/DDRX2 (With Clock Center on Data Window) ..... 87
Figure 4.9. Read/Write Mode (Normal) ..... 90
Figure 4.10. Read/Write Mode with Input and Output Registers ..... 90
Figure 4.11. Write Through (SP Read/Write on Port A, Input Registers Only) ..... 91
Figure 4.12. Transmitter and Receiver Latency Block Diagram ..... 100
Figure 4.13. SERDES External Reference Clock Waveforms ..... 103
Figure 4.14. Jitter Transfer - 3.125 Gbps. ..... 103
Figure 4.15. Jitter Transfer - 2.5 Gbps ..... 104
Figure 4.16. Jitter Transfer - 1.25 Gbps ..... 104
Figure 4.17. Jitter Transfer - 622 Mbps ..... 104
Figure 4.18. XAUI Sinusoidal Jitter Tolerance Mask ..... 107
Figure 4.19. Test Loads ..... 111
Figure 4.20. sysCONFIG Parallel Port Read Cycle. ..... 113
Figure 4.21. sysCONFIG Parallel Port Write Cycle ..... 113
Figure 4.22. sysCONFIG Master Serial Port Timing. ..... 114
Figure 4.23. sysCONFIG Slave Serial Port Timing ..... 114
Figure 4.24. Power-On-Reset (POR) Timing ..... 114
Figure 4.25. sysCONFIG Port Timing ..... 115
Figure 4.26. Configuration from PROGRAMN Timing ..... 115
Figure 4.27. Wake-Up Timing ..... 116
Figure 4.28. Master SPI Configuration Waveforms ..... 116
Figure 4.29. Master SPI POR Waveforms. ..... 116
Figure 4.30. SPI Configuration Waveforms ..... 117
Figure 4.31. Slave SPI HOLDN Waveforms ..... 117
Figure 4.32. JTAG Port Timing Waveforms ..... 118
Figure 4.33. Output Test Load, LVTTL and LVCMOS Standards ..... 119
Tables
Table 1.1. LatticeECP3 ${ }^{\text {TM }}$ Family Selection Guide ..... 9
Table 2.1. Resources and Modes Available per Slice ..... 13
Table 2.2. Slice Signal Descriptions ..... 14
Table 2.3. Number of Slices Required to Implement Distributed RAM ..... 15
Table 2.4. PLL Blocks Signal Descriptions. ..... 17
Table 2.5. DLL Signals. ..... 18
Table 2.6. Secondary Clock Regions ..... 24
Table 2.7. sysMEM Block Configurations. ..... 29
Table 2.8. Maximum Number of Elements in a Slice ..... 33
Table 2.9. Maximum Number of DSP Slices in the LatticeECP3 Family ..... 38
Table 2.10. Embedded SRAM in the LatticeECP3 Family ..... 39
Table 3.1. PIO Signal List ..... 41
Table 3.2. On-Chip Termination Options for Input Modes ..... 52
Table 3.3. LatticeECP3 SERDES Standard Support ..... 54
Table 3.4. Available SERDES Quads per LatticeECP3 Devices ..... 54
Table 3.5. LatticeECP3 Primary and Secondary Protocol Support ..... 56
Table 3.6. Selectable Master Clock (MCCLK) Frequencies During Configuration (Nominal) ..... 58
Table 4.1. LVDS25E DC Conditions. ..... 67
Table 4.2. BLVDS25 DC Conditions ..... 68
Table 4.3. LVPECL33 DC Conditions ..... 69
Table 4.4. RSDS25E DC Conditions. ..... 70
Table 4.5. MLVDS25 DC Conditions ..... 71
Table 4.6. Serial Output Timing and Levels ..... 98
Table 4.7. Channel Output Jitter ..... 99
Table 4.8. SERDES/PCS Latency Breakdown ..... 100
Table 4.9. Serial Input Data Specifications ..... 101
Table 4.10. Receiver Total Jitter Tolerance Specification ..... 101
Table 4.11. Periodic Receiver Jitter Tolerance Specification ..... 102
Table 4.12. External Reference Clock Specification (refclkp/refclkn) ..... 102
Table 4.13. Transmit ..... 106
Table 4.14. Receive and Jitter Tolerance ..... 106
Table 4.15. Transmit ..... 107
Table 4.16. Receive and Jitter Tolerance ..... 108
Table 4.17. Transmit ..... 108
Table 4.18. Receive and Jitter Tolerance ..... 109
Table 4.19. Transmit ..... 109
Table 4.20. Receive ..... 110
Table 4.21. Reference Clock ..... 110
Table 4.22. Transmit and Receive ${ }^{1,2}$ ..... 110
Table 4.23. Test Fixture Required Components, Non-Terminated Interfaces ..... 119

## 1. Introduction

### 1.1. Features

- Higher Logic Density for Increased System Integration
- 17 K to 149 K LUTs
- 116 to 586 I/O
- Embedded SERDES
- 150 Mbps to 3.2 Gbps for Generic 8b10b, 10bit SERDES, and 8-bit SERDES modes
- Data Rates 230 Mbps to 3.2 Gbps per channel for all other protocols
- Up to 16 channels per device: PCI Express, SONET/SDH, Ethernet (1GbE, SGMII, XAUI), CPRI, SMPTE 3G and Serial RapidIO
- sysDSP ${ }^{\text {m }}$
- Fully cascadable slice architecture
- 12 to 160 slices for high performance multiply and accumulate
- Powerful 54-bit ALU operations
- Time Division Multiplexing MAC Sharing
- Rounding and truncation
- Each slice supports
- Half $36 \times 36$, two $18 \times 18$ or four $9 \times 9$ multipliers
- Advanced $18 \times 36$ MAC and $18 \times 18$ Multiply- Multiply-Accumulate (MMAC) operations
- Flexible Memory Resources
- Up to 6.85 Mbits sysMEM ${ }^{\text {M }}$ Embedded Block RAM (EBR)
- $\quad 36 \mathrm{~K}$ to 303 K bits distributed RAM
- sysCLOCK Analog PLLs and DLLs
- Two DLLs and up to ten PLLs per device
- Pre-Engineered Source Synchronous I/O
- DDR registers in I/O cells
- Dedicated read/write levelling functionality
- Dedicated gearing logic
- Source synchronous standards support
- ADC/DAC, 7:1 LVDS, XGMII
- High Speed ADC/DAC devices
- Dedicated DDR/DDR2/DDR3 memory with DQS support
- Optional Inter-Symbol Interference (ISI) correction on outputs
- Programmable sysl/O™ Buffer Supports Wide Range of Interfaces
- On-chip termination
- Optional equalization filter on inputs
- LVTTL and LVCMOS 33/25/18/15/12
- SSTL 33/25/18/15 I, II
- HSTL15 I and HSTL18 I, II
- PCI and Differential HSTL, SSTL
- LVDS, Bus-LVDS, LVPECL, RSDS, MLVDS
- Flexible Device Configuration
- Dedicated bank for configuration I/O
- SPI boot flash interface
- Dual-boot images supported
- Slave SPI
- TransFR ${ }^{\text {TM }}$ I/O for simple field updates
- Soft Error Detect embedded macro
- System Level Support
- IEEE 1149.1 and IEEE 1532 compliant
- Reveal Logic Analyzer
- ORCAstra FPGA configuration utility
- On-chip oscillator for initialization \& general use
- 1.2 V core power supply

Table 1.1. LatticeECP3 ${ }^{\text {rM }}$ Family Selection Guide

| Device | ECP3-17 | ECP3-35 | ECP3-70 | ECP3-95 | ECP3-150 |
| :--- | :--- | :--- | :--- | :--- | :--- |
| LUTs (K) | 17 | 33 | 67 | 92 | 149 |
| sysMEM Blocks (18 Kbits) | 38 | 72 | 240 | 240 | 372 |
| Embedded Memory (Kbits) | 700 | 1327 | 4420 | 4420 | 6850 |
| Distributed RAM Bits (Kbits) | 36 | 68 | 145 | 188 | 303 |
| $18 \times 18$ Multipliers | 24 | 64 | 128 | 128 | 320 |
| SERDES (Quad) | 1 | 1 | 3 | 3 | 4 |
| PLLs/DLLs | $2 / 2$ | $4 / 2$ | $10 / 2$ | $10 / 2$ | $10 / 2$ |
| Packages and SERDES Channels/ I/O Combinations |  |  |  |  |  |
| 328 csBGA (10 $\times 10 \mathrm{~mm})$ | $2 / 116$ | - | - | - | - |
| $256 \mathrm{ftBGA}(17 \times 17 \mathrm{~mm})$ | $4 / 133$ | $4 / 133$ | - | - | - |
| $484 \mathrm{fpBGA}(23 \times 23 \mathrm{~mm})$ | $4 / 222$ | $4 / 295$ | $4 / 295$ | $4 / 295$ |  |
| $672 \mathrm{fpBGA}(27 \times 27 \mathrm{~mm})$ | - | $4 / 310$ | $8 / 380$ | $8 / 380$ | $8 / 380$ |
| $1156 \mathrm{fpBGA}(35 \times 35 \mathrm{~mm})$ | - | - | $12 / 490$ | $12 / 490$ | $16 / 586$ |

### 1.2. Introduction

The LatticeECP3 (EConomy Plus Third generation) family of FPGA devices is optimized to deliver high performance features such as an enhanced DSP architecture, high speed SERDES and high speed source synchronous interfaces in an economical FPGA fabric. This combination is achieved through advances in device architecture and the use of 65 nm technology making the devices suitable for high-volume, high-speed, low-cost applications.
The LatticeECP3 device family expands look-up-table (LUT) capacity to 149 K logic elements and supports up to 586 user I/O. The LatticeECP3 device family also offers up to $32018 \times 18$ multipliers and a wide range of parallel I/O standards.

The LatticeECP3 FPGA fabric is optimized with high performance and low cost in mind. The LatticeECP3 devices utilize reconfigurable SRAM logic technology and provide popular building blocks such as LUT-based logic, distributed and embedded memory, Phase Locked Loops (PLLs), Delay Locked Loops (DLLs), pre-engineered source synchronous I/O support, enhanced sysDSP slices and advanced configuration support, including encryption and dual-boot capabilities.

The pre-engineered source synchronous logic implemented in the LatticeECP3 device family supports a broad range of interface standards, including DDR3, XGMII and 7:1 LVDS.
The LatticeECP3 device family also features high speed SERDES with dedicated PCS functions. High jitter tolerance and low transmit jitter allow the SERDES plus PCS blocks to be configured to support an array of popular data protocols including PCI Express, SMPTE, Ethernet (XAUI, GbE, and SGMII) and CPRI. Transmit Pre-emphasis and Receive Equalization settings make the SERDES suitable for transmission and reception over various forms of media.
The LatticeECP3 devices also provide flexible, reliable and secure configuration options, such as dual-boot capability, bitstream encryption, and TransFR field upgrade features.

The Lattice Diamond ${ }^{\text {TM }}$ and ispLEVER ${ }^{\circledR}$ design software allows large complex designs to be efficiently implemented using the LatticeECP3 FPGA family. Synthesis library support for LatticeECP3 is available for popular logic synthesis tools. Diamond and ispLEVER tools use the synthesis tool output along with the constraints from its floor planning tools to place and route the design in the LatticeECP3 device. The tools extract the timing from the routing and back-annotate it into the design for timing verification.
Lattice provides many pre-engineered IP (Intellectual Property) modules for the LatticeECP3 family. By using these configurable soft core IPs as standardized blocks, designers are free to concentrate on the unique aspects of their design, increasing their productivity.

## 2. Architecture

### 2.1. Architecture Overview

Each LatticeECP3 device contains an array of logic blocks surrounded by Programmable I/O Cells (PIC). Interspersed between the rows of logic blocks are rows of sysMEM ${ }^{\text {TM }}$ Embedded Block RAM (EBR) and rows of sysDSP ${ }^{\text {TM }}$ Digital Signal Processing slices, as shown in Figure 2.1. The LatticeECP3-150 has four rows of DSP slices all other LatticeECP3 devices have two rows of DSP slices. In addition, the LatticeECP3 family contains SERDES Quads on the bottom of the device.
There are two kinds of logic blocks, the Programmable Functional Unit (PFU) and Programmable Functional Unit without RAM (PFF). The PFU contains the building blocks for logic, arithmetic, RAM and ROM functions. The PFF block contains building blocks for logic, arithmetic and ROM functions. Both PFU and PFF blocks are optimized for flexibility, allowing complex designs to be implemented quickly and efficiently. Logic Blocks are arranged in a twodimensional array. Only one type of block is used per row.

The LatticeECP3 devices contain one or more rows of sysMEM EBR blocks. sysMEM EBRs are large, dedicated 18Kbit fast memory blocks. Each sysMEM block can be configured in a variety of depths and widths as RAM or ROM. In addition, LatticeECP3 devices contain up to two rows of DSP slices. Each DSP slice has multipliers and adder/accumulators, which are the building blocks for complex signal processing capabilities.
The LatticeECP3 devices feature up to 16 embedded 3.2 Gbps SERDES (Serializer / Deserializer) channels. Each SERDES channel contains independent 8b/10b encoding / decoding, polarity adjust and elastic buffer logic. Each group of four SERDES channels, along with its Physical Coding Sub-layer (PCS) block, creates a quad. The functionality of the SERDES/PCS quads can be controlled by memory cells set during device configuration or by registers that are addressable during device operation. The registers in every quad can be programmed via the SERDES Client Interface ( SCl ). These quads (up to four) are located at the bottom of the devices.
Each PIC block encompasses two PIOs (PIO pairs) with their respective sysI/O buffers. The sysI/O buffers of the LatticeECP3 devices are arranged in seven banks, allowing the implementation of a wide variety of I/O standards. In addition, a separate I/O bank is provided for the programming interfaces. $50 \%$ of the PIO pairs on the left and right edges of the device can be configured as LVDS transmit/receive pairs. The PIC logic also includes pre-engineered support to aid in the implementation of high speed source synchronous standards such as XGMII, 7:1 LVDS, along with memory interfaces including DDR3.
The LatticeECP3 registers in PFU and sysI/O can be configured to be SET or RESET. After power up and the device is configured, it enters into user mode with these registers SET/RESET according to the configuration setting, allowing the device entering to a known state for predictable system function.
Other blocks provided include PLLs, DLLs and configuration functions. The LatticeECP3 architecture provides two Delay Locked Loops (DLLs) and up to ten Phase Locked Loops (PLLs). The PLL and DLL blocks are located at the end of the EBR/DSP rows.
The configuration block that supports features such as configuration bit-stream decryption, transparent updates and dual-boot support is located toward the center of this EBR row. Every device in the LatticeECP3 family supports a sysCONFIG ${ }^{\text {TM }}$ port located in the corner between banks one and two, which allows for serial or parallel device configuration.
In addition, every device in the family has a JTAG port. This family also provides an on-chip oscillator and soft error detect capability. The LatticeECP3 devices use 1.2 V as their core voltage.


Figure 2.1. Simplified Block Diagram, LatticeECP3-35 Device (Top Level)

### 2.2. PFU Blocks

The core of the LatticeECP3 device consists of PFU blocks, which are provided in two forms, the PFU and PFF. The PFUs can be programmed to perform Logic, Arithmetic, Distributed RAM and Distributed ROM functions. PFF blocks can be programmed to perform Logic, Arithmetic and ROM functions. Except where necessary, the remainder of this data sheet will use the term PFU to refer to both PFU and PFF blocks.
Each PFU block consists of four interconnected slices numbered 0-3 as shown in Figure 2.2. Each slice contains two LUTs. All the interconnections to and from PFU blocks are from routing. There are 50 inputs and 23 outputs associated with each PFU block.


Figure 2.2. PFU Diagram

### 2.2.1. Slice

Slice 0 through Slice 2 contain two LUT4s feeding two registers, whereas Slice 3 contains two LUT4s only. For PFUs, Slice 0 through Slice 2 can be configured as distributed memory, a capability not available in the PFF. Table 2.1 shows the capability of the slices in both PFF and PFU blocks along with the operation modes they enable. In addition, each PFU contains logic that allows the LUTs to be combined to perform functions such as LUT5, LUT6, LUT7 and LUT8. There is control logic to perform set/reset functions (programmable as synchronous/ asynchronous), clock select, chip-select and wider RAM/ROM functions.

Table 2.1. Resources and Modes Available per Slice

| Slice | PFU BLock | PFF Block |  |  |
| :--- | :--- | :--- | :--- | :--- |
|  | Resources | Modes | Resources | Modes |
| Slice 0 | 2 LUT4s and 2 Registers | Logic, Ripple, RAM, ROM | 2 LUT4s and 2 Registers | Logic, Ripple, ROM |
| Slice 1 | 2 LUT4s and 2 Registers | Logic, Ripple, RAM, ROM | 2 LUT4s and 2 Registers | Logic, Ripple, ROM |
| Slice 2 | 2 LUT4s and 2 Registers | Logic, Ripple, RAM, ROM | 2 LUT4s and 2 Registers | Logic, Ripple, ROM |
| Slice 3 | 2 LUT4s | Logic, ROM | 2 LUT4s | Logic, ROM |

Figure 2.3 shows an overview of the internal logic of the slice. The registers in the slice can be configured for positive/ negative and edge triggered or level sensitive clocks.
Slices 0,1 and 2 have 14 input signals: 13 signals from routing and one from the carry-chain (from the adjacent slice or PFU). There are seven outputs: six to routing and one to carry-chain (to the adjacent PFU). Slice 3 has 10 input signals from routing and four signals to routing. Table 2.2 lists the signals associated with Slice 0 to Slice 2.


Figure 2.3. Slice Diagram
Table 2.2. Slice Signal Descriptions

| Function | Type | Signal Names | Description |
| :--- | :--- | :--- | :--- |
| Input | Data signal | A0, BO, C0, D0 | Inputs to LUT4 |
| Input | Data signal | A1, B1, C1, D1 | Inputs to LUT4 |
| Input | Multi-purpose | M0 | Multipurpose Input |
| Input | Multi-purpose | M1 | Multipurpose Input |
| Input | Control signal | CE | Clock Enable |
| Input | Control signal | LSR | Local Set/Reset |
| Input | Control signal | CLK | System Clock |
| Input | Inter-PFU signal | FC | Fast Carry-in ${ }^{1}$ |
| Input | Inter-slice signal | FXA | Intermediate signal to generate LUT6 and LUT7 |
| Input | Inter-slice signal | FXB | Intermediate signal to generate LUT6 and LUT7 |
| Output | Data signals | FO, F1 | LUT4 output register bypass signals |
| Output | Data signals | Q0, Q1 | Register outputs |
| Output | Data signals | OFX0 | Output of a LUT5 MUX |
| Output | Data signals | OFX1 | Output of a LUT6, LUT7, LUT8 ${ }^{2}$ MUX depending on the slice |
| Output | Inter-PFU signal | FCO | Slice 2 of each PFU is the fast carry chain output ${ }^{1}$ |

## Notes:

1. See Figure 2.3 for connection details.
2. Requires two PFUs.

### 2.2.2. Modes of Operation

Each slice has up to four potential modes of operation: Logic, Ripple, RAM and ROM.

## Logic Mode

In this mode, the LUTs in each slice are configured as 4-input combinatorial lookup tables. A LUT4 can have 16 possible input combinations. Any four input logic functions can be generated by programming this lookup table. Since there are two LUT4s per slice, a LUT5 can be constructed within one slice. Larger look-up tables such as LUT6, LUT7 and LUT8 can be constructed by concatenating other slices. Note LUT8 requires more than four slices.

## Ripple Mode

Ripple mode supports the efficient implementation of small arithmetic functions. In ripple mode, the following functions can be implemented by each slice:

- Addition 2-bit
- Subtraction 2-bit
- Add/Subtract 2-bit using dynamic control
- Up counter 2-bit
- Down counter 2-bit
- Up/Down counter with asynchronous clear
- Up/Down counter with preload (sync)
- Ripple mode multiplier building block
- Multiplier support
- Comparator functions of $A$ and $B$ inputs
- A greater-than-or-equal-to $B$
- A not-equal-to $B$
- A less-than-or-equal-to B

Ripple Mode includes an optional configuration that performs arithmetic using fast carry chain methods. In this configuration (also referred to as CCU2 mode) two additional signals, Carry Generate and Carry Propagate, are generated on a per slice basis to allow fast arithmetic functions to be constructed by concatenating Slices.

## RAM Mode

In this mode, a 16x4-bit distributed single port RAM (SPR) can be constructed using each LUT block in Slice 0 and Slice 1 as a $16 \times 1$-bit memory. Slice 2 is used to provide memory address and control signals. A $16 \times 2$-bit pseudo dual port RAM (PDPR) memory is created by using one Slice as the read-write port and the other companion slice as the read-only port.
LatticeECP3 devices support distributed memory initialization. The Lattice design tools support the creation of a variety of different size memories. Where appropriate, the software will construct these using distributed memory primitives that represent the capabilities of the PFU. Table 2.3 shows the number of slices required to implement different distributed RAM primitives. For more information about using RAM in LatticeECP3 devices, see LatticeECP3 Memory Usage Guide (FPGA-TN-02188).

Table 2.3. Number of Slices Required to Implement Distributed RAM

|  | SPR 16X4 | PDPR 16X4 |
| :--- | :---: | :---: |
| Number of slices | 3 | 3 |

Note: SPR = Single Port RAM, PDPR = Pseudo Dual Port RAM

## ROM Mode

ROM mode uses the LUT logic; hence, Slices 0 through 3 can be used in ROM mode. Preloading is accomplished through the programming interface during PFU configuration.
For more information, refer to LatticeECP3 Memory Usage Guide (FPGA-TN-02188).

### 2.3. Routing

There are many resources provided in the LatticeECP3 devices to route signals individually or as busses with related control signals. The routing resources consist of switching circuitry, buffers and metal interconnect (routing) segments.
The LatticeECP3 family has an enhanced routing architecture that produces a compact design. The Diamond and ispLEVER design software tool suites take the output of the synthesis tool and places and routes the design.

## 2.4. sysCLOCK PLLs and DLLs

The sysCLOCK PLLs provide the ability to synthesize clock frequencies. The devices in the LatticeECP3 family support two to ten full-featured General Purpose PLLs.

### 2.4.1. General Purpose PLL

The architecture of the PLL is shown in Figure 2.4. A description of the PLL functionality follows.
CLKI is the reference frequency (generated either from the pin or from routing) for the PLL. CLKI feeds into the Input Clock Divider block. The CLKFB is the feedback signal (generated from CLKOP, CLKOS or from a user clock pin/logic). This signal feeds into the Feedback Divider. The Feedback Divider is used to multiply the reference frequency.

Both the input path and feedback signals enter the Phase Frequency Detect Block (PFD) which detects first for the frequency, and then the phase, of the CLKI and CLKFB are the same which then drives the Voltage Controlled Oscillator (VCO) block. In this block the difference between the input path and feedback signals is used to control the frequency and phase of the oscillator. A LOCK signal is generated by the VCO to indicate that the VCO has locked onto the input clock signal. In dynamic mode, the PLL may lose lock after a dynamic delay adjustment and not relock until the tLOCK parameter has been satisfied.

The output of the VCO then enters the CLKOP divider. The CLKOP divider allows the VCO to operate at higher frequencies than the clock output (CLKOP), thereby increasing the frequency range. The Phase/Duty Cycle/Duty Trim block adjusts the phase and duty cycle of the CLKOS signal. The phase/duty cycle setting can be pre-programmed or dynamically adjusted. A secondary divider takes the CLKOP or CLKOS signal and uses it to derive lower frequency outputs (CLKOK).
The primary output from the CLKOP divider (CLKOP) along with the outputs from the secondary dividers (CLKOK and CLKOK2) and Phase/Duty select (CLKOS) are fed to the clock distribution network.
The PLL allows two methods for adjusting the phase of signal. The first is referred to as Fine Delay Adjustment. This inserts up to 16 nominal 125 ps delays to be applied to the secondary PLL output. The number of steps may be set statically or from the FPGA logic. The second method is referred to as Coarse Phase Adjustment. This allows the phase of the rising and falling edge of the secondary PLL output to be adjusted in 22.5 degree steps. The number of steps may be set statically or from the FPGA logic.


Figure 2.4. General Purpose PLL Diagram
Table 2.4 provides a description of the signals in the PLL blocks.
Table 2.4. PLL Blocks Signal Descriptions

| Signal | I/O | Description |
| :--- | :--- | :--- |
| CLKI | I | Clock input from external pin or routing |
| CLKFB | I | PLL feedback input from CLKOP, CLKOS, or from a user clock (pin or logic) |
| RST | I | " 1 " to reset PLL counters, VCO, charge pumps and M-dividers |
| RSTK | I | "1" to reset K-divider |
| WRDEL | I | DPA Fine Delay Adjust input |
| CLKOS | O | PLL output to clock tree (phase shifted/duty cycle changed) |
| CLKOP | 0 | PLL output to clock tree (no phase shift) |
| CLKOK | O | PLL output to clock tree through secondary clock divider |
| CLKOK2 | O | PLL output to clock tree (CLKOP divided by 3) |
| LOCK | 0 | "1" indicates PLL LOCK to CLKI |
| FDA [3:0] | I | Dynamic fine delay adjustment on CLKOS output |
| DRPAI[3:0] | I | Dynamic coarse phase shift, rising edge setting |
| DFPAI[3:0] | I | Dynamic coarse phase shift, falling edge setting |

### 2.4.2. Delay Locked Loops (DLL)

In addition to PLLs, the LatticeECP3 family of devices has two DLLs per device.
CLKI is the input frequency (generated either from the pin or routing) for the DLL. CLKI feeds into the output muxes block to bypass the DLL, directly to the DELAY CHAIN block and (directly or through divider circuit) to the reference input of the Phase Detector (PD) input mux. The reference signal for the PD can also be generated from the Delay Chain signals. The feedback input to the PD is generated from the CLKFB pin or from a tapped signal from the Delay chain.
The PD produces a binary number proportional to the phase and frequency difference between the reference and feedback signals. Based on these inputs, the ALU determines the correct digital control codes to send to the delay chain in order to better match the reference and feedback signals. This digital code from the ALU is also transmitted via the Digital Control bus (DCNTL) bus to its associated Slave Delay lines (two per DLL). The ALUHOLD input allows the user to suspend the ALU output at its current value. The UDDCNTL signal allows the user to latch the current value on the DCNTL bus.

The DLL has two clock outputs, CLKOP and CLKOS. These outputs can individually select one of the outputs from the tapped delay line. The CLKOS has optional fine delay shift and divider blocks to allow this output to be further modified, if required. The fine delay shift block allows the CLKOS output to phase shifted a further 45, 22.5 or 11.25 degrees relative to its normal position. Both the CLKOS and CLKOP outputs are available with optional duty cycle correction. Divide by two and divide by four frequencies are available at CLKOS. The LOCK output signal is asserted when the DLL is locked. Figure 2.5 shows the DLL block diagram and Table 2.5 provides a description of the DLL inputs and outputs.
The user can configure the DLL for many common functions such as time reference delay mode and clock injection removal mode. Lattice provides primitives in its design tools for these functions.


Figure 2.5. Delay Locked Loop Diagram (DLL)
Table 2.5. DLL Signals

| Signal | I/O | Description |
| :--- | :--- | :--- |
| CLKI | I | Clock input from external pin or routing |
| CLKFB | I | DLL feed input from DLL output, clock net, routing or external pin |
| RSTN | I | Active low synchronous reset |
| ALUHOLD | I | Active high freezes the ALU |
| UDDCNTL | I | Synchronous enable signal (hold high for two cycles) from routing |
| CLKOP | 0 | The primary clock output |
| CLKOS | 0 | The secondary clock output with fine delay shift and/or division by 2 or by 4 |
| LOCK | O | Active high phase lock indicator |
| INCI | I | Incremental indicator from another DLL via CIB. |
| GRAYI[5:0] | I | Gray-coded digital control bus from another DLL in time reference mode. |
| DIFF | O | Difference indicator when DCNTL is difference than the internal setting and update is needed. |
| INCO | O | Incremental indicator to other DLLs via CIB. |
| GRAYO[5:0] | 0 | Gray-coded digital control bus to other DLLs via CIB |

LatticeECP3 devices have two general DLLs and four Slave Delay lines, two per DLL. The DLLs are in the lowest EBR row and located adjacent to the EBR. Each DLL replaces one EBR block. One Slave Delay line is placed adjacent to the DLL and the duplicate Slave Delay line (in Figure 2.6) for the DLL is placed in the I/O ring between Banks 6 and 7 and Banks 2 and 3.
The outputs from the DLL and Slave Delay lines are fed to the clock distribution network.
For more information, see LatticeECP3 sysCLOCK PLL/DLL Design and Usage Guide (FPGA-TN-02191).


Figure 2.6. Top-Level Block Diagram, High-Speed DLL and Slave Delay Line

### 2.4.3. PLL/DLL Cascading

LatticeECP3 devices have been designed to allow certain combinations of PLL and DLL cascading. The allowable combinations are:

- PLL to PLL supported
- PLL to DLL supported

The DLLs in the LatticeECP3 are used to shift the clock in relation to the data for source synchronous inputs. PLLs are used for frequency synthesis and clock generation for source synchronous interfaces. Cascading PLL and DLL blocks allows applications to utilize the unique benefits of both DLLs and PLLs.
For further information about the DLL, see the list of technical documentation at the end of this data sheet.

### 2.4.4. PLL/DLL PIO Input Pin Connections

All LatticeECP3 devices contains two DLLs and up to ten PLLs, arranged in quadrants. If a PLL and a DLL are next to each other, they share input pins as shown in the Figure 2.7.


Note: Not every PLL has an associated DLL.
Figure 2.7. Sharing of PIO Pins by PLLs and DLLs in LatticeECP3 Devices

### 2.5. Clock Dividers

LatticeECP3 devices have two clock dividers, one on the left side and one on the right side of the device. These are intended to generate a slower-speed system clock from a high-speed edge clock. The block operates in a $\div 2, \div 4$ or $\div 8$ mode and maintains a known phase relationship between the divided down clock and the high-speed clock based on the release of its reset signal. The clock dividers can be fed from selected PLL/DLL outputs, the Slave Delay lines, routing or from an external clock input. The clock divider outputs serve as primary clock sources and feed into the clock distribution network. The Reset (RST) control signal resets input and asynchronously forces all outputs to low. The RELEASE signal releases outputs synchronously to the input clock. For further information on clock dividers, see LatticeECP3 sysCLOCK PLL/DLL Design and Usage Guide (FPGA-TN-02191). Figure 2.8 shows the clock divider connections.


Figure 2.8. Clock Divider Connections

### 2.6. Clock Distribution Network

LatticeECP3 devices have eight quadrant-based primary clocks and eight secondary clock/control sources. Two high performance edge clocks are available on the top, left, and right edges of the device to support high speed interfaces. These clock sources are selected from external I/O, the sysCLOCK PLLs, DLLs or routing. These clock sources are fed throughout the chip via a clock distribution system.

### 2.6.1. Primary Clock Sources

LatticeECP3 devices derive clocks from six primary source types: PLL outputs, DLL outputs, CLKDIV outputs, dedicated clock inputs, routing and SERDES Quads. LatticeECP3 devices have two to ten sysCLOCK PLLs and two DLLs, located on the left and right sides of the device. There are six dedicated clock inputs: two on the top side, two on the left side and two on the right side of the device. Figure 2.9, Figure 2.10 and Figure 2.11 show the primary clock sources for LatticeECP3 devices.


Figure 2.9. Primary Clock Sources for LatticeECP3-17


Figure 2.10. Primary Clock Sources for LatticeECP3-35


Figure 2.11. Primary Clock Sources for LatticeECP3-70, -95, -150

### 2.6.2. Primary Clock Routing

The purpose of the primary clock routing is to distribute primary clock sources to the destination quadrants of the device. A global primary clock is a primary clock that is distributed to all quadrants. The clock routing structure in LatticeECP3 devices consists of a network of eight primary clock lines (CLK0 through CLK7) per quadrant. The primary clocks of each quadrant are generated from muxes located in the center of the device. All the clock sources are connected to these muxes. Figure 2.12 shows the clock routing for one quadrant. Each quadrant mux is identical. If desired, any clock can be routed globally.


Figure 2.12. Per Quadrant Primary Clock Selection

### 2.6.3. Dynamic Clock Control (DCC)

The DCC (Quadrant Clock Enable/Disable) feature allows internal logic control of the quadrant primary clock network. When a clock network is disabled, all the logic fed by that clock does not toggle, reducing the overall power consumption of the device.

### 2.6.4. Dynamic Clock Select (DCS)

The DCS is a smart multiplexer function available in the primary clock routing. It switches between two independent input clock sources without any glitches or runt pulses. This is achieved regardless of when the select signal is toggled. There are two DCS blocks per quadrant; in total, there are eight DCS blocks per device. The inputs to the DCS block come from the center muxes. The output of the DCS is connected to primary clocks CLK6 and CLK7 (see Figure 2.12).
Figure 2.13 shows the timing waveforms of the default DCS operating mode. The DCS block can be programmed to other modes. For more information about the DCS, see the list of technical documentation at the end of this data sheet.


Figure 2.13. DCS Waveforms

### 2.6.5. Secondary Clock/Control Sources

LatticeECP3 devices derive eight secondary clock sources (SC0 through SC7) from six dedicated clock input pads and the rest from routing. Figure 2.14 shows the secondary clock sources. All eight secondary clock sources are defined as inputs to a per-region mux SCO-SC7. SCO-SC3 are primary for control signals (CE and/or LSR), and SC4-SC7 are for the clock.

In an actual implementation, there is some overlap to maximize routability. In addition to SCO-SC3, SC7 is also an input to the control signals (LSR or CE). SC0-SC2 are also inputs to clocks along with SC4-SC7.


Note: Clock inputs can be configured in differential or single-ended mode.
Figure 2.14. Secondary Clock Sources

### 2.6.6. Secondary Clock/Control Routing

Global secondary clock is a secondary clock that is distributed to all regions. The purpose of the secondary clock routing is to distribute the secondary clock sources to the secondary clock regions. Secondary clocks in the LatticeECP3 devices are region-based resources. Certain EBR rows and special vertical routing channels bind the secondary clock regions. This special vertical routing channel aligns with either the left edge of the center DSP slice in the DSP row or the center of the DSP row. Figure 2.15 shows this special vertical routing channel and the 20 secondary clock regions for the LatticeECP3 family of devices. All devices in the LatticeECP3 family have eight secondary clock resources per region (SC0 to SC7). The same secondary clock routing can be used for control signals.

Table 2.6. Secondary Clock Regions

| Device | Number of Secondary Clock Regions |
| :--- | :---: |
| ECP3-17 | 16 |
| ECP3-35 | 16 |
| ECP3-70 | 20 |
| ECP3-95 | 20 |
| ECP3-150 | 36 |



Figure 2.15. LatticeECP3-70 and LatticeECP3-95 Secondary Clock Regions


Figure 2.16. Per Region Secondary Clock Selection

### 2.6.7. Slice Clock Selection

Figure 2.17 shows the clock selections and Figure 2.18 shows the control selections for Slice 0 through Slice 2. All the primary clocks and seven secondary clocks are routed to this clock selection mux. Other signals can be used as a clock input to the slices via routing. Slice controls are generated from the secondary clocks/controls or other signals connected via routing.
If none of the signals are selected for both clock and control then the default value of the mux output is 1 . Slice 3 does not have any registers; therefore it does not have the clock or control muxes.


Figure 2.17. Slice0 through Slice2 Clock Selection


Figure 2.18. Slice0 through Slice2 Control Selection

### 2.6.8. Edge Clock Sources

Edge clock resources can be driven from a variety of sources at the same edge. Edge clock resources can be driven from adjacent edge clock PIOs, primary clock PIOs, PLLs, DLLs, Slave Delay and clock dividers as shown in Figure 2.19.


Figure 2.19. Edge Clock Sources

### 2.6.9. Edge Clock Routing

LatticeECP3 devices have a number of high-speed edge clocks that are intended for use with the PIOs in the implementation of high-speed interfaces. There are six edge clocks per device: two edge clocks on each of the top, left, and right edges. Different PLL and DLL outputs are routed to the two muxes on the left and right sides of the device. In addition, the CLKINDEL signal (generated from the DLL Slave Delay Line block) is routed to all the edge clock muxes on the left and right sides of the device. Figure 2.20 shows the selection muxes for these clocks.


Figure 2.20. Sources of Edge Clock (Left and Right Edges)


Figure 2.21. Sources of Edge Clock (Top Edge)
The edge clocks have low injection delay and low skew. They are used to clock the I/O registers and thus are ideal for creating I/O interfaces with a single clock signal and a wide data bus. They are also used for DDR Memory or Generic DDR interfaces.

The edge clocks on the top, left, and right sides of the device can drive the secondary clocks or general routing resources of the device. The left and right side edge clocks also can drive the primary clock network through the clock dividers (CLKDIV).

## 2.7. sysMEM Memory

LatticeECP3 devices contain a number of sysMEM Embedded Block RAM (EBR). The EBR consists of an 18-Kbit RAM with memory core, dedicated input registers and output registers with separate clock and clock enable. Each EBR includes functionality to support true dual-port, pseudo dual-port, single-port RAM, ROM and FIFO buffers (via external PFUs).

### 2.7.1. sysMEM Memory Block

The sysMEM block can implement single port, dual port or pseudo dual port memories. Each block can be used in a variety of depths and widths as shown in Table 2.7. FIFOs can be implemented in sysMEM EBR blocks by implementing support logic with PFUs. The EBR block facilitates parity checking by supporting an optional parity bit for each data byte. EBR blocks provide byte-enable support for configurations with18-bit and 36-bit data widths. For more information, see LatticeECP3 Memory Usage Guide (FPGA-TN-02188).

Table 2.7. sysMEM Block Configurations

| Memory Mode | Configurations |
| :--- | :--- |
| Single Port | $16,384 \times 1$ |
|  | $8,192 \times 2$ |
|  | $4,096 \times 4$ |
|  | $2,048 \times 9$ |
|  | $1,024 \times 18$ |
|  | $512 \times 36$ |
|  | $16,384 \times 1$ |
|  | $8,192 \times 2$ |
| True Dual Port | $4,096 \times 4$ |
|  | $2,048 \times 9$ |
|  | $1,024 \times 18$ |
|  | $16,384 \times 1$ |
| Pseudo Dual Port | $8,192 \times 2$ |
|  | $4,096 \times 4$ |
|  | $2,048 \times 9$ |

### 2.7.2. Bus Size Matching

All of the multi-port memory modes support different widths on each of the ports. The RAM bits are mapped LSB word 0 to MSB word 0, LSB word 1 to MSB word 1, and so on. Although the word size and number of words for each port varies, this mapping scheme applies to each port.

### 2.7.3. 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.

### 2.7.4. Memory Cascading

Larger and deeper blocks of RAM can be created using EBR sysMEM Blocks. Typically, the Lattice design tools cascade memory transparently, based on specific design inputs.

### 2.7.5. Single, Dual and Pseudo-Dual Port Modes

In all the sysMEM RAM modes the input data and address for the ports are registered at the input of the memory array. The output data of the memory is optionally registered at the output.
EBR memory supports the following forms of write behavior for single port or dual port operation:

1. Normal - Data on the output appears only during a read cycle. During a write cycle, the data (at the current address) does not appear on the output. This mode is supported for all data widths.
2. Write Through - A copy of the input data appears at the output of the same port during a write cycle. This mode is supported for all data widths.
3. Read-Before-Write (EA devices only) - When new data is written, the old content of the address appears at the output. This mode is supported for $\mathrm{x} 9, \mathrm{x} 18$, and x 36 data widths.

### 2.7.6. Memory Core Reset

The memory array in the EBR utilizes latches at the $A$ and $B$ output ports. These latches can be reset asynchronously or synchronously. RSTA and RSTB are local signals, which reset the output latches associated with Port A and Port B, respectively. The Global Reset (GSRN) signal can reset both ports. The output data latches and associated resets for both ports are as shown in Figure 2.22.


Figure 2.22. Memory Core Reset

For further information on the sysMEM EBR block, see the list of technical documentation at the end of this data sheet.

## 2.8. $\quad$ sysDSP ${ }^{\text {TM }}$ Slice

The LatticeECP3 family provides an enhanced sysDSP architecture, making it ideally suited for low-cost, highperformance Digital Signal Processing (DSP) applications. Typical functions used in these applications are Finite Impulse Response (FIR) filters, Fast Fourier Transforms (FFT) functions, Correlators, Reed-Solomon/Turbo/Convolution encoders and decoders. These complex signal processing functions use similar building blocks such as multiply-adders and multiply-accumulators.

### 2.8.1. sysDSP Slice Approach Compared to General DSP

Conventional general-purpose DSP chips typically contain one to four (Multiply and Accumulate) MAC units with fixed data-width multipliers; this leads to limited parallelism and limited throughput. Their throughput is increased by higher clock speeds. The LatticeECP3, on the other hand, has many DSP slices that support different data widths.

This allows designers to use highly parallel implementations of DSP functions. Designers can optimize DSP performance vs. area by choosing appropriate levels of parallelism. Figure 2.23 compares the fully serial implementation to the mixed parallel and serial implementation.


Figure 2.23. Comparison of General DSP and LatticeECP3 Approaches

### 2.9. LatticeECP3 sysDSP Slice Architecture Features

The LatticeECP3 sysDSP Slice has been significantly enhanced to provide functions needed for advanced processing applications. These enhancements provide improved flexibility and resource utilization.
The LatticeECP3 sysDSP Slice supports many functions that include the following:

- Multiply (one $18 \times 36$, two $18 \times 18$ or four $9 \times 9$ Multiplies per Slice)
- Multiply ( $36 \times 36$ by cascading across two sysDSP slices)
- Multiply Accumulate (up to $18 \times 36$ Multipliers feeding an Accumulator that can have up to 54-bit resolution)
- Two Multiplies feeding one Accumulate per cycle for increased processing with lower latency (two $18 \times 18$ Multiplies feed into an accumulator that can accumulate up to 52 bits)
- Flexible saturation and rounding options to satisfy a diverse set of applications situations
- Flexible cascading across DSP slices
- Minimizes fabric use for common DSP and ALU functions
- Enables implementation of FIR Filter or similar structures using dedicated sysDSP slice resources only
- Provides matching pipeline registers
- Can be configured to continue cascading from one row of sysDSP slices to another for longer cascade chains
- Flexible and Powerful Arithmetic Logic Unit (ALU) Supports:
- Dynamically selectable ALU OPCODE
- Ternary arithmetic (addition/subtraction of three inputs)
- Bit-wise two-input logic operations (AND, OR, NAND, NOR, XOR and XNOR)
- Eight flexible and programmable ALU flags that can be used for multiple pattern detection scenarios, such as, overflow, underflow and convergent rounding, etc.
- Flexible cascading across slices to get larger functions
- RTL Synthesis friendly synchronous reset on all registers, while still supporting asynchronous reset for legacy users
- Dynamic MUX selection to allow Time Division Multiplexing (TDM) of resources for applications that require processor-like flexibility that enables different functions for each clock cycle

For most cases, as shown in Figure 2.24, the LatticeECP3 DSP slice is backwards-compatible with the LatticeECP2 ${ }^{\text {TM }}$ sysDSP block, such that, legacy applications can be targeted to the LatticeECP3 sysDSP slice. The functionality of one LatticeECP2 sysDSP Block can be mapped into two adjacent LatticeECP3 sysDSP slices, as shown in Figure 2.25.


Figure 2.24. Simplified sysDSP Slice Block Diagram


Note: A_ALU, B_ALU and C_ALU are internal signals generated by combining bits from $A A, A B, B A B B$ and $C$ inputs. See TN1182, Lat ticeECP3 sysDSP Usage Guide, for further information.

Figure 2.25. Detailed sysDSP Slice Diagram

The LatticeECP2 sysDSP block supports the following basic elements.

- MULT (Multiply)
- MAC (Multiply, Accumulate)
- MULTADDSUB (Multiply, Addition/Subtraction)
- MULTADDSUBSUM (Multiply, Addition/Subtraction, Summation)

Table 2.8 shows the capabilities of each of the LatticeECP3 slices versus the above functions.
Table 2.8. Maximum Number of Elements in a Slice

| Width of Multiply | x9 | $\mathbf{x 1 8}$ | $\mathbf{x 3 6}$ |
| :--- | :---: | :---: | :---: |
| MULT | 4 | 2 | $1 / 2$ |
| MAC | 1 | 1 | - |
| MULTADDSUB | 2 | 1 | - |
| MULTADDSUBSUM | $1^{1}$ | $1 / 2$ | - |

Note: One slice can implement 1/2 9x9 m9x9addsubsum and two m9x9addsubsum with two slices.
Some options are available in the four elements. The input register in all the elements can be directly loaded or can be loaded as a shift register from previous operand registers. By selecting "dynamic operation" the following operations are possible:

- In the Add/Sub option the Accumulator can be switched between addition and subtraction on every cycle.
- The loading of operands can switch between parallel and serial operations.

For further information, refer to LatticeECP3 sysDSP Usage Guide (FPGA-TN-02193).

### 2.9.1. MULT DSP Element

This multiplier element implements a multiply with no addition or accumulator nodes. The two operands, $A A$ and $A B$, are multiplied and the result is available at the output. The user can enable the input/output and pipeline registers. Figure 2.26 shows the MULT sysDSP element.


Figure 2.26. MULT sysDSP Element

### 2.9.2. MAC DSP Element

In this case, the two operands, $A A$ and $A B$, are multiplied and the result is added with the previous accumulated value. This accumulated value is available at the output. The user can enable the input and pipeline registers, but the output register is always enabled. The output register is used to store the accumulated value. The ALU is configured as the accumulator in the sysDSP slice in the LatticeECP3 family can be initialized dynamically. A registered overflow signal is also available. The overflow conditions are provided later in this document. Figure 2.27 shows the MAC sysDSP element.


Figure 2.27. MAC DSP Element

### 2.9.3. MMAC DSP Element

The LatticeECP3 supports a MAC with two multipliers. This is called Multiply Multiply Accumulate or MMAC. In this case, the two operands, $A A$ and $A B$, are multiplied and the result is added with the previous accumulated value and with the result of the multiplier operation of operands $B A$ and $B B$. This accumulated value is available at the output. The user can enable the input and pipeline registers, but the output register is always enabled. The output register is used to store the accumulated value. The ALU is configured as the accumulator in the sysDSP slice. A registered overflow signal is also available. The overflow conditions are provided later in this document. Figure 2.28 shows the MMAC sysDSP element.


Figure 2.28. MMAC sysDSP Element

### 2.9.4. MULTADDSUB DSP Element

In this case, the operands $A A$ and $A B$ are multiplied and the result is added/subtracted with the result of the multiplier operation of operands $B A$ and $B B$. The user can enable the input, output and pipeline registers. Figure 2.29 shows the MULTADDSUB sysDSP element.


Figure 2.29. MULTADDSUB

### 2.9.5. MULTADDSUBSUM DSP Element

In this case, the operands $A A$ and $A B$ are multiplied and the result is added/subtracted with the result of the multiplier operation of operands $B A$ and $B B$ of Slice 0 . Additionally, the operands $A A$ and $A B$ are multiplied and the result is added/subtracted with the result of the multiplier operation of operands BA and BB of Slice 1 . The results of both addition/subtractions are added by the second ALU following the slice cascade path. The user can enable the input, output and pipeline registers. Figure 2.30 and Figure 2.31 show the MULTADDSUBSUM sysDSP element.


Figure 2.30. MULTADDSUBSUM Slice 0


Figure 2.31. MULTADDSUBSUM Slice 1

### 2.10. Advanced sysDSP Slice Features

### 2.10.1. Cascading

The LatticeECP3 sysDSP slice has been enhanced to allow cascading. Adder trees are implemented fully in sysDSP slices, improving the performance. Cascading of slices uses the signals CIN, COUT and C Mux of the slice.

### 2.10.2. Addition

The LatticeECP3 sysDSP slice allows for the bypassing of multipliers and cascading of adder logic. High performance adder functions are implemented without the use of LUTs. The maximum width adders that can be implemented are 54-bit.

### 2.10.3. Rounding

The rounding operation is implemented in the ALU and is done by adding a constant followed by a truncation operation.

The rounding methods supported are:

- Rounding to zero (RTZ)
- Rounding to infinity (RTI)
- Dynamic rounding
- Random rounding
- Convergent rounding


### 2.10.4. ALU Flags

The sysDSP slice provides a number of flags from the ALU including:

- Equal to zero (EQZ)
- Equal to zero with mask (EQZM)
- Equal to one with mask (EQOM)
- Equal to pattern with mask (EQPAT)
- Equal to bit inverted pattern with mask (EQPATB)
- Accumulator Overflow (OVER)
- Accumulator Underflow (UNDER)
- Either over or under flow supporting LatticeECP2 legacy designs (OVERUNDER)


### 2.10.5. Clock, Clock Enable and Reset Resources

Global Clock, Clock Enable and Reset signals from routing are available to every sysDSP slice. From four clock sources (CLKO, CLK1, CLK2, and CLK3) one clock is selected for each input register, pipeline register and output register.
Similarly Clock Enable (CE) and Reset (RST) are selected at each input register, pipeline register and output register.

### 2.10.6. Resources Available in the LatticeECP3 Family

Table 2.9 shows the maximum number of multipliers for each member of the LatticeECP3 family. Table 2.10 shows the maximum available EBR RAM Blocks in each LatticeECP3 device. EBR blocks, together with Distributed RAM can be used to store variables locally for fast DSP operations.

Table 2.9. Maximum Number of DSP Slices in the LatticeECP3 Family

| Device | DSP Slices | 9x9 Multiplier | $\mathbf{1 8 x} \mathbf{1 8}$ Multiplier | $\mathbf{3 6 x 3 6}$ Multiplier |
| :--- | :---: | :---: | :---: | :---: |
| ECP3-17 | 12 | 48 | 24 | 6 |
| ECP3-35 | 32 | 128 | 64 | 16 |
| ECP3-70 | 64 | 256 | 128 | 32 |
| ECP3-95 | 64 | 256 | 128 | 32 |
| ECP3-150 | 160 | 640 | 320 | 80 |

Table 2.10. Embedded SRAM in the LatticeECP3 Family

| Device | EBR SRAM Block | Total EBR SRAM (Kbits) |
| :--- | :---: | :---: |
| ECP3-17 | 38 | 700 |
| ECP3-35 | 72 | 1327 |
| ECP3-70 | 240 | 4420 |
| ECP3-95 | 240 | 4420 |
| ECP3-150 | 372 | 6850 |

## 3. Programmable I/O Cells (PIC)

Each PIC contains two PIOs connected to their respective sysI/O buffers as shown in Figure 3.1. The PIO Block supplies the output data (DO) and the tri-state control signal (TO) to the sysl/O buffer and receives input from the buffer. Table 3.1 provides the PIO signal list.


* Signals are available on left/right/top edges only.
** Signals are available on the left and right sides only
*** Selected PIO.
Figure 3.1. PIC Diagram

Two adjacent PIOs can be joined to provide a differential I/O pair (labeled as "T" and " C ") as shown in Figure 3.1. The PAD Labels " $T$ " and " C " distinguish the two PIOs. Approximately $50 \%$ of the PIO pairs on the left and right edges of the device can be configured as true LVDS outputs. All I/O pairs can operate as LVDS inputs.

Table 3.1. PIO Signal List

| Name | Type | Description |
| :---: | :---: | :---: |
| INDD | Input Data | Register bypassed input. This is not the same port as INCK. |
| IPA, INA, IPB, INB | Input Data | Ports to core for input data |
| OPOSA, ONEGA ${ }^{1}$, OPOSB, ONEGB ${ }^{1}$ | Output Data | Output signals from core. An exception is the ONEGB port, used for tristate logic at the DQS pad. |
| CE | PIO Control | Clock enables for input and output block flip-flops. |
| SCLK | PIO Control | System Clock (PCLK) for input and output/TS blocks. Connected from clock ISB. |
| LSR | PIO Control | Local Set/Reset |
| ECLK1, ECLK2 | PIO Control | Edge clock sources. Entire PIO selects one of two sources using mux. |
| ECLKDQSR ${ }^{1}$ | Read Control | From DQS_STROBE, shifted strobe for memory interfaces only. |
| DDRCLKPOL ${ }^{1}$ | Read Control | Ensures transfer from DQS domain to SCLK domain. |
| DDRLAT ${ }^{1}$ | Read Control | Used to guarantee INDDRX2 gearing by selectively enabling a D-Flip-Flop in datapath. |
| DEL[3:0] | Read Control | Dynamic input delay control bits. |
| INCK | To Clock Distribution and PLL | PIO treated as clock PIO, path to distribute to primary clocks and PLL. |
| TS | Tristate Data | Tristate signal from core (SDR) |
|  | Write Control | Two clocks edges, 90 degrees out of phase, used in output gearing. |
| DQSW ${ }^{2}$ | Write Control | Used for output and tristate logic at DQS only. |
| DYNDEL[7:0] | Write Control | Shifting of write clocks for specific DQS group, using 6:0 each step is approximately 25 ps, 128 steps. Bit 7 is an invert (timing depends on input frequency). There is also a static control for this 8-bit setting, enabled with a memory cell. |
| DCNTL[6:0] | PIO Control | Original delay code from DDR DLL |
| DATAVALID ${ }^{1}$ | Output Data | Status flag from DATAVALID logic, used to indicate when input data is captured in IOLOGIC and valid to core. |
| READ | For DQS_Strobe | Read signal for DDR memory interface |
| DQSI | For DQS_Strobe | Unshifted DQS strobe from input pad |
| PRMBDET | For DQS_Strobe | DQSI biased to go high when DQSI is tristate, goes to input logic block as well as core logic. |
| GSRN | Control from routing | Global Set/Reset |

## Notes:

1. Signals available on left/right/top edges only.
2. Selected PIO.

### 3.1. PIO

The PIO contains four blocks: an input register block, output register block, tristate register block and a control logic block. These blocks contain registers for operating in a variety of modes along with the necessary clock and selection logic.

### 3.1.1. Input Register Block

The input register blocks for the PIOs, in the left, right and top edges, contain delay elements and registers that can be used to condition high-speed interface signals, such as DDR memory interfaces and source synchronous interfaces, before they are passed to the device core. Figure 3.2 shows the input register block for the left, right and top edges. The input register block for the bottom edge contains one element to register the input signal and no DDR registers. The following description applies to the input register block for PIOs in the left, right and top edges only.

Input signals are fed from the sysI/O buffer to the input register block (as signal DI). If desired, the input signal can bypass the register and delay elements and be used directly as a combinatorial signal (INDD), a clock (INCK) and, in selected blocks, the input to the DQS delay block. If an input delay is desired, designers can select either a fixed delay or a dynamic delay DEL[3:0]. The delay, if selected, reduces input register hold time requirements when using a global clock.

The input block allows three modes of operation. In single data rate (SDR) the data is registered with the system clock by one of the registers in the single data rate sync register block.
In DDR mode, two registers are used to sample the data on the positive and negative edges of the modified DQS (ECLKDQSR) in the DDR Memory mode or ECLK signal when using DDR Generic mode, creating two data streams. Before entering the core, these two data streams are synchronized to the system clock to generate two data streams.

A gearbox function can be implemented in each of the input registers on the left and right sides. The gearbox function takes a double data rate signal applied to PIOA and converts it as four data streams, INA, IPA, INB and IPB. The two data streams from the first set of DDR registers are synchronized to the edge clock and then to the system clock before entering the core. Figure 2.30 provides further information on the use of the gearbox function.
The signal DDRCLKPOL controls the polarity of the clock used in the synchronization registers. It ensures adequate timing when data is transferred to the system clock domain from the ECLKDQSR (DDR Memory Interface mode) or ECLK (DDR Generic mode). The DDRLAT signal is used to ensure the data transfer from the synchronization registers to the clock transfer and gearbox registers.
The ECLKDQSR, DDRCLKPOL and DDRLAT signals are generated in the DQS Read Control Logic Block. See Figure 3.6 for an overview of the DQS read control logic.

Further discussion about using the DQS strobe in this module is discussed in the DDR Memory section of this data sheet.
See LatticeECP3 High-Speed I/O Interface (FPGA-TN-02184) for more information on this topic.


* Only on the left and right sides.
** Selected PIO.
Note: Simplified diagram does not show CE/SET/REST details
Figure 3.2. Input Register Block for Left, Right and Top Edges


### 3.1.2. Output Register Block

The output register block registers signals from the core of the device before they are passed to the sysl/O buffers. The blocks on the left and right PIOs contain registers for SDR and full DDR operation. The topside PIO block is the same as the left and right sides except it does not support ODDRX2 gearing of output logic. ODDRX2 gearing is used in DDR3 memory interfaces. The PIO blocks on the bottom contain the SDR registers but do not support generic DDR.

Figure 3.3 shows the Output Register Block for PIOs on the left and right edges.
In SDR mode, OPOSA feeds one of the flip-flops that then feeds the output. The flip-flop can be configured as a Dtype or latch. In DDR mode, two of the inputs are fed into registers on the positive edge of the clock. At the next clock cycle, one of the registered outputs is also latched.
A multiplexer running off the same clock is used to switch the mux between the 11 and 01 inputs that will then feed the output.
A gearbox function can be implemented in the output register block that takes four data streams: OPOSA, ONEGA, OPOSB and ONEGB. All four data inputs are registered on the positive edge of the system clock and two of them are also latched. The data is then output at a high rate using a multiplexer that runs off the DQCLK0 and DQCLK1 clocks. DQCLK0 and DQCLK1 are used in this case to transfer data from the system clock to the edge clock domain. These signals are generated in the DQS Write Control Logic block. See Figure 3.6 for an overview of the DQS write control logic.
See LatticeECP3 High-Speed I/O Interface (FPGA-TN-02184) for more information on this topic.
Further discussion on using the DQS strobe in this module is discussed in the DDR Memory section of this data sheet.


Figure 3.3. Output and Tristate Block for Left and Right Edges

### 3.1.3. Tristate Register Block

The tristate register block registers tri-state control signals from the core of the device before they are passed to the sysI/O buffers. The block contains a register for SDR operation and an additional register for DDR operation.
In SDR and non-gearing DDR modes, TS input feeds one of the flip-flops that then feeds the output. In DDRX2 mode, the register TS input is fed into another register that is clocked using the DQCLK0 and DQCLK1 signals. The output of this register is used as a tristate control.

### 3.1.4. ISI Calibration

The setting for Inter-Symbol Interference (ISI) cancellation occurs in the output register block. ISI correction is only available in the DDRX2 modes. ISI calibration settings exist once per output register block, so each I/O in a DQS-12 group may have a different ISI calibration setting.
The ISI block extends output signals at certain times, as a function of recent signal history. So, if the output pattern consists of a long strings of 0 's to long strings of 1's, there are no delays on output signals. However, if there are quick, successive transitions from 010, the block will stretch out the binary 1. This is because the long trail of 0's will cause these symbols to interfere with the logic 1. Likewise, if there are quick, successive transitions from 101, the block will stretch out the binary 0 . This block is controlled by a 3-bit delay control that can be set in the DQS control logic block. For more information about this topic, see the list of technical documentation at the end of this data sheet.

### 3.1.5. Control Logic Block

The control logic block allows the selection and modification of control signals for use in the PIO block.

### 3.2. DDR Memory Support

Certain PICs have additional circuitry to allow the implementation of high-speed source synchronous and DDR, DDR2 and DDR3 memory interfaces. The support varies by the edge of the device as detailed below.

### 3.2.1. Left and Right Edges

The left and right sides of the PIC have fully functional elements supporting DDR, DDR2, and DDR3 memory interfaces. One of every 12 PIOs supports the dedicated DQS pins with the DQS control logic block. Figure 3.4 shows the DQS bus spanning 11 I/O pins. Two of every 12 PIOs support the dedicated DQS and DQS\# pins with the DQS control logic block.

### 3.2.2. Bottom Edge

PICs on the bottom edge of the device do not support DDR memory and Generic DDR interfaces.

### 3.2.3. Top Edge

PICs on the top side are similar to the PIO elements on the left and right sides but do not support gearing on the output registers. Hence, the modes to support output/tristate DDR3 memory are removed on the top side.
The exact DQS pins are shown in a dual function in the Logic Signal Connections table in this data sheet. Additional detail is provided in the Signal Descriptions table. The DQS signal from the bus is used to strobe the DDR data from the memory into input register blocks. Interfaces on the left, right and top edges are designed for DDR memories that support 10 bits of data.


Figure 3.4. DQS Grouping on the Left, Right and Top Edges

### 3.2.4. DLL Calibrated DQS Delay Block

Source synchronous interfaces generally require the input clock to be adjusted in order to correctly capture data at the input register. For most interfaces, a PLL is used for this adjustment. However, in DDR memories the clock (referred to as DQS) is not free-running so this approach cannot be used. The DQS Delay block provides the required clock alignment for DDR memory interfaces.

The delay required for the DQS signal is generated by two dedicated DLLs (DDR DLL) on opposite side of the device. Each DLL creates DQS delays in its half of the device as shown in Figure 3.5. The DDR DLL on the left side will generate delays for all the DQS Strobe pins on Banks 0,7 and 6 and DDR DLL on the right will generate delays for all the DQS pins on Banks 1, 2 and 3. The DDR DLL loop compensates for temperature, voltage and process variations by using the system clock and DLL feedback loop. DDR DLL communicates the required delay to the DQS delay block using a 7-bit calibration bus (DCNTL[6:0])
The DQS signal (selected PIOs only, as shown in Figure 3.4) feeds from the PAD through a DQS control logic block to a dedicated DQS routing resource. The DQS control logic block consists of DQS Read Control logic block that generates control signals for the read side and DQS Write Control logic that generates the control signals required for the write side. A more detailed DQS control diagram is shown in Figure 3.6, which shows how the DQS control blocks interact with the data paths.
The DQS Read control logic receives the delay generated by the DDR DLL on its side and delays the incoming DQS signal by 90 degrees. This delayed ECLKDQSR is routed to 10 or 11 DQ pads covered by that DQS signal. This block also contains a polarity control logic that generates a DDRCLKPOL signal, which controls the polarity of the clock to the sync registers in the input register blocks. The DQS Read control logic also generates a DDRLAT signal that is in the input register block to transfer data from the first set of DDR register to the second set of DDR registers when using the DDRX2 gearbox mode for DDR3 memory interface.
The DQS Write control logic block generates the DQCLKO and DQCLK1 clocks used to control the output gearing in the Output register block which generates the DDR data output and the DQS output. They are also used to control the generation of the DQS output through the DQS output register block. In addition to the DCNTL [6:0] input from the DDR DLL, the DQS Write control block also uses a Dynamic Delay DYN DEL [7:0] attribute which is used to further delay the DQS to accomplish the write leveling found in DDR3 memory. Write leveling is controlled by the DDR memory controller implementation. The DYN DELAY can set 128 possible delay step settings. In addition, the most significant bit will invert the clock for a 180-degree shift of the incoming clock. This will generate the DQSW signal used to generate the DQS output in the DQS output register block.

Figure 3.5 and Figure 3.6 show how the DQS transition signals that are routed to the PIOs.
See LatticeECP3 High-Speed I/O Interface (FPGA-TN-02184) for more information on this topic.

*Includes shared configuration I/Os and dedicated configuration I/Os.

Figure 3.5. Edge Clock, DLL Calibration and DQS Local Bus Distribution


Figure 3.6. DQS Local Bus

### 3.2.5. Polarity Control Logic

In a typical DDR Memory interface design, the phase relationship between the incoming delayed DQS strobe and the internal system clock (during the READ cycle) is unknown. The LatticeECP3 family contains dedicated circuits to transfer data between these domains. A clock polarity selector is used to prevent set-up and hold violations at the domain transfer between DQS (delayed) and the system clock. This changes the edge on which the data is registered in the synchronizing registers in the input register block. This requires evaluation at the start of each READ cycle for the correct clock polarity.
Prior to the READ operation in DDR memories, DQS is in tristate (pulled by termination). The DDR memory device drives DQS low at the start of the preamble state. A dedicated circuit detects the first DQS rising edge after the preamble state. This signal is used to control the polarity of the clock to the synchronizing registers.

### 3.2.6. DDR3 Memory Support

LatticeECP3 supports the read and write leveling required for DDR3 memory interfaces.
Read leveling is supported by the use of the DDRCLKPOL and the DDRLAT signals generated in the DQS Read Control logic block. These signals dynamically control the capture of the data with respect to the DQS at the input register block.
To accomplish write leveling in DDR3, each DQS group has a slightly different delay that is set by DYN DELAY[7:0] in the DQS Write Control logic block. The DYN DELAY can set 128 possible delay step settings. In addition, the most significant bit will invert the clock for a 180-degree shift of the incoming clock.
LatticeECP3 input and output registers can also support DDR gearing that is used to receive and transmit the high speed DDR data from and to the DDR3 Memory.
LatticeECP3 supports the 1.5V SSTL I/O standard required for the DDR3 memory interface. For more information, refer to the sysIO section of this data sheet.
See LatticeECP3 High-Speed I/O (FPGA-TN-02184) Interface for more information on DDR Memory interface implementation in LatticeECP3.

## 3.3. sysI/O Buffer

Each I/O is associated with a flexible buffer referred to as a sysI/O buffer. These buffers are arranged around the periphery of the device in groups referred to as banks. The sysI/O buffers allow users to implement the wide variety of standards that are found in today's systems including LVDS, BLVDS, HSTL, SSTL Class I \& II, LVCMOS, LVTTL, LVPECL, PCI.

### 3.3.1. sysI/O Buffer Banks

LatticeECP3 devices have six sysI/O buffer banks: six banks for user I/O arranged two per side. The banks on the bottom side are wraparounds of the banks on the lower right and left sides. The seventh sysl/O buffer bank (Configuration Bank) is located adjacent to Bank 2 and has dedicated/shared I/O for configuration. When a shared pin is not used for configuration it is available as a user I/O. Each bank is capable of supporting multiple I/O standards. Each sysI/O bank has its own I/O supply voltage (VCCIO). In addition, each bank, except the Configuration Bank, has voltage references, VREF1 and VREF2, which allow it to be completely independent from the others. Figure 3.7 shows the seven banks and their associated supplies.
In LatticeECP3 devices, single-ended output buffers and ratioed input buffers (LVTTL, LVCMOS and PCI) are powered using VCCIO. LVTTL, LVCMOS33, LVCMOS25 and LVCMOS12 can also be set as fixed threshold inputs independent of VCCIO.

Each bank can support up to two separate VREF voltages, VREF1 and VREF2, that set the threshold for the referenced input buffers. Some dedicated I/O pins in a bank can be configured to be a reference voltage supply pin. Each I/O is individually configurable based on the bank's supply and reference voltages.

TOP


Figure 3.7. LatticeECP3 Banks
LatticeECP3 devices contain two types of sysI/O buffer pairs.

## - Top (Bank 0 and Bank 1) and Bottom sysIO Buffer Pairs (Single-Ended Outputs Only)

The sysl/O buffer pairs in the top banks of the device consist of two single-ended output drivers and two sets of single-ended input buffers (both ratioed and referenced). One of the referenced input buffers can also be configured as a differential input. Only the top edge buffers have a programmable PCl clamp.

The two pads in the pair are described as "true" and "comp", where the true pad is associated with the positive side of the differential input buffer and the comp (complementary) pad is associated with the negative side of the differential input buffer.
The top and bottom sides are ideal for general purpose I/O, PCI, and inputs for LVDS (LVDS outputs are only allowed on the left and right sides). The top side can be used for the DDR3 ADDR/CMD signals.

The I/O pins located on the top and bottom sides of the device (labeled PTxxA/B or PBxxA/B) are fully hot socketable. Note that the pads in Banks 3, 6 and 8 are wrapped around the corner of the device. In these banks, only the pads located on the top or bottom of the device are hot socketable. The top and bottom side pads can be identified by the Lattice Diamond tool.

- Left and Right (Banks 2, 3, 6 and 7) sysl/O Buffer Pairs (50\% Differential and 100\% Single-Ended Outputs)

The sysl/O buffer pairs in the left and right banks of the device consist of two single-ended output drivers, two sets of single-ended input buffers (both ratioed and referenced) and one differential output driver. One of the referenced input buffers can also be configured as a differential input. In these banks the two pads in the pair are described as "true" and "comp", where the true pad is associated with the positive side of the differential I/O, and the comp (complementary) pad is associated with the negative side of the differential I/O.
In addition, programmable on-chip input termination (parallel or differential, static or dynamic) is supported on these sides, which is required for DDR3 interface. However, there is no support for hot-socketing for the I/O pins located on the left and right side of the device as the PCI clamp is always enabled on these pins.
LVDS, RSDS, PPLVDS and Mini-LVDS differential output drivers are available on 50\% of the buffer pairs on the left and right banks.

- Configuration Bank sysl/O Buffer Pairs (Single-Ended Outputs, Only on Shared Pins When Not Used by Configuration)
The sysl/O buffers in the Configuration Bank consist of ratioed single-ended output drivers and single-ended input buffers. This bank does not support PCI clamp like the other banks on the top, left, and right sides.
The two pads in the pair are described as "true" and "comp", where the true pad is associated with the positive side of the differential input buffer and the comp (complementary) pad is associated with the negative side of the differential input buffer.
Programmable PCI clamps are only available on the top banks. PCI clamps are used primarily on inputs and bidirectional pads to reduce ringing on the receiving end.


### 3.3.2. Typical sysI/O I/O Behavior During Power-up

The internal power-on-reset (POR) signal is deactivated when $\mathrm{V}_{\mathrm{cc}}, \mathrm{VCCIO8}$ and Vccaux have reached satisfactory levels. After the POR signal is deactivated, the FPGA core logic becomes active. It is the user's responsibility to ensure that all other Vccıo 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. For more information about controlling the output logic state with valid input logic levels during power-up in LatticeECP3 devices, see the list of technical documentation at the end of this data sheet.
The $\mathrm{V}_{c c}$ and $\mathrm{V}_{\text {ccaux }}$ supply the power to the FPGA core fabric, whereas the $\mathrm{V}_{\text {ccio }}$ supplies power to the I/O buffers. In order to simplify system design while providing consistent and predictable I/O behavior, it is recommended that the I/O buffers be powered-up prior to the FPGA core fabric. Vccıo supplies should be powered-up before or together with the $V_{c c}$ and $V_{c c a u x}$ supplies.

### 3.3.3. Supported sysI/O Standards

The LatticeECP3 sysI/O buffer supports both single-ended and differential standards. Single-ended standards can be further subdivided into LVCMOS, LVTTL and other standards. The buffers support the LVTTL, LVCMOS 1.2 V, $1.5 \mathrm{~V}, 1.8$ $\mathrm{V}, 2.5 \mathrm{~V}$ and 3.3 V standards. In the LVCMOS and LVTTL modes, the buffer has individual configuration options for drive strength, slew rates, bus maintenance (weak pull-up, weak pull-down, or a bus-keeper latch) and open drain. Other single-ended standards supported include SSTL and HSTL. Differential standards supported include LVDS, BLVDS, LVPECL, MLVDS, RSDS, Mini-LVDS, PPLVDS (point-to-point LVDS), TRLVDS (Transition Reduced LVDS), differential SSTL and differential HSTL. For further information on utilizing the sysl/O buffer to support a variety of standards see LatticeECP3 sysIO Usage Guide (FPGA-TN-02194).

### 3.3.4. On-Chip Programmable Termination

The LatticeECP3 supports a variety of programmable on-chip terminations options, including:

- Dynamically switchable Single-Ended Termination with programmable resistor values of 40,50, or 60 Ohms. External termination to Vtt should be used for DDR2 and DDR3 memory controller implementation.
- Common mode termination of $80,100,120$ Ohms for differential inputs


Figure 3.8. On-Chip Termination
See Table 3.2 for termination options for input modes.
Table 3.2. On-Chip Termination Options for Input Modes

| IO_TYPE | TERMINATE to VTT |  |
| :--- | :---: | :---: |
| 1,2 | DIFFERENTIAL TERMINATION RESISTOR ${ }^{1}$ |  |
| LVDS25 | p | $80,100,120$ |
| BLVDS25 | p | $80,100,120$ |
| MLVDS | p | $80,100,120$ |
| HSTL18_I | $40,50,60$ | p |
| HSTL18_II | $40,50,60$ | p |
| HSTL18D_I | $40,50,60$ | p |
| HSTL18D_II | $40,50,60$ | p |
| HSTL15_I | $40,50,60$ | p |
| HSTL15D_I | $40,50,60$ | p |
| SSTL25_I | $40,50,60$ | p |
| SSTL25_II | $40,50,60$ | p |
| SSTL25D_I | $40,50,60$ | p |
| SSTL25D_II | $40,50,60$ | p |
| SSTL18_I | $40,50,60$ | p |
| SSTL18_II | $40,50,60$ | p |
| SSTL18D_I | $40,50,60$ | p |
| SSTL18D_II | $40,50,60$ | p |
| SSTL15 | $40,50,60$ | p |
| SSTL15D | $40,50,60$ | p |

## Notes:

1. TERMINATE to VTT and DIFFRENTIAL TERMINATION RESISTOR when turned on can only have one setting per bank. Only left and right banks have this feature. Use of TERMINATE to VTT and DIFFRENTIAL TERMINATION RESISTOR are mutually exclusive in an I/O bank.
On-chip termination tolerance + - $20 \%$
2. External termination to VTT should be used when implementing DDR2 and DDR3 memory controller.

See LatticeECP3 sysIO Usage Guide (FPGA-TN-02194) for on-chip termination usage and value ranges.

### 3.3.5. Equalization Filter

Equalization filtering is available for single-ended inputs on both true and complementary I/O, and for differential inputs on the true I/O on the left, right, and top sides. Equalization is required to compensate for the difficulty of sampling alternating logic transitions with a relatively slow slew rate. It is considered the most useful for the Input DDRX2 modes, used in DDR3 memory, LVDS, or TRLVDS signaling. Equalization filter acts as a tunable filter with settings to determine the level of correction. In the LatticeECP3 devices, there are four settings available: 0 (none), 1, 2 and 3 . The default setting is 0 . The equalization logic resides in the sysl/O buffers, the two bits of setting is set uniquely in each input IOLOGIC block. Therefore, each sysI/O can have a unique equalization setting within a DQS-12 group.

### 3.3.6. Hot Socketing

LatticeECP3 devices have been carefully designed to ensure predictable behavior during power-up and powerdown. During power-up and power-down sequences, the I/O remain in tri-state until the power supply voltage is high enough to ensure reliable operation. In addition, leakage into I/O pins is controlled within specified limits. Refer to the Hot Socketing Specifications1, 2, 3 section in this data sheet.

### 3.4. SERDES and PCS (Physical Coding Sublayer)

LatticeECP3 devices feature up to 16 channels of embedded SERDES/PCS arranged in quads at the bottom of the devices supporting up to 3.2Gbps data rate. Figure 3.9 shows the position of the quad blocks for the LatticeECP3-150 devices. Table 3.3 shows the location of available SERDES Quads for all devices.
The LatticeECP3 SERDES/PCS supports a range of popular serial protocols, including:

- PCI Express 1.1
- Ethernet (XAUI, GbE - 1000 Base CS/SX/LX and SGMII)
- Serial RapidIO
- SMPTE SDI (3G, HD, SD)
- CPRI
- SONET/SDH (STS-3, STS-12, STS-48)

Each quad contains four dedicated SERDES for high speed, full duplex serial data transfer. Each quad also has a PCS block that interfaces to the SERDES channels and contains protocol specific digital logic to support the standards listed above. The PCS block also contains interface logic to the FPGA fabric. All PCS logic for dedicated protocol support can also be bypassed to allow raw 8-bit or 10-bit interfaces to the FPGA fabric.
Even though the SERDES/PCS blocks are arranged in quads, multiple baud rates can be supported within a quad with the use of dedicated, per channel $\div 1, \div 2$ and $\div 11$ rate dividers. Additionally, multiple quads can be arranged together to form larger data pipes.
For information on how to use the SERDES/PCS blocks to support specific protocols, as well on how to combine multiple protocols and baud rates within a device, refer to LatticeECP3 SERDES/PCS Usage Guide (FPGA-TN-02190).


Figure 3.9. SERDES/PCS Quads (LatticeECP3-150)
Table 3.3. LatticeECP3 SERDES Standard Support

| Standard | Data Rate (Mbps) | Number of General/Link Width | Encoding Style |
| :---: | :---: | :---: | :---: |
| PCI Express 1.1 | 2500 | x1, $\mathrm{x} 2, \mathrm{x} 4$ | 8b10b |
| Gigabit Ethernet | 1250, 2500 | x 1 | 8b10b |
| SGMII | 1250 | x1 | 8b10b |
| XAUI | 3125 | x4 | 8b10b |
| Serial RapidIO Type I, Serial RapidıO Type II, Serial RapidIO Type III | 1250, 2500, 3125 | x1, x4 | 8b10b |
| CPRI-1, CPRI-2, CPRI-3, CPRI-4 | 614.4, 1228.8, 2457.6, 3072.0 | x1 | 8b10b |
| SD-SDI (259M, 344M) | $143^{1}, 177^{1}, 270,360,540$ | $\times 1$ | NRZI/Scrambled |
| HD-SDI (292M) | 1483.5, 1485 | x1 | NRZI/Scrambled |
| 3G-SDI (424M) | 2967, 2970 | x1 | NRZI/Scrambled |
| SONET-STS-3 ${ }^{2}$ | 155.52 | x1 | N/A |
| SONET-STS-12 ${ }^{2}$ | 622.08 | x1 | N/A |
| SONET-STS-48 ${ }^{2}$ | 2488 | x1 | N/A |

## Notes:

1. For slower rates, the SERDES are bypassed and CML signals are directly connected to the FPGA routing.
2. The SONET protocol is supported in 8-bit SERDES mode. See Lattice ECP3 SERDES/PCS Usage Guide (FPGA-TN-02190) for more information.

Table 3.4. Available SERDES Quads per LatticeECP3 Devices

| Package | ECP3-17 | ECP3-35 | ECP3-70 | ECP3-95 | ECP3-150 |
| :--- | :---: | :---: | :---: | :---: | :---: |
| 256 ftBGA | 1 | 1 | - | - | - |
| 328 csBGA | 2 channels | - | - | - | - |
| 484 fpBGA | 1 | 1 | 1 | 1 | - |
| 672 fpBGA | - | 1 | 2 | 2 | 2 |
| 1156 fpBGA | - | - | 3 | 3 | 4 |

### 3.4.1. SERDES Block

A SERDES receiver channel may receive the serial differential data stream, equalize the signal, perform Clock and Data Recovery (CDR) and de-serialize the data stream before passing the 8 - or 10 -bit data to the PCS logic. The SERDES transmitter channel may receive the parallel 8- or 10-bit data, serialize the data and transmit the serial bit stream through the differential drivers. Figure 3.10 shows a single-channel SERDES/PCS block. Each SERDES channel provides a recovered clock and a SERDES transmit clock to the PCS block and to the FPGA core logic.

Each transmit channel, receiver channel, and SERDES PLL shares the same power supply (VCCA). The output and input buffers of each channel have their own independent power supplies (VCCOB and VCCIB).


Figure 3.10. Simplified Channel Block Diagram for SERDES/PCS Block

### 3.4.2. PCS

As shown in Figure 3.10, the PCS receives the parallel digital data from the deserializer and selects the polarity, performs word alignment, decodes ( $8 \mathrm{~b} / 10 \mathrm{~b}$ ), provides Clock Tolerance Compensation and transfers the clock domain from the recovered clock to the FPGA clock via the Down Sample FIFO.
For the transmit channel, the PCS block receives the parallel data from the FPGA core, encodes it with 8b/10b, selects the polarity and passes the $8 / 10$ bit data to the transmit SERDES channel.

The PCS also provides bypass modes that allow a direct 8-bit or 10-bit interface from the SERDES to the FPGA logic. The PCS interface to the FPGA can also be programmed to run at $1 / 2$ speed for a 16-bit or 20-bit interface to the FPGA logic.

### 3.4.3. SCI (SERDES Client Interface) Bus

The SERDES Client Interface (SCI) is an IP interface that allows the SERDES/PCS Quad block to be controlled by registers rather than the configuration memory cells. It is a simple register configuration interface that allows SERDES/PCS configuration without power cycling the device. The Diamond and ispLEVER design tools support all modes of the PCS. Most modes are dedicated to applications associated with a specific industry standard data protocol. Other more general purpose modes allow users to define their own operation. With these tools, the user can define the mode for each quad in a design. Popular standards such as 10 Gb Ethernet, $x 4 \mathrm{PCI}$ Express and $4 x$ Serial RapidIO can be implemented using IP (available through Lattice), a single quad (Four SERDES channels and PCS) and some additional logic from the core.
The LatticeECP3 family also supports a wide range of primary and secondary protocols. Within the same quad, the LatticeECP3 family can support mixed protocols with semi-independent clocking as long as the required clock frequencies are integer $\times 1, x 2$, or $\times 11$ multiples of each other. Table 3.5 lists the allowable combination of primary and secondary protocol combinations.

### 3.5. Flexible Quad SERDES Architecture

The LatticeECP3 family SERDES architecture is a quad-based architecture. For most SERDES settings and standards, the whole quad (consisting of four SERDES) is treated as a unit. This helps in silicon area savings, better utilization and overall lower cost.
However, for some specific standards, the LatticeECP3 quad architecture provides flexibility; more than one standard can be supported within the same quad.
Table 3.5 shows the standards can be mixed and matched within the same quad. In general, the SERDES standards whose nominal data rates are either the same or a defined subset of each other, can be supported within the same quad. In Table 3.5, the Primary Protocol column refers to the standard that determines the reference clock and PLL settings. The Secondary Protocol column shows the other standard that can be supported within the same quad.
Furthermore, Table 3.5 also implies that more than two standards in the same quad can be supported, as long as they conform to the data rate and reference clock requirements. For example, a quad may contain PCI Express 1.1, SGMII, Serial RapidIO Type I and Serial RapidIO Type II, all in the same quad.

Table 3.5. LatticeECP3 Primary and Secondary Protocol Support

| Primary Protocol | Secondary Protocol |
| :--- | :--- |
| PCI Express 1.1 | SGMII |
| PCI Express 1.1 | Gigabit Ethernet |
| PCI Express 1.1 | Serial RapidIO Type I |
| PCI Express 1.1 | Serial RapidIO Type II |
| Serial RapidIO Type I | SGMII |
| Serial RapidIO Type I | Gigabit Ethernet |
| Serial RapidIO Type II | SGMII |
| Serial RapidIO Type II | Gigabit Ethernet |
| Serial RapidIO Type II | Serial RapidIO Type I |
| CPRI-3 | CPRI-2 and CPRI-1 |
| 3G-SDI | HD-SDI and SD-SDI |

There are some restrictions to be aware of when using spread spectrum. When a quad shares a PCI Express $x 1$ channel with a non- PCl Express channel, ensure that the reference clock for the quad is compatible with all protocols within the quad. For example, a PCI Express spread spectrum reference clock is not compatible with most Gigabit Ethernet applications because of tight CTC ppm requirements.
While the LatticeECP3 architecture will allow the mixing of a PCI Express channel and a Gigabit Ethernet, Serial RapidIO or SGMII channel within the same quad, using a PCI Express spread spectrum clocking as the transmit reference clock will cause a violation of the Gigabit Ethernet, Serial RapidIO and SGMII transmit jitter specifications.

For further information on SERDES, see LatticeECP3 SERDES/PCS Usage Guide (FPGA-TN-02190).

### 3.6. IEEE 1149.1-Compliant Boundary Scan Testability

All LatticeECP3 devices have boundary scan cells that are accessed through an IEEE 1149.1 compliant Test Access Port (TAP). This allows functional testing of the circuit board on which the device is mounted through a serial scan path that can access all critical logic nodes. Internal registers are linked internally, allowing test data to be shifted in and loaded directly onto test nodes, or test data to be captured and shifted out for verification. The test access port consists of dedicated I/O: TDI, TDO, TCK and TMS. The test access port has its own supply voltage VCCJ and can operate with LVCMOS3.3, 2.5, 1.8, 1.5 and 1.2 standards.
For more information, see LatticeECP3 sysCONFIG Usage Guide (FPGA-TN-02192).

### 3.7. Device Configuration

All LatticeECP3 devices contain two ports that can be used for device configuration. The Test Access Port (TAP), which supports bit-wide configuration, and the sysCONFIG port, support dual-byte, byte and serial configuration. The TAP supports both the IEEE Standard 1149.1 Boundary Scan specification and the IEEE Standard 1532 In-System Configuration specification. The sysCONFIG port includes seven I/O used as dedicated pins with the remaining pins used as dual-use pins. See LatticeECP3 sysCONFIG Usage Guide (FPGA-TN-02192) for more information about using the dual-use pins as general purpose I/O.
There are various ways to configure a LatticeECP3 device:

1. JTAG
2. Standard Serial Peripheral Interface (SPI and SPIm modes) - interface to boot PROM memory
3. System microprocessor to drive a $x 8$ CPU port (PCM mode)
4. System microprocessor to drive a serial slave SPI port (SSPI mode)
5. Generic byte wide flash with a MachXO ${ }^{\text {M }}$ device, providing control and addressing

On power-up, the FPGA SRAM is ready to be configured using the selected sysCONFIG port. Once a configuration port is selected, it will remain active throughout that configuration cycle. The IEEE 1149.1 port can be activated any time after power-up by sending the appropriate command through the TAP port.
LatticeECP3 devices also support the Slave SPI Interface. In this mode, the FPGA behaves like a SPI Flash device (slave mode) with the SPI port of the FPGA to perform read-write operations.

### 3.7.1. Enhanced Configuration Options

LatticeECP3 devices have enhanced configuration features such as: decryption support, TransFR ${ }^{\text {TM }}$ I/O and dualboot image support.

## 1. TransFR (Transparent Field Reconfiguration)

TransFR I/O (TFR) is a unique Lattice technology that allows users to update their logic in the field without interrupting system operation using a single ispVM command. TransFR I/O allows I/O states to be frozen during device configuration. This allows the device to be field updated with a minimum of system disruption and downtime. See Minimizing System Interruption During Configuration Using TransFR Technology (FPGA-TN-02198) for details.

## 2. Dual-Boot Image Support

Dual-boot images are supported for applications requiring reliable remote updates of configuration data for the system FPGA. After the system is running with a basic configuration, a new boot image can be downloaded remotely and stored in a separate location in the configuration storage device. Any time after the update the LatticeECP3 can be re-booted from this new configuration file. If there is a problem, such as corrupt data during download or incorrect version number with this new boot image, the LatticeECP3 device can revert back to the original backup golden configuration and try again. This all can be done without power cycling the system. For more information, see LatticeECP3 sysCONFIG Usage Guide (FPGA-TN-02192).

### 3.7.2. Soft Error Detect (SED) Support

LatticeECP3 devices have dedicated logic to perform Cycle Redundancy Code (CRC) checks. During configuration, the configuration data bitstream can be checked with the CRC logic block. In addition, the LatticeECP3 device can also be programmed to utilize a Soft Error Detect (SED) mode that checks for soft errors in configuration SRAM. The SED operation can be run in the background during user mode. If a soft error occurs, during user mode (normal operation) the device can be programmed to generate an error signal.
For further information on SED support, see LatticeECP3 Soft Error Detection (SED) Usage Guide (FPGA-TN-02207).

### 3.7.3. External Resistor

LatticeECP3 devices require a single external, $10 \mathrm{kOhm} \pm 1 \%$ value between the XRES pin and ground. Device configuration will not be completed if this resistor is missing. There is no boundary scan register on the external resistor pad.

### 3.7.4. On-Chip Oscillator

Every LatticeECP3 device has an internal CMOS oscillator which is used to derive a Master Clock (MCCLK) for configuration. The oscillator and the MCCLK run continuously and are available to user logic after configuration is completed. The software default value of the MCCLK is nominally 2.5 MHz . Table 3.6 lists all the available MCCLK frequencies. When a different Master Clock is selected during the design process, the following sequence takes place:

1. Device powers up with a nominal Master Clock frequency of 3.1 MHz .
2. During configuration, users select a different master clock frequency.
3. The Master Clock frequency changes to the selected frequency once the clock configuration bits are received.
4. If the user does not select a master clock frequency, then the configuration bitstream defaults to the MCCLK frequency of 2.5 MHz .
This internal $130 \mathrm{MHz}+/-15 \%$ CMOS oscillator is available to the user by routing it as an input clock to the clock tree. For further information on the use of this oscillator for configuration or user mode, see LatticeECP3 sysCONFIG Usage Guide (FPGA-TN-02192).

Table 3.6. Selectable Master Clock (MCCLK) Frequencies During Configuration (Nominal)

| MCCLK (MHz) | MCCLK (MHz) |
| :---: | :---: |
|  | 10 |
| $2.5^{1}$ | 13 |
| 4.3 | $15^{2}$ |
| 5.4 | 20 |
| 6.9 | 26 |
| 8.1 | $33^{3}$ |
| 9.2 |  |

## Notes:

1. Software default MCCLK frequency. Hardware default is 3.1 MHz .
2. Maximum MCCLK with encryption enabled.
3. Maximum MCCLK without encryption.

### 3.8. Density Shifting

The LatticeECP3 family is designed to ensure that different density devices in the same family and in the same package have the same pinout. Furthermore, the architecture ensures a high success rate when performing design migration from lower density devices to higher density devices. In many cases, it is also possible to shift a lower utilization design targeted for a high-density device to a lower density device. However, the exact details of the final resource utilization will impact the likelihood of success in each case. An example is that some user I/O may become No Connects in smaller devices in the same package. Refer to the LatticeECP3 Pin Migration Tables and Diamond software for specific restrictions and limitations.

## 4. DC and Switching Characteristics

### 4.1. Absolute Maximum Ratings ${ }^{1,2,3}$

Supply Voltage $\mathrm{V}_{\mathrm{cc}}$
Supply Voltage Vccaux
Supply Voltage Vcc
Output Supply Voltage Vccıo
Input or I/O Tristate Voltage Applied ${ }^{4}$
Storage Temperature (Ambient)
Junction Temperature ( $\mathrm{T}_{\mathrm{J}}$ )
0.5 V to 1.32 V
0.5 V to 3.75 V
0.5 V to 3.75 V
0.5 V to 3.75 V
0.5 V to 3.75 V

65 V to $150^{\circ} \mathrm{C}$
$+125^{\circ} \mathrm{C}$

1. 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.
2. Compliance with the Lattice Thermal Management document is required.
3. All voltages referenced to GND.
4. Overshoot and undershoot of -2 V to (VIHMAX +2 ) volts is permitted for a duration of $<20 \mathrm{~ns}$.

### 4.2. Recommended Operating Conditions ${ }^{1}$

| Symbol | Parameter | Min. | Max. | Units |
| :--- | :--- | :---: | :---: | :---: |
| $\mathrm{V}_{\text {CC }}{ }^{2}$ | Core Supply Voltage | 1.14 | 1.26 | V |
| $\mathrm{~V}_{\text {CCAUX }}{ }^{2,4}$ | Auxiliary Supply Voltage, Terminating Resistor Switching Power <br> Supply (SERDES) | 3.135 | 3.465 | V |
| $\mathrm{~V}_{\text {CCPLL }}$ | PLL Supply Voltage | 3.135 | 3.465 | V |
| $\mathrm{~V}_{\text {CCIO }}{ }^{2,3}$ | I/O Driver Supply Voltage | 1.14 | 3.465 | V |
| $\mathrm{~V}_{\text {CCI }^{2}}$ | Supply Voltage for IEEE 1149.1 Test Access Port | 1.14 | 3.465 | V |
| $\mathrm{~V}_{\text {REF1 }}{ }^{7}$ and $\mathrm{V}_{\text {REF2 }}$ | Input Reference Voltage | 0.5 | 1.7 | V |
| $\mathrm{~V}_{\text {TT5 }}$ | Termination Voltage | 0.5 | 1.3125 | V |
| $\mathrm{t}_{\text {CCOM }}$ | Junction Temperature, Commercial Operation | 0 | 85 | ${ }^{\circ} \mathrm{C}$ |
| $\mathrm{t}_{\text {IIND }}$ | Junction Temperature, Industrial Operation | -40 | 100 | ${ }^{\circ} \mathrm{C}$ |
| SERDES External Power Supply6 |  |  |  |  |
| $\mathrm{V}_{\text {CCIB }}$ | Input Buffer Power Supply (1.2 V) | 1.14 | 1.26 | V |
|  | Input Buffer Power Supply (1.5 V) | 1.425 | 1.575 | V |
| $\mathrm{~V}_{\text {CCOB }}$ | Output Buffer Power Supply (1.2 V) | 1.14 | 1.26 | V |
|  | Output Buffer Power Supply (1.5 V) | 1.425 | 1.575 | V |
| $\mathrm{~V}_{\text {CCA }}$ | Transmit, Receive, PLL and Reference Clock Buffer Power Supply | 1.14 | 1.26 | V |

## Notes:

1. For correct operation, all supplies except $\mathrm{V}_{\text {REF }}$ and $\mathrm{V}_{\mathrm{T}}$ must be held in their valid operation range. This is true independent of feature usage.
2. If $\mathrm{V}_{\mathrm{ccIo}}$ or $\mathrm{V}_{\mathrm{CcJ}}$ is set to 1.2 V , they must be connected to the same power supply as $\mathrm{V}_{\mathrm{cc}}$. If $\mathrm{V}_{\mathrm{CClo}}$ or $\mathrm{V}_{\mathrm{CcI}}$ is set to 3.3 V , they must be connected to the same power supply as $\mathrm{V}_{\text {ccaux }}$.
3. See recommended voltages by $\mathrm{I} / \mathrm{O}$ standard in subsequent table.
4. $\mathrm{V}_{\text {CCAUX }}$ ramp rate must not exceed $30 \mathrm{mV} / \mu \mathrm{s}$ during power-up when transitioning between 0 V and 3.3 V .
5. If not used, $\mathrm{V}_{\mathrm{T}}$ should be left floating.
6. See LatticeECP3 SERDES/PCS Usage Guide (FPGA-TN-02190) for information on board considerations for SERDES power supplies.
7. When implementing generic DDR interface using the DQS circuit (GDDRX1/2_RX.DQS.Centered/Aligned) and LVDS inputs, it is recommended the VREF1 port of that bank be tied to VCCIO. This is required for the correct startup of the DQSBUF circuit. See LatticeECP3 High-Speed I/O Interface (TN1180) for more information.

### 4.3. Hot Socketing Specifications ${ }^{1,2,3}$

| Symbol | Parameter | Condition | Min. | Typ. | Max. | Units |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |
| IDK_HS $^{4}$ | Input or I/O Leakage Current | $0 \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{IH}}$ (Max.) | - | - | $+/-1$ | mA |
| $\mathrm{IDK}^{5}$ | Input or I/O Leakage Current | $0 \leq \mathrm{V}_{\mathrm{IN}}<\mathrm{V}_{\mathrm{CCIO}}$ | - | - | $+/-1$ | mA |
|  |  | $\mathrm{~V}_{\mathrm{CCIO}} \leq \mathrm{V}_{\mathrm{IN}} \leq \mathrm{V}_{\mathrm{CCIO}}+0.5 \mathrm{~V}$ | - | 18 | - | mA |

## Notes:

1. $\mathrm{V}_{\mathrm{CC}}, \mathrm{V}_{\mathrm{CCAUx}}$ and $\mathrm{V}_{\mathrm{CCIO}}$ should rise/fall monotonically.
2. $I_{D K}$ is additive to $I_{P U}$, $I_{P D}$ or $I_{B H}$.
3. LVCMOS and LVTTL only.
4. Applicable to general purpose I/O pins located on the top and bottom sides of the device.
5. Applicable to general purpose I/O pins located on the left and right sides of the device.

### 4.4. Hot Socketing Requirements

| Description | Min. | Typ. | Max. |
| :--- | :---: | :---: | :---: |
| Input current per SERDES I/O pin when device is powered down and inputs <br> driven. | - | - | 8 |

## Notes:

- Assumes the device is powered down, all supplies grounded, both P and N inputs driven by CML driver with maximum allowed VCCOB ( 1.575 V ), 8b10b data, internal AC coupling.
- Each $P$ and $N$ input must have less than the specified maximum input current. For a 16 -channel device, the total input current would be $8 \mathrm{~mA} * 16$ channels ${ }^{*} 2$ input pins per channel $=256 \mathrm{~mA}$


### 4.5. ESD Performance

Refer to the LatticeECP3 Product Family Qualification Summary for complete qualification data, including ESD performance.

### 4.6. DC Electrical Characteristics

Over Recommended Operating Conditions

| Symbol | Parameter | Condition | Min. | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{I}_{\mathrm{LL},} \mathrm{I}_{1 \mathrm{H}^{1,4}}$ | Input or I/O Low Leakage | $0 \leq \mathrm{V}_{\text {IN }} \leq\left(\mathrm{V}_{\text {CCIO }}-0.2 \mathrm{~V}\right)$ | - | - | 10 | $\mu \mathrm{A}$ |
| $\mathrm{IIH}^{1,3}$ | Input or I/O High Leakage | $\left(\mathrm{V}_{\text {CCIO }}-0.2 \mathrm{~V}\right)<\mathrm{V}_{\text {IN }} \leq 3.6 \mathrm{~V}$ | - | - | 150 | $\mu \mathrm{A}$ |
| Ipu | I/O Active Pull-up Current | $0 \leq \mathrm{V}_{\text {IN }} \leq 0.7 \mathrm{~V}_{\text {CCIO }}$ | -30 | - | -210 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {PD }}$ | I/O Active Pull-down Current | $\mathrm{V}_{\text {IL }}(\mathrm{MAX}) \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CCIO }}$ | 30 | - | 210 | $\mu \mathrm{A}$ |
| İнLS | Bus Hold Low Sustaining Current | $\mathrm{V}_{\text {IN }}=\mathrm{V}_{\text {IL }}(\mathrm{MAX})$ | 30 | - | - | $\mu \mathrm{A}$ |
| İннS | Bus Hold High Sustaining Current | $\mathrm{V}_{\text {IN }}=0.7 \mathrm{~V}_{\text {CCIO }}$ | -30 | - | - | $\mu \mathrm{A}$ |
| İньо $^{\text {¢ }}$ | Bus Hold Low Overdrive Current | $0 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CCIO }}$ | - | - | 210 | $\mu \mathrm{A}$ |
| Івнно $^{\text {¢ }}$ | Bus Hold High Overdrive Current | $0 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {CCIO }}$ | - | - | -210 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {внT }}$ | Bus Hold Trip Points | $0 \leq \mathrm{V}_{\text {IN }} \leq \mathrm{V}_{\text {IH }}(\mathrm{MAX})$ | $\mathrm{V}_{\text {IL }}$ (MAX) | - | $\mathrm{V}_{\mathrm{IH}}$ (MIN) | V |
| C1 | I/O Capacitance ${ }^{2}$ | $\mathrm{V}_{\text {CCIO }}=3.3 \mathrm{~V}, 2.5 \mathrm{~V}, 1.8 \mathrm{~V}, 1.5 \mathrm{~V}$, $1.2 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=1.2 \mathrm{~V}, \mathrm{~V}_{\mathrm{IO}}=0$ to $\mathrm{V}_{\mathrm{IH}}$ (MAX) | - | 5 | 8 | pf |
| C2 | Dedicated Input Capacitance ${ }^{2}$ | $\mathrm{V}_{\mathrm{CCIO}}=3.3 \mathrm{~V}, 2.5 \mathrm{~V}, 1.8 \mathrm{~V}, 1.5 \mathrm{~V}$, $1.2 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=1.2 \mathrm{~V}, \mathrm{~V}_{\mathrm{IO}}=0$ to $\mathrm{V}_{\mathrm{IH}}$ (MAX) | - | 5 | 7 | pf |

## Notes:

1. 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. Bus maintenance circuits are disabled.
2. $\mathrm{T}_{\mathrm{A}} 25 \mathrm{oC}, \mathrm{f}=1.0 \mathrm{MHz}$.
3. Applicable to general purpose $\mathrm{I} / \mathrm{O}$ in top and bottom banks.
4. When used as $\mathrm{V}_{\text {REF }}$, maximum leakage $=25 \mu \mathrm{~A}$.

### 4.7. LatticeECP3 Supply Current (Standby)

Over Recommended Operating Conditions

| Symbol | Parameter | Device | Typical |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | -6L, -7L, -8L | -6, -7, -8 |  |
| Icc | Core Power Supply Current | ECP-17EA | 29.8 | 49.4 | mA |
|  |  | ECP3-35EA | 53.7 | 89.4 | mA |
|  |  | ECP3-70EA | 137.3 | 230.7 | mA |
|  |  | ECP3-95EA | 137.3 | 230.7 | mA |
|  |  | ECP3-150EA | 219.5 | 370.9 | mA |
| $\mathrm{I}_{\text {CCAUX }}$ | Auxiliary Power Supply Current | ECP-17EA | 18.3 | 19.4 | mA |
|  |  | ECP3-35EA | 19.6 | 23.1 | mA |
|  |  | ECP3-70EA | 26.5 | 32.4 | mA |
|  |  | ECP3-95EA | 26.5 | 32.4 | mA |
|  |  | ECP3-150EA | 37.0 | 45.7 | mA |
| $\mathrm{I}_{\text {CCPLL }}$ | PLL Power Supply Current (Per PLL) | ECP-17EA | 0.0 | 0.0 | mA |
|  |  | ECP3-35EA | 0.1 | 0.1 | mA |
|  |  | ECP3-70EA | 0.1 | 0.1 | mA |
|  |  | ECP3-95EA | 0.1 | 0.1 | mA |
|  |  | ECP3-150EA | 0.1 | 0.1 | mA |
| $\mathrm{I}_{\text {Clı }}$ | Bank Power Supply Current (Per Bank) | ECP-17EA | 1.3 | 1.4 | mA |
|  |  | ECP3-35EA | 1.3 | 1.4 | mA |
|  |  | ECP3-70EA | 1.4 | 1.5 | mA |
|  |  | ECP3-95EA | 1.4 | 1.5 | mA |
|  |  | ECP3-150EA | 1.4 | 1.5 | mA |
| $\mathrm{I}_{\text {CJJ }}$ | JTAG Power Supply Current | All Devices | 2.5 | 2.5 | mA |
| $I_{\text {CCA }}$ | Transmit, Receive, PLL and Reference Clock Buffer Power Supply | ECP-17EA | 6.1 | 6.1 | mA |
|  |  | ECP3-35EA | 6.1 | 6.1 | mA |
|  |  | ECP3-70EA | 18.3 | 18.3 | mA |
|  |  | ECP3-95EA | 18.3 | 18.3 | mA |
|  |  | ECP3-150EA | 24.4 | 24.4 | mA |

## Notes:

- For further information on supply current, see the list of technical documentation at the end of this data sheet.
- Assumes all outputs are tristated, all inputs are configured as LVCMOS and held at the $\mathrm{V}_{\text {cclo }}$ or GND.
- Frequency 0 MHz .
- Pattern represents a blank configuration data file.
- $\mathrm{T}_{\mathrm{J}}=85^{\circ} \mathrm{C}$, power supplies at nominal voltage.
- To determine the LatticeECP3 peak start-up current data, use the Power Calculator tool.


### 4.8. SERDES Power Supply Requirements

Over Recommended Operating Conditions

| Symbol | Description | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: |
| Standby (Power Down) |  |  |  |  |
| $I_{\text {CCA-SB }}$ | VCCA ${ }^{\text {current ( }}$ (per channel) | 3 | 5 | mA |
| $\mathrm{I}_{\text {CCIB-SB }}$ | Input buffer current (per channel) | - | - | mA |
| ICCOB-SB | Output buffer current (per channel) | - | - | mA |
| Operating (Data Rate $=$ 3.2 Gbps) |  |  |  |  |
| $I_{\text {CCA OP }}$ | VCcA ${ }^{\text {current ( }}$ (per channel) | 68 | 77 | mA |
| $\mathrm{I}_{\text {CCIB-OP }}$ | Input buffer current (per channel) | 5 | 7 | mA |
| ICCOB-ор | Output buffer current (per channel) | 19 | 25 | mA |
| Operating (Data Rate $=$ 2.5 Gbps) |  |  |  |  |
| $\mathrm{I}_{\text {CCA }-\mathrm{OP}}$ | V ${ }_{\text {cca }}$ current (per channel) | 66 | 76 | mA |
| $\mathrm{I}_{\text {CCIB-OP }}$ | Input buffer current (per channel) | 4 | 5 | mA |
| ICCOB-OP | Output buffer current (per channel) | 15 | 18 | mA |
| Operating (Data Rate $=1.25$ Gbps) |  |  |  |  |
| $I_{\text {CCA-OP }}$ | VCCA current (per channel) | 62 | 72 | mA |
| $\mathrm{I}_{\text {CCIB-OP }}$ | Input buffer current (per channel) | 4 | 5 | mA |
| $\mathrm{I}_{\text {CCOB-OP }}$ | Output buffer current (per channel) | 15 | 18 | mA |
| Operating (Data Rate $\mathbf{=} \mathbf{2 5 0} \mathbf{~ M b p s}$ ) |  |  |  |  |
| $I_{\text {CCA OP }}$ | VCCA ${ }^{\text {current ( }}$ (per channel) | 55 | 65 | mA |
| $\mathrm{I}_{\text {CCIB-OP }}$ | Input buffer current (per channel) | 4 | 5 | mA |
| ICCOB-op | Output buffer current (per channel) | 14 | 17 | mA |
| Operating (Data Rate $=\mathbf{1 5 0} \mathbf{~ M b p s}$ ) |  |  |  |  |
| $I_{\text {CCA-OP }}$ | $\mathrm{V}_{\text {cCA }}$ current (per channel) | 55 | 65 | mA |
| $\mathrm{I}_{\text {CCIB-OP }}$ | Input buffer current (per channel) | 4 | 5 | mA |
| ICCOB-OP | Output buffer current (per channel) | 14 | 17 | mA |

## Notes:

- Equalization enabled, pre-emphasis disabled.
- One quarter of the total quad power (includes contribution from common circuits, all channels in the quad operating, preemphasis disabled, equalization enabled).
- Pre-emphasis adds 20 mA to ICCA-OP data.


## 4.9. sysl/O Recommended Operating Conditions

| Standard | $\mathrm{v}_{\text {CCIO }}$ |  |  | $\mathrm{V}_{\text {REF }}(\mathrm{V})$ |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Min. | Typ. | Max. | Min. | Typ. | Max. |
| LVCMOS33 ${ }^{2}$ | 3.135 | 3.3 | 3.465 | - | - | - |
| LVCMOS33D | 3.135 | 3.3 | 3.465 | - | - | - |
| LVCMOS25 ${ }^{2}$ | 2.375 | 2.5 | 2.625 | - | - | - |
| LVCMOS18 | 1.71 | 1.8 | 1.89 | - | - | - |
| LVCMOS15 | 1.425 | 1.5 | 1.575 | - | - | - |
| LVCMOS12 ${ }^{2}$ | 1.14 | 1.2 | 1.26 | - | - | - |
| LVTTL33 ${ }^{2}$ | 3.135 | 3.3 | 3.465 | - | - | - |
| PCI33 | 3.135 | 3.3 | 3.465 | - | - | - |
| SSTL15 ${ }^{3}$ | 1.43 | 1.5 | 1.57 | 0.68 | 0.75 | 0.9 |
| SSTL18_I, II ${ }^{2}$ | 1.71 | 1.8 | 1.89 | 0.833 | 0.9 | 0.969 |
| SSTL25_I, II ${ }^{2}$ | 2.375 | 2.5 | 2.625 | 1.15 | 1.25 | 1.35 |
| SSTL33_I, II ${ }^{2}$ | 3.135 | 3.3 | 3.465 | 1.3 | 1.5 | 1.7 |
| HSTL15_I ${ }^{2}$ | 1.425 | 1.5 | 1.575 | 0.68 | 0.75 | 0.9 |
| HSTL18_I, II ${ }^{2}$ | 1.71 | 1.8 | 1.89 | 0.816 | 0.9 | 1.08 |
| LVDS25 ${ }^{2}$ | 2.375 | 2.5 | 2.625 | - | - | - |
| LVDS25E | 2.375 | 2.5 | 2.625 | - | - | - |
| MLVDS ${ }^{1}$ | 2.375 | 2.5 | 2.625 | - | - | - |
| LVPECL33 ${ }^{1,2}$ | 3.135 | 3.3 | 3.465 | - | - | - |
| Mini LVDS | 2.375 | 2.5 | 2.625 | - | - | - |
| BLVDS25 ${ }^{1,2}$ | 2.375 | 2.5 | 2.625 | - | - | - |
| RSDS ${ }^{2}$ | 2.375 | 2.5 | 2.625 | - | - | - |
| RSDSE ${ }^{1,2}$ | 2.375 | 2.5 | 2.625 | - | - | - |
| TRLVDS | 3.14 | 3.3 | 3.47 | - | - | - |
| PPLVDS | 3.14/2.25 | 3.3/2.5 | 3.47/2.75 | - | - | - |
| SSTL15D ${ }^{3}$ | 1.43 | 1.5 | 1.57 | - | - | - |
| SSTL18D_I ${ }^{2,3,3}$, $\mathrm{Il}^{2,3}$ | 1.71 | 1.8 | 1.89 | - | - | - |
| SSTL25D_ $\mathrm{I}^{2}, \\|^{2}$ | 2.375 | 2.5 | 2.625 | - | - | - |
| SSTL33D_ ${ }^{2}, I^{2}$ | 3.135 | 3.3 | 3.465 | - | - | - |
| HSTL15D_ ${ }^{2}$ | 1.425 | 1.5 | 1.575 | - | - | - |
| HSTL18D_ ${ }^{2}$, $I^{2}$ | 1.71 | 1.8 | 1.89 | - | - | - |

## Notes:

1. Inputs on chip. Outputs are implemented with the addition of external resistors.
2. For input voltage compatibility, see LatticeECP3 sysIO Usage Guide (FPGA-TN-02194).
3. VREF is required when using Differential SSTL to interface to DDR memory.
4.10. sysi/O Single-Ended DC Electrical Characteristics ${ }^{2}$

| Input/Output Standard | $\mathrm{V}_{\mathrm{IL}}$ |  | $\mathrm{V}_{\mathrm{H}}$ |  | Vol Max. <br> (V) | V ${ }_{\text {OH }}$ Min.(V) | $\mathrm{loL}^{1}(\mathrm{~mA})$ | $\mathrm{IOH}^{1}(\mathrm{~mA})$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | Min. (V) | Max. (V) | Min. (V) | Max. (V) |  |  |  |  |
| LVCMOS33 | -0.3 | 0.8 | 2.0 | 3.6 | 0.4 | $\mathrm{V}_{\mathrm{CCIO}}-0.4$ | $\begin{gathered} 20,16,12 \\ 8,4 \end{gathered}$ | $\begin{gathered} -20,-16,- \\ 12,-8,-4 \end{gathered}$ |
|  |  |  |  |  | 0.2 | $\mathrm{V}_{\text {CCIO }}-0.2$ | 0.1 | -0.1 |
| LVCMOS25 | -0.3 | 0.7 | 1.7 | 3.6 | 0.4 | $\mathrm{V}_{\text {CCIO }}-0.4$ | $\begin{gathered} 20,16,12 \\ 8,4 \end{gathered}$ | $\begin{gathered} -20,-16,- \\ 12,-8,-4 \end{gathered}$ |
|  |  |  |  |  | 0.2 | $\mathrm{V}_{\text {CCIO }}-0.2$ | 0.1 | -0.1 |
| LVCMOS18 | -0.3 | $\begin{aligned} & 0.35 \\ & \mathrm{~V}_{\mathrm{CCIO}} \end{aligned}$ | $\begin{aligned} & \hline 0.65 \\ & \mathrm{~V}_{\text {ClIO }} \end{aligned}$ | 3.6 | 0.4 | $\mathrm{V}_{\text {cCIO }}-0.4$ | $\begin{gathered} 16,12,8, \\ 4 \\ \hline \end{gathered}$ | $\begin{gathered} -16,-12,-8, \\ -4 \end{gathered}$ |
|  |  |  |  |  | 0.2 | $\mathrm{V}_{\text {CCIO }}-0.2$ | 0.1 | -0.1 |
| LVCMOS15 | -0.3 | $\begin{aligned} & 0.35 \\ & \mathrm{~V}_{\mathrm{ClIO}} \end{aligned}$ | $\begin{aligned} & 0.65 \\ & \mathrm{~V}_{\text {CCIO }} \end{aligned}$ | 3.6 | 0.4 | $\mathrm{V}_{\text {CCIO }}-0.4$ | 8, 4 | -8, -4 |
|  |  |  |  |  | 0.2 | $\mathrm{V}_{\text {CCIO }}-0.2$ | 0.1 | -0.1 |
| LVCMOS12 | -0.3 | $\begin{aligned} & 0.35 \\ & \mathrm{~V}_{\mathrm{cc}} \end{aligned}$ | $\begin{aligned} & 0.65 \\ & \mathrm{~V}_{\mathrm{CC}} \end{aligned}$ | 3.6 | 0.4 | $\mathrm{V}_{\text {ccio }}-0.4$ | 6, 2 | -6, -2 |
|  |  |  |  |  | 0.2 | $\mathrm{V}_{\text {CCIO }}-0.2$ | 0.1 | -0.1 |
| LVTTL33 | -0.3 | 0.8 | 2.0 | 3.6 | 0.4 | $\mathrm{V}_{\text {CCIO }}-0.4$ | $\begin{gathered} 20,16,12 \\ 8,4 \end{gathered}$ | $\begin{gathered} \hline-20,-16,- \\ 12,-8,-4 \\ \hline \end{gathered}$ |
|  |  |  |  |  | 0.2 | $\mathrm{V}_{\text {CCIO }}-0.2$ | 0.1 | -0.1 |
| PCI33 | -0.3 | $\begin{aligned} & 0.3 \\ & V_{\mathrm{ClIO}} \end{aligned}$ | $\begin{aligned} & 0.5 \\ & \mathrm{~V}_{\mathrm{CCIO}} \end{aligned}$ | 3.6 | $0.1 \mathrm{~V}_{\text {ClıO }}$ | $0.9 \mathrm{~V}_{\text {Clı }}$ | 1.5 | -0.5 |
| SSTL18_I | -0.3 | $\begin{aligned} & \hline \mathrm{V}_{\text {REF }}- \\ & 0.125 \end{aligned}$ | $\begin{aligned} & V_{\text {REF }}+ \\ & 0.125 \end{aligned}$ | 3.6 | 0.4 | $\mathrm{V}_{\text {CCIO }}-0.4$ | 6.7 | -6.7 |
| $\begin{aligned} & \text { SSTL18_II (DDR2 } \\ & \text { Memory) } \end{aligned}$ | -0.3 | $\begin{aligned} & V_{\text {REF }}- \\ & 0.125 \end{aligned}$ | $\begin{aligned} & V_{\text {REF }}+ \\ & 0.125 \end{aligned}$ | 3.6 | 0.28 | $\mathrm{V}_{\text {CCIO }}-0.28$ | 8 | -8 |
|  |  |  |  |  |  |  | 11 | -11 |
| SSTL2_। | -0.3 | $\begin{aligned} & \hline V_{\text {REF }}- \\ & 0.18 \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{REF}}+ \\ & 0.18 \end{aligned}$ | 3.6 | 0.54 | $\mathrm{V}_{\text {CCIO }}-0.62$ | 7.6 | -7.6 |
|  |  |  |  |  |  |  | 12 | -12 |
| SSTL2_II (DDR <br> Memory) | -0.3 | $\begin{aligned} & \mathrm{V}_{\text {REF }}- \\ & 0.18 \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{REF}}+ \\ & 0.18 \end{aligned}$ | 3.6 | 0.35 | $\mathrm{V}_{\mathrm{CCIO}}-0.43$ | 15.2 | -15.2 |
|  |  |  |  |  |  |  | 20 | -20 |
| SSTL3_। | -0.3 | $\begin{aligned} & V_{\text {REF }}- \\ & 0.2 \end{aligned}$ | $\begin{aligned} & V_{\text {REF }}+ \\ & 0.2 \end{aligned}$ | 3.6 | 0.7 | $\mathrm{V}_{\text {CCIO }}-1.1$ | 8 | -8 |
| SSTL3_II | -0.3 | $\begin{aligned} & \mathrm{V}_{\text {REF }}- \\ & 0.2 \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{REF}}+ \\ & 0.2 \end{aligned}$ | 3.6 | 0.5 | $\mathrm{V}_{\text {CCIO }}-0.9$ | 16 | -16 |
| $\begin{aligned} & \text { SSTL15 (DDR3 } \\ & \text { Memory) } \end{aligned}$ | -0.3 | $\begin{aligned} & \hline \mathrm{V}_{\text {REF }}- \\ & 0.1 \end{aligned}$ | $\begin{aligned} & V_{\text {REF }}+ \\ & 0.1 \end{aligned}$ | 3.6 | 0.3 | $\mathrm{V}_{\mathrm{CCIO}}-0.3$ | 7.5 | -7.5 |
|  |  |  |  |  |  | $\mathrm{V}_{\text {CCIO }} * 0.8$ | 9 | -9 |
| HSTL15_I | -0.3 | $\begin{aligned} & \mathrm{V}_{\text {REF }}- \\ & 0.1 \end{aligned}$ | $\begin{aligned} & V_{\text {REF }}+ \\ & 0.1 \end{aligned}$ | 3.6 | 0.4 | $\begin{aligned} & \mathrm{V}_{\mathrm{CCIO}}- \\ & 0.4 \end{aligned}$ | 4 | -4 |
|  |  |  |  |  |  |  | 8 | -8 |
| HSTL18_I | -0.3 | $\begin{aligned} & \mathrm{V}_{\text {REF }}- \\ & 0.1 \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{REF}}+ \\ & 0.1 \end{aligned}$ | 3.6 | 0.4 | $\begin{aligned} & \mathrm{V}_{\mathrm{CClO}}- \\ & 0.4 \end{aligned}$ | 8 | -8 |
|  |  |  |  |  |  |  | 12 | -12 |
| HSTL18_II | -0.3 | $\begin{aligned} & \mathrm{V}_{\text {REF }}- \\ & 0.1 \end{aligned}$ | $\begin{aligned} & V_{\text {REF }}+ \\ & 0.1 \end{aligned}$ | 3.6 | 0.4 | $\begin{aligned} & \mathrm{V}_{\mathrm{CCIO}}- \\ & 0.4 \end{aligned}$ | 16 | -16 |

## Notes:

1. For electromigration, the average DC current drawn by I/O pads between two consecutive VCCIO or GND pad connections, or between the last VCCIO or GND in an I/O bank and the end of an I/O bank, as shown in the Logic Signal Connections table (also shown as I/O grouping) shall not exceed $n * 8 \mathrm{~mA}$, where n is the number of I/O pads between the two consecutive bank VCCIO or GND connections or between the last VCCIO and GND in a bank and the end of a bank. I/O Grouping can be found in the Data Sheet Pin Tables, which can also be generated from the Lattice Diamond software.
2. For $\mathrm{I} / \mathrm{Os}$ with mixed voltage support, $\mathrm{V}_{\mathrm{OH}}$ follows respective sysI/O bank $\mathrm{V}_{\mathrm{CCIO}}$ supply voltage, and $\mathrm{V}_{\mathrm{IL}} / \mathrm{V}_{\mathrm{IH}}$ follows the $\mathrm{I} / \mathrm{O}$ signaling standard.

### 4.11. sysl/O Differential Electrical Characteristics

## LVDS25

Over Recommended Operating Conditions

| Parameter | Description | Test Conditions | Min. | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {INP }}{ }^{*}$, $\mathrm{V}_{\text {INM }}$ * | Input Voltage | - | 0 | - | 2.4 | V |
| $\mathrm{V}_{\mathrm{CM}}{ }^{*}$ | Input Common Mode Voltage | Half the Sum of the Two Inputs | 0.05 | - | 2.35 | V |
| $\mathrm{V}_{\text {THD }}$ | Differential Input Threshold | Difference Between the Two Inputs | +/-100 | - | - | mV |
| $\mathrm{I}_{\text {N }}$ | Input Current | Power On or Power Off | - | - | +/-10 | $\mu \mathrm{A}$ |
| $\mathrm{V}_{\text {OH }}$ | Output High Voltage for $\mathrm{V}_{\text {OP }}$ or $\mathrm{V}_{\text {OM }}$ | RT $=100 \Omega$ | - | 1.38 | 1.60 | V |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage for $\mathrm{V}_{\text {OP }}$ or $\mathrm{V}_{\text {OM }}$ | RT $=100 \Omega$ | 0.9 V | 1.03 | - | V |
| $V_{\text {OD }}$ | Output Voltage Differential | ( $\mathrm{V}_{\text {OP }}-\mathrm{V}_{\text {OM }}$ ), $\mathrm{RT}=100 \Omega$ | 250 | 350 | 450 | mV |
| $\Delta \mathrm{V}_{\text {OD }}$ | Change in Vod Between High and Low | - | - | - | 50 | mV |
| $\mathrm{V}_{\text {OS }}$ | Output Voltage Offset | $\left(\mathrm{V}_{\text {OP }}+\mathrm{V}_{\text {OM }}\right) / 2, \mathrm{RT}=100 \Omega$ | 1.125 | 1.20 | 1.375 | V |
| $\Delta \mathrm{V}_{\text {os }}$ | Change in Vos Between H and L | - | - | - | 50 | mV |
| $\mathrm{I}_{\text {SAB }}$ | Output Short Circuit Current | $V_{O D}=0$ V Driver Outputs Shorted to Each Other | - | - | 12 | mA |

*Note: On the left and right sides of the device, this specification is valid only for $\mathrm{V}_{\text {ccıo }}=2.5 \mathrm{~V}$ or 3.3 V .

### 4.11.1. Differential HSTL and SSTL

Differential HSTL and SSTL outputs are implemented as a pair of complementary single-ended outputs. All allowable single-ended output classes (class I and class II) are supported in this mode.

### 4.11.2. LVDS25E

The top and bottom sides of LatticeECP3 devices support LVDS outputs via emulated complementary LVCMOS outputs in conjunction with a parallel resistor across the driver outputs. The scheme shown in Figure 4.1 is one possible solution for point-to-point signals.


Figure 4.1. LVDS25E Output Termination Example

Table 4.1. LVDS25E DC Conditions

| Parameter | Description | Typical | Units |
| :--- | :--- | :---: | :---: |
| $V_{\text {CCIO }}$ | Output Driver Supply (+/-5\%) | 2.50 | V |
| $Z_{\text {OUT }}$ | Driver Impedance | 20 | $\Omega$ |
| $R_{S}$ | Driver Series Resistor (+/-1\%) | 158 | $\Omega$ |
| $R_{P}$ | Driver Parallel Resistor (+/-1\%) | 140 | $\Omega$ |
| $R_{T}$ | Receiver Termination (+/-1\%) | 100 | $\Omega$ |
| $V_{\mathrm{OH}}$ | Output High Voltage | 1.43 | V |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage | 1.07 | V |
| $\mathrm{~V}_{\mathrm{OD}}$ | Output Differential Voltage | 0.35 | V |
| $\mathrm{~V}_{\mathrm{CM}}$ | Output Common Mode Voltage | 1.25 | V |
| $\mathrm{Z}_{\mathrm{BACK}}$ | Back Impedance | 100.5 | $\Omega$ |
| $\mathrm{I}_{\mathrm{DC}}$ | DC Output Current | 6.03 | mA |

### 4.11.3. LVCMOS33D

All I/O banks support emulated differential I/O using the LVCMOS33D I/O type. This option, along with the external resistor network, provides the system designer the flexibility to place differential outputs on an I/O bank with 3.3 V Vccıo. The default drive current for LVCMOS33D output is 12 mA with the option to change the device strength to 4 mA , $8 \mathrm{~mA}, 16 \mathrm{~mA}$ or 20 mA . Follow the LVCMOS33 specifications for the DC characteristics of the LVCMOS33D.

### 4.11.4. BLVDS25

The LatticeECP3 devices support the BLVDS standard. This standard is emulated using complementary LVCMOS outputs in conjunction with a parallel external resistor across the driver outputs. BLVDS is intended for use when multi-drop and bi-directional multi-point differential signaling is required. The scheme shown in Figure 4.2 is one possible solution for bi-directional multi-point differential signals.


Figure 4.2. BLVDS25 Multi-point Output Example
Table 4.2. BLVDS25 DC Conditions
Over Recommended Operating Conditions

| Parameter | Description | Typical |  | Units |
| :---: | :---: | :---: | :---: | :---: |
|  |  | $\mathrm{Zo}=45 \Omega$ | $\mathrm{Zo}=90 \Omega$ |  |
| $\mathrm{V}_{\text {cclo }}$ | Output Driver Supply (+/-5\%) | 2.50 | 2.50 | V |
| $\mathrm{Z}_{\text {OUt }}$ | Driver Impedance | 10.00 | 10.00 | $\Omega$ |
| Rs | Driver Series Resistor (+/-1\%) | 90.00 | 90.00 | $\Omega$ |
| $\mathrm{R}_{\mathrm{TL}}$ | Driver Parallel Resistor (+/-1\%) | 45.00 | 90.00 | $\Omega$ |
| $\mathrm{R}_{\text {TR }}$ | Receiver Termination (+/-1\%) | 45.00 | 90.00 | $\Omega$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 1.38 | 1.48 | V |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage | 1.12 | 1.02 | V |
| $V_{\text {OD }}$ | Output Differential Voltage | 0.25 | 0.46 | V |
| $\mathrm{V}_{\mathrm{CM}}$ | Output Common Mode Voltage | 1.25 | 1.25 | V |
| $\mathrm{I}_{\mathrm{DC}}$ | DC Output Current | 11.24 | 10.20 | mA |

Note: For input buffer, see the LVDS table.

### 4.12. LVPECL33

The LatticeECP3 devices support the differential LVPECL standard. This standard is emulated using complementary LVCMOS outputs in conjunction with a parallel resistor across the driver outputs. The LVPECL input standard is supported by the LVDS differential input buffer. The scheme shown in Figure 4.3 is one possible solution for point-topoint signals.


Figure 4.3. Differential LVPECL33
Table 4.3. LVPECL33 DC Conditions
Over Recommended Operating Conditions

| Parameter | Description | Typical | Units |
| :--- | :--- | :---: | :---: |
| $V_{\text {ClIO }}$ | Output Driver Supply (+/-5\%) | 3.30 | V |
| $Z_{\text {OUT }}$ | Driver Impedance | 10 | $\Omega$ |
| $R_{S}$ | Driver Series Resistor (+/-1\%) | 93 | $\Omega$ |
| $R_{P}$ | Driver Parallel Resistor (+/-1\%) | 196 | $\Omega$ |
| $R_{T}$ | Receiver Termination (+/-1\%) | 100 | $\Omega$ |
| $V_{O H}$ | Output High Voltage | 2.05 | V |
| $V_{\mathrm{OL}}$ | Output Low Voltage | 1.25 | V |
| $\mathrm{~V}_{\mathrm{OD}}$ | Output Differential Voltage | 0.80 | V |
| $\mathrm{~V}_{\mathrm{CM}}$ | Output Common Mode Voltage | 1.65 | V |
| $\mathrm{Z}_{\mathrm{BACK}}$ | Back Impedance | 100.5 | $\Omega$ |
| $\mathrm{I}_{\mathrm{DC}}$ | DC Output Current | 12.11 | mA |

Note: For input buffer, see the LVDS table.

### 4.13. RSDS25E

The LatticeECP3 devices support differential RSDS and RSDSE standards. This standard is emulated using complementary LVCMOS outputs in conjunction with a parallel resistor across the driver outputs. The RSDS input standard is supported by the LVDS differential input buffer. The scheme shown in Figure 4.4 is one possible solution for RSDS standard implementation. Resistor values in Figure 4.4 are industry standard values for $1 \%$ resistors.


Figure 4.4. RSDS25E (Reduced Swing Differential Signaling)
Table 4.4. RSDS25E DC Conditions
Over Recommended Operating Conditions

| Parameter | Description | Typical | Units |
| :--- | :--- | :---: | :---: |
| $\mathrm{V}_{\text {ClIO }}$ | Output Driver Supply (+/-5\%) | 2.50 | V |
| $\mathrm{Z}_{\text {OUT }}$ | Driver Impedance | 20 | $\Omega$ |
| $\mathrm{R}_{\mathrm{S}}$ | Driver Series Resistor (+/-1\%) | 294 | $\Omega$ |
| $\mathrm{R}_{\mathrm{P}}$ | Driver Parallel Resistor (+/-1\%) | 121 | $\Omega$ |
| $\mathrm{R}_{\mathrm{T}}$ | Receiver Termination (+/-1\%) | 100 | $\Omega$ |
| $\mathrm{~V}_{\mathrm{OH}}$ | Output High Voltage | 1.35 | V |
| $\mathrm{~V}_{\mathrm{OL}}$ | Output Low Voltage | 1.15 | V |
| $\mathrm{~V}_{\mathrm{OD}}$ | Output Differential Voltage | 0.20 | V |
| $\mathrm{~V}_{\mathrm{CM}}$ | Output Common Mode Voltage | 1.25 | V |
| $\mathrm{Z}_{\mathrm{BACK}}$ | Back Impedance | 101.5 | $\Omega$ |
| $\mathrm{I}_{\mathrm{DC}}$ | DC Output Current | 3.66 | mA |

Note: For input buffer, see the LVDS table.

### 4.13.1. MLVDS25

The LatticeECP3 devices support the differential MLVDS standard. This standard is emulated using complementary LVCMOS outputs in conjunction with a parallel resistor across the driver outputs. The MLVDS input standard is supported by the LVDS differential input buffer. The scheme shown in Figure 4.5 is one possible solution for MLVDS standard implementation. Resistor values in Figure 4.5 are industry standard values for $1 \%$ resistors.


Figure 4.5. MLVDS25 (Multipoint Low Voltage Differential Signaling)

Table 4.5. MLVDS25 DC Conditions

| Parameter | Description | Typical |  | Units |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Zo=50 2 | $\mathrm{Zo}=70 \Omega$ |  |
| $\mathrm{V}_{\text {CCIO }}$ | Output Driver Supply (+/-5\%) | 2.50 | 2.50 | V |
| ZOUT | Driver Impedance | 10.00 | 10.00 | $\Omega$ |
| RS | Driver Series Resistor (+/-1\%) | 35.00 | 35.00 | $\Omega$ |
| $\mathrm{R}_{\text {TL }}$ | Driver Parallel Resistor (+/-1\%) | 50.00 | 70.00 | $\Omega$ |
| $\mathrm{R}_{\text {TR }}$ | Receiver Termination (+/-1\%) | 50.00 | 70.00 | $\Omega$ |
| $\mathrm{V}_{\mathrm{OH}}$ | Output High Voltage | 1.52 | 1.60 | V |
| $\mathrm{V}_{\text {OL }}$ | Output Low Voltage | 0.98 | 0.90 | V |
| $V_{\text {OD }}$ | Output Differential Voltage | 0.54 | 0.70 | V |
| $V_{\text {CM }}$ | Output Common Mode Voltage | 1.25 | 1.25 | V |
| IDC | DC Output Current | 21.74 | 20.00 | mA |

Note: For input buffer, see the LVDS table.


### 4.14. Typical Building Block Function Performance

### 4.14.1. Pin-to-Pin Performance (LVCMOS25 12 mA Drive) ${ }^{1,2}$

| Function | -8 Timing | Units |
| :--- | :--- | :--- |
| Basic Functions |  |  |
| 16-bit Decoder | 4.7 |  |
| 32-bit Decoder | 4.7 |  |
| 64-bit Decoder | ns |  |
| $4: 1$ MUX | 5.7 |  |
| $8: 1$ MUX | ns |  |
| $16: 1$ MUX | 4.1 | ns |
| $32: 1$ MUX | 4.3 | ns |

## Notes:

1. These functions were generated using the ispLEVER design tool. Exact performance may vary with device and tool version. The tool uses internal parameters that have been characterized but are not tested on every device.
2. Commercial timing numbers are shown. Industrial numbers are typically slower and can be extracted from the Diamond or ispLEVER software.
4.14.2. Register-to-Register Performance ${ }^{1,2,3}$

| Function | -8 Timing | Units |
| :---: | :---: | :---: |
| Basic Functions |  |  |
| 16-bit Decoder | 500 | MHz |
| 32-bit Decoder | 500 | MHz |
| 64-bit Decoder | 500 | MHz |
| 4:1 MUX | 500 | MHz |
| 8:1 MUX | 500 | MHz |
| 16:1 MUX | 500 | MHz |
| 32:1 MUX | 445 | MHz |
| 8-bit adder | 500 | MHz |
| 16-bit adder | 500 | MHz |
| 64-bit adder | 305 | MHz |
| 16-bit counter | 500 | MHz |
| 32-bit counter | 460 | MHz |
| 64-bit counter | 320 | MHz |
| 64-bit accumulator | 315 | MHz |
| Embedded Memory Functions |  |  |
| $512 \times 36$ Single Port RAM, EBR Output Registers | 340 | MHz |
| 1024×18 True-Dual Port RAM (Write Through or Normal, EBR Output Registers) | 340 | MHz |
| 1024x18 True-Dual Port RAM (Read-Before-Write, EBR Output Registers | 130 | MHz |
| 1024x18 True-Dual Port RAM (Write Through or Normal, PLC Output Registers) | 245 | MHz |
| Distributed Memory Functions |  |  |
| 16x4 Pseudo-Dual Port RAM (One PFU) | 500 | MHz |
| 32x4 Pseudo-Dual Port RAM | 500 | MHz |
| 64x8 Pseudo-Dual Port RAM | 400 | MHz |
| DSP Function |  |  |
| 18x18 Multiplier (All Registers) | 400 | MHz |
| 9x9 Multiplier (All Registers) | 400 | MHz |
| 36x36 Multiply (All Registers) | 260 | MHz |

### 4.14.3. Register-to-Register Performance ${ }^{1,2,3}$

| Function | -8 Timing | Units |
| :--- | :---: | :---: |
| $18 \times 18$ Multiply/Accumulate (Input and Output Registers) | 200 | MHz |
| $18 \times 18$ Multiply-Add/Sub (All Registers) | 400 | MHz |

## Notes:

1. These timing numbers were generated using ispLEVER tool. Exact performance may vary with device and tool version. The tool uses internal parameters that have been characterized but are not tested on every device.
2. Commercial timing numbers are shown. Industrial numbers are typically slower and can be extracted from the Diamond or ispLEVER software.
3. For details on -9 speed grade devices, contact your Lattice Sales Representative.

### 4.15. Derating Timing Tables

Logic timing provided in the following sections of this data sheet and the Diamond and ispLEVER design tools are worst case numbers in the operating range. Actual delays at nominal temperature and voltage for best case process, can be much better than the values given in the tables. The Diamond and ispLEVER design tools can provide logic timing numbers at a particular temperature and voltage.

### 4.16. LatticeECP3 External Switching Characteristics ${ }^{1,2,3,13}$

Over Recommended Commercial Operating Conditions

| Parameter | Description | Device | -8 |  | -7 |  | -6 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Clocks |  |  |  |  |  |  |  |  |  |
| Primary Clock ${ }^{6}$ |  |  |  |  |  |  |  |  |  |
| $\mathrm{f}_{\text {MAX_PRI }}$ | Frequency for Primary Clock Tree | ECP3-150EA | - | 500 | - | 420 | - | 375 | MHz |
| $\mathrm{t}_{\text {W-PRI }}$ | Clock Pulse Width for Primary Clock | ECP3-150EA | 0.8 | - | 0.9 | - | 1.0 | - | ns |
| $\mathrm{t}_{\text {SKEW_PRI }}$ | Primary Clock Skew Within a Device | ECP3-150EA | - | 300 | - | 330 | - | 360 | ps |
| $\mathrm{t}_{\text {SKEW_PRIB }}$ | Primary Clock Skew Within a Bank | ECP3-150EA | - | 250 | - | 280 | - | 300 | ps |
| $\mathrm{f}_{\text {MAX_PRI }}$ | Frequency for Primary Clock Tree | ECP3-70EA/95EA | - | 500 | - | 420 | - | 375 | MHz |
| $\mathrm{t}_{\text {W- } \mathrm{PRI}}$ | Pulse Width for Primary Clock | ECP3-70EA/95EA | 0.8 | - | 0.9 | - | 1.0 | - | ns |
| $\mathrm{t}_{\text {SKEW_PRI }}$ | Primary Clock Skew Within a Device | ECP3-70EA/95EA | - | 360 | - | 370 | - | 380 | ps |
| $\mathrm{t}_{\text {SKEW_PRIB }}$ | Primary Clock Skew Within a Bank | ECP3-70EA/95EA | - | 310 | - | 320 | - | 330 | ps |
| $\mathrm{f}_{\text {MAX_PRI }}$ | Frequency for Primary Clock Tree | ECP3-35EA | - | 500 | - | 420 | - | 375 | MHz |
| $\mathrm{t}_{\text {W-PRI }}$ | Pulse Width for Primary Clock | ECP3-35EA | 0.8 | - | 0.9 | - | 1.0 | - | ns |
| $\mathrm{t}_{\text {SKEW_PRI }}$ | Primary Clock Skew Within a Device | ECP3-35EA | - | 300 | - | 330 | - | 360 | ps |
| $\mathrm{t}_{\text {SKEW_PRIB }}$ | Primary Clock Skew Within a Bank | ECP3-35EA | - | 250 | - | 280 | - | 300 | ps |
| $\mathrm{f}_{\text {MAX_PRI }}$ | Frequency for Primary Clock Tree | ECP3-17EA | - | 500 | - | 420 | - | 375 | MHz |
| $\mathrm{t}_{\text {W-PRI }}$ | Pulse Width for Primary Clock | ECP3-17EA | 0.8 | - | 0.9 | - | 1.0 | - | ns |
| $\mathrm{t}_{\text {SKEW_PRI }}$ | Primary Clock Skew Within a Device | ECP3-17EA | - | 310 | - | 340 | - | 370 | ps |
| $\mathrm{t}_{\text {SKEW_PRIB }}$ | Primary Clock Skew Within a Bank | ECP3-17EA | - | 220 | - | 230 | - | 240 | ps |


| Parameter | Description | Device | -8 |  | -7 |  | -6 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Edge Clock ${ }^{6}$ |  |  |  |  |  |  |  |  |  |
| $\mathrm{f}_{\text {MAX_EDGE }}$ | Frequency for Edge Clock | ECP3-150EA | - | 500 | - | 420 | - | 375 | MHz |
| $\mathrm{tw}_{\text {_ }}$ EDGE | Clock Pulse Width for Edge Clock | ECP3-150EA | 0.9 | - | 1.0 | - | 1.2 | - | ns |
| $\mathrm{t}_{\text {SKEW_EDGE_DQs }}$ | Edge Clock Skew Within an Edge of the Device | ECP3-150EA | - | 200 | - | 210 | - | 220 | ps |
| $\mathrm{f}_{\text {MAX_EDGE }}$ | Frequency for Edge Clock | ECP3-70EA/95EA | - | 500 | - | 420 | - | 375 | MHz |
| $\mathrm{t}_{\text {W_EDGE }}$ | Clock Pulse Width for Edge Clock | ECP3-70EA/95EA | 0.9 | - | 1.0 | - | 1.2 | - | ns |
| $\mathrm{t}_{\text {SKEW_EDGE_DQS }}$ | Edge Clock Skew Within an Edge of the Device | ECP3-70EA/95EA | - | 200 | - | 210 | - | 220 | ps |
| $f_{\text {MAX_EDGE }}$ | Frequency for Edge Clock | ECP3-35EA | - | 500 | - | 420 | - | 375 | MHz |
| $\mathrm{t}_{\text {W_EDGE }}$ | Clock Pulse Width for Edge Clock | ECP3-35EA | 0.9 | - | 1.0 | - | 1.2 | - | ns |
| $\mathrm{t}_{\text {SKEW_EDGE_DQS }}$ | Edge Clock Skew Within an Edge of the Device | ECP3-35EA | - | 200 | - | 210 | - | 220 | ps |
| $f_{\text {MAX_EDGE }}$ | Frequency for Edge Clock | ECP3-17EA | - | 500 | - | 420 | - | 375 | MHz |
| $\mathrm{tw}_{\text {_ }}$ EDGE | Clock Pulse Width for Edge Clock | ECP3-17EA | 0.9 | - | 1.0 | - | 1.2 | - | ns |
| $\mathrm{t}_{\text {SKEW_EDGE_DQS }}$ | Edge Clock Skew Within an Edge of the Device | ECP3-17EA | - | 200 | - | 210 | - | 220 | ps |

## Generic SDR

General I/O Pin Parameters Using Dedicated Clock Input Primary Clock Without PLL²

| $\mathrm{t}_{\text {CO }}$ | Clock to Output - <br> PIO Output <br> Register | ECP3-150EA | - | 3.9 | - | 4.3 | - | 4.7 | ns |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {SU }}$ | Clock to Data <br> Setup - PIO Input <br> Register | ECP3-150EA | 0.0 | - | 0.0 | - | 0.0 | - | ns |
| $\mathrm{t}_{\mathrm{H}}$ | Clock to Data <br> Hold - PIO Input <br> Register | ECP3-150EA | 1.5 | - | 1.7 | - | 2.0 | - | ns |
| $\mathrm{t}_{\text {SU_DEL }}$ | Clock to Data <br> Setup - PIO Input <br> Register with <br> Data Input Delay | ECP3-150EA | 1.3 | - | 1.5 | - | 1.7 | - | ns |
| $\mathrm{t}_{\text {H_DEL }}$ | Clock to Data <br> Hold - PIO Input <br> Register with <br> Input Data Delay | ECP3-150EA | 0.0 | - | 0.0 | - | 0.0 | - | ns |


| Parameter | Description | Device | -8 |  | -7 |  | -6 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\mathrm{f}_{\text {MAX_IO }}$ | Clock Frequency of I/O and PFU Register | ECP3-150EA | - | 500 | - | 420 | - | 375 | MHz |
| $\mathrm{t}_{\mathrm{co}}$ | Clock to Output PIO Output Register | ECP3-70EA/95EA | - | 3.8 | - | 4.2 | - | 4.6 | ns |
| $\mathrm{t}_{5}$ | Clock to Data <br> Setup - PIO Input Register | ECP3-70EA/95EA | 0.0 | - | 0.0 | - | 0.0 | - | ns |
| $\mathrm{t}_{\mathrm{H}}$ | Clock to Data Hold - PIO Input Register | ECP3-70EA/95EA | 1.4 | - | 1.6 | - | 1.8 | - | ns |
| $\mathrm{t}_{\text {su_del }}$ | Clock to Data <br> Setup - PIO Input <br> Register with <br> Data Input Delay | ECP3-70EA/95EA | 1.3 | - | 1.5 | - | 1.7 | - | ns |
| $\mathrm{t}_{\mathrm{H}_{-} \mathrm{DEL}}$ | Clock to Data Hold - PIO Input Register with Input Data Delay | ECP3-70EA/95EA | 0.0 | - | 0.0 | - | 0.0 | - | ns |
| $\mathrm{f}_{\text {MAX_ı }}$ | Clock Frequency of $I / O$ and PFU Register | ECP3-70EA/95EA | - | 500 | - | 420 | - | 375 | MHz |
| $\mathrm{t}_{\mathrm{co}}$ | Clock to Output PIO Output Register | ECP3-35EA | - | 3.7 | - | 4.1 | - | 4.5 | ns |
| $\mathrm{t}_{\text {su }}$ | Clock to Data Setup - PIO Input Register | ECP3-35EA | 0.0 | - | 0.0 | - | 0.0 | - | ns |
| $\mathrm{t}_{\mathrm{H}}$ | Clock to Data Hold - PIO Input Register | ECP3-35EA | 1.2 | - | 1.4 | - | 1.6 | - | ns |
| $\mathrm{t}_{\text {Su_del }}$ | Clock to Data <br> Setup - PIO Input <br> Register with Data Input Delay | ECP3-35EA | 1.3 | - | 1.4 | - | 1.5 | - | ns |
| $\mathrm{t}_{\text {H-DEL }}$ | Clock to Data Hold - PIO Input Register with Input Data Delay | ECP3-35EA | 0.0 | - | 0.0 | - | 0.0 | - | ns |
| $\mathrm{f}_{\text {MAX_10 }}$ | Clock Frequency of I/O and PFU Register | ECP3-35EA | - | 500 | - | 420 | - | 375 | MHz |
| $\mathrm{t}_{\mathrm{co}}$ | Clock to Output PIO Output Register | ECP3-17EA | - | 3.5 | - | 3.9 | - | 4.3 | ns |
| $\mathrm{t}_{\text {su }}$ | Clock to Data <br> Setup - PIO Input <br> Register | ECP3-17EA | 0.0 | - | 0.0 | - | 0.0 | - | ns |
| $\mathrm{t}_{\mathrm{H}}$ | Clock to Data Hold - PIO Input Register | ECP3-17EA | 1.3 | - | 1.5 | - | 1.6 | - | ns |


| Parameter | Description | Device | -8 |  | -7 |  | -6 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\text {SU_del }}$ | Clock to Data Setup - PIO Input Register with Data Input Delay | ECP3-17EA | 1.3 | - | 1.4 | - | 1.5 | - | ns |
| $\mathrm{t}_{\text {_ }} \mathrm{DEL}$ | Clock to Data Hold - PIO Input Register with Input Data Delay | ECP3-17EA | 0.0 | - | 0.0 | - | 0.0 | - | ns |
| fmax _10 | Clock Frequency of I/O and PFU Register | ECP3-17EA | - | 500 | - | 420 | - | 375 | MHz |

General I/O Pin Parameters Using Dedicated Clock Input Primary Clock with PLL with Clock Injection Removal Setting ${ }^{2}$

| tcople | Clock to Output PIO Output Register | ECP3-150EA | - | 3.3 | - | 3.6 | - | 39 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {suplu }}$ | Clock to Data <br> Setup - PIO Input Register | ECP3-150EA | 0.7 | - | 0.8 | - | 0.9 | - | ns |
| $\mathrm{t}_{\text {HPLL }}$ | Clock to Data Hold - PIO Input Register | ECP3-150EA | 0.8 | - | 0.9 | - | 1.0 | - | ns |
| $\mathrm{t}_{\text {SU_DELPLL }}$ | Clock to Data <br> Setup - PIO Input <br> Register with <br> Data Input Delay | ECP3-150EA | 1.6 | - | 1.8 | - | 2.0 | - | ns |
| $\mathrm{t}_{\text {H-DELPLL }}$ | Clock to Data Hold - PIO Input Register with Input Data Delay | ECP3-150EA | - | 0.0 | - | 0.0 | - | 0.0 | ns |
| $\mathrm{t}_{\text {cople }}$ | Clock to Output PIO Output Register | ECP3-70EA/95EA | - | 3.3 | - | 3.5 | - | 3.8 | ns |
| $\mathrm{t}_{\text {suplu }}$ | Clock to Data <br> Setup - PIO Input Register | ECP3-70EA/95EA | 0.7 | - | 0.8 | - | 0.9 | - | ns |
| $\mathrm{t}_{\text {HPLL }}$ | Clock to Data <br> Hold - PIO Input Register | ECP3-70EA/95EA | 0.7 | - | 0.7 | - | 0.8 | - | ns |
| $\mathrm{t}_{\text {SU_DELPLL }}$ | Clock to Data <br> Setup - PIO Input <br> Register with <br> Data Input Delay | ECP3-70EA/95EA | 1.6 | - | 1.8 | - | 2.0 | - | ns |
| $\mathrm{t}_{\text {_ DELPLL }}$ | Clock to Data Hold - PIO Input Register with Input Data Delay | ECP3-70EA/95EA | 0.0 | - | 0.0 | - | 0.0 | - | ns |
| tcopll | Clock to Output PIO Output Register | ECP3-35EA | - | 3.2 | - | 3.4 | - | 3.6 | ns |
| $\mathrm{t}_{\text {suplu }}$ | Clock to Data <br> Setup - PIO Input Register | ECP3-35EA | 0.6 | - | 0.7 | - | 0.8 | - | ns |


| Parameter | Description | Device | -8 |  | -7 |  | -6 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\text {HPLL }}$ | Clock to Data Hold - PIO Input Register | ECP3-35EA | 0.3 | - | 0.3 | - | 0.4 | - | ns |
| $\mathrm{t}_{\text {SU_DELPLL }}$ | Clock to Data <br> Setup - PIO Input <br> Register with <br> Data Input Delay | ECP3-35EA | 1.6 | - | 1.7 | - | 1.8 | - | ns |
| $\mathrm{t}_{\text {H_deLpli }}$ | Clock to Data Hold - PIO Input Register with Input Data Delay | ECP3-35EA | 0.0 | - | 0.0 | - | 0.0 | - | ns |
| $\mathrm{t}_{\text {coplu }}$ | Clock to Output PIO Output Register | ECP3-17EA | - | 3.0 | - | 3.3 | - | 3.5 | ns |
| $\mathrm{t}_{\text {supLL }}$ | Clock to Data <br> Setup - PIO Input <br> Register | ECP3-17EA | 0.6 | - | 0.7 | - | 0.8 | - | ns |
| $\mathrm{t}_{\text {HPLL }}$ | Clock to Data <br> Hold - PIO Input Register | ECP3-17EA | 0.3 | - | 0.3 | - | 0.4 | - | ns |
| $\mathrm{t}_{\text {SU_DELPLL }}$ | Clock to Data <br> Setup - PIO Input <br> Register with <br> Data Input Delay | ECP3-17EA | 1.6 | - | 1.7 | - | 1.8 | - | ns |
| $\mathrm{t}_{\text {_-deLpli }}$ | Clock to Data Hold - PIO Input Register with Input Data Delay | ECP3-17EA | 0.0 | - | 0.0 | - | 0.0 | - | ns |
| Generic DDR ${ }^{12}$ |  |  |  |  |  |  |  |  |  |
| Generic DDRX1 Inputs with Clock and Data (>10 Bits Wide) Centered at Pin (GDDRX1_RX.SCLK.Centered) Using PCLK Pin for Clock Input |  |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {SUGDDR }}$ | Data Setup <br> Before CLK | All ECP3EA Devices | 480 | - | 480 | - | 480 | - | ps |
| thogdir | Data Hold After CLK | All ECP3EA Devices | 480 | - | 480 | - | 480 | - | ps |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX1 Clock Frequency | All ECP3EA Devices | - | 250 | - | 250 | - | 250 | MHz |

Generic DDRX1 Inputs with Clock and Data (>10 Bits Wide) Aligned at Pin (GDDRX1_RX.SCLK.PLL.Aligned) Using PLLCLKIN Pin for Clock Input
Data Left, Right, and Top Sides and Clock Left and Right Sides

| t DVACLKGDDR | Data Setup <br> Before CLK | All ECP3EA <br> Devices | - | 0.225 | - | 0.225 | - | 0.225 | UI |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {DVECLKGDDR }}$ | Data Hold After <br> CLK | All ECP3EA <br> Devices | 0.775 | - | 0.775 | - | 0.775 | - | UI |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX1 Clock <br> Frequency | All ECP3EA <br> Devices | - | 250 | - | 250 | - | 250 | MHz |


| Parameter | Description |  | -8 |  | -7 |  | -6 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Generic DDRX1 Inputs with Clock and Data (>10 Bits Wide) Aligned at Pin (GDDRX1_RX.SCLK.Aligned) Using DLL - CLKIN Pin for Clock Input |  |  |  |  |  |  |  |  |  |
| Data Left, Right and Top Sides and Clock Left and Right Sides |  |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {DVACLKGdor }}$ | Data Setup <br> Before CLK | All ECP3EA Devices | - | 0.225 | - | 0.225 | - | 0.225 | UI |
| $\mathrm{t}_{\text {DVECLKGDDR }}$ | Data Hold After CLK | All ECP3EA Devices | 0.775 | - | 0.775 | - | 0.775 | - | UI |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX1 Clock Frequency | All ECP3EA Devices | - | 250 | - | 250 | - | 250 | MHz |
| Generic DDRX1 Inputs with Clock and Data (<10 Bits Wide) Centered at Pin (GDDRX1_RX.DQS.Centered) Using DQS Pin for Clock Input |  |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {SUGDDR }}$ | Data Setup After CLK | All ECP3EA Devices | 535 | - | 535 | - | 535 | - | ps |
| $\mathrm{thogdor}^{\text {l }}$ | Data Hold After CLK | All ECP3EA Devices | 535 | - | 535 | - | 535 | - | ps |
| $\mathrm{f}_{\mathrm{MAX} \text { _GDDR }}$ | DDRX1 Clock Frequency | All ECP3EA Devices | - | 250 | - | 250 | - | 250 | MHz |
| Generic DDRX1 Inputs with Clock and Data (<10bits wide) Aligned at Pin (GDDRX1_RX.DQS.Aligned) Using DQS Pin for Clock Input |  |  |  |  |  |  |  |  |  |
| Data and Clock Left and Right Sides |  |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {DVACLKGDDR }}$ | Data Setup <br> Before CLK | All ECP3EA Devices | - | 0.225 | - | 0.225 | - | 0.225 | UI |
| $\mathrm{t}_{\text {DVECLKGdor }}$ | Data Hold After CLK | All ECP3EA Devices | 0.775 | - | 0.775 | - | 0.775 | - | UI |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX1 Clock Frequency | All ECP3EA Devices | - | 250 | - | 250 | - | 250 | MHz |
| Generic DDRX2 Inputs with Clock and Data (>10 Bits Wide) Centered at Pin (GDDRX2_RX.ECLK.Centered) Using PCLK Pin for Clock Input |  |  |  |  |  |  |  |  |  |
| Left and Right Sides |  |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {SUGDDR }}$ | Data Setup <br> Before CLK | ECP3-150EA | 321 | - | 403 | - | 471 | - | ps |
| $\mathrm{t}_{\text {HOGDDR }}$ | Data Hold After CLK | ECP3-150EA | 321 | - | 403 | - | 471 | - | ps |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | ECP3-150EA | - | 405 | - | 325 | - | 280 | MHz |
| $\mathrm{t}_{\text {SUGDDR }}$ | Data Setup <br> Before CLK | ECP3-70EA/95EA | 321 | - | 403 | - | 535 | - | ps |
| $\mathrm{t}_{\text {Hogdir }}$ | Data Hold After CLK | ECP3-70EA/95EA | 321 | - | 403 | - | 535 | - | ps |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | ECP3-70EA/95EA | - | 405 | - | 325 | - | 250 | MHz |
| $\mathrm{t}_{\text {SUGDDR }}$ | Data Setup <br> Before CLK | ECP3-35EA | 335 | - | 425 | - | 535 | - | ps |
| $\mathrm{thogdir}^{\text {l }}$ | Data Hold After CLK | ECP3-35EA | 335 | - | 425 | - | 535 | - | ps |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | ECP3-35EA | - | 405 | - | 325 | - | 250 | MHz |
| $\mathrm{t}_{\text {SUGDDR }}$ | Data Setup <br> Before CLK | ECP3-17EA | 335 | - | 425 | - | 535 | - | ps |
| $\mathrm{t}_{\text {HOGDDR }}$ | Data Hold After CLK | ECP3-17EA | 335 | - | 425 | - | 535 | - | ps |


| Parameter | Description | Device | $\mathbf{- 8}$ |  | $\mathbf{- 7}$ |  | $\mathbf{- 6}$ |  | Units |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock <br> Frequency | ECP3-17EA | - | 405 | - | 325 | - | 250 | MHz |

Generic DDRX2 Inputs with Clock and Data (>10 Bits Wide) Aligned at Pin (GDDRX2_RX.ECLK.Aligned)
Left and Right Side Using DLLCLKIN Pin for Clock Input

| $\mathrm{t}_{\text {DVACLKGDDR }}$ | Data Setup <br> Before CLK | ECP3-150EA | - | 0.225 | - | 0.225 | - | 0.225 | UI |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {DVECLKGDDR }}$ | Data Hold After CLK | ECP3-150EA | 0.775 | - | 0.775 | - | 0.775 | - | UI |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | ECP3-150EA | - | 460 | - | 385 | - | 345 | MHz |
| $\mathrm{t}_{\text {DVACLIGdor }}$ | Data Setup <br> Before CLK | ECP3-70EA/95EA | - | 0.225 | - | 0.225 | - | 0.225 | UI |
| $\mathrm{t}_{\text {DVECLKGDDR }}$ | Data Hold After CLK | ECP3-70EA/95EA | 0.775 | - | 0.775 | - | 0.775 | - | UI |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | EСP3-70EA/95EA | - | 460 | - | 385 | - | 311 | MHz |
| $\mathrm{t}_{\text {DVACLKGDDR }}$ | Data Setup <br> Before CLK | ECP3-35EA | - | 0.210 | - | 0.210 | - | 0.210 | UI |
| $\mathrm{t}_{\text {dvecliggdr }}$ | Data Hold After CLK | ECP3-35EA | 0.790 | - | 0.790 | - | 0.790 | - | UI |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | ECP3-35EA | - | 460 | - | 385 | - | 311 | MHz |
| $\mathrm{t}_{\text {DVACLKGDDR }}$ | Data Setup <br> Before CLK | ECP3-17EA | - | 0.210 | - | 0.210 | - | 0.210 | UI |
| $\mathrm{t}_{\text {DVECLKGDDR }}$ | Data Hold After CLK | ECP3-17EA | 0.790 | - | 0.790 | - | 0.790 | - | UI |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | ECP3-17EA | - | 460 | - | 385 | - | 311 | MHz |

Top Side Using PCLK Pin for Clock Input

| $\mathrm{t}_{\text {DVACLKGDDR }}$ | Data Setup Before CLK | ECP3-150EA | - | 0.225 | - | 0.225 | - | 0.225 | UI |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {DVECLKGDDR }}$ | Data Hold After CLK | ECP3-150EA | 0.775 | - | 0.775 | - | 0.775 | - | UI |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | ECP3-150EA | - | 235 | - | 170 | - | 130 | MHz |
| $\mathrm{t}_{\text {DVACLKGDDR }}$ | Data Setup Before CLK | ECP3-70EA/95EA | - | 0.225 | - | 0.225 | - | 0.225 | UI |
| $\mathrm{t}_{\text {DVECLKGDDR }}$ | Data Hold After CLK | ECP3-70EA/95EA | 0.775 | - | 0.775 | - | 0.775 | - | UI |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | ECP3-70EA/95EA | - | 235 | - | 170 | - | 130 | MHz |
| $t_{\text {DVACLKGDDR }}$ | Data Setup Before CLK | ECP3-35EA | - | 0.210 | - | 0.210 | - | 0.210 | UI |
| $\mathrm{t}_{\text {DVECLKGDDR }}$ | Data Hold After CLK | ECP3-35EA | 0.790 | - | 0.790 | - | 0.790 | - | UI |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | ECP3-35EA | - | 235 | - | 170 | - | 130 | MHz |
| $t_{\text {DVACLKGDDR }}$ | Data Setup Before CLK | ECP3-17EA | - | 0.210 | - | 0.210 | - | 0.210 | UI |
| $\mathrm{t}_{\text {DVECLKGDDR }}$ | Data Hold After CLK | ECP3-17EA | 0.790 | - | 0.790 | - | 0.790 | - | UI |


| Parameter | Description | Device | -8 |  | -7 |  | -6 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | ECP3-17EA | - | 235 | - | 170 | - | 130 | MHz |

Generic DDRX2 Inputs with Clock and Data (>10bits wide) are Aligned at Pin (GDDRX2_RX.ECLK.Aligned) (No CLKDIV)
Left and Right Sides Using DLLCLKPIN for Clock Input

| $t_{\text {DVACLKGDDR }}$ | Data Setup Before CLK | ECP3-150EA | - | 0.225 | - | 0.225 | - | 0.225 | UI |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {DVECLKGDDR }}$ | Data Hold After CLK | ECP3-150EA | 0.775 | - | 0.775 | - | 0.775 | - | UI |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | ECP3-150EA | - | 460 | - | 385 | - | 345 | MHz |
| $\mathrm{t}_{\text {DVACLKGDDR }}$ | Data Setup Before CLK | ECP3-70EA/95EA | - | 0.225 | - | 0.225 | - | 0.225 | UI |
| $\mathrm{t}_{\text {DVECLKGDDR }}$ | Data Hold After CLK | ECP3-70EA/95EA | 0.775 | - | 0.775 | - | 0.775 | - | UI |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | ECP3-70EA/95EA | - | 460 | - | 385 | - | 311 | MHz |
| $\mathrm{t}_{\text {DVACLKGDDR }}$ | Data Setup Before CLK | ECP3-35EA | - | 0.210 | - | 0.210 | - | 0.210 | UI |
| $\mathrm{t}_{\text {DVECLKGDDR }}$ | Data Hold After CLK | ECP3-35EA | 0.790 | - | 0.790 | - | 0.790 | - | UI |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | ECP3-35EA | - | 460 | - | 385 | - | 311 | MHz |
| $t_{\text {DVACLKGDDR }}$ | Data Setup Before CLK (Left and Right Sides) | ECP3-17EA | - | 0.210 | - | 0.210 | - | 0.210 | UI |
| $\mathrm{t}_{\text {DVECLKGDDR }}$ | Data Hold After CLK | ECP3-17EA | 0.790 | - | 0.790 | - | 0.790 | - | UI |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | ECP3-17EA | - | 460 | - | 385 | - | 311 | MHz |

Top Side Using PCLK Pin for Clock Input

| $t_{\text {DVACLKGDDR }}$ | Data Setup Before CLK | ECP3-150EA | - | 0.225 | - | 0.225 | - | 0.225 | UI |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $t_{\text {dVECLKGDDR }}$ | Data Hold After CLK | ECP3-150EA | 0.775 | - | 0.775 | - | 0.775 | - | UI |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | ECP3-150EA | - | 235 | - | 170 | - | 130 | MHz |
| $\mathrm{t}_{\text {DVACLKGDDR }}$ | Data Setup Before CLK | ECP3-70EA/95EA | - | 0.225 | - | 0.225 | - | 0.225 | UI |
| $\mathrm{t}_{\text {DVECLKGDDR }}$ | Data Hold After CLK | ECP3-70EA/95EA | 0.775 | - | 0.775 | - | 0.775 | - | UI |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | ECP3-70EA/95EA | - | 235 | - | 170 | - | 130 | MHz |
| $\mathrm{t}_{\text {DVACLKGDDR }}$ | Data Setup Before CLK | ECP3-35EA | - | 0.210 | - | 0.210 | - | 0.210 | UI |
| $\mathrm{t}_{\text {DVECLKGDDR }}$ | Data Hold After CLK | ECP3-35EA | 0.790 | - | 0.790 | - | 0.790 | - | UI |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | ECP3-35EA | - | 235 | - | 170 | - | 130 | MHz |
| $t_{\text {DVACLKGDDR }}$ | Data Setup Before CLK | ECP3-17EA | - | 0.210 | - | 0.210 | - | 0.210 | UI |


| Parameter | Description | Device | -8 |  | -7 |  | -6 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| $\mathrm{t}_{\text {DVECLKGDDR }}$ | Data Hold After CLK | ECP3-17EA | 0.790 | - | 0.790 | - | 0.790 | - | UI |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | ECP3-17EA | - | 235 | - | 170 | - | 130 | MHz |
| Generic DDRX2 Inputs with Clock and Data (<10 Bits Wide) Centered at Pin (GDDRX2_RX.DQS.Centered) Using DQS Pin for Clock Input |  |  |  |  |  |  |  |  |  |
| Left and Right Sides |  |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {SUGDDR }}$ | Data Setup <br> Before CLK | All ECP3EA Devices | 330 | - | 330 | - | 352 | - | ps |
| $\mathrm{t}_{\text {HOGDDR }}$ | Data Hold After CLK | All ECP3EA Devices | 330 | - | 330 | - | 352 | - | ps |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | All ECP3EA Devices | - | 400 | - | 400 | - | 375 | MHz |
| Generic DDRX2 Inputs with Clock and Data (<10 Bits Wide) Aligned at Pin (GDDRX2_RX.DQS.Aligned) Using DQS Pin for Clock Input |  |  |  |  |  |  |  |  |  |
| Left and Right Sides |  |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {DVACLKGDDR }}$ | Data Setup <br> Before CLK | All ECP3EA Devices | - | 0.225 | - | 0.225 | - | 0.225 | UI |
| $\mathrm{t}_{\text {DVECLKGDDR }}$ | Data Hold After CLK | All ECP3EA Devices | 0.775 | - | 0.775 | - | 0.775 | - | UI |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | All ECP3EA Devices | - | 400 | - | 400 | - | 375 | MHz |
| Generic DDRX1 Output with Clock and Data ( $>10$ Bits Wide) Centered at Pin (GDDRX1_TX.SCLK.Centered) ${ }^{10}$ |  |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {DVBGDDR }}$ | Data Valid Before CLK | ECP3-150EA | 670 | - | 670 | - | 670 | - | ps |
| $\mathrm{t}_{\text {DVAGDDR }}$ | Data Valid After CLK | ECP3-150EA | 670 | - | 670 | - | 670 | - | ps |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX1 Clock Frequency | ECP3-150EA | - | 250 | - | 250 | - | 250 | MHz |
| $\mathrm{t}_{\text {DVBGDDR }}$ | Data Valid Before CLK | ECP3-70EA/95EA | 666 | - | 665 | - | 664 | - | ps |
| $\mathrm{t}_{\text {DVAGDDR }}$ | Data Valid After CLK | ECP3-70EA/95EA | 666 | - | 665 | - | 664 | - | ps |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX1 Clock <br> Frequency | ECP3-70EA/95EA | - | 250 | - | 250 | - | 250 | MHz |
| $\mathrm{t}_{\text {DVBGDDR }}$ | Data Valid Before CLK | ECP3-35EA | 683 | - | 688 | - | 690 | - | ps |
| $\mathrm{t}_{\text {DVAGDDR }}$ | Data Valid After CLK | ECP3-35EA | 683 | - | 688 | - | 690 | - | ps |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX1 Clock Frequency | ECP3-35EA | - | 250 | - | 250 | - | 250 | MHz |
| $\mathrm{t}_{\text {DVBGDDR }}$ | Data Valid Before CLK | ECP3-17EA | 683 | - | 688 | - | 690 | - | ps |
| $\mathrm{t}_{\text {DVAGDDR }}$ | Data Valid After CLK | ECP3-17EA | 683 | - | 688 | - | 690 | - | ps |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX1 Clock <br> Frequency | ECP3-17EA | - | 250 | - | 250 | - | 250 | MHz |


| Parameter | Description | Device | -8 |  | -7 |  | -6 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Generic DDRX1 Output with Clock and Data Aligned at Pin (GDDRX1_TX.SCLK.Aligned) ${ }^{10}$ |  |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {DIBGDDR }}$ | Data Invalid Before Clock | ECP3-150EA | - | 335 | - | 338 | - | 341 | ps |
| $\mathrm{t}_{\text {DIAGDDR }}$ | Data Invalid After Clock | ECP3-150EA | - | 335 | - | 338 | - | 341 | ps |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX1 Clock Frequency | ECP3-150EA | - | 250 | - | 250 | - | 250 | MHz |
| $\mathrm{t}_{\text {DIBGDDR }}$ | Data Invalid Before Clock | ECP3-70EA/95EA | - | 339 | - | 343 | - | 347 | ps |
| $\mathrm{t}_{\text {DIAGDDR }}$ | Data Invalid After Clock | ECP3-70EA/95EA | - | 339 | - | 343 | - | 347 | ps |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX1 Clock <br> Frequency | ECP3-70EA/95EA | - | 250 | - | 250 | - | 250 | MHz |
| $\mathrm{t}_{\text {DIBGDDR }}$ | Data Invalid Before Clock | ECP3-35EA | - | 322 | - | 320 | - | 321 | ps |
| $\mathrm{t}_{\text {DIAGDDR }}$ | Data Invalid After Clock | ECP3-35EA | - | 322 | - | 320 | - | 321 | ps |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX1 Clock <br> Frequency | ECP3-35EA | - | 250 | - | 250 | - | 250 | MHz |
| $\mathrm{t}_{\text {DIBGDDR }}$ | Data Invalid Before Clock | ECP3-17EA | - | 322 | - | 320 | - | 321 | ps |
| $\mathrm{t}_{\text {DIAGDDR }}$ | Data Invalid After Clock | ECP3-17EA | - | 322 | - | 320 | - | 321 | ps |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX1 Clock Frequency | ECP3-17EA | - | 250 | - | 250 | - | 250 | MHz |

Generic DDRX1 Output with Clock and Data (<10 Bits Wide) Centered at Pin (GDDRX1_TX.DQS.Centered) ${ }^{10}$
Left and Right Sides

| $\mathrm{t}_{\text {DVBGDDR }}$ | Data Valid Before CLK | ECP3-150EA | 670 | - | 670 | - | 670 | - | ps |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {DVAGDDR }}$ | Data Valid After CLK | ECP3-150EA | 670 | - | 670 | - | 670 | - | ps |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX1 Clock Frequency | ECP3-150EA | - | 250 | - | 250 | - | 250 | MHz |
| $\mathrm{t}_{\text {DVGGDDR }}$ | Data Valid Before CLK | ECP3-70EA/95EA | 657 | - | 652 | - | 650 | - | ps |
| $\mathrm{t}_{\text {DVAGDDR }}$ | Data Valid After CLK | ECP3-70EA/95EA | 657 | - | 652 | - | 650 | - | ps |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX1 Clock <br> Frequency | ECP3-70EA/95EA | - | 250 | - | 250 | - | 250 | MHz |
| $\mathrm{t}_{\text {DVBGDDR }}$ | Data Valid Before CLK | ECP3-35EA | 670 | - | 675 | - | 676 | - | ps |
| $\mathrm{t}_{\text {DVAGDDR }}$ | Data Valid After CLK | ECP3-35EA | 670 | - | 675 | - | 676 | - | ps |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX1 Clock Frequency | ECP3-35EA | - | 250 | - | 250 | - | 250 | MHz |
| $\mathrm{t}_{\text {DVBGDDR }}$ | Data Valid Before CLK | ECP3-17EA | 670 | - | 670 | - | 670 | - | ps |
| $\mathrm{t}_{\text {DVAGDDR }}$ | Data Valid After CLK | ECP3-17EA | 670 | - | 670 | - | 670 | - | ps |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX1 Clock <br> Frequency | ECP3-17EA | - | 250 | - | 250 | - | 250 | MHz |


| Parameter | Description | Device | -8 |  | -7 |  | -6 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| Generic DDRX2 Output with Clock and Data (>10 Bits Wide) Aligned at Pin (GDDRX2_TX.Aligned) |  |  |  |  |  |  |  |  |  |
| Left and Right Sides |  |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {IIBGDDR }}$ | Data Invalid Before Clock | All ECP3EA Devices | - | 200 | - | 210 | - | 220 | ps |
| $\mathrm{t}_{\text {DIAGDDR }}$ | Data Invalid After Clock | All ECP3EA Devices | - | 200 | - | 210 | - | 220 | ps |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock Frequency | All ECP3EA Devices | - | 500 | - | 420 | - | 375 | MHz |

Generic DDRX2 Output with Clock and Data (<10 Bits Wide) Centered at Pin Using DQSDLL (GDDRX2_TX.DQSDLL.Centered) ${ }^{11}$ Left and Right Sides

| t $_{\text {DVBGDDR }}$ | Data Valid Before <br> CLK | All ECP3EA <br> Devices | 400 | - | 400 | - | 431 | - | ps |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| t $_{\text {DVAGDDR }}$ | Data Valid After <br> CLK | All ECP3EA <br> Devices | 400 | - | 400 | - | 432 | - | ps |
| fmax_GDDr | DDRX2 Clock <br> Frequency | All ECP3EA <br> Devices | - | 400 | - | 400 | - | 375 | MHz |

Generic DDRX2 Output with Clock and Data (>10 Bits Wide) Centered at Pin Using PLL (GDDRX2_TX.PLL.Centered) ${ }^{10}$
Left and Right Sides

| $\mathrm{t}_{\text {DVBGDDR }}$ | Data Valid Before <br> CLK | All ECP3EA <br> Devices | 285 | - | 370 | - | 431 | - | ps |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {DVAGDDR }}$ | Data Valid After <br> CLK | All ECP3EA <br> Devices | 285 | - | 370 | - | 432 | - | ps |
| $\mathrm{f}_{\text {MAX_GDDR }}$ | DDRX2 Clock <br> Frequency | All ECP3EA <br> Devices | - | 500 | - | 420 | - | 375 | MHz |

## Memory Interface

DDR/DDR2 I/O Pin Parameters (Input Data are Strobe Edge Aligned, Output Strobe Edge is Data Centered) ${ }^{4}$

| tovado | Data Valid After DQS (DDR Read) | All ECP3 Devices | - | 0.225 | - | 0.225 | - | 0.225 | UI |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {dveda }}$ | Data Hold After DQS (DDR Read) | All ECP3 Devices | 0.64 | - | 0.64 | - | 0.64 | - | UI |
| $\mathrm{t}_{\text {DQVBS }}$ | Data Valid Before DQS | All ECP3 Devices | 0.25 | - | 0.25 | - | 0.25 | - | UI |
| $\mathrm{t}_{\text {davas }}$ | Data Valid After DQS | All ECP3 Devices | 0.25 | - | 0.25 | - | 0.25 | - | UI |
| $\mathrm{f}_{\text {MAX_D }}$ | DDR Clock Frequency | All ECP3 Devices | 95 | 200 | 95 | 200 | 95 | 166 | MHz |
| $\mathrm{f}_{\text {MAX_D }}$ 2 2 | DDR2 clock frequency | All ECP3 Devices | 125 | 266 | 125 | 200 | 125 | 166 | MHz |

DDR3 (Using PLL for SCLK) I/O Pin Parameters

| $\mathrm{t}_{\text {DVADQ }}$ | Data Valid After <br> DQS (DDR Read) | All ECP3 Devices | - | 0.225 | - | 0.225 | - | 0.225 | UI |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {DVEDQ }}$ | Data Hold After <br> DQS (DDR Read) | All ECP3 Devices | 0.64 | - | 0.64 | - | 0.64 | - | UI |
| $\mathrm{t}_{\text {DQvBS }}$ | Data Valid Before <br> DQS | All ECP3 Devices | 0.25 | - | 0.25 | - | 0.25 | - | UI |
| $\mathrm{t}_{\text {DQVAS }}$ | Data Valid After <br> DQS | All ECP3 Devices | 0.25 | - | 0.25 | - | 0.25 | - | UI |
| $\mathrm{f}_{\text {MAX_DDR3 }}$ | DDR3 clock <br> frequency | All ECP3 Devices | 300 | 400 | 266 | 333 | 266 | 300 | MHz |


| Parameter | Description | Device | -8 |  | -7 |  | -6 |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| DDR3 Clock Timing |  |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\mathrm{CH}}(\mathrm{avg})^{9}$ | Average High Pulse Width | All ECP3 Devices | 0.47 | 0.53 | 0.47 | 0.53 | 0.47 | 0.53 | UI |
| $\mathrm{tcL}_{\text {c }}(\mathrm{avg})^{9}$ | Average Low Pulse Width | All ECP3 Devices | 0.47 | 0.53 | 0.47 | 0.53 | 0.47 | 0.53 | UI |
| $\mathrm{t}_{\text {JTT }}(\mathrm{per}, \mathrm{lck})^{9}$ | Output Clock Period Jitter During DLL Locking Period | All ECP3 Devices | -90 | 90 | -90 | 90 | -90 | 90 | ps |
| $\mathrm{t}_{\text {JIT }}(\mathrm{cc}, \mathrm{lck})^{9}$ | Output Cycle-to- <br> Cycle Period Jitter During DLL Locking Period | All ECP3 Devices | - | 180 | - | 180 | - | 180 | ps |

## Notes:

1. Commercial timing numbers are shown. Industrial numbers are typically slower and can be extracted from the Diamond or ispLEVER software.
2. General I/O timing numbers based on LVCMOS 2.5, 12 mA , Fast Slew Rate, Opf load.
3. Generic DDR timing numbers based on LVDS I/O.
4. DDR timing numbers based on SSTL25. DDR2 timing numbers based on SSTL18.
5. DDR3 timing numbers based on SSTL15.
6. Uses LVDS I/O standard.
7. The current version of software does not support per bank skew numbers; this will be supported in a future release.
8. Maximum clock frequencies are tested under best case conditions. System performance may vary upon the user environment.
9. Using settings generated by IPexpress.
10. These numbers are generated using best case PLL located in the center of the device.
11. Uses SSTL25 Class II Differential I/O Standard.
12. All numbers are generated with ispLEVER 8.1 software.
13. For details on -9 speed grade devices, contact your Lattice Sales Representative.


Figure 4.6. Generic DDRX1/DDRX2 (With Clock and Data Edges Aligned)


Figure 4.7. DDR/DDR2/DDR3 Parameters


Figure 4.8. Generic DDRX1/DDRX2 (With Clock Center on Data Window)

### 4.17. LatticeECP3 Internal Switching Characteristics ${ }^{1,2,5}$

Over Recommended Commercial Operating Conditions

| Parameter | Description | -8 |  | -7 |  | -6 |  | Units. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| PFU/PFF Logic Mode Timing |  |  |  |  |  |  |  |  |
| tLuT4_Pfu | LUT4 delay (A to D inputs to F output) | - | 0.147 | - | 0.163 | - | 0.179 | ns |
| tLut6_PFU | LUT6 delay (A to D inputs to OFX output) | - | 0.281 | - | 0.335 | - | 0.379 | ns |
| $\mathrm{t}_{\text {LSR_PFU }}$ | Set/Reset to output of PFU (Asynchronous) | - | 0.593 | - | 0.674 | - | 0.756 | ns |
| $\mathrm{t}_{\text {ISRREC_PFU }}$ | Asynchronous Set/Reset recovery time for PFU Logic | - | 0.298 | - | 0.345 | - | 0.391 | ns |
| $\mathrm{t}_{\text {Sum_PFU }}$ | Clock to Mux (M0,M1) Input Setup Time | 0.134 | - | 0.144 | - | 0.153 | - | ns |
| $\mathrm{t}_{\mathrm{Hm} \text { _PFU }}$ | Clock to Mux (M0,M1) Input Hold Time | -0.097 | - | -0.103 | - | -0.109 | - | ns |
| $\mathrm{t}_{\text {SUD_PFU }}$ | Clock to D input setup time | 0.061 | - | 0.068 | - | 0.075 | - | ns |
| $\mathrm{t}_{\mathrm{HD}}$ - FF | Clock to D input hold time | 0.019 | - | 0.013 | - | 0.015 | - | ns |
| $\mathrm{t}_{\text {cK2Q_PFU }}$ | Clock to Q delay, (D-type Register Configuration) | - | 0.243 | - | 0.273 | - | 0.303 | ns |
| PFU Dual Port Memory Mode Timing |  |  |  |  |  |  |  |  |
| tcoram_Pfu | Clock to Output (F Port) | - | 0.710 | - | 0.803 | - | 0.897 | ns |
| $\mathrm{t}_{\text {SUdATA_PFU }}$ | Data Setup Time | -0.137 | - | -0.155 | - | -0.174 | - | ns |
| $\mathrm{t}_{\text {HDATA_PFU }}$ | Data Hold Time | 0.188 | - | 0.217 | - | 0.246 | - | ns |
| tsuador_Pfu | Address Setup Time | -0.227 | - | -0.257 | - | -0.286 | - | ns |
| $\mathrm{t}_{\text {HADDR_PFU }}$ | Address Hold Time | 0.240 | - | 0.275 | - | 0.310 | - | ns |
| tsuwren_pfu | Write/Read Enable Setup Time | -0.055 | - | -0.055 | - | -0.063 | - | ns |
| thwren_pfu | Write/Read Enable Hold Time | 0.059 | - | 0.059 | - | 0.071 | - | ns |

## PIC Timing

PIO Input/Output Buffer Timing

| $\mathrm{t}_{\text {IN_PIO }}$ | Input Buffer Delay (LVCMOS25) | - | 0.423 | - | 0.466 | - | 0.508 | ns |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| tout_pio | Output Buffer Delay (LVCMOS25) | - | 1.241 | - | 1.301 | - | 1.361 | ns |
| IOLOGIC Input/Output Timing |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {SU_P_PIo }}$ | Input Register Setup Time (Data Before Clock) | 0.956 | - | 1.124 | - | 1.293 | - | ns |
| $\mathrm{thİPIO}$ | Input Register Hold Time (Data after Clock) | 0.225 | - | 0.184 | - | 0.240 | - | ns |
| tcoo_PIo | Output Register Clock to Output Delay4 | - | 1.09 | - | 1.16 | - | 1.23 | ns |
| $\mathrm{t}_{\text {SUCE_PIo }}$ | Input Register Clock Enable Setup Time | 0.220 | - | 0.185 | - | 0.150 | - | ns |
| thce_plo | Input Register Clock Enable Hold Time | -0.085 | - | -0.072 | - | -0.058 | - | ns |
| tsulsk_PIo | Set/Reset Setup Time | 0.117 | - | 0.103 | - | 0.088 | - | ns |
| thlsk_PIO | Set/Reset Hold Time | -0.107 | - | -0.094 | - | -0.081 | - | ns |


| Parameter | Description | -8 |  | -7 |  | -6 |  | Units. |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. |  |
| EBR Timing |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {CO_EbR }}$ | Clock (Read) to output from Address or Data | - | 2.78 | - | 2.89 | - | 2.99 | ns |
| $\mathrm{t}_{\text {coo_Ebr }}$ | Clock (Write) to output from EBR output Register | - | 0.31 | - | 0.32 | - | 0.33 | ns |
| $\mathrm{t}_{\text {SUDATA_E }}$ | Setup Data to EBR Memory | -0.218 | - | -0.227 | - | -0.237 | - | ns |
| $\mathrm{t}_{\text {HDATA_EBR }}$ | Hold Data to EBR Memory | 0.249 | - | 0.257 | - | 0.265 | - | ns |
| tsuador_EBR | Setup Address to EBR Memory | -0.071 | - | -0.070 | - | -0.068 | - | ns |
| $\mathrm{t}_{\text {HADDR_EBR }}$ | Hold Address to EBR Memory | 0.118 | - | 0.098 | - | 0.077 | - | ns |
| $\mathrm{t}_{\text {SUWREN_EBR }}$ | Setup Write/Read Enable to EBR Memory | -0.107 | - | -0.106 | - | -0.106 | - | ns |
| thwren_Ebr | Hold Write/Read Enable to EBR Memory | 0.141 | - | 0.145 | - | 0.149 | - | ns |
| $\mathrm{t}_{\text {SUCE_EBR }}$ | Clock Enable Setup Time to EBR Output Register | 0.087 | - | 0.096 | - | 0.104 | - | ns |
| $\mathrm{t}_{\text {HCE_EBR }}$ | Clock Enable Hold Time to EBR Output Register | -0.066 | - | -0.080 | - | -0.094 | - | ns |
| $\mathrm{t}_{\text {SUBE_EBR }}$ | Byte Enable Set-Up Time to EBR Output Register | -0.071 | - | -0.070 | - | -0.068 | - | ns |
| $\mathrm{t}_{\text {HBE_EBR }}$ | Byte Enable Hold Time to EBR Output Register | 0.118 | - | 0.098 | - | 0.077 | - | ns |
| DSP Block Timing ${ }^{3}$ |  |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {SUI_DSP }}$ | Input Register Setup Time | 0.32 | - | 0.36 | - | 0.39 | - | ns |
| $\mathrm{t}_{\text {HI_DSP }}$ | Input Register Hold Time | -0.17 | - | -0.19 | - | -0.21 | - | ns |
| tsup_DSP | Pipeline Register Setup Time | 2.23 | - | 2.30 | - | 2.37 | - | ns |
| $\mathrm{t}_{\text {HP_DSP }}$ | Pipeline Register Hold Time | -1.02 | - | -1.09 | - | -1.15 | - | ns |
| $\mathrm{t}_{\text {suo_ }{ }^{\text {d }} \text { P }}$ | Output Register Setup Time | 3.09 | - | 3.22 | - | 3.34 | - | ns |
| $\mathrm{t}_{\text {HO_SSP }}$ | Output Register Hold Time | -1.67 | - | -1.76 | - | -1.84 | - | ns |
| $\mathrm{t}_{\text {col_ }}$ DSP | Input Register Clock to Output Time | - | 3.05 | - | 3.35 | - | 3.73 | ns |
| $\mathrm{t}_{\text {cop_DSP }}$ | Pipeline Register Clock to Output Time | - | 1.30 | - | 1.47 | - | 1.64 | ns |
| tcoo_DSP | Output Register Clock to Output Time | - | 0.58 | - | 0.60 | - | 0.62 | ns |
| $\mathrm{t}_{\text {SUOPT_DSP }}$ | Opcode Register Setup Time | 0.31 | - | 0.35 | - | 0.39 | - | ns |
| $\mathrm{t}_{\text {Hopt_DSP }}$ | Opcode Register Hold Time | -0.20 | - | -0.24 | - | -0.27 | - | ns |
| $\mathrm{t}_{\text {SUDATA_DSP }}$ | Cascade_data through ALU to Output Register Setup Time | 1.69 | - | 1.94 | - | 2.14 | - | ns |
| $\mathrm{t}_{\text {HPDATA_dSP }}$ | Cascade_data through ALU to Output Register Hold Time | -0.58 | - | -0.80 | - | -0.97 | - | ns |

## Notes:

1. Internal parameters are characterized but not tested on every device.
2. Commercial timing numbers are shown. Industrial timing numbers are typically slower and can be extracted from the Diamond or ispLEVER software.
3. DSP slice is configured in Multiply Add/Sub $18 \times 18$ mode.
4. The output register is in Flip-flop mode.
5. For details on -9 speed grade devices, contact your Lattice Sales Representative.

### 4.18. Timing Diagrams



Figure 4.9. Read/Write Mode (Normal)
Note: Input data and address are registered at the positive edge of the clock and output data appears after the positive edge of the clock.


Figure 4.10. Read/Write Mode with Input and Output Registers


Figure 4.11. Write Through (SP Read/Write on Port A, Input Registers Only)

Note: Input data and address are registered at the positive edge of the clock and output data appears after the positive edge of the clock.

### 4.19. LatticeECP3 Family Timing Adders ${ }^{1,2,3,4,5,7}$

Over Recommended Commercial Operating Conditions

| Buffer Type | Description | -8 | -7 | -6 | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Input Adjusters |  |  |  |  |  |
| LVDS25E | LVDS, Emulated, $\mathrm{V}_{\text {cııO }}=2.5 \mathrm{~V}$ | 0.03 | -0.01 | -0.03 | ns |
| LVDS25 | LVDS, $\mathrm{V}_{\text {ccIo }}=2.5 \mathrm{~V}$ | 0.03 | 0.00 | -0.04 | ns |
| BLVDS25 | BLVDS, Emulated, $\mathrm{V}_{\text {ccIo }}=2.5 \mathrm{~V}$ | 0.03 | 0.00 | -0.04 | ns |
| MLVDS25 | MLVDS, Emulated, $\mathrm{V}_{\text {ccıo }}=2.5 \mathrm{~V}$ | 0.03 | 0.00 | -0.04 | ns |
| RSDS25 | RSDS, $\mathrm{V}_{\text {ccIo }}=2.5 \mathrm{~V}$ | 0.03 | -0.01 | -0.03 | ns |
| PPLVDS | Point-to-Point LVDS | 0.03 | -0.01 | -0.03 | ns |
| TRLVDS | Transition-Reduced LVDS | 0.03 | 0.00 | -0.04 | ns |
| Mini MLVDS | Mini LVDS | 0.03 | -0.01 | -0.03 | ns |
| LVPECL33 | LVPECL, Emulated, $\mathrm{V}_{\text {ccıo }}=3.3 \mathrm{~V}$ | 0.17 | 0.23 | 0.28 | ns |
| HSTL18_I | HSTL_18 class I, $\mathrm{V}_{\text {clio }}=1.8 \mathrm{~V}$ | 0.20 | 0.17 | 0.13 | ns |
| HSTL18_II | HSTL_18 class II, V $\mathrm{CcIO}=1.8 \mathrm{~V}$ | 0.20 | 0.17 | 0.13 | ns |
| HSTL18D_I | Differential HSTL 18 class I | 0.20 | 0.17 | 0.13 | ns |
| HSTL18D_II | Differential HSTL 18 class II | 0.20 | 0.17 | 0.13 | ns |
| HSTL15_I | HSTL_15 class I, V $\mathrm{CcIO}^{\text {a }}=1.5 \mathrm{~V}$ | 0.10 | 0.12 | 0.13 | ns |
| HSTL15D_I | Differential HSTL 15 class I | 0.10 | 0.12 | 0.13 | ns |
| SSTL33_I | SSTL_3 class I, $\mathrm{V}_{\text {ccIo }}=3.3 \mathrm{~V}$ | 0.17 | 0.23 | 0.28 | ns |
| SSTL33_II | SSTL_3 class II, $\mathrm{V}_{\text {ccio }}=3.3 \mathrm{~V}$ | 0.17 | 0.23 | 0.28 | ns |
| SSTL33D_I | Differential SSTL_3 class I | 0.17 | 0.23 | 0.28 | ns |
| SSTL33D_II | Differential SSTL_3 class II | 0.17 | 0.23 | 0.28 | ns |
| SSTL25_I | SSTL_2 class I, $\mathrm{V}_{\text {ccIo }}=2.5 \mathrm{~V}$ | 0.12 | 0.14 | 0.16 | ns |
| SSTL25_II | SSTL_2 class II, $\mathrm{V}_{\text {clio }}=2.5 \mathrm{~V}$ | 0.12 | 0.14 | 0.16 | ns |
| SSTL25D_I | Differential SSTL_2 class I | 0.12 | 0.14 | 0.16 | ns |
| SSTL25D_II | Differential SSTL_2 class II | 0.12 | 0.14 | 0.16 | ns |
| SSTL18_I | SSTL_18 class I, $\mathrm{V}_{\text {clio }}=1.8 \mathrm{~V}$ | 0.08 | 0.06 | 0.04 | ns |
| SSTL18_II | SSTL_18 class II, V $\mathrm{CCIO}=1.8 \mathrm{~V}$ | 0.08 | 0.06 | 0.04 | ns |
| SSTL18D_I | Differential SSTL_18 class I | 0.08 | 0.06 | 0.04 | ns |
| SSTL18D_II | Differential SSTL_18 class II | 0.08 | 0.06 | 0.04 | ns |
| SSTL15 | SSTL_15, $\mathrm{V}_{\text {clio }}=1.5 \mathrm{~V}$ | 0.087 | 0.059 | 0.032 | ns |
| SSTL15D | Differential SSTL_15 | 0.087 | 0.059 | 0.032 | ns |
| LVTTL33 | LVTTL, $\mathrm{V}_{\text {cCIO }}=3.3 \mathrm{~V}$ | 0.07 | 0.07 | 0.07 | ns |
| LVCMOS33 | LVCMOS, $\mathrm{V}_{\text {CCIO }}=3.3 \mathrm{~V}$ | 0.07 | 0.07 | 0.07 | ns |
| LVCMOS25 | LVCMOS, $\mathrm{V}_{\text {ccio }}=2.5 \mathrm{~V}$ | 0.00 | 0.00 | 0.00 | ns |
| LVCMOS18 | LVCMOS, $\mathrm{V}_{\text {CCIO }}=1.8 \mathrm{~V}$ | -0.13 | -0.13 | -0.13 | ns |
| LVCMOS15 | LVCMOS, $\mathrm{V}_{\text {ccio }}=1.5 \mathrm{~V}$ | -0.07 | -0.07 | -0.07 | ns |
| LVCMOS12 | LVCMOS, $\mathrm{V}_{\text {ccio }}=1.2 \mathrm{~V}$ | -0.20 | -0.19 | -0.19 | ns |
| PCI33 | $\mathrm{PCI}, \mathrm{V}_{\text {CCIO }}=3.3 \mathrm{~V}$ | 0.07 | 0.07 | 0.07 | ns |
| Output Adjusters |  |  |  |  |  |
| LVDS25E | LVDS, Emulated, $\mathrm{V}_{\text {cıIO }}=2.5 \mathrm{~V}$ | 1.02 | 1.14 | 1.26 | ns |
| LVDS25 | LVDS, $\mathrm{V}_{\text {ccIo }}=2.5 \mathrm{~V}$ | -0.11 | -0.07 | -0.03 | ns |
| BLVDS25 | BLVDS, Emulated, $\mathrm{V}_{\text {ccIo }}=2.5 \mathrm{~V}$ | 1.01 | 1.13 | 1.25 | ns |
| MLVDS25 | MLVDS, Emulated, $\mathrm{V}_{\text {cCIO }}=2.5 \mathrm{~V}$ | 1.01 | 1.13 | 1.25 | ns |
| RSDS25 | RSDS, $\mathrm{V}_{\text {ccio }}=2.5 \mathrm{~V}$ | -0.07 | -0.04 | -0.01 | ns |
| PPLVDS | Point-to-Point LVDS, True LVDS, VCCIO $=2.5 \mathrm{~V}$ or 3.3 V | -0.22 | -0.19 | -0.16 | ns |


| Buffer Type | Description | -8 | -7 | -6 | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| LVPECL33 | LVPECL, Emulated, $\mathrm{V}_{\text {cclo }}=3.3 \mathrm{~V}$ | 0.67 | 0.76 | 0.86 | ns |
| HSTL18_I | HSTL_18 class 18 mA drive, $\mathrm{V}_{\text {ccIo }}=1.8 \mathrm{~V}$ | 1.20 | 1.34 | 1.47 | ns |
| HSTL18_II | HSTL_18 class II, $\mathrm{V}_{\text {cılO }}=1.8 \mathrm{~V}$ | 0.89 | 1.00 | 1.11 | ns |
| HSTL18D_I | Differential HSTL 18 class 18 mA drive | 1.20 | 1.34 | 1.47 | ns |
| HSTL18D_II | Differential HSTL 18 class II | 0.89 | 1.00 | 1.11 | ns |
| HSTL15_I | HSTL_15 class 14 mA drive, $\mathrm{V}_{\text {ccıo }}=1.5 \mathrm{~V}$ | 1.67 | 1.83 | 1.99 | ns |
| HSTL15D_I | Differential HSTL 15 class 14 mA drive | 1.67 | 1.83 | 1.99 | ns |
| SSTL33_I | SSTL_3 class I, $\mathrm{V}_{\text {ccIo }}=3.3 \mathrm{~V}$ | 1.12 | 1.17 | 1.21 | ns |
| SSTL33_II | SSTL_3 class II, $\mathrm{V}_{\text {CCIO }}=3.3 \mathrm{~V}$ | 1.08 | 1.12 | 1.15 | ns |
| SSTL33D_I | Differential SSTL_3 class I | 1.12 | 1.17 | 1.21 | ns |
| SSTL33D_II | Differential SSTL_3 class II | 1.08 | 1.12 | 1.15 | ns |
| SSTL25_I | SSTL_2 class 18 mA drive, $\mathrm{V}_{\text {cclo }}=2.5 \mathrm{~V}$ | 1.06 | 1.19 | 1.31 | ns |
| SSTL25_II | SSTL_2 class II 16 mA drive, $\mathrm{V}_{\text {ccIo }}=2.5 \mathrm{~V}$ | 1.04 | 1.17 | 1.31 | ns |
| SSTL25D_I | Differential SSTL_2 class 18 mA drive | 1.06 | 1.19 | 1.31 | ns |
| SSTL25D_II | Differential SSTL_2 class II 16 mA drive | 1.04 | 1.17 | 1.31 | ns |
| SSTL18_I | SSTL_1.8 class I, V $\mathrm{VClO}=1.8 \mathrm{~V}$ | 0.70 | 0.84 | 0.97 | ns |
| SSTL18_II | SSTL_1.8 class II 8 mA drive, $\mathrm{V}_{\text {ccio }}=1.8 \mathrm{~V}$ | 0.70 | 0.84 | 0.97 | ns |
| SSTL18D_I | Differential SSTL_1.8 class I | 0.70 | 0.84 | 0.97 | ns |
| SSTL18D_II | Differential SSTL_1.8 class 118 mA drive | 0.70 | 0.84 | 0.97 | ns |
| SSTL15 | SSTL_1.5, V ${ }_{\text {CCIO }}=1.5 \mathrm{~V}$ | 1.22 | 1.35 | 1.48 | ns |
| SSTL15D | Differential SSTL_15 | 1.22 | 1.35 | 1.48 | ns |
| LVTTL33_4mA | LVTTL 4 mA drive, $\mathrm{V}_{\text {ccıo }}=3.3 \mathrm{~V}$ | 0.25 | 0.24 | 0.23 | ns |
| LVTTL33_8mA | LVTTL 8 mA drive, $\mathrm{V}_{\text {clio }}=3.3 \mathrm{~V}$ | -0.06 | -0.06 | -0.07 | ns |
| LVTTL33_12mA | LVTTL 12 mA drive, $\mathrm{V}_{\text {cclo }}=3.3 \mathrm{~V}$ | -0.01 | -0.02 | -0.02 | ns |
| LVTTL33_16mA | LVTTL 16 mA drive, $\mathrm{V}_{\text {ccIo }}=3.3 \mathrm{~V}$ | -0.07 | -0.07 | -0.08 | ns |
| LVTTL33_20mA | LVTTL 20 mA drive, $\mathrm{V}_{\text {ccıo }}=3.3 \mathrm{~V}$ | -0.12 | -0.13 | -0.14 | ns |
| LVCMOS33_4mA | LVCMOS 3.34 mA drive, fast slew rate | 0.25 | 0.24 | 0.23 | ns |
| LVCMOS33_8mA | LVCMOS 3.38 mA drive, fast slew rate | -0.06 | -0.06 | -0.07 | ns |
| LVCMOS33_12mA | LVCMOS 3.312 mA drive, fast slew rate | -0.01 | -0.02 | -0.02 | ns |
| LVCMOS33_16mA | LVCMOS 3.316 mA drive, fast slew rate | -0.07 | -0.07 | -0.08 | ns |
| LVCMOS33_20mA | LVCMOS 3.320 mA drive, fast slew rate | -0.12 | -0.13 | -0.14 | ns |
| LVCMOS25_4mA | LVCMOS 2.54 mA drive, fast slew rate | 0.12 | 0.10 | 0.09 | ns |
| LVCMOS25_8mA | LVCMOS 2.58 mA drive, fast slew rate | -0.05 | -0.06 | -0.07 | ns |
| LVCMOS25_12mA | LVCMOS 2.512 mA drive, fast slew rate | 0.00 | 0.00 | 0.00 | ns |
| LVCMOS25_16mA | LVCMOS 2.516 mA drive, fast slew rate | -0.12 | -0.13 | -0.14 | ns |
| LVCMOS25_20mA | LVCMOS 2.520 mA drive, fast slew rate | -0.12 | -0.13 | -0.14 | ns |
| LVCMOS18_4mA | LVCMOS 1.84 mA drive, fast slew rate | 0.11 | 0.12 | 0.14 | ns |
| LVCMOS18_8mA | LVCMOS 1.88 mA drive, fast slew rate | 0.11 | 0.12 | 0.14 | ns |
| LVCMOS18_12mA | LVCMOS 1.812 mA drive, fast slew rate | -0.04 | -0.03 | -0.03 | ns |
| LVCMOS18_16mA | LVCMOS 1.816 mA drive, fast slew rate | -0.04 | -0.03 | -0.03 | ns |
| LVCMOS15_4mA | LVCMOS 1.54 mA drive, fast slew rate | 0.21 | 0.25 | 0.29 | ns |
| LVCMOS15_8mA | LVCMOS 1.58 mA drive, fast slew rate | 0.05 | 0.07 | 0.09 | ns |
| LVCMOS12_2mA | LVCMOS 1.22 mA drive, fast slew rate | 0.43 | 0.51 | 0.59 | ns |
| LVCMOS12_6mA | LVCMOS 1.26 mA drive, fast slew rate | 0.23 | 0.28 | 0.33 | ns |
| LVCMOS33_4mA | LVCMOS 3.34 mA drive, slow slew rate | 1.44 | 1.58 | 1.72 | ns |
| LVCMOS33_8mA | LVCMOS 3.38 mA drive, slow slew rate | 0.98 | 1.10 | 1.22 | ns |


| Buffer Type | Description | -8 | -7 | -6 | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| LVCMOS33_12mA | LVCMOS 3.312 mA drive, slow slew rate | 0.67 | 0.77 | 0.86 | ns |
| LVCMOS33_16mA | LVCMOS 3.316 mA drive, slow slew rate | 0.97 | 1.09 | 1.21 | ns |
| LVCMOS33_20mA | LVCMOS 3.320 mA drive, slow slew rate | 0.67 | 0.76 | 0.85 | ns |
| LVCMOS25_4mA | LVCMOS 2.54 mA drive, slow slew rate | 1.48 | 1.63 | 1.78 | ns |
| LVCMOS25_8mA | LVCMOS 2.58 mA drive, slow slew rate | 1.02 | 1.14 | 1.27 | ns |
| LVCMOS25_12mA | LVCMOS 2.512 mA drive, slow slew rate | 0.74 | 0.84 | 0.94 | ns |
| LVCMOS25_16mA | LVCMOS 2.516 mA drive, slow slew rate | 1.02 | 1.14 | 1.26 | ns |
| LVCMOS25_20mA | LVCMOS 2.520 mA drive, slow slew rate | 0.74 | 0.83 | 0.93 | ns |
| LVCMOS18_4mA | LVCMOS 1.84 mA drive, slow slew rate | 1.60 | 1.77 | 1.93 | ns |
| LVCMOS18_8mA | LVCMOS 1.88 mA drive, slow slew rate | 1.11 | 1.25 | 1.38 | ns |
| LVCMOS18_12mA | LVCMOS 1.812 mA drive, slow slew rate | 0.87 | 0.98 | 1.09 | ns |
| LVCMOS18_16mA | LVCMOS 1.816 mA drive, slow slew rate | 0.86 | 0.97 | 1.07 | ns |
| LVCMOS15_4mA | LVCMOS 1.54 mA drive, slow slew rate | 1.71 | 1.89 | 2.08 | ns |
| LVCMOS15_8mA | LVCMOS 1.58 mA drive, slow slew rate | 1.20 | 1.34 | 1.48 | ns |
| LVCMOS12_2mA | LVCMOS 1.22 mA drive, slow slew rate | 1.37 | 1.56 | 1.74 | ns |
| LVCMOS12_6mA | LVCMOS 1.26 mA drive, slow slew rate | 1.11 | 1.27 | 1.43 | ns |
| PCI33 | $\mathrm{PCI}, \mathrm{VCCIO}=3.3 \mathrm{~V}$ | -0.12 | -0.13 | -0.14 | ns |

## Notes:

1. Timing adders are characterized but not tested on every device.
2. LVCMOS timing measured with the load specified in Switching Test Condition table.
3. All other standards tested according to the appropriate specifications.
4. Not all I/O standards and drive strengths are supported for all banks. See the Architecture section of this data sheet for details.
5. Commercial timing numbers are shown. Industrial numbers are typically slower and can be extracted from the Diamond or ispLEVER software.
6. This data does not apply to the LatticeECP3-17EA device.
7. For details on -9 speed grade devices, contact your Lattice Sales Representative.

### 4.20. LatticeECP3 Maximum I/O Buffer Speed ${ }^{1,2,3,4,5,6}$

Over Recommended Operating Conditions

| Buffer | Description | Max. | Units |
| :---: | :---: | :---: | :---: |
| Maximum Input Frequency |  |  |  |
| LVDS25 | LVDS, $\mathrm{V}_{\text {CCIO }}=2.5 \mathrm{~V}$ | 400 | MHz |
| MLVDS25 | MLVDS, Emulated, $\mathrm{V}_{\text {ccIo }}=2.5 \mathrm{~V}$ | 400 | MHz |
| BLVDS25 | BLVDS, Emulated, $\mathrm{V}_{\text {cııo }}=2.5 \mathrm{~V}$ | 400 | MHz |
| PPLVDS | Point-to-Point LVDS | 400 | MHz |
| TRLVDS | Transition-Reduced LVDS | 612 | MHz |
| Mini LVDS | Mini LVDS | 400 | MHz |
| LVPECL33 | LVPECL, Emulated, $\mathrm{V}_{\text {clıO }}=3.3 \mathrm{~V}$ | 400 | MHz |
| HSTL18 (all supported classes) | HSTL_18 class I, II, $\mathrm{V}_{\text {ccio }}=1.8 \mathrm{~V}$ | 400 | MHz |
| HSTL15 | HSTL_15 class I, $\mathrm{V}_{\text {clio }}=1.5 \mathrm{~V}$ | 400 | MHz |
| SSTL33 (all supported classes) | SSTL_3 class I, II, $\mathrm{V}_{\text {clı0 }}=3.3 \mathrm{~V}$ | 400 | MHz |
| SSTL25 (all supported classes) | SSTL_2 class I, II, $\mathrm{V}_{\text {clıO }}=2.5 \mathrm{~V}$ | 400 | MHz |
| SSTL18 (all supported classes) | SSTL_18 class I, II, $\mathrm{V}_{\text {ccio }}=1.8 \mathrm{~V}$ | 400 | MHz |
| LVTTL33 | LVTTL, $\mathrm{V}_{\text {ccio }}=3.3 \mathrm{~V}$ | 166 | MHz |
| LVCMOS33 | LVCMOS, $\mathrm{V}_{\text {ccio }}=3.3 \mathrm{~V}$ | 166 | MHz |
| LVCMOS25 | LVCMOS, $\mathrm{V}_{\text {ccio }}=2.5 \mathrm{~V}$ | 166 | MHz |
| LVCMOS18 | LVCMOS, $\mathrm{V}_{\text {ccio }}=1.8 \mathrm{~V}$ | 166 | MHz |
| LVCMOS15 | LVCMOS 1.5, $\mathrm{V}_{\text {ccIo }}=1.5 \mathrm{~V}$ | 166 | MHz |
| LVCMOS12 | LVCMOS 1.2, $\mathrm{V}_{\text {ccio }}=1.2 \mathrm{~V}$ | 166 | MHz |
| PCI33 | $\mathrm{PCI}, \mathrm{VCCIO}=3.3 \mathrm{~V}$ | 66 | MHz |
| Maximum Output Frequency |  |  |  |
| LVDS25E | LVDS, Emulated, $\mathrm{V}_{\text {clıO }}=2.5 \mathrm{~V}$ | 300 | MHz |
| LVDS25 | LVDS, $\mathrm{V}_{\text {çıo }}=2.5 \mathrm{~V}$ | 612 | MHz |
| MLVDS25 | MLVDS, Emulated, $\mathrm{V}_{\text {ccIo }}=2.5 \mathrm{~V}$ | 300 | MHz |
| RSDS25 | RSDS, Emulated, $\mathrm{V}_{\text {ccıo }}=2.5 \mathrm{~V}$ | 612 | MHz |
| BLVDS25 | BLVDS, Emulated, $\mathrm{V}_{\text {cııO }}=2.5 \mathrm{~V}$ | 300 | MHz |
| PPLVDS | Point-to-point LVDS | 612 | MHz |
| LVPECL33 | LVPECL, Emulated, $\mathrm{V}_{\text {ccIo }}=3.3 \mathrm{~V}$ | 612 | MHz |
| Mini-LVDS | Mini LVDS | 612 | MHz |
| HSTL18 (all supported classes) | HSTL_18 class I, II, $\mathrm{V}_{\text {cclo }}=1.8 \mathrm{~V}$ | 200 | MHz |
| HSTL15 (all supported classes) | HSTL_15 class I, $\mathrm{V}_{\text {clio }}=1.5 \mathrm{~V}$ | 200 | MHz |
| SSTL33 (all supported classes) | SSTL_3 class I, II, $\mathrm{V}_{\text {clio }}=3.3 \mathrm{~V}$ | 233 | MHz |
| SSTL25 (all supported classes) | SSTL_2 class I, II, $\mathrm{V}_{\text {clio }}=2.5 \mathrm{~V}$ | 233 | MHz |
| SSTL18 (all supported classes) | SSTL_18 class I, II, $\mathrm{V}_{\text {ccio }}=1.8 \mathrm{~V}$ | 266 | MHz |
| LVTTL33 | LVTTL, $\mathrm{V}_{\text {ccio }}=3.3 \mathrm{~V}$ | 166 | MHz |
| LVCMOS33 (For all drives) | LVCMOS, 3.3 V | 166 | MHz |
| LVCMOS25 (For all drives) | LVCMOS, 2.5 V | 166 | MHz |
| LVCMOS18 (For all drives) | LVCMOS, 1.8 V | 166 | MHz |
| LVCMOS15 (For all drives) | LVCMOS, 1.5 V | 166 | MHz |
| LVCMOS12 (For all drives except 2 mA ) | LVCMOS, $\mathrm{V}_{\text {ccio }}=1.2 \mathrm{~V}$ | 166 | MHz |
| LVCMOS12 (2 mA drive) | LVCMOS, $\mathrm{V}_{\text {clio }}=1.2 \mathrm{~V}$ | 100 | MHz |
| PCI33 | $\mathrm{PCI}, \mathrm{V}_{\text {ccio }}=3.3 \mathrm{~V}$ | 66 | MHz |

## Notes:

1. These maximum speeds are characterized but not tested on every device.
2. Maximum I/O speed for differential output standards emulated with resistors depends on the layout.
3. LVCMOS timing is measured with the load specified in the Switching Test Conditions table of this document.
4. All speeds are measured at fast slew.
5. Actual system operation may vary depending on user logic implementation.
6. Maximum data rate equals 2 times the clock rate when utilizing DDR.

### 4.21. sysCLOCK PLL Timing

Over Recommended Operating Conditions

| Parameter | Descriptions | Conditions | Clock | Min. | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{f}_{\mathrm{IN}}$ | Input clock frequency (CLKI, CLKFB) | - | Edge clock | 2 | - | 500 | MHz |
|  |  |  | Primary clock ${ }^{4}$ | 2 | - | 420 | MHz |
| $\mathrm{f}_{\text {OUT }}$ | Output clock frequency (CLKOP, CLKOS) | - | Edge clock | 4 | - | 500 | MHz |
|  |  |  | Primary clock ${ }^{4}$ | 4 | - | 420 | MHz |
| fout1 | K-Divider output frequency | CLKOK | - | 0.03125 | - | 250 | MHz |
| $\mathrm{f}_{\text {OUT2 }}$ | K2-Divider output frequency | CLKOK2 | - | 0.667 | - | 166 | MHz |
| $\mathrm{f}_{\mathrm{Vco}}$ | PLL VCO frequency | - | - | 500 | - | 1000 | MHz |
| $\mathrm{f}_{\text {PFD }}{ }^{3}$ | Phase detector input frequency | - | Edge clock | 2 | - | 500 | MHz |
|  |  |  | Primary clock ${ }^{4}$ | 2 | - | 420 | MHz |
| AC Characteristics |  |  |  |  |  |  |  |
| $\mathrm{t}_{\text {PA }}$ | Programmable delay unit | - | - | 65 | 130 | 260 | ps |
| $\mathrm{t}_{\mathrm{DT}}$ | Output clock duty cycle (CLKOS, at 50\% setting) | - | Edge clock | 45 | 50 | 55 | \% |
|  |  | $\mathrm{f}_{\text {OUT }} \leq 250 \mathrm{MHz}$ | Primary clock | 45 | 50 | 55 | \% |
|  |  | $\mathrm{f}_{\text {OUT }}>250 \mathrm{MHz}$ | Primary clock | 30 | 50 | 70 | \% |
| $\mathrm{t}_{\text {CPA }}$ | Coarse phase shift error (CLKOS, at all settings) | - | - | -5 | 0 | +5 | \% of period |
| $\mathrm{t}_{\text {OPW }}$ | Output clock pulse width high or low (CLKOS) | - | - | 1.8 | - | - | ns |
| $\mathrm{t}_{\text {OPJTT }}{ }^{1}$ | Output clock period jitter | $\mathrm{f}_{\text {OUT }} \geq 420 \mathrm{MHz}$ | - | - | - | 200 | ps |
|  |  | $\begin{aligned} & 420 \mathrm{MHz}>\text { foUt }^{2} 100 \\ & \mathrm{MHz} \end{aligned}$ | - | - | - | 250 | ps |
|  |  | $\mathrm{f}_{\text {OUT }}<100 \mathrm{MHz}$ | - | - | - | 0.025 | UIPP |
| $\mathrm{t}_{\text {sk }}$ | Input clock to output clock skew when $\mathrm{N} / \mathrm{M}=$ integer | - | - | - | - | 500 | ps |
| $\mathrm{t}_{\text {LOCK }}{ }^{2}$ | Lock time | 2 to 25 MHz | - | - | - | 200 | us |
|  |  | 25 to 500 MHz | - | - | - | 50 | us |
| tunlock | Reset to PLL unlock time to ensure fast reset | - | - | - | - | 50 | ns |
| $\mathrm{t}_{\mathrm{HI}}$ | Input clock high time | 90\% to 90\% | - | 0.5 | - | - | ns |
| $\mathrm{t}_{\mathrm{LO}}$ | Input clock low time | 10\% to 10\% | - | 0.5 | - | - | ns |
| $\mathrm{t}_{\text {IPJIT }}$ | Input clock period jitter | - | - | - | - | 400 | ps |
| $\mathrm{t}_{\text {RST }}$ | Reset signal pulse width high, RSTK | - | - | 10 | - | - | ns |
|  | Reset signal pulse width high, RST | - | - | 500 | - | - | ns |

## Notes:

1. Jitter sample is taken over 10,000 samples of the primary PLL output with clean reference clock with no additional I/O toggling.
2. Output clock is valid after $t_{\text {Lock }}$ for PLL reset and dynamic delay adjustment.
3. Period jitter and cycle-to-cycle jitter numbers are guaranteed for $f_{\text {PFD }}>4 \mathrm{MHz}$. For $f_{\text {PFD }}<4 \mathrm{MHz}$, the jitter numbers may not be met in certain conditions. Contact the factory for $\mathrm{f}_{\text {PFD }}<4 \mathrm{MHz}$.
4. When using internal feedback, maximum can be up to 500 MHz .

### 4.22. DLL Timing

Over Recommended Operating Conditions

| Parameter | Description | Condition | Min. | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{f}_{\text {REF }}$ | Input reference clock frequency (on-chip or offchip) | - | 133 | - | 500 | MHz |
| $\mathrm{f}_{\mathrm{FB}}$ | Feedback clock frequency (on-chip or off-chip) | - | 133 | - | 500 | MHz |
| $\mathrm{f}_{\text {CLKOP }}{ }^{1}$ | Output clock frequency, CLKOP | - | 133 | - | 500 | MHz |
| $\mathrm{f}_{\text {CLKOS }}{ }^{2}$ | Output clock frequency, CLKOS | - | 33.3 | - | 500 | MHz |
| $\mathrm{t}_{\text {PJIT }}$ | Output clock period jitter (clean input) | - | - | - | 200 | ps p-p |
| $\mathrm{t}_{\text {DUTY }}$ | Output clock duty cycle (at 50\% levels, 50\% duty cycle input clock, $50 \%$ duty cycle circuit turned off, time reference delay mode) | Edge Clock | 40 | - | 60 | \% |
|  |  | Primary Clock | 30 | - | 70 | \% |
| $t_{\text {DUTYTRD }}$ | Output clock duty cycle (at 50\% levels, arbitrary duty cycle input clock, $50 \%$ duty cycle circuit enabled, time reference delay mode) | Primary Clock < 250 MHz | 45 | - | 55 | \% |
|  |  | Primary Clock $\geq 250 \mathrm{MHz}$ | 30 | - | 70 | \% |
|  |  | Edge Clock | 45 | - | 55 | \% |
| $t_{\text {DUTYCIR }}$ | Output clock duty cycle (at 50\% levels, arbitrary duty cycle input clock, $50 \%$ duty cycle circuit enabled, clock injection removal mode) with DLL cascading | Primary Clock < 250 MHz | 40 | - | 60 | \% |
|  |  | Primary Clock $\geq 250 \mathrm{MHz}$ | 30 | - | 70 | \% |
|  |  | Edge Clock | 45 | - | 55 | \% |
| $\mathrm{t}_{\text {SKEW }}{ }^{3}$ | Output clock to clock skew between two outputs with the same phase setting | - | - | - | 100 | ps |
| $t_{\text {PHASE }}$ | Phase error measured at device pads between off-chip reference clock and feedback clocks | - | - | - | $\begin{aligned} & +/- \\ & 400 \end{aligned}$ | ps |
| $\mathrm{t}_{\text {PWH }}$ | Input clock minimum pulse width high (at 80\% level) | - | 550 | - | - | ps |
| $\mathrm{t}_{\text {PWL }}$ | Input clock minimum pulse width low (at 20\% level) | - | 550 | - | - | ps |
| $\mathrm{t}_{\text {INSTB }}$ | Input clock period jitter | - | - | - | 500 | ps |
| $\mathrm{t}_{\text {LOCK }}$ | DLL lock time | - | 8 | - | 8200 | cycles |
| $\mathrm{t}_{\text {RSWD }}$ | Digital reset minimum pulse width (at 80\% level) | - | 3 | - | - | ns |
| $\mathrm{t}_{\text {DEL }}$ | Delay step size | - | 27 | 45 | 70 | ps |
| $\mathrm{t}_{\text {RANGE1 }}$ | Max. delay setting for single delay block (64 taps) | - | 1.9 | 3.1 | 4.4 | ns |
| $\mathrm{t}_{\text {RANGE4 }}$ | Max. delay setting for four chained delay blocks | - | 7.6 | 12.4 | 17.6 | ns |

## Notes:

1. CLKOP runs at the same frequency as the input clock.
2. CLKOS minimum frequency is obtained with divide by 4.
3. This is intended to be a path-matching design guideline and is not a measurable specification.

### 4.23. SERDES High-Speed Data Transmitter ${ }^{1}$

Table 4.6. Serial Output Timing and Levels

| Symbol | Description | Frequency | Min. | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $V_{\text {TX-DIFF-P-P-1.44 }}$ | Differential swing (1.44 V setting) ${ }^{1,2}$ | 0.15 to 3.125 Gbps | 1150 | 1440 | 1730 | mV , p-p |
| $V_{\text {TX-DIFF-P-P-P1.35 }}$ | Differential swing (1.35 V setting) ${ }^{1,2}$ | 0.15 to 3.125 Gbps | 1080 | 1350 | 1620 | mV , p-p |
| $V_{\text {TX-DIFF-P-P- } 1.26}$ | Differential swing (1.26 V setting) ${ }^{1,2}$ | 0.15 to 3.125 Gbps | 1000 | 1260 | 1510 | mV , p-p |
| $\mathrm{V}_{\text {TX-DIFF-P-P-P1.13 }}$ | Differential swing (1.13 V setting) ${ }^{1,2}$ | 0.15 to 3.125 Gbps | 840 | 1130 | 1420 | mV , p-p |
| $V_{\text {TX-DIFF-P-P-1.04 }}$ | Differential swing (1.04 V setting) ${ }^{1,2}$ | 0.15 to 3.125 Gbps | 780 | 1040 | 1300 | $\mathrm{mV}, \mathrm{p}$-p |
| $\mathrm{V}_{\text {TX-DIFF-P-P-0. } 02}$ | Differential swing (0.92 V setting) ${ }^{1,2}$ | 0.15 to 3.125 Gbps | 690 | 920 | 1150 | mV , p-p |
| $V_{\text {TX-DIFF-P-P-0. } 07}$ | Differential swing ( 0.87 V setting) ${ }^{1,2}$ | 0.15 to 3.125 Gbps | 650 | 870 | 1090 | $\mathrm{mV}, \mathrm{p}$-p |
| $\mathrm{V}_{\text {TX-DIFF-P-P-0. } 0 \text { P }}$ | Differential swing ( 0.78 V setting) ${ }^{1,2}$ | 0.15 to 3.125 Gbps | 585 | 780 | 975 | mV , p-p |
| $\mathrm{V}_{\text {TX-DIFF-P-P--0. } 64}$ | Differential swing ( 0.64 V setting) ${ }^{1,2}$ | 0.15 to 3.125 Gbps | 480 | 640 | 800 | mV , p-p |
| $V_{\text {Ocm }}$ | Output common mode voltage | - | $\begin{gathered} \mathrm{V}_{\mathrm{CCOB}} \\ -0.75 \end{gathered}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CCOB}} \\ & -0.60 \end{aligned}$ | $\begin{aligned} & \mathrm{V}_{\mathrm{CCOB}} \\ & -0.45 \end{aligned}$ | V |
| $\mathrm{T}_{\text {TX-R }}$ | Rise time (20\% to 80\%) | - | 145 | 185 | 265 | ps |
| $\mathrm{T}_{\text {TX-F }}$ | Fall time (80\% to 20\%) | - | 145 | 185 | 265 | ps |
| $\mathrm{Z}_{\text {TX-OI-SE }}$ | Output Impedance 50/75/HiZ Ohms (single ended) | - | -20\% | $\begin{gathered} 50 / 75 / \\ \mathrm{Hi} \mathrm{Z} \\ \hline \end{gathered}$ | +20\% | $\Omega$ |
| RLTX-RL | Return loss (with package) | - | 10 |  |  | dB |
| T TX-INtRASKEW | Lane-to-lane TX skew within a SERDES quad block (intra-quad) | - | - | - | 200 | ps |
| $\mathrm{T}_{\text {TX-INTERSKEW }}{ }^{3}$ | Lane-to-lane skew between SERDES quad blocks (inter-quad) | - | - | - | $\begin{array}{r} 1 \mathrm{UI} \\ +200 \end{array}$ | ps |

## Notes:

1. All measurements are with 50 Ohm impedance.
2. See LatticeECP3 SERDES/PCS Usage Guide (FPGA-TN-02190) for actual binary settings and the min-max range.
3. Inter-quad skew is between all SERDES channels on the device and requires the use of a low skew internal reference clock.

Table 4.7. Channel Output Jitter

| Description | Frequency | Min. | Typ. | Max. | Units |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Deterministic | 3.125 Gbps | - | - | 0.17 | UI, p-p |
| Random | 3.125 Gbps | - | - | 0.25 | UI, p-p |
| Total | 3.125 Gbps | - | - | 0.35 | UI, p-p |
| Deterministic | 2.5 Gbps | - | - | 0.17 | UI, p-p |
| Random | 2.5 Gbps | - | - | 0.20 | UI, p-p |
| Total | 2.5 Gbps | - | - | 0.35 | UI, p-p |
| Deterministic | 1.25 Gbps | - | - | 0.10 | UI, p-p |
| Random | 1.25 Gbps | - | - | 0.22 | UI, p-p |
| Total | 1.25 Gbps | - | - | 0.24 | UI, p-p |
| Deterministic | 622 Mbps | - | - | 0.10 | UI, p-p |
| Random | 622 Mbps | - | - | 0.20 | UI, p-p |
| Total | 622 Mbps | - | - | 0.24 | UI, p-p |
| Deterministic | 250 Mbps | - | - | 0.10 | UI, p-p |
| Random | 250 Mbps | - | - | UI, p-p |  |
| Total | 250 Mbps | - | - | UI, p-p |  |
| Deterministic | 150 Mbps | - | - | 0.24 | UI, p-p |
| Random | 150 Mbps | 150 Mbps | - | - | 0.18 |
| Total |  | - | - | UI, p-p |  |

Note: Values are measured with PRBS $2^{7}-1$, all channels operating, FPGA logic active, I/O around SERDES pins quiet, reference clock @ 10X mode.

### 4.24. SERDES/PCS Block Latency

Table 4.8 describes the latency of each functional block in the transmitter and receiver. Latency is given in parallel clock cycles. Figure 4.12 shows the location of each block.

Table 4.8. SERDES/PCS Latency Breakdown

| Item | Description | Min. | Avg. | Max. | Fixed | Bypass | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Transmit Data Latency ${ }^{1}$ |  |  |  |  |  |  |  |
| T1 | FPGA Bridge - Gearing disabled with different clocks | 1 | 3 | 5 | - | 1 | word clk |
|  | FPGA Bridge - Gearing disabled with same clocks | - | - | - | 3 | 1 | word clk |
|  | FPGA Bridge - Gearing enabled | 1 | 3 | 5 | - | - | word clk |
| T2 | 8b10b Encoder | - | - | - | 2 | 1 | word clk |
| T3 | SERDES Bridge transmit | - | - | - | 2 | 1 | word clk |
| T4 | Serializer: 8-bit mode | - | - | - | $15+\Delta 1$ | - | $\mathrm{UI}+\mathrm{ps}$ |
|  | Serializer: 10-bit mode | - | - | - | $18+\Delta 1$ | - | $\mathrm{Ul}+\mathrm{ps}$ |
| T5 | Pre-emphasis ON | - | - | - | $1+\Delta 2$ | - | $\mathrm{Ul}+\mathrm{ps}$ |
|  | Pre-emphasis OFF | - | - | - | $0+\Delta 3$ | - | $\mathrm{UI}+\mathrm{ps}$ |
| Receive Data Latency ${ }^{2}$ |  |  |  |  |  |  |  |
| R1 | Equalization ON | - | - | - | $\Delta 1$ | - | $\mathrm{Ul}+\mathrm{ps}$ |
|  | Equalization OFF | - | - | - | $\Delta 2$ | - | $\mathrm{Ul}+\mathrm{ps}$ |
| R2 | Deserializer: 8-bit mode | - | - | - | $10+\Delta 3$ | - | $\mathrm{UI}+\mathrm{ps}$ |
|  | Deserializer: 10-bit mode | - | - | - | $12+\Delta 3$ | - | UI + ps |
| R3 | SERDES Bridge receive | - | - | - | 2 | - | word clk |
| R4 | Word alignment | 3.1 | - | 4 | - | - | word clk |
| R5 | 8b10b decoder | - | - | - | 1 | - | word clk |
| R6 | Clock Tolerance Compensation | 7 | 15 | 23 | 1 | 1 | word clk |
| R7 | FPGA Bridge - Gearing disabled with different clocks | 1 | 3 | 5 | - | 1 | word clk |
|  | FPGA Bridge - Gearing disabled with same clocks | - | - | - | 3 | 1 | word clk |
|  | FPGA Bridge - Gearing enabled | 1 | 3 | 5 | - | - | word clk |

## Notes:

1. $\Delta 1=-245 \mathrm{ps}, \Delta 2=+88 \mathrm{ps}, \Delta 3=+112 \mathrm{ps}$.
2. $\Delta 1=+118 \mathrm{ps}, \Delta 2=+132 \mathrm{ps}, \Delta 3=+700 \mathrm{ps}$.


Figure 4.12. Transmitter and Receiver Latency Block Diagram

### 4.25. SERDES High Speed Data Receiver

Table 4.9. Serial Input Data Specifications

| Symbol | Description |  | Min. | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RX-CID ${ }_{\text {S }}$ | Stream of nontransitions ${ }^{1}$ <br> (CID = Consecutive Identical Digits) @ $10^{-12}$ BER | $\begin{aligned} & 3.125 \\ & \mathrm{G} \end{aligned}$ | - | - | 136 | Bits |
|  |  | 2.5 G | - | - | 144 |  |
|  |  | $\begin{aligned} & 1.485 \\ & \mathrm{G} \end{aligned}$ | - | - | 160 |  |
|  |  | $\begin{aligned} & 622 \\ & \mathrm{M} \end{aligned}$ | - | - | 204 |  |
|  |  | $\begin{aligned} & 270 \\ & M \end{aligned}$ | - | - | 228 |  |
|  |  | $\begin{aligned} & 150 \\ & M \end{aligned}$ | - | - | 296 |  |
| $\mathrm{V}_{\text {RX-DIFF-S }}$ | Differential input sensitivity |  | 150 | - | 1760 | mV, p-p |
| $\mathrm{V}_{\mathrm{RX} \text {-IN }}$ | Input levels |  | 0 | - | $\mathrm{V}_{\text {CCA }}+0.5^{4}$ | V |
| $\mathrm{V}_{\text {RX-CM-DC }}$ | Input common mode range (DC coupled) |  | 0.6 | - | $\mathrm{V}_{\text {CCA }}$ | V |
| $\mathrm{V}_{\text {RX-CM-AC }}$ | Input common mode range (AC coupled) ${ }^{3}$ |  | 0.1 | - | $\mathrm{V}_{\text {CCA }}+0.2$ | V |
| T ${ }_{\text {RX-RELOCK }}$ | SCDR re-lock time ${ }^{2}$ |  | - | 1000 | - | Bits |
| $Z_{\text {RX-TERM }}$ | Input termination 50/75 $/$ /High Z |  | -20\% | 50/75/Hiz | +20\% | $\Omega$ |
| RL $\mathrm{RXX-RL}$ | Return loss (without package) |  | 10 | - | - | dB |

## Notes:

1. This is the number of bits allowed without a transition on the incoming data stream when using DC coupling.
2. This is the typical number of bit times to re-lock to a new phase or frequency within $+/-300 \mathrm{ppm}$, assuming 8 b 10 b encoded data.
3. AC coupling is used to interface to LVPECL and LVDS. LVDS interfaces are found in laser drivers and Fibre Channel equipment. LVDS interfaces are generally found in 622 Mbps SERDES devices.
4. Up to 1.76 V .

### 4.25.1. Input Data Jitter Tolerance

A receiver's ability to tolerate incoming signal jitter is very dependent on jitter type. High speed serial interface standards have recognized the dependency on jitter type and have specifications to indicate tolerance levels for different jitter types as they relate to specific protocols. Sinusoidal jitter is considered to be a worst case jitter type.

Table 4.10. Receiver Total Jitter Tolerance Specification

| Description | Frequency | Condition | Min. | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Deterministic | 3.125 Gbps | 600 mV differential eye | - | - | 0.47 | UI, p-p |
| Random |  | 600 mV differential eye | - | - | 0.18 | UI, p-p |
| Total |  | 600 mV differential eye | - | - | 0.65 | UI, p-p |
| Deterministic | 2.5 Gbps | 600 mV differential eye | - | - | 0.47 | UI, p-p |
| Random |  | 600 mV differential eye | - | - | 0.18 | UI, p-p |
| Total |  | 600 mV differential eye | - | - | 0.65 | UI, p-p |
| Deterministic | 1.25 Gbps | 600 mV differential eye | - | - | 0.47 | UI, p-p |
| Random |  | 600 mV differential eye | - | - | 0.18 | UI, p-p |
| Total |  | 600 mV differential eye | - | - | 0.65 | UI, p-p |
| Deterministic | 622 Mbps | 600 mV differential eye | - | - | 0.47 | UI, p-p |
| Random |  | 600 mV differential eye | - | - | 0.18 | UI, p-p |
| Total |  | 600 mV differential eye | - | - | 0.65 | UI, p-p |

Note: Values are measured with CJPAT, all channels operating, FPGA Logic active, I/O around SERDES pins quiet, voltages are nominal, room temperature.

Table 4.11. Periodic Receiver Jitter Tolerance Specification

| Description | Frequency | Condition | Min. | Typ. | Max. | Units |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |
| Periodic | 2.97 Gbps | 600 mV differential eye | - | - | 0.24 | UI, p-p |
| Periodic | 2.5 Gbps | 600 mV differential eye | - | - | 0.22 | UI, p-p |
| Periodic | 1.485 Gbps | 600 mV differential eye | - | - | 0.24 | UI, p-p |
| Periodic | 622 Mbps | 600 mV differential eye | - | - | 0.15 | UI, p-p |
| Periodic | 150 Mbps | 600 mV differential eye | - | - | 0.5 | UI, p-p |

Note: Values are measured with PRBS 27-1, all channels operating, FPGA Logic active, I/O around SERDES pins quiet, voltages are nominal, room temperature.

### 4.25.2. SERDES External Reference Clock

The external reference clock selection and its interface are a critical part of system applications for this product. Table 4.12 specifies reference clock requirements, over the full range of operating conditions.

Table 4.12. External Reference Clock Specification (refclkp/refclkn)

| Symbol | Description | Min. | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{F}_{\text {REF }}$ | Frequency range | 15 | - | 320 | MHz |
| $\mathrm{F}_{\text {REF-PPM }}$ | Frequency tolerance ${ }^{1}$ | -1000 | - | 1000 | ppm |
| $V_{\text {REF-IN-SE }}$ | Input swing, single-ended clock ${ }^{2}$ | 200 | - | $V_{\text {CCA }}$ | $\mathrm{mV}, \mathrm{p}-\mathrm{p}$ |
| $V_{\text {REF-IN-DIFF }}$ | Input swing, differential clock | 200 | - | $2 * \mathrm{~V}_{\text {CCA }}$ | $m V, p-p$ <br> differential |
| $\mathrm{V}_{\text {REF-IN }}$ | Input levels | 0 | - | $\mathrm{V}_{\text {CCA }}+0.3$ | V |
| $\mathrm{D}_{\text {REF }}$ | Duty cycle ${ }^{3}$ | 40 | - | 60 | \% |
| $\mathrm{T}_{\text {REF-R }}$ | Rise time (20\% to 80\%) | 200 | 500 | 1000 | ps |
| T REF-F | Fall time (80\% to 20\%) | 200 | 500 | 1000 | ps |
| ZREF-IN-TERM-DIFF | Differential input termination | -20\% | 100/2K | +20\% | $\Omega$ |
| Cref-In-CAP | Input capacitance | - | - | 7 | pF |

## Notes:

1. Depending on the application, the PLL_LOL_SET and CDR_LOL_SET control registers may be adjusted for other tolerance values as described in LatticeECP3 SERDES/PCS Usage Guide (FPGA-TN-02190).
2. The signal swing for a single-ended input clock must be as large as the p-p differential swing of a differential input clock to get the same gain at the input receiver. Lower swings for the clock may be possible, but will tend to increase jitter.
3. Measured at $50 \%$ amplitude.



Figure 4.13. SERDES External Reference Clock Waveforms


Figure 4.14. Jitter Transfer - 3.125 Gbps


Figure 4.15. Jitter Transfer - 2.5 Gbps


Figure 4.16. Jitter Transfer - 1.25 Gbps


Figure 4.17. Jitter Transfer - 622 Mbps

### 4.26. PCI Express Electrical and Timing Characteristics

### 4.26.1. AC and DC Characteristics

Over Recommended Operating Conditions

| Symbol | Description | Test Conditions | Min | Typ | Max | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Transmit ${ }^{1}$ |  |  |  |  |  |  |
| UI | Unit interval | - | 399.88 | 400 | 400.12 | ps |
| $\mathrm{V}_{\text {TX-DIF-_P-P }}$ | Differential peak-to-peak output voltage | - | 0.8 | 1.0 | 1.2 | V |
| $V_{\text {TX-DE-RATIO }}$ | De-emphasis differential output voltage ratio | - | -3 | -3.5 | -4 | dB |
| $\mathrm{V}_{\text {TX-CM-AC_P }}$ | RMS AC peak common-mode output voltage | - | - | - | 20 | mV |
| $\mathrm{V}_{\text {TX-RCV-DETECT }}$ | Amount of voltage change allowed during receiver detection | - | - | - | 600 | mV |
| $\mathrm{V}_{T X-\mathrm{DC}-\mathrm{CM}}$ | Tx DC common mode voltage | - | 0 | - | $\begin{gathered} \hline \text { VCCOB }+ \\ 5 \% \end{gathered}$ | V |
| $\mathrm{I}_{\text {TX-SHORT }}$ | Output short circuit current | $\begin{aligned} & \mathrm{V}_{T X-D+}=0.0 \mathrm{~V} \\ & \mathrm{~V}_{T X-D}=0.0 \mathrm{~V} \end{aligned}$ | - | - | 90 | mA |
| $\mathrm{Z}_{\text {TX-DIFF-DC }}$ | Differential output impedance | - | 80 | 100 | 120 | Ohms |
| RLTx-DIFF | Differential return loss | - | 10 | - | - | dB |
| $\mathrm{RL}_{\text {TX-CM }}$ | Common mode return loss | - | 6.0 | - | - | dB |
| $\mathrm{T}_{\text {TX-RISE }}$ | Tx output rise time | 20 to 80\% | 0.125 | - | - | UI |
| $\mathrm{T}_{\text {TX-FALL }}$ | Tx output fall time | 20 to 80\% | 0.125 | - | - | UI |
| $\mathrm{L}_{\text {TXX-SkEW }}$ | Lane-to-lane static output skew for all lanes in port/link | - | - | - | 1.3 | ns |
| $\mathrm{T}_{\text {TX-EYE }}$ | Transmitter eye width | - | 0.75 | - | - | UI |
| $\mathrm{T}_{\text {TX-EYE-MEDIAN-TO-MAX-IITTER }}$ | Maximum time between jitter median and maximum deviation from median | - | - | - | 0.125 | UI |
| Receive ${ }^{1,2}$ |  |  |  |  |  |  |
| UI | Unit Interval | - | 399.88 | 400 | 400.12 | ps |
| $\mathrm{V}_{\text {RX-DIFF_P-P }}$ | Differential peak-to-peak input voltage | - | $0.34{ }^{3}$ | - | 1.2 | V |
| $\mathrm{V}_{\text {RX-IDLE-DET-DIFF_P-P }}$ | Idle detect threshold voltage | - | 65 | - | $340^{3}$ | mV |
| $\mathrm{V}_{\text {RX-CM-AC_P }}$ | Receiver common mode voltage for AC coupling | - | - | - | 150 | mV |
| $Z_{\text {RX-DIFF-DC }}$ | DC differential input impedance | - | 80 | 100 | 120 | $\Omega$ |
| $\mathrm{Z}_{\text {RX-D }}$ | DC input impedance | - | 40 | 50 | 60 | $\Omega$ |
| $\mathrm{Z}_{\text {RX-HIGH-IMP-DC }}$ | Power-down DC input impedance | - | 200K | - | - | $\Omega$ |
| RLRX-DIFF | Differential return loss | - | 10 | - | - | dB |
| RLRX-CM | Common mode return loss | - | 6.0 | - | - | dB |
| TrX-IDL-DET-Diff-ENTERTIME | Maximum time required for receiver to recognize and signal an unexpected idle on link | - | - | - | - | ms |

## Notes:

1. Values are measured at 2.5 Gbps .
2. Measured with external AC -coupling on the receiver.
3. Not in compliance with PCI Express 1.1 standard.

Data Sheet

### 4.27. XAUI/Serial Rapid I/O Type 3/CPRI LV E. 30 Electrical and Timing Characteristics

### 4.27.1. AC and DC Characteristics

Table 4.13. Transmit
Over Recommended Operating Conditions

| Symbol | Description | Test Conditions | Min. | Typ. | Max. | Units |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{T}_{\mathrm{RF}}$ | Differential rise/fall time | $20 \%-80 \%$ | - | 80 | - | ps |
| $\mathrm{Z}_{\text {TX_DIFF_DC }}$ | Differential impedance | - | 80 | 100 | 120 | $\Omega$ |
| $\mathrm{~J}_{\text {TX_DDJ }}{ }^{2,3,4}$ | Output data deterministic jitter | - | - | - | 0.17 | Ul |
| $\mathrm{J}_{\text {TX_TJ }} 1,2,3,4$ | Total output data jitter | - | - | - | 0.35 | UI |

## Notes:

1. Total jitter includes both deterministic jitter and random jitter.
2. Jitter values are measured with each CML output AC coupled into a $50-\mathrm{Ohm}$ impedance ( $100-\mathrm{Ohm}$ differential impedance).
3. Jitter and skew are specified between differential crossings of the $50 \%$ threshold of the reference signal.
4. Values are measured at 2.5 Gbps .

Table 4.14. Receive and Jitter Tolerance
Over Recommended Operating Conditions

| Symbol | Description | Test Conditions | Min. | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RL RX_DIFF | Differential return loss | From 100 MHz to 3.125 GHz | 10 | - | - | dB |
| $R L_{\text {RX_CM }}$ | Common mode return loss | From 100 MHz to 3.125 GHz | 6 | - | - | dB |
| $Z_{\text {RX_DIFF }}$ | Differential termination resistance | - | 80 | 100 | 120 | $\Omega$ |
| $J_{\text {RX_DJ }}{ }^{1,2,3}$ | Deterministic jitter tolerance (peak-to-peak) | - | - | - | 0.37 | UI |
| $\mathrm{J}_{\mathrm{RX} \text { _RJ }}{ }^{1,2,3}$ | Random jitter tolerance (peak-to-peak) | - | - | - | 0.18 | UI |
| $\mathrm{J}_{\text {RX_SJ }}{ }^{1,2,3}$ | Sinusoidal jitter tolerance (peak-to-peak) | - | - | - | 0.10 | UI |
| $\mathrm{J}_{\text {RX_TJ }}{ }^{1,2,3}$ | Total jitter tolerance (peak-to-peak) | - | - | - | 0.65 | UI |
| TRX_EYE | Receiver eye opening | - | 0.35 | - | - | UI |

## Notes:

1. Total jitter includes deterministic jitter, random jitter and sinusoidal jitter. The sinusoidal jitter tolerance mask is shown in Figure 4.18.
2. Jitter values are measured with each high-speed input AC coupled into a $50-\Omega$ impedance.
3. Jitter and skew are specified between differential crossings of the $50 \%$ threshold of the reference signal.
4. Jitter tolerance parameters are characterized when Full Rx Equalization is enabled.
5. Values are measured at 2.5 Gbps .


Note: The sinusoidal jitter tolerance is measured with at least 0.37 Ulpp of Deterministic jitter ( $D \mathrm{j}$ ) and the sum of Dj and Rj (random jitter) is at least 0.55 Ulpp. Therefore, the sum of $D j, R j$ and $S j$ (sinusoidal $j i t t e r$ ) is at least 0.65 Ulpp ( $D j=0.37, R j=0.18, S j=0.1$ ).

Figure 4.18. XAUI Sinusoidal Jitter Tolerance Mask

### 4.28. Serial Rapid I/O Type 2/CPRI LV E. 24 Electrical and Timing Characteristics

### 4.28.1. AC and DC Characteristics

Table 4.15. Transmit

| Symbol | Description | Test Conditions | Min. | Typ. | Max. | Units |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{T}_{\text {RF }^{1}}$ | Differential rise/fall time | $20 \%-80 \%$ | - | 80 | - | ps |
| $\mathrm{Z}_{\mathrm{TX} \text { _DIFF_DC }}$ | Differential impedance | - | 80 | 100 | 120 | $\Omega$ |
| $\mathrm{~J}_{\mathrm{TX}_{\text {_DJ }}{ }^{3,4,5}}$ | Output data deterministic jitter | - | - | - | 0.17 | UI |
| $\mathrm{J}_{\text {TX_ }^{2} \mathrm{~J}^{2,3,4,5}}$ | Total output data jitter | - | - | - | 0.35 | UI |

Notes:

1. Rise and Fall times measured with board trace, connector and approximately 2.5 pf load.
2. Total jitter includes both deterministic jitter and random jitter. The random jitter is the total jitter minus the actual deterministic jitter.
3. Jitter values are measured with each CML output AC coupled into a $50-\mathrm{Ohm}$ impedance ( $100-\mathrm{Ohm}$ differential impedance).
4. Jitter and skew are specified between differential crossings of the $50 \%$ threshold of the reference signal.
5. Values are measured at 2.5 Gbps .

Table 4.16. Receive and Jitter Tolerance

| Symbol | Description | Test Conditions | Min. | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RL RX_DIFF | Differential return loss | From 100 MHz to 2.5 GHz | 10 | - | - | dB |
| RL $\mathrm{RXX}_{\text {_CM }}$ | Common mode return loss | From 100 MHz to 2.5 GHz | 6 | - | - | dB |
| $\mathrm{Z}_{\text {RX_DIFF }}$ | Differential termination resistance | - | 80 | 100 | 120 | $\Omega$ |
| $\mathrm{J}_{\text {RX_DJ }}{ }^{2,3,4,5}$ | Deterministic jitter tolerance (peak-topeak) | - | - | - | 0.37 | UI |
| $\mathrm{J}_{\text {RX_RJ }}{ }^{2,3,4,5}$ | Random jitter tolerance (peak-to-peak) | - | - | - | 0.18 | UI |
| $\mathrm{J}_{\text {RX_S }{ }^{2, ~ 3, ~ 4, ~} 5}$ | Sinusoidal jitter tolerance (peak-to-peak) | - | - | - | 0.10 | UI |
| $\mathrm{J}_{\text {RX_TJ }}{ }^{1,2,3,4,5}$ | Total jitter tolerance (peak-to-peak) | - | - | - | 0.65 | UI |
| TRX_EYE | Receiver eye opening | - | 0.35 | - | - | UI |

## Notes:

1. Total jitter includes deterministic jitter, random jitter and sinusoidal jitter. The sinusoidal jitter tolerance mask is shown in Figure 4.18.
2. Jitter values are measured with each high-speed input AC coupled into a 50-Ohm impedance.
3. Jitter and skew are specified between differential crossings of the $50 \%$ threshold of the reference signal.
4. Jitter tolerance, Differential Input Sensitivity and Receiver Eye Opening parameters are characterized when Full Rx Equalization is enabled.
5. Values are measured at 2.5 Gbps .

### 4.29. Gigabit Ethernet/Serial Rapid I/O Type 1/SGMII/CPRI LV E. 12 Electrical and Timing Characteristics

### 4.29.1. AC and DC Characteristics

Table 4.17. Transmit

| Symbol | Description | Test Conditions | Min. | Typ. | Max. |
| :--- | :--- | :--- | :---: | :---: | :---: |
| $\mathrm{T}_{\text {RF }}$ | Differential rise/fall time | $20 \%-80 \%$ | - | 80 | - |
| $\mathrm{Z}_{\text {TX_DIFF_DC }}$ | Differential impedance | - | 80 | 100 | 120 |
| $\mathrm{~J}_{\text {TX_DDJ }}{ }^{3,4,5}$ | Output data deterministic jitter | - | - | - | 0.10 |
| $\mathrm{~J}_{\text {TX_TJ }}{ }^{2,3,4,5}$ | Total output data jitter | - | - | - | 0.24 |

## Notes:

1. Rise and fall times measured with board trace, connector and approximately 2.5 pf load.
2. Total jitter includes both deterministic jitter and random jitter. The random jitter is the total jitter minus the actual deterministic jitter.
3. Jitter values are measured with each CML output AC coupled into a $50-\mathrm{Ohm}$ impedance (100-Ohm differential impedance).
4. Jitter and skew are specified between differential crossings of the $50 \%$ threshold of the reference signal.
5. Values are measured at 1.25 Gbps .

Table 4.18. Receive and Jitter Tolerance

| Symbol | Description | Test Conditions | Min. | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| RL $\mathrm{RX}_{\text {_DIFF }}$ | Differential return loss | From 100 MHz to 1.25 GHz | 10 | - | - | dB |
| RLRX_CM | Common mode return loss | From 100 MHz to 1.25 GHz | 6 | - | - | dB |
| $\mathrm{Z}_{\text {RX_DIFF }}$ | Differential termination resistance | - | 80 | 100 | 120 | $\Omega$ |
| $\mathrm{J}_{\text {RX_DJ }}{ }^{1,2,3,4,5}$ | Deterministic jitter tolerance (peak-to-peak) | - | - | - | 0.34 | UI |
| $\mathrm{J}_{\text {RX_RJ }}{ }^{1,2,3,4,5}$ | Random jitter tolerance (peak-to-peak) | - | - | - | 0.26 | UI |
| $\mathrm{J}_{\text {RX_SJ }}{ }^{1,2,3,4,5}$ | Sinusoidal jitter tolerance (peak-to-peak) | - | - | - | 0.11 | UI |
| $\mathrm{J}_{\text {RX_TJ }}{ }^{1,2,3,4,5}$ | Total jitter tolerance (peak-to-peak) | - | - | - | 0.71 | UI |
| T ${ }_{\text {RX_EYE }}$ | Receiver eye opening | - | 0.29 | - | - | UI |

## Notes:

1. Total jitter includes deterministic jitter, random jitter and sinusoidal jitter. The sinusoidal jitter tolerance mask is shown in Figure 4.18.
2. Jitter values are measured with each high-speed input AC coupled into a 50-Ohm impedance.
3. Jitter and skew are specified between differential crossings of the $50 \%$ threshold of the reference signal.
4. Jitter tolerance, Differential Input Sensitivity and Receiver Eye Opening parameters are characterized when Full Rx Equalization is enabled.
5. Values are measured at 1.25 Gbps .

### 4.30. SMPTE SD/HD-SDI/3G-SDI (Serial Digital Interface) Electrical and Timing Characteristics

### 4.30.1. AC and DC Characteristics

Table 4.19. Transmit

| Symbol | Description | Test Conditions | Min. | Typ. | Max. | Units |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |
| BR $_{\text {SDO }}$ | Serial data rate | - | 270 | - | 2975 | Mbps |
| $\mathrm{T}_{\text {JALIGNMENT }}{ }^{2}$ | Serial output jitter, alignment | 270 Mbps | - | - | 0.20 | UI |
| $\mathrm{T}_{\text {JALIGNMENT }}{ }^{2}$ | Serial output jitter, alignment | 1485 Mbps | - | - | 0.20 | UI |
| $\mathrm{T}_{\text {JALIGNMENT }}{ }^{1,2}$ | Serial output jitter, alignment | 2970 Mbps | - | - | 0.30 | UI |
| $\mathrm{T}_{\text {JTIMING }}$ | Serial output jitter, timing | 270 Mbps | - | - | 0.20 | UI |
| $\mathrm{T}_{\text {JTIMING }}$ | Serial output jitter, timing | 1485 Mbps | - | - | 1.0 | UI |
| $\mathrm{T}_{\text {JTIMING }}$ | Serial output jitter, timing | 2970 Mbps | - | - | 2.0 | UI |

## Notes:

1. Timing jitter is measured in accordance with SMPTE RP 184-1996, SMPTE RP 192-1996 and the applicable serial data transmission standard, SMPTE 259M-1997 or SMPTE 292M (proposed). A color bar test pattern is used. The value of fSCLK is 270 MHz or 360 MHz for SMPTE 259M, 540 MHz for SMPTE 344M or 1485 MHz for SMPTE 292 M serial data rates. See the Timing Jitter Bandpass section.
2. Jitter is defined in accordance with SMPTE RP1 184-1996 as: jitter at an equipment output in the absence of input jitter.
3. All Tx jitter is measured at the output of an industry standard cable driver; connection to the cable driver is via a $50 \Omega$ impedance differential signal from the Lattice SERDES device.
4. The cable driver drives: $R L=75 \Omega$, $A C$-coupled at 270 , 1485 , or $2970 \mathrm{Mbps}, \operatorname{RREFLVL}=R R E F P R E=4.75 \mathrm{k} \Omega 1 \%$.

Table 4.20. Receive

| Symbol | Description | Test Conditions | Min. | Typ. | Max. | Units |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |
| BR | Serial input data rate | - | 270 | - | 2970 | Mbps |
| CID | Stream of non- <br> transitions (=Consecutive <br> Identical Digits) | - | $7(3 \mathrm{G}) / 26($ SMP <br> TE Triple rates $)$ <br> $@ 10-12 ~ B E R ~$ | - | - | Bits |

Table 4.21. Reference Clock

| Symbol | Description | Test Conditions | Min. | Typ. | Max. | Units |
| :--- | :--- | :--- | :---: | :---: | :---: | :---: |
| FVcLK | Video output clock <br> frequency | - | 27 | - | 74.25 | MHz |
| DC $_{V}$ | Duty cycle, video clock | - | 45 | 50 | 55 | $\%$ |

### 4.31. HDMI (High-Definition Multimedia Interface) Electrical and Timing Characteristics

### 4.31.1. AC and DC Characteristics

Table 4.22. Transmit and Receive ${ }^{1,2}$

| Symbol | Description | Spec. Compliance |  | Units |
| :---: | :---: | :---: | :---: | :---: |
|  |  | Min. Spec. | Max. Spec. |  |
| Transmit |  |  |  |  |
| Intra-pair Skew | - | - | 75 | ps |
| Inter-pair Skew | - | - | 800 | ps |
| TMDS Differential Clock Jitter | - | - | 0.25 | UI |
| Receive |  |  |  |  |
| $\mathrm{R}_{\mathrm{T}}$ | Termination Resistance | 40 | 60 | $\Omega$ |
| $\mathrm{V}_{\text {ICM }}$ | Input AC Common Mode Voltage (50- $\Omega$ Setting) | - | 50 | mV |
| TMDS Clock Jitter | Clock Jitter Tolerance | - | 0.25 | UI |

## Notes:

1. Output buffers must drive a translation device. Max. speed is 2 Gbps . If translation device does not modify rise/fall time, the maximum speed is 1.5 Gbps .
2. Input buffers must be AC coupled in order to support the 3.3 V common mode. Generally, HDMI inputs are terminated by an external cable equalizer before data/clock is forwarded to the LatticeECP3 device.

Test Loads

$C_{L}$ incl uding probe and jig capacitance, 3 pF max.
$S_{1}$ - open, $S_{2}$-closed for $V^{\text {OH }}$ measurement
$S_{1}^{1}$ - closed, $S_{2}^{2}$ - open for $V_{O L}$ measurement

*Risetime compensation.

## Timing Jitter Bandpass



Figure 4.19. Test Loads
-

### 4.32. LatticeECP3 sysCONFIG Port Timing Specifications

Over Recommended Operating Conditions

| Parameter | Description |  | Min. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| POR, Configuration Initialization, and Wakeup |  |  |  |  |  |
| $\mathrm{t}_{\text {ICFG }}$ | Time from the Application of VCC, VCCAUX or VCCIO8* (Whichever is the Last to Cross the POR Trip Point) to the Rising Edge of INITN | Master mode | - | 23 | ms |
|  |  | Slave mode | - | 6 | ms |
| $\mathrm{t}_{\mathrm{vmc}}$ | Time from tICFG to the Valid Master MCLK |  | - | 5 | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {PRGM }}$ | PROGRAMN Low Time to Start Configuration |  | 25 | - | ns |
| $\mathrm{t}_{\text {PRGMR }}$ | PROGRAMN Pin Pulse Rejection |  | - | 10 | ns |
| $\mathrm{t}_{\text {DPPIIIT }}$ | Delay Time from PROGRAMN Low to INITN Low |  | - | 37 | ns |
| $\mathrm{t}_{\text {DPPDONE }}$ | Delay Time from PROGRAMN Low to DONE Low |  | - | 37 | ns |
| $\mathrm{t}_{\text {DINIT }}{ }^{1}$ | PROGRAMN High to INITN High Delay |  | - | 1 | ms |
| $\mathrm{t}_{\text {MWC }}$ | Additional Wake Master Clock Signals After DONE Pin is High |  | 100 | 500 | cycles |
| $\mathrm{t}_{\mathrm{cz}}$ | MCLK From Active To Low To High-Z |  | - | 300 | ns |
| $\mathrm{t}_{\text {IODISs }}$ | User I/O Disable from PROGRAMN Low |  | - | 100 | ns |
| tioenss | User I/O Enabled Time from CCLK Edge During Wake-up Sequence |  | - | 100 | ns |

All Configuration Modes

| $\mathrm{t}_{\text {SUCDI }}$ | Data Setup Time to CCLK/MCLK |  | 5 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\mathrm{HCDI}}$ | Data Hold Time to CCLK/MCLK |  | 1 | - | ns |
| $\mathrm{t}_{\text {CODO }}$ | CCLK/MCLK to DOUT in Flowthrough Mode |  | -0.2 | 12 | ns |
| Slave Serial |  |  |  |  |  |
| $\mathrm{t}_{\text {SSCH }}$ | CCLK Minimum High Pulse |  | 5 | - | ns |
| $\mathrm{t}_{\text {SSCL }}$ | CCLK Minimum Low Pulse |  | 5 | - | ns |
| $\mathrm{f}_{\text {CCLK }}$ | CCLK Frequency | Without encryption | - | 33 | MHz |
|  |  | With encryption | - | 20 | MHz |

Master and Slave Parallel

| $\mathrm{t}_{\text {sucs }}$ | CSN[1:0] Setup Time to CCLK/MCLK |  | 7 | - | ns |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {HCS }}$ | CSN[1:0] Hold Time to CCLK/MCLK |  | 1 | - | ns |
| tsuwd | WRITEN Setup Time to CCLK/MCLK |  | 7 | - | ns |
| $\mathrm{t}_{\text {HwD }}$ | WRITEN Hold Time to CCLK/MCLK |  | 1 | - | ns |
| $\mathrm{t}_{\text {cCB }}$ | CCLK/MCLK to BUSY Delay Time |  | - | 12 | ns |
| $\mathrm{t}_{\text {CORD }}$ | CCLK to Out for Read Data |  | - | 12 | ns |
| $\mathrm{t}_{\text {BSCH }}$ | CCLK Minimum High Pulse |  | 6 | - | ns |
| $\mathrm{t}_{\text {BSCL }}$ | CCLK Minimum Low Pulse |  | 6 | - | ns |
| $\mathrm{t}_{\text {BSCyC }}$ | Byte Slave Cycle Time |  | 30 | - | ns |
| $\mathrm{f}_{\text {ccık }}$ | CCLK/MCLK Frequency | Without encryption | - | 33 | MHz |
|  |  | With encryption | - | 20 | MHz |


| Master and Slave SPI |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{t}_{\text {cFGX }}$ | INITN High to MCLK Low |  | - | 80 | ns |
| tcsspl | INITN High to CSSPIN Low |  | 0.2 | 2 | $\mu \mathrm{s}$ |
| $\mathrm{t}_{\text {SOCDO }}$ | MCLK Low to Output Valid |  | - | 15 | ns |
| $\mathrm{t}_{\text {CSPID }}$ | CSSPIN[0:1] Low to First MCLK Edge Setup Time |  | 0.3 | - | $\mu \mathrm{s}$ |
| $\mathrm{f}_{\text {cCLK }}$ | CCLK Frequency | Without encryption | - | 33 | MHz |
|  |  | With encryption | - | 20 | MHz |
| $\mathrm{t}_{\mathrm{sSCH}}$ | CCLK Minimum High Pulse |  | 5 | - | ns |
| $\mathrm{t}_{\text {SSCL }}$ | CCLK Minimum Low Pulse |  | 5 | - | ns |
| $\mathrm{t}_{\mathrm{HLCH}}$ | HOLDN Low Setup Time (Relative to CCLK) |  | 5 | - | ns |
| $\mathrm{t}_{\text {СННн }}$ | HOLDN Low Hold Time (Relative to CCLK) |  | 5 | - | ns |


| Parameter | Description | Min. | Max. | Units |
| :--- | :--- | :---: | :---: | :---: | :---: |
| Master and Slave SPI | 5 | - | ns |  |
| $\mathrm{t}_{\text {CHHL }}$ | HOLDN High Hold Time (Relative to CCLK) | 5 | - | ns |
| $\mathrm{t}_{\text {HHCH }}$ | HOLDN High Setup Time (Relative to CCLK) | - | 9 | ns |
| $\mathrm{t}_{\text {HLQZ }}$ | HOLDN to Output High-Z | - | 9 | ns |
| $\mathrm{t}_{\text {HHQX }}$ | HOLDN to Output Low-Z |  |  |  |

Note: Re-toggling the PROGRAMN pin is not permitted until the INITN pin is high. Avoid consecutive toggling of the PROGRAMN.

| Parameter | Min. | Max. | Units |
| :--- | :--- | :--- | :--- |
| Master Clock Frequency | Selected value $-15 \%$ | Selected value $+15 \%$ | MHz |
| Duty Cycle | 40 | 60 | $\%$ |



Figure 4.20. sysCONFIG Parallel Port Read Cycle


1. In Master Parallel Mode the FPGA provides CCLK (MCLK). In Slave Parallel Mode the external device provides CCLK.

Figure 4.21. sysCONFIG Parallel Port Write Cycle


Figure 4.22. sysCONFIG Master Serial Port Timing


Figure 4.23. sysCONFIG Slave Serial Port Timing


1. Time tak en from VCC, VCCAUX or VCCIO8, whichever is the last to cross the POR trip point.
2. Device is in a Master Mode (SPI, SPIm).
3. The CFG pins are normally static (hard wired).

Figure 4.24. Power-On-Reset (POR) Timing


Figure 4.25. sysCONFIG Port Timing


1. The CFG pins are normally static (hardwired)

Figure 4.26. Configuration from PROGRAMN Timing


Figure 4.27. Wake-Up Timing


Figure 4.28. Master SPI Configuration Waveforms


Figure 4.29. Master SPI POR Waveforms


Figure 4.30. SPI Configuration Waveforms


Figure 4.31. Slave SPI HOLDN Waveforms

### 4.33. JTAG Port Timing Specifications

Over Recommended Operating Conditions

| Symbol | Parameter | Min | Max | Units |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{f}_{\text {MAX }}$ | TCK clock frequency | - | 25 | MHz |
| $\mathrm{t}_{\text {BTCP }}$ | TCK [BSCAN] clock pulse width | 40 | - | ns |
| $\mathrm{t}_{\text {BTCPH }}$ | TCK [BSCAN] clock pulse width high | 20 | - | ns |
| $\mathrm{t}_{\text {BTCPL }}$ | TCK [BSCAN] clock pulse width low | 20 | - | ns |
| $\mathrm{t}_{\text {BTS }}$ | TCK [BSCAN] setup time | 10 | - | ns |
| $\mathrm{t}_{\text {BTH }}$ | TCK [BSCAN] hold time | 8 | - | ns |
| $\mathrm{t}_{\text {BTRF }}$ | TCK [BSCAN] rise/fall time | 50 | - | $\mathrm{mV} / \mathrm{ns}$ |
| $\mathrm{t}_{\text {BTCO }}$ | TAP controller falling edge of clock to valid output | - | 10 | ns |
| $\mathrm{t}_{\text {BTCODIS }}$ | TAP controller falling edge of clock to valid disable | - | 10 | ns |
| $\mathrm{t}_{\text {BTCOEN }}$ | TAP controller falling edge of clock to valid enable | - | 10 | ns |
| $\mathrm{t}_{\text {BTCRS }}$ | BSCAN test capture register setup time | 8 | - | ns |
| $\mathrm{t}_{\text {BTCRH }}$ | BSCAN test capture register hold time | 25 | - | ns |
| $\mathrm{t}_{\text {BUTCO }}$ | BSCAN test update register, falling edge of clock to valid output | - | 25 | ns |
| $\mathrm{t}_{\text {BTUODIS }}$ | BSCAN test update register, falling edge of clock to valid disable | - | 25 | ns |
| $\mathrm{t}_{\text {BTUPOEN }}$ | BSCAN test update register, falling edge of clock to valid enable | - | 25 | ns |



Figure 4.32. JTAG Port Timing Waveforms

### 4.34. Switching Test Conditions

Figure 4.33 shows the output test load that is used for AC testing. The specific values for resistance, capacitance, voltage, and other test conditions are shown in Figure 4.23.

*CLIncludes Test Fixture and Probe Capacitance
Figure 4.33. Output Test Load, LVTTL and LVCMOS Standards
Table 4.23. Test Fixture Required Components, Non-Terminated Interfaces

| Test Condition | $\mathrm{R}_{1}$ | $\mathrm{R}_{2}$ | $C_{L}$ | Timing Ref. | $\mathrm{V}_{\mathrm{T}}$ |
| :---: | :---: | :---: | :---: | :---: | :---: |
| LVTTL and other LVCMOS settings (L -> H, H -> L) | $\infty$ | $\infty$ | 0 pF | LVCMOS 3.3 $=1.5 \mathrm{~V}$ | - |
|  |  |  |  | LVCMOS $2.5=\mathrm{V}_{\mathrm{cco}} / 2$ | - |
|  |  |  |  | LVCMOS $1.8=\mathrm{V}_{\text {clıo }} / 2$ | - |
|  |  |  |  | LVCMOS $1.5=\mathrm{V}_{\text {cıIO }} / 2$ | - |
|  |  |  |  | LVCMOS $1.2=\mathrm{V}_{\text {ccıo }} / 2$ | - |
| LVCMOS $2.5 \mathrm{I} / \mathrm{O}(\mathrm{Z}->\mathrm{H})$ | $\infty$ | $1 \mathrm{M} \times$ | 0 pF | $\mathrm{V}_{\text {cıIo }} / 2$ | - |
| LVCMOS $2.5 \mathrm{I} / \mathrm{O}(\mathrm{Z}->\mathrm{L})$ | $1 \mathrm{M} \Omega$ | $\infty$ | 0 pF | $\mathrm{V}_{\text {ccio }} / 2$ | $\mathrm{V}_{\text {ccio }}$ |
| LVCMOS 2.5 I/O (H-> Z) | $\infty$ | 100 | 0 pF | $\mathrm{V}_{\mathrm{OH}}-0.10$ | - |
| LVCMOS 2.5 I/O (L -> Z) | 100 | $\infty$ | 0 pF | $\mathrm{V}_{\text {OL }}+0.10$ | $\mathrm{V}_{\text {ccıo }}$ |

Note: Output test conditions for all other interfaces are determined by the respective standards.

### 4.35. sysl/O Differential Electrical Characteristics

### 4.35.1. Transition Reduced LVDS (TRLVDS DC Specification)

Over Recommended Operating Conditions

| Symbol | Description | Min. | Nom. | Max. | Units |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {CCO }}$ | Driver supply voltage (+/-5\%) | 3.14 | 3.3 | 3.47 | V |
| $\mathrm{~V}_{\text {ID }}$ | Input differential voltage | 150 | - | 1200 | mV |
| $\mathrm{V}_{\text {ICM }}$ | Input common mode voltage | 3 | - | 3.265 | V |
| $\mathrm{~V}_{\text {CCO }}$ | Termination supply voltage | 3.14 | 3.3 | 3.47 | V |
| $\mathrm{R}_{\mathrm{T}}$ | Termination resistance (off-chip) | 45 | 50 | 55 | $\Omega$ |

Note: LatticeECP3 supports only the TRLVDS receiver.


### 4.35.2. Mini LVDS

Over Recommended Operating Conditions

| Symbol | Description | Min. | Typ. | Max. | Units |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\mathrm{Z}_{0}$ | Single-ended PCB trace impedance | 30 | 50 | 75 | Ohms |
| $\mathrm{R}_{\mathrm{T}}$ | Differential termination resistance | 50 | 100 | 150 | Ohms |
| $\mathrm{V}_{\text {OD }}$ | Output voltage, differential, $\left\|\mathrm{V}_{\text {OP }}-\mathrm{V}_{\text {OM }}\right\|$ | 300 | - | 600 | mV |
| Vos | Output voltage, common mode, $\left\|\mathrm{V}_{\text {OP }}+\mathrm{V}_{\text {OM }}\right\| / 2$ | 1 | 1.2 | 1.4 | V |
| $\Delta \mathrm{V}_{\text {OD }}$ | Change in $\mathrm{V}_{\mathrm{OD}}$, between H and L | - | - | 50 | mV |
| $\Delta \mathrm{V}_{\text {ID }}$ | Change in $\mathrm{V}_{\text {OS }}$, between H and L | - | - | 50 | mV |
| $\mathrm{V}_{\text {THD }}$ | Input voltage, differential, $\left\|\mathrm{V}_{\text {INP }}-\mathrm{V}_{\text {INM }}\right\|$ | 200 | - | 600 | mV |
| $\mathrm{V}_{\text {CM }}$ | Input voltage, common mode, $\left\|\mathrm{V}_{\text {INP }}+\mathrm{V}_{\text {INM }}\right\| / 2$ | $0.3+\left(\mathrm{V}_{\text {THD }} / 2\right)$ | - | $2.1-\left(\mathrm{V}_{\text {THD }} / 2\right)$ |  |
| $\mathrm{T}_{\mathrm{R},} \mathrm{T}_{\mathrm{F}}$ | Output rise and fall times, 20\% to 80\% | - | - | 550 | ps |
| Toduty | Output clock duty cycle | 40 | - | 60 | \% |

Note: Data is for 6 mA differential current drive. Other differential driver current options are available.

### 4.35.3. Point-to-Point LVDS (PPLVDS)

Over Recommended Operating Conditions

| Description | Min. | Typ. | Max. | Units |
| :--- | :---: | :---: | :---: | :---: |
| Output driver supply (+/-5\%) | 3.14 | 3.3 | 3.47 | V |
|  | 2.25 | 2.5 | 2.75 | V |
| Input differential voltage | 100 | - | 400 | mV |
| Input common mode voltage | 0.2 | - | 2.3 | VV |
| Output differential voltage | 130 | - | 400 |  |
| Output common mode voltage | 0.5 | 0.8 | 1.4 | V |

### 4.35.4. RSDS

Over Recommended Operating Conditions

| Symbol | Description | Min. | Typ. | Max. | Units |
| :--- | :--- | :---: | :---: | :---: | :---: |
| $V_{O D}$ | Output voltage, differential, $R_{T}=100 \Omega$ | 100 | 200 | 600 | mV |
| $V_{\text {OS }}$ | Output voltage, common mode | 0.5 | 1.2 | 1.5 | V |
| $\mathrm{I}_{\text {RSDS }}$ | Differential driver output current | 1 | 2 | 6 | mA |
| $\mathrm{~V}_{\text {THD }}$ | Input voltage differential | 100 | - | - | mV |
| $\mathrm{V}_{\mathrm{CM}}$ | Input common mode voltage | 0.3 | - | 1.5 | V |
| $\mathrm{~T}_{\mathrm{R},} \mathrm{T}_{\mathrm{F}}$ | Output rise and fall times, $20 \%$ to $80 \%$ | - | 500 | - | ps |
| $\mathrm{T}_{\text {ODUTY }}$ | Output clock duty cycle | 35 | 50 | 65 | $\%$ |

Note: Data is for 2 mA drive. Other differential driver current options are available.

## 5. Pinout Information

### 5.1. Signal Descriptions

| Signal Name | I/O | Description |
| :---: | :---: | :---: |
| General Purpose |  |  |
| P[Edge] [Row/Column Number]_[A/B] | 1/0 | [Edge] indicates the edge of the device on which the pad is located. Valid edge designations are L (Left), B (Bottom), R (Right), T (Top). <br> [Row/Column Number] indicates the PFU row or the column of the device on which the PIC exists. When Edge is T (Top) or B (Bottom), only need to spec- ify Column Number. When Edge is L (Left) or R (Right), only need to specify Row Number. <br> [A/B] indicates the PIO within the PIC to which the pad is connected. Some of these user-programmable pins are shared with special function pins. These pins, when not used as special purpose pins, can be programmed as I/O for user logic. During configuration the user-programmable I/O are tri-stated with an internal pull-up resistor enabled. If any pin is not used (or not bonded to a package pin), it is also tri-stated with an internal pull-up resistor enabled after configuration. |
| P[Edge][Row Number]E_[A/B/C/D] | 1 | These general purpose signals are input-only pins and are located near the PLLs. |
| GSRN | 1 | Global RESET signal (active low). Any I/O pin can be GSRN. |
| NC | - | No connect. |
| RESERVED | - | This pin is reserved and should not be connected to anything on the board. |
| GND | - | Ground. Dedicated pins. |
| $\mathrm{V}_{\text {cc }}$ | - | Power supply pins for core logic. Dedicated pins. |
| $\mathrm{V}_{\text {ccaux }}$ | - | Auxiliary power supply pin. This dedicated pin powers all the differential and referenced input buffers. |
| $\mathrm{V}_{\text {cliox }}$ | - | Dedicated power supply pins for I/O bank x. |
| $V_{\text {cCA }}$ | - | SERDES, transmit, receive, PLL and reference clock buffer power supply. All VCCA supply pins must always be powered to the recommended operating voltage range. If no SERDES channels are used, connect VCCA to VCC. |
| $\mathrm{V}_{\text {CCPLL_[LOC] }}$ | - | General purpose PLL supply pins where LOC=L (left) or R (right). |
| $\mathrm{V}_{\text {REF1_x }}, \mathrm{V}_{\text {REF2_x }}$ | - | Reference supply pins for I/O bank x. Pre-determined pins in each bank are assigned as VREF inputs. When not used, they may be used as I/O pins. |
| VTTx | - | Power supply for on-chip termination of I/O. |
| XRES ${ }^{1}$ | - | $10 \mathrm{k} \Omega+/-1 \%$ resistor must be connected between this pad and ground. |
| PLL, DLL, and Clock Functions |  |  |
| [LOC][num]_GPLL[T, C]_IN_[index] | I | General Purpose PLL (GPLL) input pads: LUM, LLM, RUM, RLM, num = row from center, $\mathrm{T}=$ true and $\mathrm{C}=$ complement, index $\mathrm{A}, \mathrm{B}, \mathrm{C} . .$. at each side. |
| [LOC][num]_GPLL[T, C]_FB_[index] | 1 | Optional feedback GPLL input pads: LUM, LLM, RUM, RLM, num = row from center, $\mathrm{T}=$ true and $\mathrm{C}=$ complement, index $\mathrm{A}, \mathrm{B}, \mathrm{C}$...at each side. |
| [LOC]0_GDLLT_IN_[index]2 | I/O | General Purpose DLL (GDLL) input pads where LOC=RUM or LUM, T is True Complement, index is A or B. |
| [LOC]0_GDLLT_FB_[index]2 | I/O | Optional feedback GDLL input pads where LOC=RUM or LUM, T is True Complement, index is A or B . |
| PCLK[T, C][n:0]_[3:0]2 | 1/0 | Primary Clock pads, $\mathrm{T}=$ true and $\mathrm{C}=$ complement, n per side, indexed by bank and $0,1,2,3$ within bank. |
| [LOC]DQS[num] | 1/0 | DQ input/output pads: T (top), R (right), B (bottom), L (left), DQS, num = ball function number. |
| [LOC]DQ[num] | I/O | DQ input/output pads: T (top), R (right), B (bottom), L (left), DQ, associated DQS number. |


| Signal Name | I/O | Description |
| :---: | :---: | :---: |
| Test and Programming (Dedicated Pins) |  |  |
| TMS | 1 | Test Mode Select input, used to control the 1149.1 state machine. Pull-up is enabled during configuration. |
| TCK | 1 | Test Clock input pin, used to clock the 1149.1 state machine. No pull-up enabled. |
| TDI | 1 | Test Data in pin. Used to load data into device using 1149.1 state machine. After power-up, this TAP port can be activated for configuration by sending appropriate command. (Note: once a configuration port is selected it is locked. Another configuration port cannot be selected until the power-up sequence). Pull-up is enabled during configuration. |
| TDO | 0 | Output pin. Test Data Out pin used to shift data out of a device using 1149.1. |
| VCCJ | - | Power supply pin for JTAG Test Access Port. |
| Configuration Pads (Used During sysCONFIG) |  |  |
| CFG[2:0] | 1 | Mode pins used to specify configuration mode values latched on rising edge of INITN. During configuration, a pull-up is enabled. These are dedicated pins. |
| INITN | I/O | Open Drain pin. Indicates the FPGA is ready to be configured. During configuration, a pull-up is enabled. It is a dedicated pin. |
| PROGRAMN | 1 | Initiates configuration sequence when asserted low. This pin always has an active pull-up. It is a dedicated pin. |
| DONE | I/O | Open Drain pin. Indicates that the configuration sequence is complete, and the startup sequence is in progress. It is a dedicated pin. |
| CCLK | 1 | Input Configuration Clock for configuring an FPGA in Slave SPI, Serial, and CPU modes. It is a dedicated pin. |
| MCLK | I/O | Output Configuration Clock for configuring an FPGA in SPI, SPIm, and Master configuration modes. |
| BUSY/SISPI | 0 | Parallel configuration mode busy indicator. SPI/SPIm mode data output. |
| CSN/SN/OEN | I/O | Parallel configuration mode active-low chip select. Slave SPI chip select. Parallel burst Flash output enable. |
| CS1N/HOLDN/RDY | 1 | Parallel configuration mode active-low chip select. Slave SPI hold input. |
| WRITEN | 1 | Write enable for parallel configuration modes. |
| DOUT/CSON/CSSPI1N | 0 | Serial data output. Chip select output. SPI/SPIm mode chip select. |
| D[0]/SPIFASTN | I/O | sysCONFIG Port Data I/O for Parallel mode. Open drain during configuration. |
|  |  | sysCONFIG Port Data I/O for SPI or SPIm. When using the SPI or SPIm mode, this pin should either be tied high or low, must not be left floating. Open drain during configuration. |
| D1 | I/O | Parallel configuration I/O. Open drain during configuration. |
| D2 | I/O | Parallel configuration I/O. Open drain during configuration. |
| D3/SI | I/O | Parallel configuration I/O. Slave SPI data input. Open drain during configuration. |
| D4/SO | I/O | Parallel configuration I/O. Slave SPI data output. Open drain during configuration. |
| D5 | I/O | Parallel configuration I/O. Open drain during configuration. |
| D6/SPID1 | I/O | Parallel configuration I/O. SPI/SPIm data input. Open drain during configuration. |
| D7/SPID0 | I/O | Parallel configuration I/O. SPI/SPIm data input. Open drain during configuration. |
| DI/CSSPION/CEN | I/O | Serial data input for slave serial mode. SPI/SPIm mode chip select. |


| Signal Name | 1/0 | Description |
| :---: | :---: | :---: |
| Dedicated SERDES Signals ${ }^{3}$ |  |  |
| PCS[Index]_HDINNm | 1 | High-speed input, negative channel m |
| PCS[Index]_HDOUTNm | 0 | High-speed output, negative channel m |
| PCS[Index]_REFCLKN | 1 | Negative Reference Clock Input |
| PCS[Index]_HDINPm | 1 | High-speed input, positive channel m |
| PCS[Index]_HDOUTPm | 0 | High-speed output, positive channel m |
| PCS[Index]_REFCLKP | 1 | Positive Reference Clock Input |
| PCS[Index]_VCCOBm | - | Output buffer power supply, channel m (1.2V/1.5) |
| PCS[Index]_VCCIBm | - | Input buffer power supply, channel m (1.2V/1.5V) |

## Notes:

1. When placing switching I/O around these critical pins that are designed to supply the device with the proper reference or supply voltage, care must be given.
2. These pins are dedicated inputs or can be used as general purpose I/O.
3. $m$ defines the associated channel in the quad.

### 5.2. PICs and DDR Data (DQ) Pins Associated with the DDR Strobe (DQS) Pin

| PICs Associated with DQS Strobe | PIO Within PIC | DDR Strobe (DQS) and Data (DQ) Pins |
| :---: | :---: | :---: |
| For Left and Right Edges of the Device |  |  |
| P[Edge] [n-3] | A | DQ |
|  | B | DQ |
| P[Edge] [n-2] | A | DQ |
|  | B | DQ |
| P[Edge] [ $\mathrm{n}-1$ ] | A | DQ |
|  | B | DQ |
| P[Edge] [n] | A | [Edge]DQSn |
|  | B | DQ |
| P[Edge] [ $\mathrm{n}+1$ ] | A | DQ |
|  | B | DQ |
| P[Edge] [ $\mathrm{n}+2$ ] | A | DQ |
|  | B | DQ |
| For Top Edge of the Device |  |  |
| P[Edge] [n-3] | A | DQ |
|  | B | DQ |
| P[Edge] [n-2] | A | DQ |
|  | B | DQ |
| P[Edge] [ $\mathrm{n}-1$ ] | A | DQ |
|  | B | DQ |
| P[Edge] [n] | A | [Edge]DQSn |
|  | B | DQ |
| P[Edge] [ $\mathrm{n}+1$ ] | A | DQ |
|  | B | DQ |
| P[Edge] [ $\mathrm{n}+2$ ] | A | DQ |
|  | B | DQ |

Note: $n$ is a row PIC number.

### 5.3. Pin Information Summary

| Pin Information Summary |  | ECP3-17EA |  |  | ECP3-35EA |  |  | ECP3-70EA |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin Type |  |  |  |  | 256 | 484 | 672 | 484 | 672 | 1156 |
|  |  | ftBGA | csBGA | fpBGA | ftBGA | fpBGA | fpBGA | fpBGA | fpBGA | fpBGA |
| General Purpose Inputs/Outputs per Bank | Bank 0 | 26 | 20 | 36 | 26 | 42 | 48 | 42 | 60 | 86 |
|  | Bank 1 | 14 | 10 | 24 | 14 | 36 | 36 | 36 | 48 | 78 |
|  | Bank 2 | 6 | 7 | 12 | 6 | 24 | 24 | 24 | 34 | 36 |
|  | Bank 3 | 18 | 12 | 44 | 16 | 54 | 59 | 54 | 59 | 86 |
|  | Bank 6 | 20 | 11 | 44 | 18 | 63 | 61 | 63 | 67 | 86 |
|  | Bank 7 | 19 | 26 | 32 | 19 | 36 | 42 | 36 | 48 | 54 |
|  | Bank 8 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 | 24 |
| General Purpose Inputs per Bank | Bank 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 2 | 2 | 2 | 2 | 2 | 4 | 4 | 4 | 8 | 8 |
|  | Bank 3 | 0 | 0 | 0 | 2 | 4 | 4 | 4 | 12 | 12 |
|  | Bank 6 | 0 | 0 | 0 | 2 | 4 | 4 | 4 | 12 | 12 |
|  | Bank 7 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 8 | 8 |
|  | Bank 8 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| General Purpose Outputs per Bank | Bank 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 2 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 3 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 6 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 7 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 8 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |
| Total Single-Ended User I/O |  | 133 | 116 | 222 | 133 | 295 | 310 | 295 | 380 | 490 |
| VCC |  | 6 | 16 | 16 | 6 | 16 | 32 | 16 | 32 | 32 |
| VCCAUX |  | 4 | 5 | 8 | 4 | 8 | 12 | 8 | 12 | 16 |
| VTT |  | 4 | 7 | 4 | 4 | 4 | 4 | 4 | 4 | 8 |
| VCCA |  | 4 | 6 | 4 | 4 | 4 | 8 | 4 | 8 | 16 |
| VCCPLL |  | 2 | 2 | 4 | 2 | 4 | 4 | 4 | 4 | 4 |
| VCCIO | Bank 0 | 2 | 3 | 2 | 2 | 2 | 4 | 2 | 4 | 4 |
|  | Bank 1 | 2 | 3 | 2 | 2 | 2 | 4 | 2 | 4 | 4 |
|  | Bank 2 | 2 | 2 | 2 | 2 | 2 | 4 | 2 | 4 | 4 |
|  | Bank 3 | 2 | 3 | 2 | 2 | 2 | 4 | 2 | 4 | 4 |
|  | Bank 6 | 2 | 3 | 2 | 2 | 2 | 4 | 2 | 4 | 4 |
|  | Bank 7 | 2 | 3 | 2 | 2 | 2 | 4 | 2 | 4 | 4 |
|  | Bank 8 | 1 | 2 | 2 | 1 | 2 | 2 | 2 | 2 | 2 |
| VCCJ |  | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 |
| TAP |  | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 | 4 |
| GND, GNDIO |  | 51 | 126 | 98 | 51 | 98 | 139 | 98 | 139 | 233 |
| NC |  | 0 | 0 | 73 | 0 | 0 | 96 | 0 | 0 | 238 |
| Reserved1 |  | 0 | 0 | 2 | 0 | 2 | 2 | 2 | 2 | 2 |
| SERDES |  | 26 | 18 | 26 | 26 | 26 | 26 | 26 | 52 | 78 |
| Miscellaneous Pins |  | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 | 8 |
| Total Bonded Pins |  | 256 | 328 | 484 | 256 | 484 | 672 | 484 | 672 | 1156 |

Pin Information Summary (Cont.)

| Pin Information Summary |  | ECP3-17EA |  |  | ECP3-35EA |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin Type |  | 256 | 328 | 484 | 256 | 484 | 672 |
| Emulated Differential I/O per Bank | Bank 0 | 13 | 10 | 18 | 13 | 21 | 24 |
|  | Bank 1 | 7 | 5 | 12 | 7 | 18 | 18 |
|  | Bank 2 | 2 | 2 | 4 | 1 | 8 | 8 |
|  | Bank 3 | 4 | 2 | 13 | 5 | 20 | 19 |
|  | Bank 6 | 5 | 1 | 13 | 6 | 22 | 20 |
|  | Bank 7 | 6 | 9 | 10 | 6 | 11 | 13 |
|  | Bank 8 | 12 | 12 | 12 | 12 | 12 | 12 |
| Highspeed Differential I/O per Bank | Bank 0 | 0 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 1 | 0 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 2 | 2 | 2 | 3 | 3 | 6 | 6 |
|  | Bank 3 | 5 | 4 | 9 | 4 | 9 | 12 |
|  | Bank 6 | 5 | 4 | 9 | 4 | 11 | 12 |
|  | Bank 7 | 5 | 6 | 8 | 5 | 9 | 10 |
|  | Bank 8 | 0 | 0 | 0 | 0 | 0 | 0 |
| Total Single Ended/ Total Differential I/O per Bank | Bank 0 | 26/13 | 20/10 | 36/18 | 26/13 | 42/21 | 48/24 |
|  | Bank 1 | 14/7 | 10/5 | 24/12 | 14/7 | 36/18 | 36/18 |
|  | Bank 2 | 8/4 | 9/4 | 14/7 | 8/4 | 28/14 | 28/14 |
|  | Bank 3 | 18/9 | 12/6 | 44/22 | 18/9 | 58/29 | 63/31 |
|  | Bank 6 | 20/10 | 11/5 | 44/22 | 20/10 | 67/33 | 65/32 |
|  | Bank 7 | 23/11 | 30/15 | 36/18 | 23/11 | 40/20 | 46/23 |
|  | Bank 8 | 24/12 | 24/12 | 24/12 | 24/12 | 24/12 | 24/12 |
| DDR Groups Bonded per Bank2 | Bank 0 | 2 | 1 | 3 | 2 | 3 | 4 |
|  | Bank 1 | 1 | 0 | 2 | 1 | 3 | 3 |
|  | Bank 2 | 0 | 0 | 1 | 0 | 2 | 2 |
|  | Bank 3 | 1 | 0 | 3 | 1 | 3 | 4 |
|  | Bank 6 | 1 | 0 | 3 | 1 | 4 | 4 |
|  | Bank 7 | 1 | 2 | 2 | 1 | 3 | 3 |
|  | Configuration Bank 8 | 0 | 0 | 0 | 0 | 0 | 0 |
| SERDES Quads |  | 1 | 1 | 1 | 1 | 1 | 1 |

## Notes:

1. These pins must remain floating on the board.
2. Some DQS groups may not support DQS-12. Refer to the device pinout (.csv) file.

Pin Information Summary (Cont.)

| Pin Information Summary |  | ECP3-70EA |  |  |
| :---: | :---: | :---: | :---: | :---: |
| Pin Type |  | 484 fpBGA | 672 fpBGA | 1156 fpBGA |
| Emulated Differential I/O per Bank | Bank 0 | 21 | 30 | 43 |
|  | Bank 1 | 18 | 24 | 39 |
|  | Bank 2 | 8 | 12 | 13 |
|  | Bank 3 | 20 | 23 | 33 |
|  | Bank 6 | 22 | 25 | 33 |
|  | Bank 7 | 11 | 16 | 18 |
|  | Bank 8 | 12 | 12 | 12 |
| High-Speed Differential I/ O per Bank | Bank 0 | 0 | 0 | 0 |
|  | Bank 1 | 0 | 0 | 0 |
|  | Bank 2 | 6 | 9 | 9 |
|  | Bank 3 | 9 | 12 | 16 |
|  | Bank 6 | 11 | 14 | 16 |
|  | Bank 7 | 9 | 12 | 13 |
|  | Bank 8 | 0 | 0 | 0 |
| Total Single-Ended/ Total Differential I/O per Bank | Bank 0 | 42/21 | 60/30 | 86/43 |
|  | Bank 1 | 36/18 | 48/24 | 78/39 |
|  | Bank 2 | 28/14 | 42/21 | 44/22 |
|  | Bank 3 | 58/29 | 71/35 | 98/49 |
|  | Bank 6 | 67/33 | 78/39 | 98/49 |
|  | Bank 7 | 40/20 | 56/28 | 62/31 |
|  | Bank 8 | 24/12 | 24/12 | 24/12 |
| DDR Groups Bonded per Bank* | Bank 0 | 3 | 5 | 7 |
|  | Bank 1 | 3 | 4 | 7 |
|  | Bank 2 | 2 | 3 | 3 |
|  | Bank 3 | 3 | 4 | 5 |
|  | Bank 6 | 4 | 4 | 5 |
|  | Bank 7 | 3 | 4 | 4 |
|  | Configuration Bank 8 | 0 | 0 | 0 |
| SERDES Quads |  | 1 | 2 | 3 |

*Note: Some DQS groups may not support DQS-12. Refer to the device pinout (.csv) file.

Pin Information Summary (Cont.)

| Pin Information Summary |  | ECP3-95EA |  |  | ECP3-150EA |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin Type |  | 484 | 672 | 1156 | 672 | 1156 |
| General Purpose Inputs/Outputs per bank | Bank 0 | 42 | 60 | 86 | 60 | 94 |
|  | Bank 1 | 36 | 48 | 78 | 48 | 86 |
|  | Bank 2 | 24 | 34 | 36 | 34 | 58 |
|  | Bank 3 | 54 | 59 | 86 | 59 | 104 |
|  | Bank 6 | 63 | 67 | 86 | 67 | 104 |
|  | Bank 7 | 36 | 48 | 54 | 48 | 76 |
|  | Bank 8 | 24 | 24 | 24 | 24 | 24 |
| General Purpose Inputs per Bank | Bank 0 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 1 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 2 | 4 | 8 | 8 | 8 | 8 |
|  | Bank 3 | 4 | 12 | 12 | 12 | 12 |
|  | Bank 6 | 4 | 12 | 12 | 12 | 12 |
|  | Bank 7 | 4 | 8 | 8 | 8 | 8 |
|  | Bank 8 | 0 | 0 | 0 | 0 | 0 |
| General Purpose Outputs per Bank | Bank 0 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 1 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 2 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 3 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 6 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 7 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 8 | 0 | 0 | 0 | 0 | 0 |
| Total Single-Ended User I/O |  | 295 | 380 | 490 | 380 | 586 |
| VCC |  | 16 | 32 | 32 | 32 | 32 |
| VCCAUX |  | 8 | 12 | 16 | 12 | 16 |
| VTT |  | 4 | 4 | 8 | 4 | 8 |
| VCCA |  | 4 | 8 | 16 | 8 | 16 |
| VCCPLL |  | 4 | 4 | 4 | 4 | 4 |
| VCCIO | Bank 0 | 2 | 4 | 4 | 4 | 4 |
|  | Bank 1 | 2 | 4 | 4 | 4 | 4 |
|  | Bank 2 | 2 | 4 | 4 | 4 | 4 |
|  | Bank 3 | 2 | 4 | 4 | 4 | 4 |
|  | Bank 6 | 2 | 4 | 4 | 4 | 4 |
|  | Bank 7 | 2 | 4 | 4 | 4 | 4 |
|  | Bank 8 | 2 | 2 | 2 | 2 | 2 |
| VCCJ |  | 1 | 1 | 1 | 1 | 1 |
| TAP |  | 4 | 4 | 4 | 4 | 4 |
| GND, GNDIO |  | 98 | 139 | 233 | 139 | 233 |
| NC |  | 0 | 0 | 238 | 0 | 116 |
| Reserved* |  | 2 | 2 | 2 | 2 | 2 |
| SERDES |  | 26 | 52 | 78 | 52 | 104 |
| Miscellaneous Pins |  | 8 | 8 | 8 | 8 | 8 |
| Total Bonded Pins |  | 484 | 672 | 1156 | 672 | 1156 |


| Pin Information Summary |  | ECP3-95EA |  |  | ECP3-150EA |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Pin Type |  | 484 | 672 | 1156 | 672 | 1156 |
| Emulated Differential I/O per Bank | Bank 0 | 21 | 30 | 43 | 30 | 47 |
|  | Bank 1 | 18 | 24 | 39 | 24 | 43 |
|  | Bank 2 | 8 | 12 | 13 | 12 | 18 |
|  | Bank 3 | 20 | 23 | 33 | 23 | 37 |
|  | Bank 6 | 22 | 25 | 33 | 25 | 37 |
|  | Bank 7 | 11 | 16 | 18 | 16 | 24 |
|  | Bank 8 | 12 | 12 | 12 | 12 | 12 |
| Highspeed Differential I/O per Bank | Bank 0 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 1 | 0 | 0 | 0 | 0 | 0 |
|  | Bank 2 | 6 | 9 | 9 | 9 | 15 |
|  | Bank 3 | 9 | 12 | 16 | 12 | 21 |
|  | Bank 6 | 11 | 14 | 16 | 14 | 21 |
|  | Bank 7 | 9 | 12 | 13 | 12 | 18 |
|  | Bank 8 | 0 | 0 | 0 | 0 | 0 |
| Total Single Ended/ Total Differential I/O per Bank | Bank 0 | 42/21 | 60/30 | 86/43 | 60/30 | 94/47 |
|  | Bank 1 | 36/18 | 48/24 | 78/39 | 48/24 | 86/43 |
|  | Bank 2 | 28/14 | 42/21 | 44/22 | 42/21 | 66/33 |
|  | Bank 3 | 58/29 | 71/35 | 98/49 | 71/35 | 116/58 |
|  | Bank 6 | 67/33 | 78/39 | 98/49 | 78/39 | 116/58 |
|  | Bank 7 | 40/20 | 56/28 | 62/31 | 56/28 | 84/42 |
|  | Bank 8 | 24/12 | 24/12 | 24/12 | 24/12 | 24/12 |
| DDR Groups Bonded per Bank | Bank 0 | 3 | 5 | 7 | 5 | 7 |
|  | Bank 1 | 3 | 4 | 7 | 4 | 7 |
|  | Bank 2 | 2 | 3 | 3 | 3 | 4 |
|  | Bank 3 | 3 | 4 | 5 | 4 | 7 |
|  | Bank 6 | 4 | 4 | 5 | 4 | 7 |
|  | Bank 7 | 3 | 4 | 4 | 4 | 6 |
|  | Configuration Bank 8 | 0 | 0 | 0 | 0 | 0 |
| SERDES Quads |  |  | 1 | 2 | 2 | 4 |

*Note: These pins must remain floating on the board.

### 5.3.1. Package Pinout Information

Package pinout information can be found under "Data Sheets" on the LatticeECP3 product pages on the Lattice website at http://www.latticesemi.com/Products/FPGAandCPLD/LatticeECP3 and in the Diamond or ispLEVER software tools. To create pinout information from within ispLEVER Design Planner, select Tools > Spreadsheet View. Then select Select File > Export and choose a type of output file. To create a pin information file from within Diamond select Tools > Spreadsheet View or Tools >Package View; then, select File > Export and choose a type of output file. See Diamond or ispLEVER Help for more information.

### 5.4. Thermal Management

Thermal management is recommended as part of any sound FPGA design methodology. To assess the thermal characteristics of a system, Lattice specifies a maximum allowable junction temperature in all device data sheets. Designers must complete a thermal analysis of their specific design to ensure that the device and package do not exceed the junction temperature limits. Refer to the Thermal Management document to find the device/package specific thermal values.

### 5.4.1. For Further Information

For further information regarding Thermal Management, refer to the following:

- Thermal Management document
- Power Consumption and Management for LatticeECP3 Devices (FPGA-TN-02189)
- Power Calculator tool included with the Diamond and ispLEVER design tools, or as a standalone download from www.latticesemi.com/software


## 6. Ordering Information

### 6.1. LatticeECP3 Part Number Description



* Green = Halogen free and lead free.


### 6.2. Ordering Information

LatticeECP3 devices have top-side markings, for commercial and industrial grades, as shown below:


Note: See PCN 05A-12 for information regarding a change to the top-side mark logo.

### 6.2.1. LatticeECP3 Devices, Green and Lead-Free Packaging

The following devices may have associated errata. Specific devices with associated errata will be notated with a footnote.
Commercial

| Part Number | Voltage | Grade | Power | Package* | Pins | Temp. | LUTs (K) |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| LFE3-17EA-6FTN256C | 1.2 V | -6 | STD | Lead-Free ftBGA | 256 | COM | 17 |
| LFE3-17EA-7FTN256C | 1.2 V | -7 | STD | Lead-Free ftBGA | 256 | COM | 17 |
| LFE3-17EA-8FTN256C | 1.2 V | -8 | STD | Lead-Free ftBGA | 256 | COM | 17 |
| LFE3-17EA-6LFTN256C | 1.2 V | -6 | LOW | Lead-Free ftBGA | 256 | COM | 17 |
| LFE3-17EA-7LFTN256C | 1.2 V | -7 | LOW | Lead-Free ftBGA | 256 | COM | 17 |
| LFE3-17EA-8LFTN256C | 1.2 V | -8 | LOW | Lead-Free ftBGA | 256 | COM | 17 |
| LFE3-17EA-6MG328C | 1.2 V | -6 | STD | Green csBGA | 328 | COM | 17 |
| LFE3-17EA-7MG328C | 1.2 V | -7 | STD | Green csBGA | 328 | COM | 17 |
| LFE3-17EA-8MG328C | 1.2 V | -8 | STD | Green csBGA | 328 | COM | 17 |
| LFE3-17EA-6LMG328C | 1.2 V | -6 | LOW | Green csBGA | 328 | COM | 17 |
| LFE3-17EA-7LMG328C | 1.2 V | -7 | LOW | Green csBGA | 328 | COM | 17 |
| LFE3-17EA-8LMG328C | 1.2 V | -8 | LOW | Green csBGA | 328 | COM | 17 |
| LFE3-17EA-6FN484C | 1.2 V | -6 | STD | Lead-Free fpBGA | 484 | COM | 17 |
| LFE3-17EA-7FN484C | 1.2 V | -7 | STD | Lead-Free fpBGA | 484 | COM | 17 |
| LFE3-17EA-8FN484C | 1.2 V | -8 | STD | Lead-Free fpBGA | 484 | COM | 17 |
| LFE3-17EA-6LFN484C | $1.2 ~ V$ | -6 | LOW | Lead-Free fpBGA | 484 | COM | 17 |
| LFE3-17EA-7LFN484C | $1.2 ~ V ~$ | -7 | LOW | Lead-Free fpBGA | 484 | COM | 17 |
| LFE3-17EA-8LFN484C | 1.2 V | -8 | LOW | Lead-Free fpBGA | 484 | COM | 17 |

*Note: Green = Halogen free and lead free.

| Part Number | Voltage | Grade* | Power | Package | Pins | Temp. | LUTs (K) |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| LFE3-35EA-6FTN256C | 1.2 V | -6 | STD | Lead-Free ftBGA | 256 | COM | 33 |
| LFE3-35EA-7FTN256C | 1.2 V | -7 | STD | Lead-Free ftBGA | 256 | COM | 33 |
| LFE3-35EA-8FTN256C | 1.2 V | -8 | STD | Lead-Free ftBGA | 256 | COM | 33 |
| LFE3-35EA-6LFTN256C | 1.2 V | -6 | LOW | Lead-Free ftBGA | 256 | COM | 33 |
| LFE3-35EA-7LFTN256C | 1.2 V | -7 | LOW | Lead-Free ftBGA | 256 | COM | 33 |
| LFE3-35EA-8LFTN256C | 1.2 V | -8 | LOW | Lead-Free ftBGA | 256 | COM | 33 |
| LFE3-35EA-6FN484C | 1.2 V | -6 | STD | Lead-Free fpBGA | 484 | COM | 33 |
| LFE3-35EA-7FN484C | 1.2 V | -7 | STD | Lead-Free fpBGA | 484 | COM | 33 |
| LFE3-35EA-8FN484C | 1.2 V | -8 | STD | Lead-Free fpBGA | 484 | COM | 33 |
| LFE3-35EA-6LFN484C | 1.2 V | -6 | LOW | Lead-Free fpBGA | 484 | COM | 33 |
| LFE3-35EA-7LFN484C | 1.2 V | -7 | LOW | Lead-Free fpBGA | 484 | COM | 33 |
| LFE3-35EA-8LFN484C | 1.2 V | -8 | LOW | Lead-Free fpBGA | 484 | COM | 33 |
| LFE3-35EA-6FN672C | 1.2 V | -6 | STD | Lead-Free fpBGA | 672 | COM | 33 |
| LFE3-35EA-7FN672C | 1.2 V | -7 | STD | Lead-Free fpBGA | 672 | COM | 33 |
| LFE3-35EA-8FN672C | 1.2 V | -8 | STD | Lead-Free fpBGA | 672 | COM | 33 |
| LFE3-35EA-6LFN672C | 1.2 V | -6 | LOW | Lead-Free fpBGA | 672 | COM | 33 |
| LFE3-35EA-7LFN672C | 1.2 V | -7 | LOW | Lead-Free fpBGA | 672 | COM | 33 |
| LFE3-35EA-8LFN672C | 1.2 V | -8 | LOW | Lead-Free fpBGA | 672 | COM | 33 |

*Note: For ordering information on -9 speed grade devices, contact your Lattice Sales Representative.

| Part Number | Voltage | Grade* | Power | Package | Pins | Temp. | LUTs (K) |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| LFE3-70EA-6FN484C | 1.2 V | -6 | STD | Lead-Free fpBGA | 484 | COM | 67 |
| LFE3-70EA-7FN484C | 1.2 V | -7 | STD | Lead-Free fpBGA | 484 | COM | 67 |
| LFE3-70EA-8FN484C | 1.2 V | -8 | STD | Lead-Free fpBGA | 484 | COM | 67 |
| LFE3-70EA-6LFN484C | 1.2 V | -6 | LOW | Lead-Free fpBGA | 484 | COM | 67 |
| LFE3-70EA-7LFN484C | 1.2 V | -7 | LOW | Lead-Free fpBGA | 484 | COM | 67 |
| LFE3-70EA-8LFN484C | 1.2 V | -8 | LOW | Lead-Free fpBGA | 484 | COM | 67 |
| LFE3-70EA-6FN672C | 1.2 V | -6 | STD | Lead-Free fpBGA | 672 | COM | 67 |
| LFE3-70EA-7FN672C | 1.2 V | -7 | STD | Lead-Free fpBGA | 672 | COM | 67 |
| LFE3-70EA-8FN672C | 1.2 V | -8 | STD | Lead-Free fpBGA | 672 | COM | 67 |
| LFE3-70EA-6LFN672C | 1.2 V | -6 | LOW | Lead-Free fpBGA | 672 | COM | 67 |
| LFE3-70EA-7LFN672C | 1.2 V | -7 | LOW | Lead-Free fpBGA | 672 | COM | 67 |
| LFE3-70EA-8LFN672C | 1.2 V | -8 | LOW | Lead-Free fpBGA | 672 | COM | 67 |
| LFE3-70EA-6FN1156C | 1.2 V | -6 | STD | Lead-Free fpBGA | 1156 | COM | 67 |
| LFE3-70EA-7FN1156C | 1.2 V | -7 | STD | Lead-Free fpBGA | 1156 | COM | 67 |
| LFE3-70EA-8FN1156C | 1.2 V | -8 | STD | Lead-Free fpBGA | 1156 | COM | 67 |
| LFE3-70EA-6LFN1156C | 1.2 V | -6 | LOW | Lead-Free fpBGA | 1156 | COM | 67 |
| LFE3-70EA-7LFN1156C | 1.2 V | -7 | LOW | Lead-Free fpBGA | 1156 | COM | 67 |
| LFE3-70EA-8LFN1156C | 1.2 V | -8 | LOW | Lead-Free fpBGA | 1156 | COM | 67 |

*Note: For ordering information on -9 speed grade devices, contact your Lattice Sales Representative.

| Part Number | Voltage | Grade* | Power | Package | Pins | Temp. | LUTs (K) |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| LFE3-95EA-6FN484C | 1.2 V | -6 | STD | Lead-Free fpBGA | 484 | COM | 92 |
| LFE3-95EA-7FN484C | 1.2 V | -7 | STD | Lead-Free fpBGA | 484 | COM | 92 |
| LFE3-95EA-8FN484C | 1.2 V | -8 | STD | Lead-Free fpBGA | 484 | COM | 92 |
| LFE3-95EA-6LFN484C | 1.2 V | -6 | LOW | Lead-Free fpBGA | 484 | COM | 92 |
| LFE3-95EA-7LFN484C | 1.2 V | -7 | LOW | Lead-Free fpBGA | 484 | COM | 92 |
| LFE3-95EA-8LFN484C | 1.2 V | -8 | LOW | Lead-Free fpBGA | 484 | COM | 92 |
| LFE3-95EA-6FN672C | 1.2 V | -6 | STD | Lead-Free fpBGA | 672 | COM | 92 |
| LFE3-95EA-7FN672C | 1.2 V | -7 | STD | Lead-Free fpBGA | 672 | COM | 92 |
| LFE3-95EA-8FN672C | 1.2 V | -8 | STD | Lead-Free fpBGA | 672 | COM | 92 |
| LFE3-95EA-6LFN672C | 1.2 V | -6 | LOW | Lead-Free fpBGA | 672 | COM | 92 |
| LFE3-95EA-7LFN672C | 1.2 V | -7 | LOW | Lead-Free fpBGA | 672 | COM | 92 |
| LFE3-95EA-8LFN672C | 1.2 V | -8 | LOW | Lead-Free fpBGA | 672 | COM | 92 |
| LFE3-95EA-6FN1156C | 1.2 V | -6 | STD | Lead-Free fpBGA | 1156 | COM | 92 |
| LFE3-95EA-7FN1156C | 1.2 V | -7 | STD | Lead-Free fpBGA | 1156 | COM | 92 |
| LFE3-95EA-8FN1156C | 1.2 V | -8 | STD | Lead-Free fpBGA | 1156 | COM | 92 |
| LFE3-95EA-6LFN1156C | 1.2 V | -6 | LOW | Lead-Free fpBGA | 1156 | COM | 92 |
| LFE3-95EA-7LFN1156C | 1.2 V | -7 | LOW | Lead-Free fpBGA | 1156 | COM | 92 |
| LFE3-95EA-8LFN1156C | 1.2 V | -8 | LOW | Lead-Free fpBGA | 1156 | COM | 92 |

*Note: For ordering information on -9 speed grade devices, contact your Lattice Sales Representative.

| Part Number | Voltage | Grade* | Power | Package | Pins | Temp. | LUTs (K) |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| LFE3-150EA-6FN672C | 1.2 V | -6 | STD | Lead-Free fpBGA | 672 | COM | 149 |
| LFE3-150EA-7FN672C | 1.2 V | -7 | STD | Lead-Free fpBGA | 672 | COM | 149 |
| LFE3-150EA-8FN672C | 1.2 V | -8 | STD | Lead-Free fpBGA | 672 | COM | 149 |
| LFE3-150EA-6LFN672C | 1.2 V | -6 | LOW | Lead-Free fpBGA | 672 | COM | 149 |
| LFE3-150EA-7LFN672C | 1.2 V | -7 | LOW | Lead-Free fpBGA | 672 | COM | 149 |
| LFE3-150EA-8LFN672C | 1.2 V | -8 | LOW | Lead-Free fpBGA | 672 | COM | 149 |
| LFE3-150EA-6FN1156C | 1.2 V | -6 | STD | Lead-Free fpBGA | 1156 | COM | 149 |
| LFE3-150EA-7FN1156C | 1.2 V | -7 | STD | Lead-Free fpBGA | 1156 | COM | 149 |
| LFE3-150EA-8FN1156C | 1.2 V | -8 | STD | Lead-Free fpBGA | 1156 | COM | 149 |
| LFE3-150EA-6LFN1156C | 1.2 V | -6 | LOW | Lead-Free fpBGA | 1156 | COM | 149 |
| LFE3-150EA-7LFN1156C | 1.2 V | -7 | LOW | Lead-Free fpBGA | 1156 | COM | 149 |
| LFE3-150EA-8LFN1156C | 1.2 V | -8 | LOW | Lead-Free fpBGA | 1156 | COM | 149 |

*Note: For ordering information on -9 speed grade devices, contact your Lattice Sales Representative.

| Part Number | Voltage | Grade | Power | Package | Pins | Temp. | LUTs (K) |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| LFE3-150EA-6FN672CTW $^{1}$ | 1.2 V | -6 | STD | Lead-Free fpBGA | 672 | COM | 149 |
| LFE3-150EA-7FN672CTW $^{1}$ | 1.2 V | -7 | STD | Lead-Free fpBGA | 672 | COM | 149 |
| LFE3-150EA-8FN672CTW $^{1}$ | 1.2 V | -8 | STD | Lead-Free fpBGA | 672 | COM | 149 |
| LFE3-150EA-6FN1156CTW $^{1}$ | 1.2 V | -6 | STD | Lead-Free fpBGA | 1156 | COM | 149 |
| LFE3-150EA-7FN1156CTW $^{1}$ | 1.2 V | -7 | STD | Lead-Free fpBGA | 1156 | COM | 149 |
| LFE3-150EA-8FN1156CTW $^{1}$ | 1.2 V | -8 | STD | Lead-Free fpBGA | 1156 | COM | 149 |

## Note:

Specifications for the LFE3-150EA-spFNpkgCTW and LFE3-150EA-spFNpkgITW devices, (where $s p$ is the speed and $p k g$ is the package), are the same as the LFE3-150EA-spFNpkgC and LFE3-150EA-spFNpkgl devices respectively, except as specified below.

- The CTC (Clock Tolerance Circuit) inside the SERDES hard PCS in the TW device is not functional but it can be bypassed and implemented in soft IP.
- The SERDES XRES pin on the TW device passes CDM testing at 250 V .


## Industrial

The following devices may have associated errata. Specific devices with associated errata will be notated with a footnote.

| Part Number | Voltage | Grade | Power | Package* | Pins | Temp. | LUTs (K) |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| LFE3-17EA-6FTN256I | 1.2 V | -6 | STD | Lead-Free ftBGA | 256 | IND | 17 |
| LFE3-17EA-7FTN256I | 1.2 V | -7 | STD | Lead-Free ftBGA | 256 | IND | 17 |
| LFE3-17EA-8FTN256I | 1.2 V | -8 | STD | Lead-Free ftBGA | 256 | IND | 17 |
| LFE3-17EA-6LFTN256I | 1.2 V | -6 | LOW | Lead-Free ftBGA | 256 | IND | 17 |
| LFE3-17EA-7LFTN256I | 1.2 V | -7 | LOW | Lead-Free ftBGA | 256 | IND | 17 |
| LFE3-17EA-8LFTN256I | 1.2 V | -8 | LOW | Lead-Free ftBGA | 256 | IND | 17 |
| LFE3-17EA-6MG328I | 1.2 V | -6 | STD | Lead-Free csBGA | 328 | IND | 17 |
| LFE3-17EA-7MG328I | 1.2 V | -7 | STD | Lead-Free csBGA | 328 | IND | 17 |
| LFE3-17EA-8MG328I | 1.2 V | -8 | STD | Lead-Free csBGA | 328 | IND | 17 |
| LFE3-17EA-6LMG328I | 1.2 V | -6 | LOW | Green csBGA | 328 | IND | 17 |
| LFE3-17EA-7LMG328I | 1.2 V | -7 | LOW | Green csBGA | 328 | IND | 17 |
| LFE3-17EA-8LMG328I | 1.2 V | -8 | LOW | Green csBGA | 328 | IND | 17 |
| LFE3-17EA-6FN484I | 1.2 V | -6 | STD | Lead-Free fpBGA | 484 | IND | 17 |
| LFE3-17EA-7FN484I | 1.2 V | -7 | STD | Lead-Free fpBGA | 484 | IND | 17 |
| LFE3-17EA-8FN484I | 1.2 V | -8 | STD | Lead-Free fpBGA | 484 | IND | 17 |
| LFE3-17EA-6LFN484I | 1.2 V | -6 | LOW | Lead-Free fpBGA | 484 | IND | 17 |
| LFE3-17EA-7LFN484I | 1.2 V | -7 | LOW | Lead-Free fpBGA | 484 | IND | 17 |
| LFE3-17EA-8LFN484I | 1.2 V | -8 | LOW | Lead-Free fpBGA | 484 | IND | 17 |

*Note: Green = Halogen free and lead free.

| Part Number | Voltage | Grade1 | Power | Package | Pins | Temp. | LUTs (K) |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| LFE3-35EA-6FTN256I | 1.2 V | -6 | STD | Lead-Free ftBGA | 256 | IND | 33 |
| LFE3-35EA-7FTN256I | 1.2 V | -7 | STD | Lead-Free ftBGA | 256 | IND | 33 |
| LFE3-35EA-8FTN256I | 1.2 V | -8 | STD | Lead-Free ftBGA | 256 | IND | 33 |
| LFE3-35EA-6LFTN256I | 1.2 V | -6 | LOW | Lead-Free ftBGA | 256 | IND | 33 |
| LFE3-35EA-7LFTN256I | 1.2 V | -7 | LOW | Lead-Free ftBGA | 256 | IND | 33 |
| LFE3-35EA-8LFTN256I | 1.2 V | -8 | LOW | Lead-Free ftBGA | 256 | IND | 33 |
| LFE3-35EA-6FN484I | 1.2 V | -6 | STD | Lead-Free fpBGA | 484 | IND | 33 |
| LFE3-35EA-7FN484I | 1.2 V | -7 | STD | Lead-Free fpBGA | 484 | IND | 33 |
| LFE3-35EA-8FN484I | 1.2 V | -8 | STD | Lead-Free fpBGA | 484 | IND | 33 |
| LFE3-35EA-6LFN484I | 1.2 V | -6 | LOW | Lead-Free fpBGA | 484 | IND | 33 |
| LFE3-35EA-7LFN484I | 1.2 V | -7 | LOW | Lead-Free fpBGA | 484 | IND | 33 |
| LFE3-35EA-8LFN484I | 1.2 V | -8 | LOW | Lead-Free fpBGA | 484 | IND | 33 |
| LFE3-35EA-6FN672I | 1.2 V | -6 | STD | Lead-Free fpBGA | 672 | IND | 33 |
| LFE3-35EA-7FN672I | 1.2 V | -7 | STD | Lead-Free fpBGA | 672 | IND | 33 |
| LFE3-35EA-8FN672I | 1.2 V | -8 | STD | Lead-Free fpBGA | 672 | IND | 33 |
| LFE3-35EA-6LFN672I | 1.2 V | -6 | LOW | Lead-Free fpBGA | 672 | IND | 33 |
| LFE3-35EA-7LFN672I | 1.2 V | -7 | LOW | Lead-Free fpBGA | 672 | IND | 33 |
| LFE3-35EA-8LFN672I | 1.2 V | -8 | LOW | Lead-Free fpBGA | 672 | IND | 33 |

Note: For ordering information on -9 speed grade devices, ontact your Lattice Sales Representative.

| Part Number | Voltage | Grade* | Power | Package | Pins | Temp. | LUTs (K) |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| LFE3-70EA-6FN484I | 1.2 V | -6 | STD | Lead-Free fpBGA | 484 | IND | 67 |
| LFE3-70EA-7FN484I | 1.2 V | -7 | STD | Lead-Free fpBGA | 484 | IND | 67 |
| LFE3-70EA-8FN484I | 1.2 V | -8 | STD | Lead-Free fpBGA | 484 | IND | 67 |
| LFE3-70EA-6LFN484I | 1.2 V | -6 | LOW | Lead-Free fpBGA | 484 | IND | 67 |
| LFE3-70EA-7LFN484I | 1.2 V | -7 | LOW | Lead-Free fpBGA | 484 | IND | 67 |
| LFE3-70EA-8LFN484I | 1.2 V | -8 | LOW | Lead-Free fpBGA | 484 | IND | 67 |
| LFE3-70EA-6FN672I | 1.2 V | -6 | STD | Lead-Free fpBGA | 672 | IND | 67 |
| LFE3-70EA-7FN672I | 1.2 V | -7 | STD | Lead-Free fpBGA | 672 | IND | 67 |
| LFE3-70EA-8FN672I | 1.2 V | -8 | STD | Lead-Free fpBGA | 672 | IND | 67 |
| LFE3-70EA-6LFN672I | 1.2 V | -6 | LOW | Lead-Free fpBGA | 672 | IND | 67 |
| LFE3-70EA-7LFN672I | 1.2 V | -7 | LOW | Lead-Free fpBGA | 672 | IND | 67 |
| LFE3-70EA-8LFN672I | 1.2 V | -8 | LOW | Lead-Free fpBGA | 672 | IND | 67 |
| LFE3-70EA-6FN1156I | 1.2 V | -6 | STD | Lead-Free fpBGA | 1156 | IND | 67 |
| LFE3-70EA-7FN1156I | 1.2 V | -7 | STD | Lead-Free fpBGA | 1156 | IND | 67 |
| LFE3-70EA-8FN1156I | 1.2 V | -8 | STD | Lead-Free fpBGA | 1156 | IND | 67 |
| LFE3-70EA-6LFN1156I | 1.2 V | -6 | LOW | Lead-Free fpBGA | 1156 | IND | 67 |
| LFE3-70EA-7LFN1156I | 1.2 V | -7 | LOW | Lead-Free fpBGA | 1156 | IND | 67 |
| LFE3-70EA-8LFN1156I | 1.2 V | -8 | LOW | Lead-Free fpBGA | 1156 | IND | 67 |

Note: For ordering information on -9 speed grade devices, contact your Lattice Sales Representative.

| Part Number | Voltage | Grade* | Power | Package | Pins | Temp. | LUTs (K) |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| LFE3-95EA-6FN484I | 1.2 V | -6 | STD | Lead-Free fpBGA | 484 | IND | 92 |
| LFE3-95EA-7FN484I | 1.2 V | -7 | STD | Lead-Free fpBGA | 484 | IND |  |
| LFE3-95EA-8FN484I | 1.2 V | -8 | STD | Lead-Free fpBGA | 484 | IND |  |
| LFE3-95EA-6LFN484I | 1.2 V | -6 | LOW | Lead-Free fpBGA | 484 | IND | 92 |
| LFE3-95EA-7LFN484I | 1.2 V | -7 | LOW | Lead-Free fpBGA | 484 | IND | 92 |
| LFE3-95EA-8LFN484I | 1.2 V | -8 | LOW | Lead-Free fpBGA | 484 | IND | 92 |
| LFE3-95EA-6FN672I | 1.2 V | -6 | STD | Lead-Free fpBGA | 672 | IND |  |
| LFE3-95EA-7FN672I | 1.2 V | -7 | STD | Lead-Free fpBGA | 672 | IND | 92 |
| LFE3-95EA-8FN672I | 1.2 V | -8 | STD | Lead-Free fpBGA | 672 | IND | 92 |
| LFE3-95EA-6LFN672I | 1.2 V | -6 | LOW | Lead-Free fpBGA | 672 | IND | 92 |
| LFE3-95EA-7LFN672I | 1.2 V | -7 | LOW | Lead-Free fpBGA | 672 | IND | 92 |
| LFE3-95EA-8LFN672I | 1.2 V | -8 | LOW | Lead-Free fpBGA | 672 | IND | 92 |
| LFE3-95EA-6FN1156I | 1.2 V | -6 | STD | Lead-Free fpBGA | 1156 | IND | 92 |
| LFE3-95EA-7FN1156I | 1.2 V | -7 | STD | Lead-Free fpBGA | 1156 | IND | 92 |
| LFE3-95EA-8FN1156I | 1.2 V | -8 | STD | Lead-Free fpBGA | 1156 | IND | 92 |
| LFE3-95EA-6LFN1156I | 1.2 V | -6 | LOW | Lead-Free fpBGA | 1156 | IND | 92 |
| LFE3-95EA-7LFN1156I | 1.2 V | -7 | LOW | Lead-Free fpBGA | 1156 | IND | 92 |
| LFE3-95EA-8LFN1156I | 1.2 V | -8 | LOW | Lead-Free fpBGA | 1156 | IND | 92 |

*Note: For ordering information on -9 speed grade devices, contact your Lattice Sales Representative.

| Part Number | Voltage | Grade* | Power | Package | Pins | Temp. | LUTs (K) |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| LFE3-150EA-6FN672I | 1.2 V | -6 | STD | Lead-Free fpBGA | 672 | IND | 149 |
| LFE3-150EA-7FN672I | 1.2 V | -7 | STD | Lead-Free fpBGA | 672 | IND | 149 |
| LFE3-150EA-8FN672I | 1.2 V | -8 | STD | Lead-Free fpBGA | 672 | IND | 149 |
| LFE3-150EA-6LFN672I | 1.2 V | -6 | LOW | Lead-Free fpBGA | 672 | IND | 149 |
| LFE3-150EA-7LFN672I | 1.2 V | -7 | LOW | Lead-Free fpBGA | 672 | IND | 149 |
| LFE3-150EA-8LFN672I | 1.2 V | -8 | LOW | Lead-Free fpBGA | 672 | IND | 149 |
| LFE3-150EA-6FN1156I | 1.2 V | -6 | STD | Lead-Free fpBGA | 1156 | IND | 149 |
| LFE3-150EA-7FN1156I | 1.2 V | -7 | STD | Lead-Free fpBGA | 1156 | IND | 149 |
| LFE3-150EA-8FN1156I | 1.2 V | -8 | STD | Lead-Free fpBGA | 1156 | IND | 149 |
| LFE3-150EA-6LFN1156I | 1.2 V | -6 | LOW | Lead-Free fpBGA | 1156 | IND | 149 |
| LFE3-150EA-7LFN1156I | 1.2 V | -7 | LOW | Lead-Free fpBGA | 1156 | IND | 149 |
| LFE3-150EA-8LFN1156I | 1.2 V | -8 | LOW | Lead-Free fpBGA | 1156 | IND | 149 |

*Note: For ordering information on -9 speed grade devices, contact your Lattice Sales Representative.

| Part Number | Voltage | Grade | Power | Package | Pins | Temp. | LUTs (K) |
| :--- | :--- | :--- | :--- | :--- | :--- | :--- | :--- |
| LFE3-150EA-6FN672ITW* | 1.2 V | -6 | STD | Lead-Free fpBGA | 672 | IND | 149 |
| LFE3-150EA-7FN672ITW* | 1.2 V | -7 | STD | Lead-Free fpBGA | 672 | IND | 149 |
| LFE3-150EA-8FN672ITW* | 1.2 V | -8 | STD | Lead-Free fpBGA | 672 | IND | 149 |
| LFE3-150EA-6FN1156ITW* | 1.2 V | -6 | STD | Lead-Free fpBGA | 1156 | IND | 149 |
| LFE3-150EA-7FN1156ITW* | 1.2 V | -7 | STD | Lead-Free fpBGA | 1156 | IND | 149 |
| LFE3-150EA-8FN1156ITW* | 1.2 V | -8 | STD | Lead-Free fpBGA | 1156 | IND | 149 |

*Note: Specifications for the LFE3-150EA-spFNpkgCTW and LFE3-150EA-spFNpkgITW devices, (where sp is the speed and $p k g$ is the package), are the same as the LFE3-150EA-spFNpkgC and LFE3-150EA-spFNpkgI devices respectively, except as specified below.

- The CTC (Clock Tolerance Circuit) inside the SERDES hard PCS in the TW device is not functional but it can be bypassed and implemented in soft IP.
- The SERDES XRES pin on the TW device passes CDM testing at 250 V .


## 7. Supplemental Information

### 7.1. For Further Information

A variety of technical notes for the LatticeECP3 family are available on the Lattice website at www.latticesemi.com.

- LatticeECP3 sysCONFIG Usage Guide (FPGA-TN-02192)
- LatticeECP3 SERDES/PCS Usage Guide (FPGA-TN-02190)
- LatticeECP3 sysIO Usage Guide (FPGA-TN-02194)
- LatticeECP3 sysCLOCK PLL/DLL Design and Usage Guide (FPGA-TN-02191)
- LatticeECP3 Memory Usage Guide (FPGA-TN-02188)
- LatticeECP3 High-Speed I/O Interface (FPGA-TN-02184)
- Power Consumption and Management for LatticeECP3 Devices (FPGA-TN-02189)
- LatticeECP3 sysDSP Usage Guide (FPGA-TN-02193)
- LatticeECP3 Soft Error Detection (SED) Usage Guide (FPGA-TN-02207)
- LatticeECP3 Hardware Checklist (FPGA-TN-02183)
- LatticeECP2MS and LatticeECP2S Devices (TN1215)
- LatticeECP3, LatticeECP2/M, ECP5 and ECP5-5G Dual Boot and Multiple Boot Feature (FPGA-TN-02203)
- LatticeECP3 Slave SPI Port User's Guide (FPGA-TN-02136)

For further information on interface standards refer to the following websites:

- JEDEC Standards (LVTTL, LVCMOS, SSTL, HSTL): www.jedec.org
- PCI: www.pcisig.com


## Technical Support Assistance

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


## Revision History

Revision 3.0, June 2021

| Section | Change Summary |
| :--- | :--- |
| sysl/O Single-Ended DC Electrical <br> Characteristics | Added footnote 2 in section 4.10 sysI/O Single-Ended DC Electrical Characteristics. |
| Supplemental Information | Updated hyperlink for LatticeECP3, LatticeECP2/M, ECP5 and ECP5-5G Dual Boot and <br> Multiple Boot Feature (FPGA-TN-02203) in For Further Information section. |

Revision 2.9EA, January 2020

| Section | Change Summary |
| :---: | :---: |
| All | - Changed document number from DS1021 to FPGA-DS-02074. <br> - Updated document template. |
| Disclaimers | Added this section. |
| DC and Switching Characteristics | - Updated Recommended Operating Conditions1 section. Added footnote to Vref1. <br> - Updated LatticeECP3 External Switching Characteristics ${ }^{1,2,3,13}$ section. Corrected header to Generic DDRX2 Output with Clock and Data (<10 Bits Wide) Centered at Pin Using DQSDLL (GDDRX2_TX.DQSDLL. Centered). |
| All | Updated references to: <br> - FPGA-TN-02136, LatticeECP3 SPI Slave Port User Guide (previously TN1222) <br> - FPGA-TN-02192, LatticeECP3 sysCONFIG Usage Guide (previously TN1169) |

## Revision 2.8EA, March 2015

| Section | Change Summary |
| :--- | :--- |
| Pinout Information | Updated Package Pinout Information section. Changed reference to <br> http://www.latticesemi.com/Products/FPGAandCPLD/LatticeECP3. |
| All | Minor style/formatting changes. |

Revision 2.7EA, April 2014

| Section | Change Summary |
| :---: | :---: |
| DC and Switching Characteristics | Updated LatticeECP3 Supply Current (Standby) table power numbers. Removed speed grade -9 timing numbers in the following sections: <br> - Typical Building Block Function Performance <br> - LatticeECP3 External Switching Characteristics <br> - LatticeECP3 Internal Switching Characteristics <br> - LatticeECP3 Family Timing Adders |
| Ordering Information | Removed ordering information for -9 speed grade devices. |

Revision 2.6EA, March 2014

| Section | Change Summary |
| :--- | :--- |
| DC and Switching Characteristics | Added information to the sysI/O Single-Ended DC Electrical Characteristics section footnote. |

Revision 2.5EA, February 2014

| Section | Change Summary |
| :--- | :--- |
| DC and Switching Characteristics | Updated Hot Socketing Specifications table. Changed I Ipw to IpD in footnote 3. <br>  <br>  <br>  <br>  <br>  <br> Updated the following figures: <br> • Figure 4.25, sysCONFIG Port Timing <br> - Figure 4.27, Wake-Up Timing |
| Supplemental Information | Added technical note references. |

Revision 2.4EA, September 2013

| Section | Change Summary |
| :--- | :--- |
| DC and Switching Characteristics | Updated the Wake-Up Timing Diagram |
|  | Added the following figures: |
|  | $\bullet \quad$ Master SPI POR Waveforms |
|  | $\bullet \quad$ SPI Configuration Waveforms |
|  | - Slave SPI HOLDN Waveforms |
|  | Added tIODISS and tIOENSS parameters in LatticeECP3 sysCONFIG Port Timing Specifications |
|  | table. |

Revision 2.3EA, June 2013

| Section | Change Summary |
| :---: | :---: |
| Architecture | - sysl/O Buffer Banks text section - Updated description of "Top (Bank 0 and Bank 1) and Bottom sysIO Buffer Pairs (Single-Ended Outputs Only)" for hot socketing information. <br> - sysl/O Buffer Banks text section - Updated description of "Configuration Bank sysl/O Buffer Pairs (Single-Ended Outputs, Only on Shared Pins When Not Used by Configuration)" for PCI clamp information. <br> - On-Chip Oscillator section - clarified the speed of the internal CMOS oscillator (130 $\mathrm{MHz}+/-15 \%)$. <br> - Architecture Overview section - Added information on the state of the register on power up and after configuration. |
| DC and Switching Characteristics | - sysl/O Recommended Operating Conditions table - Removed reference to footnote 1 from RSDS standard. <br> - sysI/O Single-Ended DC Electrical Characteristics table - Modified footnote 1. <br> - Added Oscillator Output Frequency table. <br> - LatticeECP3 sysCONFIG Port Timing Specifications table - Updated min. column for tcodo parameter. <br> - LatticeECP3 Family Timing Adders table - Description column, references to VCCIO = 3.0 V changed to 3.3 V . For PPLVDS, description changed from emulated to True LVDS and $\mathrm{VCCIO}=2.5 \mathrm{~V}$ changed to $\mathrm{VCCIO}=2.5 \mathrm{~V}$ or 3.3 V . <br> - LatticeECP3 Maximum I/O Buffer Speed table - Description column, references to $\mathrm{VCCIO}=3.0 \mathrm{~V}$ changed to 3.3 V . <br> - Updated SERDES External Reference Clock Waveforms. <br> - Transmitter and Receiver Latency Block Diagram - Updated sections of the diagram to match descriptions on the SERDES/PCS Latency Breakdown table. |
| Pinout Information | - "Logic Signal Connections" section heading renamed "Package Pinout Information". Software menu selections within this section have been updated. <br> - Signal Descriptions table - Updated description for $V_{c c A}$ signal. |

## Revision 2.2EA, April 2012

| Section | Change Summary |
| :--- | :--- |
| Architecture | $\bullet \quad$ Updated first paragraph of Output Register Block section. <br> $\bullet$ <br> $\bullet$ <br> • Updated the information about sysIO buffer pairs below Figure 3.7. <br> section. |
| DC and Switching Characteristics | Corrected the Definitions in the sysCLOCK PLL Timing table for t trst. |
| Ordering Information | Updated topside marks with new logos in the Ordering Information section. |

Revision 2.1EA, February 2012

| Section | Change Summary |
| :--- | :--- |
| All | Updated document with new corporate logo. |

Revision 2.0EA, November 2011

| Section | Change Summary |
| :---: | :---: |
| Introduction | Added information for LatticeECP3-17EA, 328-ball csBGA package. |
| Architecture | Added information for LatticeECP3-17EA, 328-ball csBGA package. |
| DC and Switching Characteristics | - Updated LatticeECP3 Supply Current table power numbers. <br> - Typical Building Block Function Performance table, LatticeECP3 External Switching Characteristics table, LatticeECP3 Internal Switching Characteristics table and LatticeECP3 Family Timing Adders: Added speed grade -9 and updated speed grade -8, 7 and -6 timing numbers. |
| Pinout Information | Added information for LatticeECP3-17EA, 328-ball csBGA package. |
| Ordering Information | - Added information for LatticeECP3-17EA, 328-ball csBGA package. <br> - Added ordering information for low power devices and -9 speed grade devices. |

Revision 1.9EA, July 2011

| Section | Change Summary |
| :--- | :--- |
| DC and Switching Characteristics | $\bullet \quad$Removed ESD Performance table and added reference to LatticeECP3 Product Family <br> Qualification Summary document. |
|  | $\bullet \quad$sysCLOCK PLL TIming table, added footnote 4. <br> External Reference Clock Specification table - removed reference to VREF-CM-AC and <br> removed footnote for VREF-CM-AC. |
| Pinout Information | Pin Information Summary table: Corrected VCCIO Bank8 data for LatticeECP3-17EA 256-ball <br> ftBGA package and LatticeECP-35EA 256-ball ftBGA package. |

Revision 1.8EA, April 2011

| Section | Change Summary |
| :---: | :---: |
| Architecture | Updated Secondary Clock/Control Sources text section. |
| DC and Switching Characteristics | - Added data for 150 Mbps to SERDES Power Supply Requirements table. <br> - Updated Frequencies in Table 4.6 Serial Output Timing and Levels <br> - Added Data for 150 Mbps to Table 4.7 Channel Output Jitter <br> - Corrected External Switching Characteristics table, Description for DDR3 Clock Timing, $\mathrm{t}_{\boldsymbol{\prime} / \mathrm{t}}$. <br> - Corrected Internal Switching Characteristics table, Description for EBR Timing, $\mathrm{t}_{\text {suwren_ebr }}$ and $\mathrm{t}_{\text {Hwren_ebr. }}$. <br> - Added footnote 1 to sysConfig Port Timing Specifications table. <br> - Updated description for RX-CIDs to 150M in Table 4.9 Serial Input Data Specifications <br> - Updated Frequency to 150 Mbps in Table 4.11 Periodic Receiver Jitter Tolerance Specification |

Revision 1.7EA, December 2010

| Section | Change Summary |  |
| :--- | :--- | :--- |
| Multiple | $\bullet$ | Data sheet made final. Removed "preliminary" headings. |
|  | $\bullet$ | Removed data for $70 E$ <br> specific devices. |
|  | $\bullet$ | Updated for Lattice Diamond design software. |


| Section | Change Summary |
| :---: | :---: |
|  | Characteristics table. <br> - Corrected titles for Figures 4.7 (DDR/DDR2/DDR3 Parameters) and 4.8 (Generic DDR/DDRX2 Parameters). <br> - Updated titles for Figures 4.5 (MLVDS25 (Multipoint Low Voltage Differential Signaling)) and 4.6 (Generic DDRX1/DDRX2 (With Clock and Data Edges Aligned)). <br> - Updated Supply Current table. <br> - Added GDDR interface information to the External Switching and Characteristics table. <br> - Added footnote to sysIO Recommended Operating Conditions table. <br> - Added footnote to LVDS25 table. <br> - Corrected DDR section footnotes and references. <br> - Corrected Hot Socketing support from "top and bottom banks" to "top and bottom I/O pins". |
| Pinout Information | Updated description for VTTx. |

Revision 1.6EA, March 2010

| Section | Change Summary |
| :--- | :--- |
| Architecture | Added Read-Before-Write information. |
| DC and Switching Characteristics | $\bullet \quad$ Added footnote \#6 to Maximum I/O Buffer Speed table. <br> $\bullet$ <br> Corrected minimum operating conditions for input and output differential voltages in <br> the Point-to-Point LVDS table. |
| Pinout Information | Added pin information for the LatticeECP3-70EA and LatticeECP3-95EA devices. |
| Ordering Information | $\bullet$ <br> • Added ordering part numbers for the LatticeECP3-70EA and LatticeECP3-95EA devices. <br> $\bullet \quad$ Removed dual mark information. |

## Revision 1.5EA, November 2009

| Section | Change Summary |
| :---: | :---: |
| Introduction | - Updated Embedded SERDES features. <br> - Added SONET/SDH to Embedded SERDES protocols. |
| Architecture | - Updated Figure 2.4, General Purpose PLL Diagram. <br> - Updated SONET/SDH to SERDES and PCS protocols. <br> - Updated Table 3.3, SERDES Standard Support to include SONET/ SDH and updated footnote 2. |
| DC and Switching Characterisitcs | - Added footnote to ESD Performance table. <br> - Updated SERDES Power Supply Requirements table and footnotes. <br> - Updated Maximum I/O Buffer Speed table. <br> - Updated Pin-to-Pin Peformance table. <br> - Updated sysCLOCK PLL Timing table. <br> - Updated DLL timing table. <br> - Updated High-Speed Data Transmitter tables. <br> - Updated High-Speed Data Receiver table. <br> - Updated footnote for Receiver Total Jitter Tolerance Specification table. <br> - Updated Periodic Receiver Jitter Tolerance Specification table. <br> - Updated SERDES External Reference Clock Specification table. <br> - Updated PCI Express Electrical and Timing AC and DC Characteristics. <br> - Deleted Reference Clock table for PCI Express Electrical and Timing AC and DC Characteristics. <br> - Updated SMPTE AC/DC Characteristics Transmit table. <br> - Updated Mini LVDS table. <br> - Updated RSDS table. <br> - Added Supply Current (Standby) table for EA devices. <br> - Updated Internal Switching Characteristics table. <br> - Updated Register-to-Register Performance table. |


| Section | Change Summary |
| :---: | :---: |
|  | - Added HDMI Electrical and Timing Characteristics data. <br> - Updated Family Timing Adders table. <br> - Updated sysCONFIG Port Timing Specifications table. <br> - Updated Recommended Operating Conditions table. <br> - Updated Hot Socket Specifications table. <br> - Updated Single-Ended DC table. <br> - Updated TRLVDS table and figure. <br> - Updated Serial Data Input Specifications table. <br> - Updated HDMI Transmit and Receive table. |
| Ordering Information | Added LFE3-150EA "TW" devices and footnotes to the Commercial and Industrial tables. |

Revision 1.4EA, September 2009

| Section | Change Summary |
| :---: | :---: |
| Architecture | - Corrected link in sysMEM Memory Block section. <br> - Updated information for On-Chip Programmable Termination and modified corresponding figure. <br> - Added footnote 2 to On-Chip Programmable Termination Options for Input Modes table. <br> - Corrected Per Quadrant Primary Clock Selection figure. |
| DC and Switching Characteristics | - Modified - 8 Timing data for $1024 \times 18$ True-Dual Port RAM (Read-Before-Write, EBR Output Registers) <br> - Added ESD Performance table. <br> - LatticeECP3 External Switching Characteristics table - updated data for $\mathrm{t}_{\text {DIBGDDR }}, \mathrm{t}_{\mathrm{w}}$ PRI, $\mathrm{t}_{\mathrm{W} \text { _ } \text { EDGE }}$ and $\mathrm{t}_{\text {SKEW_EDGE_DQs. }}$. <br> - LatticeECP3 Internal Switching Characteristics table - updated data for tcoo_po and added footnote \#4. <br> - sysCLOCK PLL Timing table - updated data for fout. <br> - External Reference Clock Specification (refclkp/refclkn) table - updated data for $\mathrm{V}_{\text {REF-IN- }}$ se and $\mathrm{V}_{\text {REF-IN-DIIF. }}$ <br> - LatticeECP3 sysCONFIG Port Timing Specifications table - updated data for $\mathrm{t}_{\text {Mwc }}$. <br> - Added TRLVDS DC Specification table and diagram. <br> - Updated Mini LVDS table. |

Revision 1.3EA, August 2009

| Section | Change Summary |
| :--- | :--- |
| DC and Switching Characteristics | Corrected truncated numbers for $\mathrm{V}_{\text {CCIB }}$ and $\mathrm{V}_{\text {CCOB }}$ in Recommended Operating Conditions <br> table. |

## Revision 1.2EA, July 2009

| Section | Change Summary |
| :---: | :---: |
| Multiple | Changed references of "multi-boot" to "dual-boot" throughout the data sheet. |
| Architecture | - Updated On-Chip Programmable Termination bullets. <br> - Updated On-Chip Termination Options for Input Modes table. <br> - Updated On-Chip Termination figure. |
| DC and Switching Characteristics | - Changed min/max data for FREF_PPM and added footnote 4 in SERDES External Reference Clock Specification table. <br> - Updated SERDES minimum frequency. |
| Pinout Information | Corrected MCLK to be I/O and CCLK to be I in Signal Descriptions table |

Revision 1.1EA, May 2009

| Section | Change Summary |
| :---: | :---: |
| All | Removed references to Parallel burst mode Flash. |
| Introduction | - Features - Changed 250 Mbps to 230 Mbps in Embedded SERDES bulleted section and added a footnote to indicate 230 Mbps applies to 8 b 10 b and 10b12b applications. <br> - Updated data for ECP3-17 in LatticeECP3 Family Selection Guide table. <br> - Changed embedded memory from 552 to 700 Kbits in LatticeECP3 Family Selection Guide table. |
| Architecture | - Updated description for CLKFB in General Purpose PLL Diagram. <br> - Corrected Primary Clock Sources text section. <br> - Corrected Secondary Clock/Control Sources text section. <br> - Corrected Secondary Clock Regions table. <br> - Corrected note below Detailed sysDSP Slice Diagram. <br> - Corrected Clock, Clock Enable, and Reset Resources text section. <br> - Corrected ECP3-17 EBR number in Embedded SRAM in the LatticeECP3 Family table. <br> - Added On-Chip Termination Options for Input Modes table. <br> - Updated Available SERDES Quads per LatticeECP3 Devices table. <br> - Updated Simplified Channel Block Diagram for SERDES/PCS Block diagram. <br> - Updated Device Configuration text section. <br> - Corrected software default value of MCCLK to be 2.5 MHz . |
| DC and Switching Characteristics | - Updated VCCOB Min/Max data in Recommended Operating Conditions table. <br> - Corrected footnote 2 in sysIO Recommended Operating Conditions table. <br> - Added added footnote 7 for tsKEw_PRIB $^{\text {to External Switching Characteristics table. }}$ <br> - Added 2-to-1 Gearing text section and table. <br> - Updated External Reference Clock Specification (refclkp/refclkn) table. <br> - LatticeECP3 sysCONFIG Port Timing Specifications - updated tDINIT information. <br> - Added sysCONFIG Port Timing waveform. <br> - $\quad$ Serial Input Data Specifications table, delete Typ data for $\mathrm{V}_{\text {RX-DIFF-S }}$. <br> - Added footnote 4 to sysCLOCK PLL Timing table for $t_{\text {PFD }}$. <br> - Added SERDES/PCS Block Latency Breakdown table. <br> - External Reference Clock Specifications table, added footnote 4, add symbol name vREF-IN-DIFF. <br> - Added SERDES External Reference Clock Waveforms. <br> - Updated Serial Output Timing and Levels table. <br> - Pin-to-pin performance table, changed "typically 3\% slower" to "typically slower". <br> - Updated timing information <br> - Updated SERDES minimum frequency <br> - Added data to the following tables: External Switching Characteristics, Internal Switching Characteristics, Family Timing Adders, Maximum I/O Buffer Speed, DLL Timing, High Speed Data Transmitter, Channel Output Jitter, Typical Building Block Function Performance, Register-to-Register Performance, and Power Supply Requirements. <br> - Updated Serial Input Data Specifications table. <br> - Updated Transmit table, Serial Rapid I/O Type 2 Electrical and Timing Characteristics section. |
| Pinout Information | - Updated Signal Description tables. <br> - Updated Pin Information Summary tables and added footnote 1. |

Revision 1.0EA, February 2009

| Section | Change Summary |
| :--- | :--- |
| All | Initial release. |

