# Intel - EP4CE30F29C8LN Datasheet





Welcome to <u>E-XFL.COM</u>

### Understanding <u>Embedded - FPGAs (Field</u> <u>Programmable Gate Array)</u>

Embedded - FPGAs, or Field Programmable Gate Arrays, are advanced integrated circuits that offer unparalleled flexibility and performance for digital systems. Unlike traditional fixed-function logic devices, FPGAs can be programmed and reprogrammed to execute a wide array of logical operations, enabling customized functionality tailored to specific applications. This reprogrammability allows developers to iterate designs quickly and implement complex functions without the need for custom hardware.

### **Applications of Embedded - FPGAs**

The versatility of Embedded - FPGAs makes them indispensable in numerous fields. In telecommunications.

#### Details

| Product Status                 | Active                                                    |
|--------------------------------|-----------------------------------------------------------|
| Number of LABs/CLBs            | 1803                                                      |
| Number of Logic Elements/Cells | 28848                                                     |
| Total RAM Bits                 | 608256                                                    |
| Number of I/O                  | 532                                                       |
| Number of Gates                | -                                                         |
| Voltage - Supply               | 0.97V ~ 1.03V                                             |
| Mounting Type                  | Surface Mount                                             |
| Operating Temperature          | 0°C ~ 85°C (TJ)                                           |
| Package / Case                 | 780-BGA                                                   |
| Supplier Device Package        | 780-FBGA (29x29)                                          |
| Purchase URL                   | https://www.e-xfl.com/product-detail/intel/ep4ce30f29c8ln |
|                                |                                                           |

Email: info@E-XFL.COM

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

This chapter provides additional information about the document and Altera.

# **About this Handbook**

This handbook provides comprehensive information about the Altera<sup>®</sup> Cyclone<sup>®</sup> IV family of devices.

# **How to Contact Altera**

To locate the most up-to-date information about Altera products, refer to the following table.

| Contact <sup>(1)</sup>         | <b>Contact Method</b> | Address                   |  |  |  |  |  |
|--------------------------------|-----------------------|---------------------------|--|--|--|--|--|
| Technical support              | Website               | www.altera.com/support    |  |  |  |  |  |
| Technical training             | Website               | www.altera.com/training   |  |  |  |  |  |
| recinical training             | Email                 | custrain@altera.com       |  |  |  |  |  |
| Product literature             | Website               | www.altera.com/literature |  |  |  |  |  |
| Nontechnical support (general) | Email                 | nacomp@altera.com         |  |  |  |  |  |
| (software licensing)           | Email                 | authorization@altera.com  |  |  |  |  |  |

Note to Table:

(1) You can also contact your local Altera sales office or sales representative.

# **Typographic Conventions**

The following table shows the typographic conventions this document uses.

| Visual Cue                                | Meaning                                                                                                                                                                                                                             |
|-------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bold Type with Initial Capital<br>Letters | Indicate command names, dialog box titles, dialog box options, and other GUI labels. For example, <b>Save As</b> dialog box. For GUI elements, capitalization matches the GUI.                                                      |
| bold type                                 | Indicates directory names, project names, disk drive names, file names, file name<br>extensions, software utility names, and GUI labels. For example, <b>\qdesigns</b><br>directory, <b>D:</b> drive, and <b>chiptrip.gdf</b> file. |
| Italic Type with Initial Capital Letters  | Indicate document titles. For example, Stratix IV Design Guidelines.                                                                                                                                                                |
|                                           | Indicates variables. For example, $n + 1$ .                                                                                                                                                                                         |
| italic type                               | Variable names are enclosed in angle brackets (< >). For example, <i><file name=""></file></i> and <i><project name="">.pof</project></i> file.                                                                                     |
| Initial Capital Letters                   | Indicate keyboard keys and menu names. For example, the Delete key and the Options menu.                                                                                                                                            |
| "Subheading Title"                        | Quotation marks indicate references to sections in a document and titles of Quartus II Help topics. For example, "Typographic Conventions."                                                                                         |

# 2. Logic Elements and Logic Array Blocks in Cyclone IV Devices

#### CYIV-51002-1.0

This chapter contains feature definitions for logic elements (LEs) and logic array blocks (LABs). Details are provided on how LEs work, how LABs contain groups of LEs, and how LABs interface with the other blocks in Cyclone<sup>®</sup> IV devices.

# **Logic Elements**

Logic elements (LEs) are the smallest units of logic in the Cyclone IV device architecture. LEs are compact and provide advanced features with efficient logic usage. Each LE has the following features:

- A four-input look-up table (LUT), which can implement any function of four variables
- A programmable register
- A carry chain connection
- A register chain connection
- The ability to drive the following interconnects:
  - Local
  - Row
  - Column
  - Register chain
  - Direct link
- Register packing support
- Register feedback support



Figure 3–3 and Figure 3–4 show the address clock enable waveform during read and write cycles, respectively.



Figure 3–3. Cyclone IV Devices Address Clock Enable During Read Cycle Waveform

Figure 3-4. Cyclone IV Devices Address Clock Enable During Write Cycle Waveform



# **Mixed-Width Support**

M9K memory blocks support mixed data widths. When using simple dual-port, true dual-port, or FIFO modes, mixed width support allows you to read and write different data widths to an M9K memory block. For more information about the different widths supported per memory mode, refer to "Memory Modes" on page 3–7.

Violating the setup or hold time on the M9K memory block input registers may corrupt memory contents. This applies to both read and write operations.

# **Single-Port Mode**

Single-port mode supports non-simultaneous read and write operations from a single address. Figure 3–6 shows the single-port memory configuration for Cyclone IV devices M9K memory blocks.

### Figure 3–6. Single-Port Memory <sup>(1)</sup>, <sup>(2)</sup>



#### Notes to Figure 3-6:

- (1) You can implement two single-port memory blocks in a single M9K block.
- (2) For more information, refer to "Packed Mode Support" on page 3-4.

During a write operation, the behavior of the RAM outputs is configurable. If you activate rden during a write operation, the RAM outputs show either the new data being written or the old data at that address. If you perform a write operation with rden deactivated, the RAM outputs retain the values they held during the most recent active rden signal.

To choose the desired behavior, set the **Read-During-Write** option to either **New Data** or **Old Data** in the RAM MegaWizard Plug-In Manager in the Quartus II software. For more information about read-during-write mode, refer to "Read-During-Write Operations" on page 3–15.

The port width configurations for M9K blocks in single-port mode are as follow:

- 8192 × 1
- 4096 × 2
- 2048 × 4
- 1024 × 8
- 1024 × 9
- 512 × 16
- 512 × 18
- 256 × 32
- 256 × 36

| GCLK Network Clock | GCLK Networks |   |   |   |   |              |              |                                                                                                                                                    |              |              |              |              |              |              |              |    |              |              |    |              |
|--------------------|---------------|---|---|---|---|--------------|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|----|--------------|--------------|----|--------------|
| Sources            | 0             | 1 | 2 | 3 | 4 | 5            | 6            | 7                                                                                                                                                  | 8            | 9            | 10           | 11           | 12           | 13           | 14           | 15 | 16           | 17           | 18 | 19           |
| PLL_3_C1           | —             | — | — | — | — | _            | $\checkmark$ | —                                                                                                                                                  | —            | $\checkmark$ | —            | —            | —            |              | _            | —  | $\checkmark$ | _            | —  | $\checkmark$ |
| PLL_3_C2           | —             | — |   | — | - | ~            |              | $\checkmark$                                                                                                                                       | —            | —            |              | -            |              |              |              | ~  | —            | ~            | —  | —            |
| PLL_3_C3           | —             |   |   |   | _ |              | ~            |                                                                                                                                                    | ~            |              |              | _            |              |              |              |    | >            |              | >  | —            |
| PLL_3_C4           | —             |   |   |   | _ |              |              | >                                                                                                                                                  |              | >            |              | _            |              |              |              |    |              | $\checkmark$ |    | $\checkmark$ |
| PLL_4_C0 (3)       | —             |   |   |   | _ | $\checkmark$ |              |                                                                                                                                                    | >            |              | $\checkmark$ | _            | _            | $\checkmark$ |              |    |              |              |    | —            |
| PLL_4_C1 (3)       | —             |   | _ |   | _ | _            | $\checkmark$ |                                                                                                                                                    |              | >            | _            | $\checkmark$ |              |              | $\checkmark$ |    |              | _            |    | —            |
| PLL_4_C2 (3)       | —             |   |   |   | _ | $\checkmark$ |              | >                                                                                                                                                  |              |              | $\checkmark$ | _            | $\checkmark$ |              |              |    |              |              |    | —            |
| PLL_4_C3 (3)       | —             |   | _ |   | — | _            | $\checkmark$ |                                                                                                                                                    | >            |              |              | <b>~</b>     |              | $\checkmark$ | _            |    |              | _            |    | —            |
| PLL_4_C4 (3)       | —             |   | _ |   | _ | _            | _            | $\mathbf{\mathbf{\mathbf{\mathbf{\mathbf{\mathbf{\mathbf{\mathbf{\mathbf{\mathbf{\mathbf{\mathbf{\mathbf{\mathbf{\mathbf{\mathbf{\mathbf{\mathbf{$ |              | >            | _            | _            | $\checkmark$ |              | $\checkmark$ |    |              | _            |    | —            |
| DPCLK2             | —             |   |   |   | _ |              |              |                                                                                                                                                    |              |              |              | _            |              |              |              |    | >            |              |    | —            |
| DPCLK3 (4)         | —             |   |   |   | _ |              |              |                                                                                                                                                    |              |              |              | _            |              |              |              |    |              |              | >  | —            |
| DPCLK4 (4)         | —             |   |   |   | - |              |              |                                                                                                                                                    |              |              |              | -            |              |              |              |    |              | <b>&gt;</b>  |    | —            |
| DPCLK5             | -             |   | _ |   | - | _            | _            |                                                                                                                                                    |              |              | —            | -            | _            | _            | _            |    |              | _            |    | $\checkmark$ |
| DPCLK6 (4)         | —             | _ |   | — |   |              |              | —                                                                                                                                                  | $\checkmark$ | _            |              |              |              |              |              |    | _            |              | —  | —            |
| DPCLK7             | —             | _ |   | _ | — | _            | $\checkmark$ | _                                                                                                                                                  | _            | _            | _            | —            |              | _            | _            | —  | _            | _            | _  | —            |
| DPCLK8             | —             | _ |   | _ | — | _            | _            | _                                                                                                                                                  | _            | $\checkmark$ | _            | —            |              | _            | _            | —  | _            | _            | _  | —            |
| DPCLK9 (4)         | —             | — |   | _ | — | —            | —            | $\checkmark$                                                                                                                                       | —            | —            | —            | —            |              | —            | —            | —  | —            | —            | _  | —            |
| DPCLK10            | —             | — |   | _ | — | —            | —            |                                                                                                                                                    | —            |              | —            | —            |              | —            | $\checkmark$ | —  | —            | —            | _  | —            |
| DPCLK11 (4)        | —             | — | — | — | — | —            | —            | —                                                                                                                                                  | —            | —            | —            | —            | $\checkmark$ | —            | —            | —  | —            | —            | —  | —            |
| DPCLK12 (4)        | —             | — |   | — | — |              |              |                                                                                                                                                    | —            |              | —            | —            |              | $\checkmark$ |              | —  | —            |              | —  | —            |
| DPCLK13            | —             |   |   | — | — |              | —            |                                                                                                                                                    |              |              |              | $\checkmark$ |              |              | —            |    |              | —            |    | —            |

# Table 5–1. GCLK Network Connections for EP4CGX15, EP4CGX22, and EP4CGX30<sup>(1), (2)</sup> (Part 2 of 2)

### Notes to Table 5-1:

(1) EP4CGX30 information in this table refers to all EP4CGX30 packages except F484 package.

(2)  $PLL_1$  and  $PLL_2$  are multipurpose PLLs while  $PLL_3$  and  $PLL_4$  are general purpose PLLs.

(3) PLL\_4 is only available in EP4CGX22 and EP4CGX30 devices in F324 package.

(4) This pin applies to EP4CGX22 and EP4CGX30 devices.

# Table 5–2. GCLK Network Connections for EP4CGX30, EP4CGX50, EP4CGX75, EP4CGX110, and EP4CGX150 Devices <sup>(1), (2)</sup> (Part 4 of 4)

| GCLK Network Clock | GCLK Networks |   |   |   |   |   |   |   |   |   |    |    |    |    |    |    |    |    |    |              |    |    |    |    |    |    |    |    |    |    |
|--------------------|---------------|---|---|---|---|---|---|---|---|---|----|----|----|----|----|----|----|----|----|--------------|----|----|----|----|----|----|----|----|----|----|
| Sources            | 0             | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19           | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 |
| DPCLK17            |               |   |   |   | — | — | _ | — | — | — | —  | —  | _  | —  | —  | —  | —  | —  | -  | $\checkmark$ | —  | —  | _  |    | _  | —  | —  | —  | —  | —  |

#### Notes to Table 5-2:

(1) EP4CGX30 information in this table refers to only EP4CGX30 device in F484 package.

(2) PLL\_1, PLL\_2, PLL\_3, and PLL\_4 are general purpose PLLs while PLL\_5, PLL\_6, PLL\_7, and PLL\_8 are multipurpose PLLs.

(3) PLL\_7 and PLL\_8 are not available in EP4CXGX30, EP4CGX50, EP4CGX75, EP4CGX110, and EP4CGX150 devices in F484 package.

| GCLK Network Clock      | GCLK Networks |              |              |              |              |              |              |              |              |              |              |              |              |    |              |    |              |    |    |              |
|-------------------------|---------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|----|--------------|----|--------------|----|----|--------------|
| Sources                 | 0             | 1            | 2            | 3            | 4            | 5            | 6            | 7            | 8            | 9            | 10           | 11           | 12           | 13 | 14           | 15 | 16           | 17 | 18 | 19           |
| CLK1                    | —             | $\checkmark$ | $\checkmark$ | —            | —            | —            | —            | —            | —            | —            | —            | —            | —            | —  | —            | —  | —            | —  | —  | —            |
| CLK2/DIFFCLK_1p         |               | $\checkmark$ |              | $\checkmark$ | $\checkmark$ |              |              |              |              | _            |              |              |              |    |              |    |              | _  | -  | —            |
| CLK3/DIFFCLK_1n         | $\checkmark$  |              |              | $\checkmark$ |              |              |              |              |              | _            |              |              |              |    |              |    |              | _  | _  | _            |
| CLK4/DIFFCLK_2p         | -             | _            | -            | -            | -            | $\checkmark$ | -            | >            | -            | <            |              |              |              |    |              |    |              |    |    | _            |
| CLK5/DIFFCLK_2n         |               |              |              |              |              |              | $\checkmark$ | $\checkmark$ |              |              | —            | —            | —            | —  | —            |    | —            |    |    | —            |
| CLK6/DIFFCLK_3p         |               |              |              |              |              |              | ~            |              | $\checkmark$ | $\checkmark$ |              |              |              |    |              |    |              | _  | _  | _            |
| CLK7/DIFFCLK_3n         | -             | _            | -            | -            | -            | $\checkmark$ | -            |              | $\checkmark$ | Ι            |              |              |              |    |              |    |              |    |    | _            |
| CLK8/DIFFCLK_5n (2)     |               |              |              |              |              |              |              | —            |              |              | $\checkmark$ | _            | $\checkmark$ | _  | $\checkmark$ |    | _            | Ι  | Ι  | —            |
| CLK9/DIFFCLK_5p (2)     |               |              |              |              |              |              |              | —            |              |              | —            | $\checkmark$ | $\checkmark$ | —  | —            |    | —            |    |    | —            |
| CLK10/DIFFCLK_4n (2)    | _             | _            | _            | _            | —            | _            | —            | _            | _            | _            |              | ~            | _            | ~  | ~            | _  |              | _  | _  |              |
| CLK11/DIFFCLK_4p<br>(2) | _             | _            | _            | _            | _            | _            | _            | _            | _            | _            | ~            | _            | _            | ~  | _            | _  | _            | _  | _  |              |
| CLK12/DIFFCLK_7n<br>(2) | _             |              | _            | _            | _            | _            | _            |              | _            | _            | _            |              |              | _  |              | ~  | _            | ~  | _  | ~            |
| CLK13/DIFFCLK_7p<br>(2) |               |              |              |              | _            | _            | _            | _            |              | _            | _            | _            | _            | _  | _            | _  | $\checkmark$ | ~  | _  |              |
| CLK14/DIFFCLK_6n<br>(2) |               | _            | —            |              | —            |              | —            | _            | —            | _            |              | _            | _            |    |              |    | ~            | _  | ~  | $\checkmark$ |

# Table 5-3. GCLK Network Connections for Cyclone IV E Devices (1) (Part 1 of 3)

In this mode, the activeclock signal mirrors the clkswitch signal. As both blocks are still functional during the manual switch, neither clkbad signals go high. Because the switchover circuit is positive edge-sensitive, the falling edge of the clkswitch signal does not cause the circuit to switch back from inclk1 to inclk0. When the clkswitch signal goes high again, the process repeats. The clkswitch signal and the automatic switch only works depending on the availability of the clock that is switched to. If the clock is unavailable, the state machine waits until the clock is available.



When CLKSWITCH = 1, it overrides the automatic switch-over function. As long as clkswitch signal is high, further switch-over action is blocked.

|               | • |
|---------------|---|
| inclk0        |   |
| inclk1 _      |   |
| muxout        |   |
| clkswitch _   |   |
| activeclock _ |   |
| clkbad0 —     |   |
| clkbad1 —     |   |

# Figure 5–19. Clock Switchover Using the clkswitch Control (1)

### Note to Figure 5–19:

(1) Both inclk0 and inclk1 must be running when the clkswitch signal goes high to start a manual clock switchover event.

# **Manual Clock Switchover**

PLLs of Cyclone IV devices support manual switchover, in which the clkswitch signal controls whether inclk0 or inclk1 is the input clock to the PLL. The characteristics of a manual switchover are similar to the manual override feature in an automatic clock switchover, in which the switchover circuit is edge-sensitive. When the clkswitch signal goes high, the switchover sequence starts. The falling edge of the clkswitch signal does not cause the circuit to switch back to the previous input clock.

• For more information about PLL software support in the Quartus II software, refer to the *ALTPLL Megafunction User Guide*.

# Guidelines

Use the following guidelines to design with clock switchover in PLLs:

 Clock loss detection and automatic clock switchover require the inclk0 and inclk1 frequencies be within 20% of each other. Failing to meet this requirement causes the clkbad0 and clkbad1 signals to function improperly.

| Signal Name | Description                                                                                                                                                                                                                                | Source                      | Destination                       |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------|-----------------------------------|
| scanclk     | Free running clock from core used in<br>combination with phasestep to enable or<br>disable dynamic phase shifting. Shared with<br>scanclk for dynamic reconfiguration.                                                                     | GCLK or I/O pins            | PLL<br>reconfiguration<br>circuit |
| phasedone   | When asserted, it indicates to core logic that<br>the phase adjustment is complete and PLL is<br>ready to act on a possible second adjustment<br>pulse. Asserts based on internal PLL timing.<br>De-asserts on the rising edge of scanclk. | PLL reconfiguration circuit | Logic array or<br>I/O pins        |

| Table 5-12. | <b>Dvnamic</b> | Phase | Shiftina | Control | Signals | (Part 2 of 2 | 1 |
|-------------|----------------|-------|----------|---------|---------|--------------|---|
|             |                |       |          |         |         | 1            |   |

Table 5–13 lists the PLL counter selection based on the corresponding PHASECOUNTERSELECT setting.

Table 5–13. Phase Counter Select Mapping

|     | phasecounterselec | t   | Salaata             |
|-----|-------------------|-----|---------------------|
| [2] | [1]               | [0] | Selects             |
| 0   | 0                 | 0   | All Output Counters |
| 0   | 0                 | 1   | M Counter           |
| 0   | 1                 | 0   | C0 Counter          |
| 0   | 1                 | 1   | C1 Counter          |
| 1   | 0                 | 0   | C2 Counter          |
| 1   | 0                 | 1   | C3 Counter          |
| 1   | 1                 | 0   | C4 Counter          |

To perform one dynamic phase-shift, follow these steps:

- 1. Set PHASEUPDOWN and PHASECOUNTERSELECT as required.
- 2. Assert PHASESTEP for at least two SCANCLK cycles. Each PHASESTEP pulse allows one phase shift.
- 3. Deassert PHASESTEP after PHASEDONE goes low.
- 4. Wait for PHASEDONE to go high.
- 5. Repeat steps 1 through 4 as many times as required to perform multiple phaseshifts.

<code>PHASEUPDOWN</code> and <code>PHASECOUNTERSELECT</code> signals are synchronous to <code>SCANCLK</code> and must meet the  $t_{su}$  and  $t_h$  requirements with respect to the <code>SCANCLK</code> edges.

You can repeat dynamic phase-shifting indefinitely. For example, in a design where the VCO frequency is set to 1,000 MHz and the output clock frequency is set to 100 MHz, performing 40 dynamic phase shifts (each one yields 125 ps phase shift) results in shifting the output clock by 180°, in other words, a phase shift of 5 ns.

| Differential I/O Standards          | I/O Bank Location | External Resistor<br>Network at<br>Transmitter | Transmitter (TX) | Receiver (RX) |
|-------------------------------------|-------------------|------------------------------------------------|------------------|---------------|
|                                     | 5,6               | Not Required                                   |                  |               |
|                                     | 3,4,5,6,7,8       | Three Resistors                                | <b>`</b>         | v             |
|                                     | 5,6               | Not Required                                   |                  |               |
| RSDS                                | 3,4,7,8           | Three Resistors                                | ✓                | —             |
|                                     | 3,4,5,6,7,8       | Single Resistor                                |                  |               |
|                                     | 5,6               | Not Required                                   |                  |               |
| mini-LVDS                           | 3,4,5,6,7,8       | Three Resistors                                | <b>`</b>         | —             |
| סחמס                                | 5,6               | Not Required                                   |                  |               |
| FFD3                                | 3,4,5,6,7,8       | Three Resistors                                | <b>`</b>         | —             |
| BLVDS (1)                           | 3,4,5,6,7,8       | Single Resistor                                | $\checkmark$     | $\checkmark$  |
| LVPECL (2)                          | 3,4,5,6,7,8       | —                                              | —                | $\checkmark$  |
| Differential SSTL-2 <sup>(3)</sup>  | 3,4,5,6,7,8       | —                                              | $\checkmark$     | $\checkmark$  |
| Differential SSTL-18 (3)            | 3,4,5,6,7,8       | —                                              | $\checkmark$     | $\checkmark$  |
| Differential HSTL-18 (3)            | 3,4,5,6,7,8       | —                                              | $\checkmark$     | $\checkmark$  |
| Differential HSTL-15 (3)            | 3,4,5,6,7,8       | —                                              | $\checkmark$     | $\checkmark$  |
| Differential HSTL-12 <sup>(3)</sup> | 4,5,6,7,8         | —                                              | ~                | $\checkmark$  |

Table 6–7. Differential I/O Standards Supported in Cyclone IV GX I/O Banks

### Notes to Table 6-7:

(1) Transmitter and Receiver  $f_{MAX}$  depend on system topology and performance requirement.

(2) The LVPECL I/O standard is only supported on dedicated clock input pins.

(3) The differential SSTL-2, SSTL-18, HSTL-18, HSTL-15, and HSTL-12 I/O standards are only supported on clock input pins and PLL output clock pins. PLL output clock pins do not support Class II interface type of differential SSTL-18, HSTL-18, HSTL-15, and HSTL-12 I/O standards.

You can use I/O pins and internal logic to implement a high-speed differential interface in Cyclone IV devices. Cyclone IV devices do not contain dedicated serialization or deserialization circuitry. Therefore, shift registers, internal phase-locked loops (PLLs), and I/O cells are used to perform serial-to-parallel conversions on incoming data and parallel-to-serial conversion on outgoing data. The differential interface data serializers and deserializers (SERDES) are automatically constructed in the core logic elements (LEs) with the Quartus II software ALTLVDS megafunction.

Figure 6–16. RSDS, Mini-LVDS, or PPDS Interface with External Resistor Network on the Top and Bottom I/O Banks (1)

Note to Figure 6–16:

(1)  $R_S$  and  $R_P$  values are pending characterization.

A resistor network is required to attenuate the output voltage swing to meet RSDS, mini-LVDS, and PPDS specifications when using emulated transmitters. You can modify the resistor network values to reduce power or improve the noise margin.

The resistor values chosen must satisfy Equation 6–1.

#### Equation 6–1. Resistor Network

$$\frac{R_{\rm S} \times \frac{R_{\rm P}}{2}}{R_{\rm S} + \frac{R_{\rm P}}{2}} = 50 \ \Omega$$

[7]

Altera recommends that you perform simulations using Cyclone IV devices IBIS models to validate that custom resistor values meet the RSDS, mini-LVDS, or PPDS requirements.

It is possible to use a single external resistor instead of using three resistors in the resistor network for an RSDS interface, as shown in Figure 6–17. The external single-resistor solution reduces the external resistor count while still achieving the required signaling level for RSDS. However, the performance of the single-resistor solution is lower than the performance with the three-resistor network.

Figure 6–17 shows the RSDS interface with a single resistor network on the top and bottom I/O banks.





(1)  $R_P$  value is pending characterization.

Use the ACTIVE\_DISENGAGE instruction with the CONFIG\_IO instruction to interrupt configuration. Table 8–16 lists the sequence of instructions to use for various CONFIG\_IO usage scenarios.

|                                                         | Configuration Scheme and Current State of the Cyclone IV Device |                          |                      |             |    |      |       |       |          |     |    |    |  |  |
|---------------------------------------------------------|-----------------------------------------------------------------|--------------------------|----------------------|-------------|----|------|-------|-------|----------|-----|----|----|--|--|
| JTAG Instruction                                        | l<br>(Inte                                                      | Prior to U<br>rrupting ( | ser Mod<br>Configura | e<br>ation) |    | User | Mode  |       | Power Up |     |    |    |  |  |
|                                                         | PS                                                              | FPP                      | AS                   | AP          | PS | FPP  | AS    | AP    | PS       | FPP | AS | AP |  |  |
| ACTIVE_DISENGAGE                                        | 0                                                               | 0                        | 0                    | 0           | 0  | 0    | 0     | 0     |          | —   | —  | —  |  |  |
| CONFIG_IO                                               | R                                                               | R                        | R                    | R           | R  | R    | R     | R     | NA       | NA  | NA | NA |  |  |
| JTAG Boundary Scan<br>Instructions (no<br>JTAG_PROGRAM) | 0                                                               | 0                        | 0                    | 0           | 0  | 0    | 0     | 0     | _        | _   | _  | _  |  |  |
| ACTIVE_ENGAGE                                           |                                                                 |                          | R (2)                | R (2)       |    |      | R (2) | R (2) |          |     |    |    |  |  |
| PULSE_NCONFIG                                           | Α                                                               | А                        | A <sup>(3)</sup>     | A (3)       | А  | Α    | 0     | 0     | _        |     |    |    |  |  |
| Pulse nCONFIG pin                                       |                                                                 |                          | A (3)                | A (3)       |    |      | 0     | 0     | _        |     |    |    |  |  |
| JTAG TAP Reset                                          | R                                                               | R                        | R                    | R           | R  | R    | R     | R     | _        |     | _  |    |  |  |

Table 8–16. JTAG CONFIG\_IO (without JTAG\_PROGRAM) Instruction Flows (1)

Notes to Table 8-16:

(1) You must execute "R" indicates that the instruction before the next instruction, "O" indicates the optional instruction, "A" indicates that the instruction must be executed, and "NA" indicates that the instruction is not allowed in this mode.

(2) Required if you use ACTIVE\_DISENGAGE.

(3) Neither of the instruction is required if you use ACTIVE ENGAGE.

The CONFIG\_IO instruction does not hold nSTATUS low until reconfiguration. You must disengage the AS or AP configuration controller by issuing the ACTIVE\_DISENGAGE and ACTIVE\_ENGAGE instructions when active configuration is interrupted. You must issue the ACTIVE\_DISENGAGE instruction alone or prior to the CONFIG\_IO instruction if the JTAG\_PROGRAM instruction is to be issued later (Table 8–17). This puts the active configuration controllers into the idle state. The active configuration controller is reengaged after user mode is reached through JTAG programming (Table 8–17).

While executing the CONFIG IO instruction, all user I/Os are tri-stated.

If reconfiguration after interruption is performed using configuration modes (rather than using JTAG\_PROGRAM), it is not necessary to issue the ACTIVE\_DISENGAGE instruction prior to CONFIG\_IO. You can start reconfiguration by either pulling nCONFIG low for at least 500 ns or issuing the PULSE\_NCONFIG instruction. If the ACTIVE\_DISENGAGE instruction was issued and the JTAG\_PROGRAM instruction fails to enter user mode, you must issue the ACTIVE\_ENGAGE instruction to reactivate the active configuration controller. Issuing the ACTIVE\_ENGAGE instruction also triggers reconfiguration in configuration modes; therefore, it is not necessary to pull nCONFIG low or issue the PULSE\_NCONFIG instruction.



Figure 1–26. PLL Input Reference Clocks in Transceiver Operation for F484 and Larger Packages  $^{(1)}$ ,  $^{(2)}$ ,  $^{(3)}$ 

### Notes to Figure 1-26:

- (1) The REFCLK2 and REFCLK3 pins are dual-purpose CLKIO, REFCLK, or DIFFCLK pins that reside in banks 3A and 8A respectively.
- (2) The REFCLK[1..0] and REFCLK[5..4] pins are dual-purpose differential REFCLK or DIFFCLK pins that reside in banks 3B and 8B respectively. These clock input pins do not have access to the clock control blocks and GCLK networks. For more details, refer to the *Clock Networks and PLLs in Cyclone IV Devices* chapter.
- (3) Using any clock input pins other than the designated REFCLK pins as shown here to drive the MPLLs and GPLLs may have reduced jitter performance.

The input reference clocks reside in banks 3A, 3B, 8A, and 8B have dedicated  $V_{CC\_CLKIN3A}$ ,  $V_{CC\_CLKIN3B}$ ,  $V_{CC\_CLKIN8A}$ , and  $V_{CC\_CLKIN8B}$  power supplies separately in their respective I/O banks to avoid the different power level requirements in the same bank for general purpose I/Os (GPIOs). Table 1–6 lists the supported I/O standard for the REFCLK pins.

| I/O Standard                | ЦССІ     |                     | Torminatio | VCC_  | CLKIN Level   | I/O Pin Type         |    |                    |  |  |
|-----------------------------|----------|---------------------|------------|-------|---------------|----------------------|----|--------------------|--|--|
|                             | Protocol | Coupling            | n          | Input | Output        | Column I/O Row I/O S |    | Supported<br>Banks |  |  |
| LVDS                        | ALL      | Differential        | Off-chip   | 2.5 V | Not Supported | Yes No               |    | 3A, 3B, 8A, 8B     |  |  |
| LVPECL                      | ALL      | AC (Needs           | Off-chip   | 2.5 V | Not Supported | Yes                  | No | 3A, 3B, 8A, 8B     |  |  |
| 1.2 V, 1.5 V,<br>3.3 V PCML | ALL      | resistor to restore | Off-chip   | 2.5 V | Not Supported | Yes                  | No | 3A, 3B, 8A, 8B     |  |  |
|                             | ALL      |                     | Off-chip   | 2.5 V | Not Supported | Yes                  | No | 3A, 3B, 8A, 8B     |  |  |
|                             | ALL      | V <sub>CM</sub> )   | Off-chip   | 2.5 V | Not Supported | Yes                  | No | 3A, 3B, 8A, 8B     |  |  |
| HCSL                        | PCle     | Differential<br>DC  | Off-chip   | 2.5 V | Not Supported | Yes                  | No | 3A, 3B, 8A, 8B     |  |  |

Table 1–6. REFCLK I/O Standard Support

- transmitter in electrical idle
- receiver signal detect
- receiver spread spectrum clocking

## **Low-Latency PCS Operation**

When configured in low-latency PCS operation, the following blocks in the transceiver PCS are bypassed, resulting in a lower latency PCS datapath:

- 8B/10B encoder and decoder
- word aligner
- rate match FIFO
- byte ordering

Figure 1–47 shows the transceiver channel datapath in Basic mode with low-latency PCS operation.

Figure 1–47. Transceiver Channel Datapath in Basic Mode with Low-Latency PCS Operation



### **Transmitter in Electrical Idle**

The transmitter buffer supports electrical idle state, where when enabled, the differential output buffer driver is tri-stated. During electrical idle, the output buffer assumes the common mode output voltage levels. For details about the electrical idle features, refer to "PCI Express (PIPE) Mode" on page 1–52.

P

<sup>2</sup> The transmitter in electrical idle feature is required for compliance to the version 2.00 of PHY Interface for the PCI Express (PIPE) Architecture specification for PCIe protocol implementation.

## **Signal Detect at Receiver**

Signal detect at receiver is only supported when 8B/10B encoder/decoder block is enabled.

# **All Supported Functional Modes Except the PCIe Functional Mode**

This section describes reset sequences for transceiver channels in bonded and non-bonded configurations. Timing diagrams of some typical configurations are shown to facilitate proper reset sequence implementation. In these functional modes, you can set the receiver CDR either in automatic lock or manual lock mode.

In manual lock mode, the receiver CDR locks to the reference clock (lock-to-reference) or the incoming serial data (lock-to-data), depending on the logic levels on the rx\_locktorefclk and rx\_locktodata signals. With the receiver CDR in manual lock mode, you can either configure the transceiver channels in the Cyclone IV GX device in a non-bonded configuration or a bonded configuration. In a bonded configuration, for example in XAUI mode, four channels are bonded together.

Table 2–4 lists the lock-to-reference (LTR) and lock-to-data (LTD) controller lock modes for the rx\_locktorefclk and rx\_locktodata signals.

| rx_locktorefclk | rx_locktodata | LTR/LTD Controller Lock Mode |
|-----------------|---------------|------------------------------|
| 1               | 0             | Manual, LTR Mode             |
| —               | 1             | Manual, LTD Mode             |
| 0               | 0             | Automatic Lock Mode          |

Table 2–4. Lock-To-Reference and Lock-To-Data Modes

# **Bonded Channel Configuration**

In a bonded channel configuration, you can reset all the bonded channels simultaneously. Examples of bonded channel configurations are the XAUI, PCIe Gen1 ×2 and ×4, and Basic ×2 and ×4 functional modes. In Basic ×2 and ×4 functional mode, you can bond **Transmitter Only** channels together.

In XAUI mode, the receiver and transmitter channels are bonded. Each of the receiver channels in this mode has its own rx\_freqlocked output status signals. You must consider the timing of these signals in the reset sequence.

Table 2–5 lists the reset and power-down sequences for bonded configurations under the stated functional modes.

| Table 2–5. | Reset and | Power-Down | Sequences 1 | for Bonded | Channel | Configurations |
|------------|-----------|------------|-------------|------------|---------|----------------|
|------------|-----------|------------|-------------|------------|---------|----------------|

| Channel Set Up           | Receiver CDR Mode                               | Refer to                                                                              |  |  |  |  |  |
|--------------------------|-------------------------------------------------|---------------------------------------------------------------------------------------|--|--|--|--|--|
| Transmitter Only         | Basic ×2 and ×4                                 | "Transmitter Only Channel" on page 2–7                                                |  |  |  |  |  |
| Receiver and Transmitter | Automatic lock mode for XAUI<br>functional mode | "Receiver and Transmitter Channel—Receiver<br>CDR in Automatic Lock Mode" on page 2–8 |  |  |  |  |  |
| Receiver and Transmitter | Manual lock mode for XAUI functional mode       | "Receiver and Transmitter Channel—Receiver<br>CDR in Manual Lock Mode" on page 2–9    |  |  |  |  |  |

The **Offset cancellation for Receiver channels** option is automatically enabled in both the ALTGX and ALTGX\_RECONFIG MegaWizard Plug-In Managers for **Receiver and Transmitter** and **Receiver only** configurations. It is not available for **Transmitter only** configurations. For **Receiver and Transmitter** and **Receiver only** configurations, you must connect the necessary interface signals between the ALTGX\_RECONFIG and ALTGX (with receiver channels) instances.

Offset cancellation is automatically executed once every time the device is powered on. The control logic for offset cancellation is integrated into the dynamic reconfiguration controller. You must connect the ALTGX\_RECONFIG instance to the ALTGX instances (with receiver channels) in your design. You must connect the reconfig\_fromgxb, reconfig\_togxb, and necessary clock signals to both the ALTGX\_RECONFIG and ALTGX (with receiver channels) instances.

When the device powers up, the dynamic reconfiguration controller initiates offset cancellation on the receiver channel by disconnecting the receiver input pins from the receiver data path. Subsequently, the offset cancellation process goes through different states and culminates in the offset cancellation of the receiver buffer.

Offset cancellation process only occurs one time after power up and does not occur when subsequent reconfig\_reset is asserted. If you assert reconfig\_reset after the offset cancellation process is completed, the offset cancellation process will not run again.

If you assert reconfig\_reset upon power up; offset cancellation will not begin until reconfig\_reset is deasserted. If you assert reconfig\_reset after power up but before offset cancellation process is completed; offset cancellation will not complete and restart only when reconfig\_reset is deasserted.

Figure 3–2 shows the connection for offset cancellation mode.

# Figure 3–2. ALTGX and ALTGX\_RECONFIG Connection for the Offset Cancellation Process



## Note to Figure 3-2:

(1) This block is active during the offset cancellation process.

- The dynamic reconfiguration controller sends and receives data to the transceiver channel through the reconfig\_togxb and reconfig\_fromgxb signals.
- The gxb\_powerdown signal must not be asserted during the offset cancellation sequence.

# **Option 1: Share a Single Transmitter Core Clock Between Transmitters**

- Enable this option if you want tx\_clkout of the first channel (channel 0) of the transceiver block to provide the write clock to the Transmitter Phase Compensation FIFOs of the remaining channels in the transceiver block.
- This option is typically enabled when all the channels of a transceiver block have the same functional mode and data rate and are reconfigured to the identical functional mode and data rate.

Figure 3–11 shows the sharing of channel 0's tx\_clkout between all four regular channels of a transceiver block.





The .**mif** files carries the reconfiguration information that will be used to reconfigure the multipurpose PLL or general purpose PLL dynamically. The .**mif** contents is generated automatically when you select the **Enable PLL Reconfiguration** option in the **Reconfiguration Setting** in ALTGX instances. The .**mif** files will be generated based on the data rate and input reference clock setting in the ALTGX MegaWizard. You must use the external ROM and feed its content to the ALTPLL\_RECONFIG megafunction to reconfigure the multipurpose PLL setting.



Figure 3–16 shows the connection for PLL reconfiguration mode.





### Notes to Figure 3-16:

- (1)  $\langle n \rangle =$  (number of transceiver PLLs configured in the ALTGX MegaWizard) 1.
- (2) You must connect the pll\_reconfig\_done signal from the ALTGX to the pll\_scandone port from ALTPLL\_RECONFIG.

(3) You need two ALTPLL\_RECONFIG controllers if you have two separate ALTGX instances with transceiver PLL instantiated in each ALTGX instance.

**C** For more information about connecting the ALTPLL\_RECONFIG and ALTGX instances, refer to the *AN 609: Implementing Dynamic Reconfiguration in Cyclone IV GX Devices*.

Table 1–42 and Table 1–43 list the IOE programmable delay for Cyclone IV E 1.2 V core voltage devices.

|                                                                       |                                   | Numbor  |               | Max Offset |          |       |             |       |       |       |       |      |
|-----------------------------------------------------------------------|-----------------------------------|---------|---------------|------------|----------|-------|-------------|-------|-------|-------|-------|------|
| Parameter                                                             | Paths<br>Affected                 | of      | Min<br>Offset | Fa         | ast Corn | er    | Slow Corner |       |       |       |       | Unit |
|                                                                       |                                   | Setting |               | C6         | 17       | A7    | C6          | C7    | C8    | 17    | A7    |      |
| Input delay from pin to internal cells                                | Pad to I/O<br>dataout to<br>core  | 7       | 0             | 1.314      | 1.211    | 1.211 | 2.177       | 2.340 | 2.433 | 2.388 | 2.508 | ns   |
| Input delay from pin to input register                                | Pad to I/O<br>input register      | 8       | 0             | 1.307      | 1.203    | 1.203 | 2.19        | 2.387 | 2.540 | 2.430 | 2.545 | ns   |
| Delay from output<br>register to output pin                           | I/O output<br>register to<br>pad  | 2       | 0             | 0.437      | 0.402    | 0.402 | 0.747       | 0.820 | 0.880 | 0.834 | 0.873 | ns   |
| Input delay from<br>dual-purpose clock pin<br>to fan-out destinations | Pad to global<br>clock<br>network | 12      | 0             | 0.693      | 0.665    | 0.665 | 1.200       | 1.379 | 1.532 | 1.393 | 1.441 | ns   |

Notes to Table 1-42:

(1) The incremental values for the settings are generally linear. For the exact values for each setting, use the latest version of the Quartus II software.

(2) The minimum and maximum offset timing numbers are in reference to setting **0** as available in the Quartus II software.

|                                                                       |                                   | Numbor  |               | Max Offset |          |       |             |       |       |       |       |      |
|-----------------------------------------------------------------------|-----------------------------------|---------|---------------|------------|----------|-------|-------------|-------|-------|-------|-------|------|
| Parameter                                                             | Paths<br>Affected                 | of      | Min<br>Offset | Fa         | ast Corn | er    | Slow Corner |       |       |       |       | Unit |
|                                                                       |                                   | Setting |               | C6         | 17       | A7    | C6          | C7    | C8    | 17    | A7    |      |
| Input delay from pin to internal cells                                | Pad to I/O<br>dataout to<br>core  | 7       | 0             | 1.314      | 1.209    | 1.209 | 2.201       | 2.386 | 2.510 | 2.429 | 2.548 | ns   |
| Input delay from pin to<br>input register                             | Pad to I/O<br>input register      | 8       | 0             | 1.312      | 1.207    | 1.207 | 2.202       | 2.402 | 2.558 | 2.447 | 2.557 | ns   |
| Delay from output<br>register to output pin                           | I/O output<br>register to<br>pad  | 2       | 0             | 0.458      | 0.419    | 0.419 | 0.783       | 0.861 | 0.924 | 0.875 | 0.915 | ns   |
| Input delay from<br>dual-purpose clock pin<br>to fan-out destinations | Pad to global<br>clock<br>network | 12      | 0             | 0.686      | 0.657    | 0.657 | 1.185       | 1.360 | 1.506 | 1.376 | 1.422 | ns   |

Table 1–43. IOE Programmable Delay on Row Pins for Cyclone IV E 1.2 V Core Voltage Devices (1), (2)

### Notes to Table 1-43:

(1) The incremental values for the settings are generally linear. For the exact values for each setting, use the latest version of the Quartus II software.

(2) The minimum and maximum offset timing numbers are in reference to setting **0** as available in the Quartus II software.