Primitive: Input Fixed or Variable Delay Element
- PRIMITIVE_GROUP: I/O
- PRIMITIVE_SUBGROUP: DELAY
- Families: UltraScale, UltraScale+
Introduction
In component mode, I/O blocks contain a programmable delay element called IDELAYE3. The IDELAYE3 can be connected to an input register/ISERDESE3 or driven directly into device logic. The IDELAYE3 is a 512-tap delay element with a calibrated tap resolution. Refer to the device Data Sheet for delay values. The IDELAYE3 allows incoming signals to be delayed on an individual basis.
Port Descriptions
Port | Direction | Width | Function |
---|---|---|---|
CASC_IN | Input | 1 | Cascade delay input from slave ODELAY CASCADE_OUT. |
CASC_OUT | Output | 1 | Cascade delay output to ODELAY input cascade. |
CASC_RETURN | Input | 1 | Cascade delay returning from slave ODELAY DATAOUT. |
CE | Input | 1 | Active-High enable increment/decrement function. |
CLK | Input | 1 | Clock Input |
CNTVALUEIN<8:0> | Input | 9 | Counter value from device logic for dynamically loadable tap value input. |
CNTVALUEOUT<8:0> | Output | 9 | The CNTVALUEOUT pins are used for reporting the dynamically switching value of the delay element. CNTVALUEOUT is only available when IDELAYE3 is in "VARIABLE" or "VAR_LOAD" mode. |
DATAIN | Input | 1 | The DATAIN input is directly driven by the device logic providing a logic accessible delay line. The data is driven back into the device logic through the DATAOUT port with a delay set by the DELAY_VALUE. |
DATAOUT | Output | 1 | Delayed data output from one of two data input ports (IDATAIN or DATAIN). |
EN_VTC | Input | 1 | Keep delay constant over VT. |
IDATAIN | Input | 1 | Data input for IDELAY from the IBUF. |
INC | Input | 1 | Increment / Decrement tap delay input. |
LOAD | Input | 1 | Loads the IDELAYE3 primitive to the pre-programmed value in VARIABLE mode. In VAR_LOAD mode, it load the value of CNTVALUEIN. |
RST | Input | 1 | Asynchronous Reset to the DELAY_VALUE, active level based on IS_RST_INVERTED. |
Design Entry Method
Instantiation | Yes |
Inference | No |
IP and IP Integrator Catalog | Yes |
Available Attributes
Attribute | Type | Allowed Values | Default | Description |
---|---|---|---|---|
CASCADE | STRING | "NONE", "MASTER", "SLAVE_END", "SLAVE_MIDDLE" | "NONE" | Sets the location of the IDELAYE3 when it is used in a cascaded configuration.
|
DELAY_FORMAT | STRING | "TIME", "COUNT" | "TIME" | Sets the units of DELAY_VALUE of the IDELAYE3. It is recommended to use TIME when DELAY_TYPE is FIXED and use COUNT when DELAY_TYPE is VARIABLE or VAR_LOAD.
|
DELAY_SRC | STRING | "IDATAIN", "DATAIN" | "IDATAIN" | Select the delay source input to the IDELAYE3.
|
DELAY_TYPE | STRING | "FIXED", "VARIABLE", "VAR_LOAD" | "FIXED" | Sets the type of tap delay line.
|
DELAY_VALUE | DECIMAL | 0 to 1250 | 0 | Specifies the fixed delay in ps in "FIXED" mode or the initial starting number of taps in "VARIABLE" mode or "VAR_LOAD" mode (input path). |
IS_CLK_INVERTED | BINARY | 1'b0 to 1'b1 | 1'b0 | Specifies whether the CLK pin is active-High or active-Low. |
IS_RST_INVERTED | BINARY | 1'b0 to 1'b1 | 1'b0 | Specifies whether the RST pin is active-High or active-Low. |
REFCLK_FREQUENCY | 1 significant digit FLOAT | 200.0 to 800.0 | 300.0 | Sets the tap value (in MHz) used by the timing analyzer for static timing analysis and functional/timing simulation. The frequency of REFCLK must be within the given datasheet range to guarantee performance. |
SIM_DEVICE | STRING | "7SERIES", "ULTRASCALE" | "ULTRASCALE" | Set the device version for simulation functionality. |
UPDATE_MODE | STRING | "ASYNC", "MANUAL", "SYNC" | "ASYNC" | Determines when updates to the delay will take effect.
|
VHDL Instantiation Template
Unless they already exist, copy the following
two statements and paste them before the entity declaration.
Library UNISIM;
use UNISIM.vcomponents.all;
-- IDELAYE3: Input Fixed or Variable Delay Element
-- UltraScale
-- Xilinx HDL Language Template, version 2022.2
IDELAYE3_inst : IDELAYE3
generic map (
CASCADE => "NONE", -- Cascade setting (MASTER, NONE, SLAVE_END, SLAVE_MIDDLE)
DELAY_FORMAT => "TIME", -- Units of the DELAY_VALUE (COUNT, TIME)
DELAY_SRC => "IDATAIN", -- Delay input (DATAIN, IDATAIN)
DELAY_TYPE => "FIXED", -- Set the type of tap delay line (FIXED, VARIABLE, VAR_LOAD)
DELAY_VALUE => 0, -- Input delay value setting
IS_CLK_INVERTED => '0', -- Optional inversion for CLK
IS_RST_INVERTED => '0', -- Optional inversion for RST
REFCLK_FREQUENCY => 300.0, -- IDELAYCTRL clock input frequency in MHz (200.0-800.0)
SIM_DEVICE => "ULTRASCALE_PLUS", -- Set the device version for simulation functionality (ULTRASCALE,
-- ULTRASCALE_PLUS, ULTRASCALE_PLUS_ES1, ULTRASCALE_PLUS_ES2)
UPDATE_MODE => "ASYNC" -- Determines when updates to the delay will take effect (ASYNC, MANUAL,
-- SYNC)
)
port map (
CASC_OUT => CASC_OUT, -- 1-bit output: Cascade delay output to ODELAY input cascade
CNTVALUEOUT => CNTVALUEOUT, -- 9-bit output: Counter value output
DATAOUT => DATAOUT, -- 1-bit output: Delayed data output
CASC_IN => CASC_IN, -- 1-bit input: Cascade delay input from slave ODELAY CASCADE_OUT
CASC_RETURN => CASC_RETURN, -- 1-bit input: Cascade delay returning from slave ODELAY DATAOUT
CE => CE, -- 1-bit input: Active-High enable increment/decrement input
CLK => CLK, -- 1-bit input: Clock input
CNTVALUEIN => CNTVALUEIN, -- 9-bit input: Counter value input
DATAIN => DATAIN, -- 1-bit input: Data input from the logic
EN_VTC => EN_VTC, -- 1-bit input: Keep delay constant over VT
IDATAIN => IDATAIN, -- 1-bit input: Data input from the IOBUF
INC => INC, -- 1-bit input: Increment / Decrement tap delay input
LOAD => LOAD, -- 1-bit input: Load DELAY_VALUE input
RST => RST -- 1-bit input: Asynchronous Reset to the DELAY_VALUE
);
-- End of IDELAYE3_inst instantiation
Verilog Instantiation Template
// IDELAYE3: Input Fixed or Variable Delay Element
// UltraScale
// Xilinx HDL Language Template, version 2022.2
IDELAYE3 #(
.CASCADE("NONE"), // Cascade setting (MASTER, NONE, SLAVE_END, SLAVE_MIDDLE)
.DELAY_FORMAT("TIME"), // Units of the DELAY_VALUE (COUNT, TIME)
.DELAY_SRC("IDATAIN"), // Delay input (DATAIN, IDATAIN)
.DELAY_TYPE("FIXED"), // Set the type of tap delay line (FIXED, VARIABLE, VAR_LOAD)
.DELAY_VALUE(0), // Input delay value setting
.IS_CLK_INVERTED(1'b0), // Optional inversion for CLK
.IS_RST_INVERTED(1'b0), // Optional inversion for RST
.REFCLK_FREQUENCY(300.0), // IDELAYCTRL clock input frequency in MHz (200.0-800.0)
.SIM_DEVICE("ULTRASCALE_PLUS"), // Set the device version for simulation functionality (ULTRASCALE,
// ULTRASCALE_PLUS, ULTRASCALE_PLUS_ES1, ULTRASCALE_PLUS_ES2)
.UPDATE_MODE("ASYNC") // Determines when updates to the delay will take effect (ASYNC, MANUAL,
// SYNC)
)
IDELAYE3_inst (
.CASC_OUT(CASC_OUT), // 1-bit output: Cascade delay output to ODELAY input cascade
.CNTVALUEOUT(CNTVALUEOUT), // 9-bit output: Counter value output
.DATAOUT(DATAOUT), // 1-bit output: Delayed data output
.CASC_IN(CASC_IN), // 1-bit input: Cascade delay input from slave ODELAY CASCADE_OUT
.CASC_RETURN(CASC_RETURN), // 1-bit input: Cascade delay returning from slave ODELAY DATAOUT
.CE(CE), // 1-bit input: Active-High enable increment/decrement input
.CLK(CLK), // 1-bit input: Clock input
.CNTVALUEIN(CNTVALUEIN), // 9-bit input: Counter value input
.DATAIN(DATAIN), // 1-bit input: Data input from the logic
.EN_VTC(EN_VTC), // 1-bit input: Keep delay constant over VT
.IDATAIN(IDATAIN), // 1-bit input: Data input from the IOBUF
.INC(INC), // 1-bit input: Increment / Decrement tap delay input
.LOAD(LOAD), // 1-bit input: Load DELAY_VALUE input
.RST(RST) // 1-bit input: Asynchronous Reset to the DELAY_VALUE
);
// End of IDELAYE3_inst instantiation
Related Information
- See the UltraScale Architecture SelectIO Resources User Guide (UG571).