



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            | 3491                                                     |
| Number of Logic Elements/Cells | 55856                                                    |
| Total RAM Bits                 | 2396160                                                  |
| Number of I/O                  | 324                                                      |
| Number of Gates                | -                                                        |
| Voltage - Supply               | 1.15V ~ 1.25V                                            |
| Mounting Type                  | Surface Mount                                            |
| Operating Temperature          | 0°C ~ 85°C (TJ)                                          |
| Package / Case                 | 484-BGA                                                  |
| Supplier Device Package        | 484-FBGA (23x23)                                         |
| Purchase URL                   | https://www.e-xfl.com/product-detail/intel/ep4ce55f23c6n |
|                                |                                                          |

Email: info@E-XFL.COM

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

| Manual Clock Switchover                     | 5–30 |
|---------------------------------------------|------|
| Guidelines                                  | 5–30 |
| Programmable Bandwidth                      | 5–32 |
| Phase Shift Implementation                  | 5–32 |
| PLL Cascading                               | 5–33 |
| PLL Reconfiguration                         | 5–34 |
| PLL Reconfiguration Hardware Implementation | 5–34 |
| Post-Scale Counters (C0 to C4)              | 5–36 |
| Scan Chain Description                      | 5–37 |
| Charge Pump and Loop Filter                 | 5–38 |
| Bypassing a PLL Counter                     | 5–39 |
| Dynamic Phase Shifting                      | 5–39 |
| Spread-Spectrum Clocking                    | 5–41 |
| PLL Specifications                          | 5–41 |
| Document Revision History                   | 5–42 |

## Section II. I/O Interfaces

| LNAPTER 6. I/U FEATURES IN LYCIONE IN DEVI |
|--------------------------------------------|
|--------------------------------------------|

| Cyclone IV I/O Elements                                              | 6–2  |
|----------------------------------------------------------------------|------|
| I/O Element Features                                                 |      |
| Programmable Current Strength                                        | 6–3  |
| Slew Rate Control                                                    | 6–4  |
| Open-Drain Output                                                    |      |
| Bus Hold                                                             | 6–4  |
| Programmable Pull-Up Resistor                                        |      |
| Programmable Delay                                                   | 6–5  |
| PCI-Clamp Diode                                                      |      |
| OCT Support                                                          |      |
| On-Chip Series Termination with Calibration                          |      |
| On-Chip Series Termination Without Calibration                       |      |
| I/O Standards                                                        | 6–11 |
| Termination Scheme for I/O Standards                                 |      |
| Voltage-Referenced I/O Standard Termination                          | 6–14 |
| Differential I/O Standard Termination                                |      |
| I/O Banks                                                            |      |
| High-Speed Differential Interfaces                                   |      |
| External Memory Interfacing                                          |      |
| Pad Placement and DC Guidelines                                      |      |
| Pad Placement                                                        |      |
| DC Guidelines                                                        |      |
| Clock Pins Functionality                                             |      |
| High-Speed I/O Interface                                             |      |
| High-Speed I/O Standards Support                                     |      |
| High Speed Serial Interface (HSSI) Input Reference Clock Support     |      |
| LVDS I/O Standard Support in Cyclone IV Devices                      |      |
| Designing with LVDS                                                  |      |
| BLVDS I/O Standard Support in Cyclone IV Devices                     |      |
| Designing with BLVDS                                                 |      |
| RSDS, Mini-LVDS, and PPDS I/O Standard Support in Cyclone IV Devices |      |
| Designing with RSDS, Mini-LVDS, and PPDS                             |      |
| LVPECL I/O Support in Cyclone IV Devices                             |      |
| Differential SSTL I/O Standard Support in Cyclone IV Devices         |      |
|                                                                      |      |

- Cyclone IV GX devices offer up to eight high-speed transceivers that provide:
  - Data rates up to 3.125 Gbps
  - 8B/10B encoder/decoder
  - 8-bit or 10-bit physical media attachment (PMA) to physical coding sublayer (PCS) interface
  - Byte serializer / deserializer (SERDES)
  - Word aligner
  - Rate matching FIFO
  - TX bit slipper for Common Public Radio Interface (CPRI)
  - Electrical idle
  - Dynamic channel reconfiguration allowing you to change data rates and protocols on-the-fly
  - Static equalization and pre-emphasis for superior signal integrity
  - 150 mW per channel power consumption
  - Flexible clocking structure to support multiple protocols in a single transceiver block
- Cyclone IV GX devices offer dedicated hard IP for PCI Express (PIPE) (PCIe) Gen 1:
  - ×1, ×2, and ×4 lane configurations
  - End-point and root-port configurations
  - Up to 256-byte payload
  - One virtual channel
  - 2 KB retry buffer
  - 4 KB receiver (Rx) buffer
- Cyclone IV GX devices offer a wide range of protocol support:
  - PCIe (PIPE) Gen 1 ×1, ×2, and ×4 (2.5 Gbps)
  - Gigabit Ethernet (1.25 Gbps)
  - CPRI (up to 3.072 Gbps)
  - XAUI (3.125 Gbps)
  - Triple rate serial digital interface (SDI) (up to 2.97 Gbps)
  - Serial RapidIO (3.125 Gbps)
  - Basic mode (up to 3.125 Gbps)
  - V-by-One (up to 3.0 Gbps)
  - DisplayPort (2.7 Gbps)
  - Serial Advanced Technology Attachment (SATA) (up to 3.0 Gbps)
  - OBSAI (up to 3.072 Gbps)

In addition to the three general routing outputs, LEs in an LAB have register chain outputs, which allows registers in the same LAB to cascade together. The register chain output allows the LUTs to be used for combinational functions and the registers to be used for an unrelated shift register implementation. These resources speed up connections between LABs while saving local interconnect resources.

## **LE Operating Modes**

Cyclone IV LEs operate in the following modes:

- Normal mode
- Arithmetic mode

The Quartus<sup>®</sup> II software automatically chooses the appropriate mode for common functions, such as counters, adders, subtractors, and arithmetic functions, in conjunction with parameterized functions such as the library of parameterized modules (LPM) functions. You can also create special-purpose functions that specify which LE operating mode to use for optimal performance, if required.

### **Normal Mode**

Normal mode is suitable for general logic applications and combinational functions. In normal mode, four data inputs from the LAB local interconnect are inputs to a four-input LUT (Figure 2–2). The Quartus II Compiler automatically selects the carry-in (cin) or the data3 signal as one of the inputs to the LUT. LEs in normal mode support packed registers and register feedback.

Figure 2–2 shows LEs in normal mode.





2–3

## **Power-Up Conditions and Memory Initialization**

The M9K memory block outputs of Cyclone IV devices power up to zero (cleared) regardless of whether the output registers are used or bypassed. All M9K memory blocks support initialization using a **.mif**. You can create **.mif**s in the Quartus II software and specify their use using the RAM MegaWizard Plug-In Manager when instantiating memory in your design. Even if memory is pre-initialized (for example, using a **.mif**), it still powers up with its outputs cleared. Only the subsequent read after power up outputs the pre-initialized values.

**To** For more information about **.mif**s, refer to the *RAM Megafunction User Guide* and the *Quartus II Handbook*.

## **Power Management**

The M9K memory block clock enables of Cyclone IV devices allow you to control clocking of each M9K memory block to reduce AC power consumption. Use the rden signal to ensure that read operations only occur when necessary. If your design does not require read-during-write, reduce power consumption by deasserting the rden signal during write operations or any period when there are no memory operations. The Quartus II software automatically powers down any unused M9K memory blocks to save static power.

## **Document Revision History**

Table 3–6 shows the revision history for this chapter.

| Table 3-6. | Document | Revision | History |
|------------|----------|----------|---------|
|------------|----------|----------|---------|

| Date          | Version | Changes                                    |
|---------------|---------|--------------------------------------------|
| November 2011 | 1.1     | Updated the "Byte Enable Support" section. |
| November 2009 | 1.0     | Initial release.                           |

Table 4–1 lists the number of embedded multipliers and the multiplier modes that can be implemented in each Cyclone IV device.

| Device Family | Device    | Embedded<br>Multipliers | 9 × 9<br>Multipliers <i>(</i> 1) | 18 × 18<br>Multipliers <sup>(1)</sup> |
|---------------|-----------|-------------------------|----------------------------------|---------------------------------------|
|               | EP4CGX15  | 0                       | 0                                | 0                                     |
|               | EP4CGX22  | 40                      | 80                               | 40                                    |
|               | EP4CGX30  | 80                      | 160                              | 80                                    |
| Cyclone IV GX | EP4CGX50  | 140                     | 280                              | 140                                   |
|               | EP4CGX75  | 198                     | 396                              | 198                                   |
|               | EP4CGX110 | 280                     | 560                              | 280                                   |
|               | EP4CGX150 | 360                     | 720                              | 360                                   |
|               | EP4CE6    | 15                      | 30                               | 15                                    |
|               | EP4CE10   | 23                      | 46                               | 23                                    |
|               | EP4CE15   | 56                      | 112                              | 56                                    |
|               | EP4CE22   | 66                      | 132                              | 66                                    |
| Cyclone IV E  | EP4CE30   | 66                      | 132                              | 66                                    |
|               | EP4CE40   | 116                     | 232                              | 116                                   |
|               | EP4CE55   | 154                     | 308                              | 154                                   |
|               | EP4CE75   | 200                     | 400                              | 200                                   |
|               | EP4CE115  | 266                     | 532                              | 266                                   |

Table 4–1. Number of Embedded Multipliers in Cyclone IV Devices

Note to Table 4-1:

(1) These columns show the number of  $9 \times 9$  or  $18 \times 18$  multipliers for each device.

In addition to the embedded multipliers in Cyclone IV devices, you can implement soft multipliers by using the M9K memory blocks as look-up tables (LUTs). The LUTs contain partial results from the multiplication of input data with coefficients that implement variable depth and width high-performance soft multipliers for low-cost, high-volume DSP applications. The availability of soft multipliers increases the number of available multipliers in the device.

- **For more information about M9K memory blocks, refer to the** *Memory Blocks in Cyclone IV Devices* chapter.
- **\*** For more information about soft multipliers, refer to *AN 306: Implementing Multipliers in FPGA Devices*.

## Architecture

Each embedded multiplier consists of the following elements:

- Multiplier stage
- Input and output registers
- Input and output interfaces



#### Figure 5-4. Clock Networks and Clock Control Block Locations in Cyclone IV E Devices

#### Notes to Figure 5-4:

- (1) There are five clock control blocks on each side.
- (2) Only one of the corner CDPCLK pins in each corner can feed the clock control block at a time. You can use the other CDPCLK pins as general-purpose I/O (GPIO) pins.
- (3) Dedicated clock pins can feed into this PLL. However, these paths are not fully compensated.
- (4)  $PLL_3$  and  $PLL_4$  are not available in EP4CE6 and EP4CE10 devices.

The inputs to the clock control blocks on each side of the Cyclone IV GX device must be chosen from among the following clock sources:

- Four clock input pins
- Ten PLL counter outputs (five from each adjacent PLLs)
- Two, four, or six DPCLK pins from the top, bottom, and right sides of the device
- Five signals from internal logic

## **PLLs in Cyclone IV Devices**

Cyclone IV GX devices offer two variations of PLLs: general purpose PLLs and multipurpose PLLs. Cyclone IV E devices only have the general purpose PLLs.

The general purpose PLLs are used for general-purpose applications in the FPGA fabric and periphery such as external memory interfaces. The multipurpose PLLs are used for clocking the transceiver blocks. When the multipurpose PLLs are not used for transceiver clocking, they can be used for general-purpose clocking.



Cyclone IV GX devices contain up to eight general purpose PLLs and multipurpose PLLs while Cyclone IV E devices have up to four general purpose PLLs that provide robust clock management and synthesis for device clock management, external system clock management, and high-speed I/O interfaces.



• For more information about the number of general purpose PLLs and multipurpose PLLs in each device density, refer to the *Cyclone IV Device Family Overview* chapter.

The general I/O pins cannot drive the PLL clock input pins.

Table 5–5 lists the features available in Cyclone IV GX PLLs.

Table 5-5. Cyclone IV GX PLL Features (Part 1 of 2)

|                                            | Availability                                                                                      |                           |                          |                          |              |                   |                    |                           |              |              |
|--------------------------------------------|---------------------------------------------------------------------------------------------------|---------------------------|--------------------------|--------------------------|--------------|-------------------|--------------------|---------------------------|--------------|--------------|
| Features                                   | Ge                                                                                                | General Purpose PLLs      |                          |                          |              | Multipurpose PLLs |                    |                           |              |              |
|                                            | PLL_1<br>(1), (10)                                                                                | <b>PLL_2</b><br>(1), (10) | PLL_<br>3 <sup>(2)</sup> | PLL_<br>4 <sup>(3)</sup> | PLL_1<br>(4) | PLL_2<br>(4)      | PLL_5<br>(1), (10) | <b>PLL_6</b><br>(1), (10) | PLL_7        | PLL_8<br>(1) |
| C (output counters)                        |                                                                                                   |                           | -                        | -                        |              | 5                 | •                  | -                         | •            |              |
| M, N, C counter sizes                      |                                                                                                   |                           |                          |                          | 1 to 5       | 12 <i>(5)</i>     |                    |                           |              |              |
| Dedicated clock outputs                    |                                                                                                   |                           |                          | 1 single-                | ended or     | 1 differe         | ential pair        |                           |              |              |
| Clock input pins                           | 12 single-ended or 6 differential pairs <sup>(6)</sup><br>and 4 differential pairs <sup>(7)</sup> |                           |                          |                          |              |                   |                    |                           |              |              |
| Spread-spectrum input clock tracking       | ✓ (8)                                                                                             |                           |                          |                          |              |                   |                    |                           |              |              |
| PLL cascading                              |                                                                                                   |                           |                          |                          | Throug       | h GCLK            |                    |                           |              |              |
| Source-Synchronous Mode                    | $\checkmark$                                                                                      | $\checkmark$              | $\checkmark$             | $\checkmark$             | $\checkmark$ | $\checkmark$      | $\checkmark$       | _                         | _            | $\checkmark$ |
| No Compensation Mode                       | $\checkmark$                                                                                      | $\checkmark$              | $\checkmark$             | $\checkmark$             | $\checkmark$ | $\checkmark$      | $\checkmark$       | $\checkmark$              | $\checkmark$ | $\checkmark$ |
| Normal Mode                                | $\checkmark$                                                                                      | $\checkmark$              | $\checkmark$             | $\checkmark$             | $\checkmark$ | $\checkmark$      | $\checkmark$       | _                         | -            | $\checkmark$ |
| Zero Delay Buffer Mode                     | $\checkmark$                                                                                      | $\checkmark$              | $\checkmark$             | $\checkmark$             | $\checkmark$ | $\checkmark$      | $\checkmark$       | _                         | _            | $\checkmark$ |
| Deterministic Latency<br>Compensation Mode | ~                                                                                                 | ~                         | _                        | _                        | ~            | ~                 | ~                  | ~                         | ~            | ~            |
| Phase shift resolution <sup>(9)</sup>      | Down to 96 ps increments                                                                          |                           |                          |                          |              |                   |                    |                           |              |              |
| Programmable duty cycle                    | ✓                                                                                                 |                           |                          |                          |              |                   |                    |                           |              |              |
| Output counter cascading                   | ✓                                                                                                 |                           |                          |                          |              |                   |                    |                           |              |              |

### **Deterministic Latency Compensation Mode**

The deterministic latency mode compensates for the delay of the multipurpose PLLs through the clock network and serializer in Common Public Radio Interface (CPRI) applications. In this mode, the PLL PFD feedback path compensates the latency uncertainty in Tx dataout and Tx clkout paths relative to the reference clock.

## **Hardware Features**

Cyclone IV PLLs support several features for general-purpose clock management. This section discusses clock multiplication and division implementation, phase shifting implementations, and programmable duty cycles.

## **Clock Multiplication and Division**

Each Cyclone IV PLL provides clock synthesis for PLL output ports using  $M/(N^*post-scale \text{ counter})$  scaling factors. The input clock is divided by a pre-scale factor, N, and is then multiplied by the M feedback factor. The control loop drives the VCO to match  $f_{IN}$  (M/N). Each output port has a unique post-scale counter that divides down the high-frequency VCO. For multiple PLL outputs with different frequencies, the VCO value is the least common multiple of the output frequencies that meets its frequency specifications. For example, if output frequencies required from one PLL are 33 and 66 MHz, the Quartus II software sets the VCO to 660 MHz (the least common multiple of 33 and 66 MHz in the VCO range). Then, the post-scale counters scale down the VCO frequency for each output port.

There is one pre-scale counter, N, and one multiply counter, M, per PLL, with a range of 1 to 512 for both M and N. The N counter does not use duty cycle control because the purpose of this counter is only to calculate frequency division. There are five generic post-scale counters per PLL that can feed GCLKs or external clock outputs. These post-scale counters range from 1 to 512 with a 50% duty cycle setting. The post-scale counters range from 1 to 256 with any non-50% duty cycle setting. The sum of the high/low count values chosen for a design selects the divide value for a given counter.

The Quartus II software automatically chooses the appropriate scaling factors according to the input frequency, multiplication, and division values entered into the ALTPLL megafunction.

Phase alignment between output counters is determined using the t<sub>PLL\_PSERR</sub> specification.

## **PLL Reconfiguration**

PLLs use several divide counters and different VCO phase taps to perform frequency synthesis and phase shifts. In PLLs of Cyclone IV devices, you can reconfigure both counter settings and phase shift the PLL output clock in real time. You can also change the charge pump and loop filter components, which dynamically affects PLL bandwidth. You can use these PLL components to update the output clock frequency, PLL bandwidth, and phase shift in real time, without reconfiguring the entire FPGA.

The ability to reconfigure the PLL in real time is useful in applications that might operate at multiple frequencies. It is also useful in prototyping environments, allowing you to sweep PLL output frequencies and adjust the output clock phase dynamically. For instance, a system generating test patterns is required to generate and send patterns at 75 or 150 MHz, depending on the requirements of the device under test. Reconfiguring PLL components in real time allows you to switch between two such output frequencies in a few microseconds.

You can also use this feature to adjust clock-to-out ( $t_{CO}$ ) delays in real time by changing the PLL output clock phase shift. This approach eliminates the need to regenerate a configuration file with the new PLL settings.

## **PLL Reconfiguration Hardware Implementation**

The following PLL components are configurable in real time:

- Pre-scale counter (N)
- Feedback counter (M)
- Post-scale output counters (C0-C4)
- Dynamically adjust the charge pump current (I<sub>CP</sub>) and loop filter components (R, C) to facilitate on-the-fly reconfiguration of the PLL bandwidth

Table 6–2 on page 6–7 shows the possible settings for I/O standards with current strength control. These programmable current strength settings are a valuable tool in helping decrease the effects of simultaneously switching outputs (SSO) in conjunction with reducing system noise. The supported settings ensure that the device driver meets the specifications for IOH and IOL of the corresponding I/O standard.

 $\square$  When you use programmable current strength, on-chip series termination (R<sub>S</sub> OCT) is not available.

### **Slew Rate Control**

The output buffer for each Cyclone IV I/O pin provides optional programmable output slew-rate control. Table 6–2 on page 6–7 shows the possible slew rate option and the Quartus II default slew rate setting. However, these fast transitions may introduce noise transients in the system. A slower slew rate reduces system noise, but adds a nominal delay to rising and falling edges. Because each I/O pin has an individual slew-rate control, you can specify the slew rate on a pin-by-pin basis. The slew-rate control affects both the rising and falling edges. Slew rate control is available for single-ended I/O standards with current strength of 8 mA or higher.

- You cannot use the programmable slew rate feature when using OCT with calibration.
- You cannot use the programmable slew rate feature when using the 3.0-V PCI, 3.0-V PCI-X, 3.3-V LVTTL, or 3.3-V LVCMOS I/O standards. Only the fast slew rate (default) setting is available.

### **Open-Drain Output**

Cyclone IV devices provide an optional open-drain (equivalent to an open-collector) output for each I/O pin. This open-drain output enables the device to provide system-level control signals (for example, interrupt and write enable signals) that are asserted by multiple devices in your system.

### **Bus Hold**

Each Cyclone IV device user I/O pin provides an optional bus-hold feature. The bus-hold circuitry holds the signal on an I/O pin at its last-driven state. Because the bus-hold feature holds the last-driven state of the pin until the next input signal is present, an external pull-up or pull-down resistor is not necessary to hold a signal level when the bus is tri-stated.

The bus-hold circuitry also pulls undriven pins away from the input threshold voltage in which noise can cause unintended high-frequency switching. You can select this feature individually for each I/O pin. The bus-hold output drives no higher than  $V_{\rm CCIO}$  to prevent overdriving signals.

IF you enable the bus-hold feature, the device cannot use the programmable pull-up option. Disable the bus-hold feature when the I/O pin is configured for differential signals. Bus-hold circuitry is not available on dedicated clock pins.

Bus-hold circuitry is only active after configuration. When going into user mode, the bus-hold circuit captures the value on the pin present at the end of configuration.



#### Figure 6–11. Cyclone IV GX I/O Banks for EP4CGX50, EP4CGX75, EP4CGX110, and EP4CGX150 <sup>(1), (2), (9)</sup>

#### Notes to Figure 6–11:

- (1) This is a top view of the silicon die. For exact pin locations, refer to the pin list and the Quartus II software.
- (2) True differential (PPDS, LVDS, mini-LVDS, and RSDS I/O standards) outputs are supported in row I/O banks 5 and 6 only. External resistors are needed for the differential outputs in column I/O banks.
- (3) The LVPECL I/O standard is only supported on clock input pins. This I/O standard is not supported on output pins.
- (4) The HSTL-12 Class II is supported in column I/O banks 4, 7, and 8.
- (5) The differential SSTL-18 and SSTL-2, differential HSTL-18, and HSTL-15 I/O standards are supported only on clock input pins and phase-locked loops (PLLs) 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.
- (6) The differential HSTL-12 I/O standard is only supported on clock input pins and PLL output clock pins. Differential HSTL-12 Class II is supported only in column I/O banks 4, 7, and 8.
- (7) BLVDS output uses two single-ended outputs with the second output programmed as inverted. BLVDS input uses the LVDS input buffer.
- (8) The PCI-X I/O standard does not meet the IV curve requirement at the linear region.
- (9) The OCT block is located in the shaded banks 4, 5, and 7.
- (10) The dedicated clock input I/O banks 3A, 3B, 8A, and 8B can be used either for HSSI input reference clock pins or clock input pins.
- (11) Single-ended clock input support is available for dedicated clock input I/O banks 3B and 8B.



# Figure 8–24. JTAG Configuration of a Single Device Using a Download Cable (1.5-V or 1.8-V $V_{\text{CCIO}}$ Powering the JTAG Pins)

#### Notes to Figure 8-24:

- (1) Connect these pull-up resistors to the  $V_{CCIO}$  supply of the bank in which the pin resides.
- (2) Connect the nCONFIG and MSEL pins to support a non-JTAG configuration scheme. If you only use JTAG configuration, connect the nCONFIG pin to logic-high and the MSEL pins to GND. In addition, pull DCLK and DATA[0] to either high or low, whichever is convenient on your board.
- (3) In the USB-Blaster and ByteBlaster II cables, this pin is connected to nCE when it is used for AS programming; otherwise it is a no connect.
- (4) The nCE must be connected to GND or driven low for successful JTAG configuration.
- (5) The nCEO pin is left unconnected or used as a user I/O pin when it does not feed the nCE pin of another device.
- (6) Power up the V<sub>CC</sub> of the EthernetBlaster, ByteBlaster II or USB-Blaster cable with supply from V<sub>CCI0</sub>. The Ethernet-Blaster, ByteBlaster II, and USB-Blaster cables do not support a target supply voltage of 1.2 V. For the target supply voltage value, refer to the *ByteBlaster II Download Cable User Guide*, the USB-Blaster Download Cable User Guide, and the EthernetBlaster Communications Cable User Guide.
- (7) Resistor value can vary from 1 k $\Omega$  to 10 k $\Omega$ .

To configure a single device in a JTAG chain, the programming software places all other devices in bypass mode. In bypass mode, devices pass programming data from the TDI pin to the TDO pin through a single bypass register without being affected internally. This scheme enables the programming software to program or verify the target device. Configuration data driven into the device appears on the TDO pin one clock cycle later.

The Quartus II software verifies successful JTAG configuration after completion. At the end of configuration, the software checks the state of CONF\_DONE through the JTAG port. When Quartus II generates a **.jam** for a multi-device chain, it contains instructions so that all the devices in the chain are initialized at the same time. If CONF\_DONE is not high, the Quartus II software indicates that configuration has failed. If CONF\_DONE is high, the software indicates that configuration was successful. After the configuration bitstream is serially sent using the JTAG TDI port, the TCK port clocks an additional clock cycles to perform device initialization.

| Pin Name         | User Mode                | Configuration<br>Scheme | Pin Type                    | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|------------------|--------------------------|-------------------------|-----------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| CONF_DONE        | N/A                      | All                     | Bidirectional<br>open-drain | <ul> <li>Status output—the target Cyclone IV device drives the CONF_DONE pin low before and during configuration. After all the configuration data is received without error and the initialization cycle starts, the target device releases CONF_DONE.</li> <li>Status input—after all the data is received and CONF_DONE goes high, the target device initializes and enters user mode. The CONF_DONE pin must have an</li> </ul>                                                    |
|                  |                          |                         |                             | external 10-kΩ pull-up resistor in order for the device to initialize.<br>Driving CONF_DONE low after configuration and initialization does not affect the configured device. Do not connect hus                                                                                                                                                                                                                                                                                       |
|                  |                          |                         |                             | holds or ADC to CONF_DONE pin.                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| nCE              | N/A                      | All                     | Input                       | Active-low chip enable. The nCE pin activates the Cyclone IV device with a low signal to allow configuration. You must hold nCE pin low during configuration, initialization, and user-mode. In a single-device configuration, you must tie the nCE pin low. In a multi-device configuration, nCE of the first device is tied low while its nCEO pin is connected to nCE of the next device in the chain. You must hold the nCE pin low for successful JTAG programming of the device. |
|                  | N/A if<br>option is on.  |                         | Output                      | Output that drives low when configuration is complete. In a single-device configuration, you can leave this pin floating or use it as a user I/O pin after configuration. In a multi-device configuration, this pin feeds the $nCE$ pin of the next device. The $nCEO$ of the last device in the chain is left floating or used as a user I/O pin after configuration.                                                                                                                 |
| nCEO             | I/O if option<br>is off. | All                     | open-drain                  | If you use the nCEO pin to feed the nCE pin of the next device, use an external 10-k $\Omega$ pull-up resistor to pull the nCEO pin high to the V <sub>CCIO</sub> voltage of its I/O bank to help the internal weak pull-up resistor.                                                                                                                                                                                                                                                  |
|                  |                          |                         |                             | If you use the nCEO pin as a user I/O pin after configuration, set the state of the pin on the <b>Dual-Purpose Pin</b> settings.                                                                                                                                                                                                                                                                                                                                                       |
| nCSO,            |                          |                         |                             | Output control signal from the Cyclone IV device to the serial configuration device in AS mode that enables the configuration device. This pin functions as nCSO in AS mode and FLASH_nCE in AP mode.                                                                                                                                                                                                                                                                                  |
| FLASH_nCE<br>(1) | I/O                      | AS, AP <i>(2)</i>       | Output                      | Output control signal from the Cyclone IV device to the parallel flash in AP mode that enables the flash. Connects to the $CE\#$ pin on the Micron P30 or P33 flash. <sup>(2)</sup>                                                                                                                                                                                                                                                                                                    |
|                  |                          |                         |                             | This pin has an internal pull-up resistor that is always active.                                                                                                                                                                                                                                                                                                                                                                                                                       |

| Table 8-20 | . Dedicated | Configuration | Pins on th | ne Cyclone | IV Device | (Part 2 of 4) |
|------------|-------------|---------------|------------|------------|-----------|---------------|
|------------|-------------|---------------|------------|------------|-----------|---------------|

In a DC-coupled link, the transmitter DC common mode voltage is seen unblocked at the receiver input buffer as shown in Figure 1–13. The link common mode voltage depends on the transmitter common mode voltage and the receiver common mode voltage. When using the receiver OCT and on-chip biasing circuitry in a DC coupled link, you must ensure the transmitter common mode voltage is compatible with the receiver common mode requirements. If you disable the OCT, you must terminate and bias the receiver externally and ensure compatibility between the transmitter and the receiver common mode voltage.





Figure 1–14 shows the receiver input buffer block diagram.





The receiver input buffers support the following features:

## **Word Aligner**

Figure 1–16 shows the word aligner block diagram. The word aligner receives parallel data from the deserializer and restores the word boundary based on a pre-defined alignment pattern that must be received during link synchronization. The word aligner supports three operational modes as listed in Table 1–3.





#### Table 1-3. Word Aligner Modes

| Modes                                      | PMA-PCS Interface Widths | Allowed Word Alignment<br>Pattern Lengths |
|--------------------------------------------|--------------------------|-------------------------------------------|
| Manual Alignment                           | 8-bit                    | 16 bits                                   |
| Manual Algument                            | 10-bit                   | 7 or 10 bits                              |
| Rit Clin                                   | 8-bit                    | 16 bits                                   |
| Bit-Silp                                   | 10-bit                   | 7 or 10 bits                              |
| Automatic Synchronization State<br>Machine | 10-bit                   | 7 or 10 bits                              |

#### **Manual Alignment Mode**

In manual alignment mode, the rx\_enapatternalign port controls the word aligner with either an 8- or 10-bit data width setting.

The 8-bit word aligner is edge-sensitive to the rx\_enapatternalign signal. A rising edge on rx\_enapatternalign signal after deassertion of the rx\_digitalreset signal triggers the word aligner to look for the word alignment pattern in the received data stream. It updates the word boundary if it finds the word alignment pattern in a new word boundary. Any word alignment pattern received thereafter in a different word boundary causes the word aligner to re-align to the new word boundary only if there is a rising edge in the rx enapatternalign signal.

The 10-bit word aligner is level-sensitive to the rx\_enapatternalign signal. The word aligner looks for the programmed 7-bit or 10-bit word alignment pattern or its complement in the received data stream, if the rx\_enapatternalign signal is held high. It updates the word boundary if it finds the word alignment pattern in a new word boundary. If the rx\_enapatternalign signal is deasserted, the word alignment pattern maintains the current word boundary even when it receives the word alignment pattern in a new word boundary.

The hard IP block supports 1, 2, or 4 initial lane configurations with a maximum payload of 256 bytes at Gen1 frequency. The application interface is 64 bits with a data width of 16 bits per channel running at up to 125 MHz. As a hard macro and a verified block, it uses very few FPGA resources, while significantly reducing design risk and the time required to achieve timing closure. It is compliant with the PCI Express Base Specification 1.1. You do not have to pay a licensing fee to use this module. Configuring the hard IP block requires using the PCI Express Compiler.



For more information about the hard IP block, refer to the *PCI Express Compiler User Guide*.

Figure 1–43 shows the lane placement requirements when implementing PCIe with hard IP block.



Figure 1–43. PCIe with Hard IP Block Lane Placement Requirements <sup>(1)</sup>

#### Note to Figure 1-43:

(1) Applicable for PCle ×1, ×2, and ×4 implementations with hard IP blocks only.

PCIe Lane 0

## **Transceiver Functional Modes**

The Cyclone IV GX transceiver supports the functional modes as listed in Table 1–14 for protocol implementation.

| Functional Mode       | Protocol                                      | Key Feature                                                                                                                                                                                                     | Reference                                 |
|-----------------------|-----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------|
| Basic                 | Proprietary, SATA, V-<br>by-One, Display Port | Low latency PCS, transmitter in electrical idle, signal detect at receiver, wider spread asynchronous SSC                                                                                                       | "Basic Mode" on<br>page 1–48              |
| PCI Express<br>(PIPE) | PCIe Gen1 with PIPE<br>Interface              | PIPE ports, receiver detect, transmitter in electrical<br>idle, electrical idle inference, signal detect at receiver,<br>fast recovery, protocol-compliant word aligner and<br>rate match FIFO, synchronous SSC | "PCI Express (PIPE)<br>Mode" on page 1–52 |
| GIGE                  | GbE                                           | Running disparity preservation, protocol-compliant<br>word aligner, recovered clock port for applications<br>such as Synchronous Ethernet                                                                       | "GIGE Mode" on<br>page 1–59               |
| Serial RapidIO        | SRIO                                          | Protocol-compliant word aligner                                                                                                                                                                                 | "Serial RapidIO Mode"<br>on page 1–64     |
| XAUI                  | XAUI                                          | Deskew FIFO, protocol-compliant word aligner and rate match FIFO                                                                                                                                                | "XAUI Mode" on<br>page 1–67               |

Table 1–14. Transceiver Functional Modes for Protocol Implementation (Part 1 of 2)

### **Receive Bit-Slip Indication**

The number of bits slipped in the word aligner for synchronization in manual alignment mode is provided with the rx\_bitslipboundaryselectout [4..0] signal. For example, if one bit is slipped in word aligner to achieve synchronization, the output on rx\_bitslipboundaryselectout [4..0] signal shows a value of 1 (5'00001). The information from this signal helps in latency calculation through the receiver as the number of bits slipped in the word aligner varies at each synchronization.

### **Transmit Bit-Slip Control**

The transmitter datapath supports bit-slip control to delay the serial data transmission by a number of specified bits in PCS with tx\_bitslipboundaryselect[4..0] port. With 8- or 10-bit channel width, the transmitter supports zero to nine bits of data slip. This feature helps to maintain a fixed round trip latency by compensating latency variation from word aligner when providing the appropriate values on tx\_bitslipboundaryselect[4..0] port based on values on rx\_bitslipboundaryselectout[4..0] signal.

### **PLL PFD feedback**

In Deterministic Latency mode, when transmitter input reference clock frequency is the same as the low-speed clock, the PLL that clocks the transceiver supports PFD feedback. When enabled, the PLL compensates for delay uncertainty in the low-speed clock (tx\_clkout in ×1 configuration or coreclkout in ×4 configuration) path relative to input reference and the transmitter datapath latency is fixed relative to the transmitter input reference clock.

### **SDI Mode**

SDI mode provides the non-bonded (×1) transceiver channel datapath configuration for HD- and 3G-SDI protocol implementations.

Cyclone IV GX transceivers configured in SDI mode provides the serialization and deserialization functions that supports the SDI data rates as listed in Table 1–24.

| SMPTE<br>Standard <sup>(1)</sup> | Configuration         | Data Rate (Mbps) | FPGA Fabric-to-<br>Transceiver Width | Byte SERDES Usage |
|----------------------------------|-----------------------|------------------|--------------------------------------|-------------------|
| 292M                             | High definition (HD)  | 1483.5           | 20-bit                               | Used              |
|                                  |                       |                  | 10-bit                               | Not used          |
|                                  |                       | 1485             | 20-bit                               | Used              |
|                                  |                       |                  | 10-bit                               | Not used          |
| 424M                             | Third-generation (3G) | 2967             | 20-bit                               | llead             |
|                                  |                       | 2970             |                                      | USEU              |

Table 1–24. Supported SDI Data Rates

#### Note to Table 1-24:

(1) Society of Motion Picture and Television Engineers (SMPTE).

SDI functions such as scrambling/de-scrambling, framing, and cyclic redundancy check (CRC) must be implemented in the user logic.

| Block  | Port Name                   | Input/<br>Output | Clock Domain                                                                   | Description                                                                                                                                                                                                         |
|--------|-----------------------------|------------------|--------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|        | rx_rmfifofull               |                  | Synchronous to tx_clkout<br>(non-bonded modes) or<br>coreclkout (bonded modes) | Rate match FIFO full status indicator.                                                                                                                                                                              |
|        |                             |                  |                                                                                | A high level indicates the rate match FIFO is full.                                                                                                                                                                 |
|        |                             | Output           |                                                                                | <ul> <li>Driven for a minimum of two serial clock cycles in<br/>configurations without a byte serializer and a<br/>minimum of three recovered clock cycles in<br/>configurations with a byte serializer.</li> </ul> |
|        | rx_rmfifoempty              |                  | Synchronous to tx_clkout<br>(non-bonded modes) or<br>coreclkout (bonded modes) | Rate match FIFO empty status indicator.                                                                                                                                                                             |
|        |                             |                  |                                                                                | A high level indicates the rate match FIFO is empty.                                                                                                                                                                |
|        |                             | Output           |                                                                                | Driven for a minimum of two serial clock cycles in<br>configurations without a byte serializer and a<br>minimum of three recovered clock cycles in<br>configurations with a byte serializer.                        |
|        | rx_ctrldetect               |                  | Synchronous to tx_clkout<br>(non-bonded modes) or<br>coreclkout (bonded modes) | 8B/10B decoder control or data identifier.                                                                                                                                                                          |
|        |                             | Output           |                                                                                | <ul> <li>A high level indicates received code group is a /Kx.y/<br/>control code group.</li> </ul>                                                                                                                  |
|        |                             |                  |                                                                                | <ul> <li>A low level indicates received code group is a /Dx.y/<br/>data code group.</li> </ul>                                                                                                                      |
|        |                             |                  |                                                                                | 8B/10B code group violation or disparity error indicator.                                                                                                                                                           |
|        | rx_errdetect                |                  | Synchronous to tx_clkout<br>(non-bonded modes) or<br>coreclkout (bonded modes) | <ul> <li>A high level indicates that a code group violation or<br/>disparity error was detected on the associated<br/>received code group.</li> </ul>                                                               |
|        |                             | Output           |                                                                                | <ul> <li>Use with the rx_disperr signal to differentiate<br/>between a code group violation or a disparity error as<br/>follows: [rx_errdetect:rx_disperr]</li> </ul>                                               |
| RX PCS |                             |                  |                                                                                | <ul> <li>2'b00—no error</li> </ul>                                                                                                                                                                                  |
|        |                             |                  |                                                                                | <ul> <li>2'b10—code group violation</li> </ul>                                                                                                                                                                      |
|        |                             |                  |                                                                                | <ul> <li>2'b11—disparity error or both</li> </ul>                                                                                                                                                                   |
|        | rx_disperr                  | Output           | Synchronous to tx_clkout<br>(non-bonded modes) or<br>coreclkout (bonded modes) | 8B/10B disparity error indicator.                                                                                                                                                                                   |
|        |                             |                  |                                                                                | <ul> <li>A high level indicates that a disparity error was<br/>detected on the associated received code group.</li> </ul>                                                                                           |
|        | rx_runningdisp              |                  | Synchronous to tx_clkout<br>(non-bonded modes) or<br>coreclkout (bonded modes) | 8B/10B current running disparity indicator.                                                                                                                                                                         |
|        |                             | Output           |                                                                                | <ul> <li>A high level indicates a positive current running<br/>disparity at the end of the decoded byte</li> </ul>                                                                                                  |
|        |                             |                  |                                                                                | <ul> <li>A low level indicates a negative current running<br/>disparity at the end of the decoded byte</li> </ul>                                                                                                   |
|        | rx_enabyteord               |                  | Asynchronous signal                                                            | Enable byte ordering control                                                                                                                                                                                        |
|        |                             | Input            |                                                                                | <ul> <li>A low-to-high transition triggers the byte ordering<br/>block to restart byte ordering operation.</li> </ul>                                                                                               |
|        | rx_byteorder<br>alignstatus |                  | Synchronous to tx_clkout<br>(non-bonded modes) or<br>coreclkout (bonded modes) | Byte ordering status indicator.                                                                                                                                                                                     |
|        |                             | Output           |                                                                                | A high level indicates that the byte ordering block has<br>detected the programmed byte ordering pattern in the<br>least significant byte of the received data from the<br>byte deserializer.                       |
|        |                             |                  | Synchronous to tx_clkout                                                       | Parallel data output from the receiver to the FPGA fabric.                                                                                                                                                          |
|        | rx_dataout                  | Output           | (non-bonded modes) or<br>coreclkout (bonded modes)                             | <ul> <li>Bus width depends on channel width multiplied by<br/>number of channels per instance.</li> </ul>                                                                                                           |

Table 1–27. Receiver Ports in ALTGX Megafunction for Cyclone IV GX (Part 2 of 3)

## 2. Cyclone IV Reset Control and Power Down

Cyclone<sup>®</sup> IV GX devices offer multiple reset signals to control transceiver channels independently. The ALTGX Transceiver MegaWizard<sup>™</sup> Plug-In Manager provides individual reset signals for each channel instantiated in your design. It also provides one power-down signal for each transceiver block.

This chapter includes the following sections:

- "User Reset and Power-Down Signals" on page 2–2
- "Transceiver Reset Sequences" on page 2–4
- "Dynamic Reconfiguration Reset Sequences" on page 2–19
- "Power Down" on page 2–21
- "Simulation Requirements" on page 2–22
- "Reference Information" on page 2–23

Figure 2–1 shows the reset control and power-down block for a Cyclone IV GX device.



#### Figure 2–1. Reset Control and Power-Down Block

© 2014 Altera Corporation. All rights reserved. ALTERA, ARRIA, CYCLONE, HARDCOPY, MAX, MEGACORE, NIOS, QUARTUS and STRATIX words and logos are trademarks of Altera Corporation and registered in the U.S. Patent and Trademark Office and in other countries. All other words and logos identified as trademarks or service marks are the property of their respective holders as described at www.altera.com/common/legal.html. Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera assumes no responsibility or liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Altera. Altera customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.



Cyclone IV Device Handbook, Volume 2 September 2014

- 2. After the PLL is reset, wait for the pll\_locked signal to go high (marker 4) indicating that the PLL is locked to the input reference clock. After the assertion of the pll\_locked signal, deassert the tx\_digitalreset signal (marker 5).
- 3. Wait at least five parallel clock cycles after the pll\_locked signal is asserted to deassert the rx\_analogreset signal (marker 6).
- 4. When the rx\_freqlocked signal goes high (marker 7), from that point onwards, wait for at least t<sub>LTD\_Auto</sub> time, then deassert the rx\_digitalreset signal (marker 8). At this point, the receiver is ready for data traffic.

### **Reset Sequence in Channel Reconfiguration Mode**

Use the example reset sequence shown in Figure 2–12 when you are using the dynamic reconfiguration controller to change the PCS settings of the transceiver channel. In this example, the dynamic reconfiguration is used to dynamically reconfigure the transceiver channel configured in Basic ×1 mode with receiver CDR in automatic lock mode.

# Figure 2–12. Reset Sequence When Using the Dynamic Reconfiguration Controller to Change the PCS Settings of the Transceiver Channel



#### Notes to Figure 2-12:

- (1) For t<sub>LTD Auto</sub> duration, refer to the *Cyclone IV Device Datasheet* chapter.
- (2) The busy signal is asserted and deasserted only during initial power up when offset cancellation occurs. In subsequent reset sequences, the busy signal is asserted and deasserted only if there is a read or write operation to the ALTGX\_RECONFIG megafunction.