1
0
Fork 0

DDMTD: replace FD with ISERDESE2

This commit is contained in:
morgan 2024-04-25 11:02:19 +08:00
parent 14fa038118
commit bd30de9e6e
1 changed files with 38 additions and 12 deletions

View File

@ -10,18 +10,44 @@ class DDMTDSampler(Module):
# # # # # #
ref_beating_FF = Signal() ref_clk = Signal()
main_beating_FF = Signal() self.specials +=[
self.specials += [ # ISERDESE2 can only be driven from fabric via IDELAYE2 (see UG471)
# Two back to back FFs are used to prevent metastability Instance("IDELAYE2",
Instance("FD", i_C=ClockSignal("helper"), p_DELAY_SRC="DATAIN",
i_D=cd_ref.clk, o_Q=ref_beating_FF), p_HIGH_PERFORMANCE_MODE="TRUE",
Instance("FD", i_C=ClockSignal("helper"), p_REFCLK_FREQUENCY=208.3, # REFCLK frequency from IDELAYCTRL
i_D=ref_beating_FF, o_Q=self.ref_beating), p_IDELAY_VALUE=0,
Instance("FD", i_C=ClockSignal("helper"),
i_D=main_clk_se, o_Q=main_beating_FF), i_DATAIN=cd_ref.clk,
Instance("FD", i_C=ClockSignal("helper"),
i_D=main_beating_FF, o_Q=self.main_beating) o_DATAOUT=ref_clk
),
Instance("ISERDESE2",
p_IOBDELAY="IFD", # use DDLY as input
p_DATA_RATE="SDR",
p_DATA_WIDTH=2, # min is 2
p_NUM_CE=1,
i_DDLY=ref_clk,
i_CE1=1,
i_CLK=ClockSignal("helper"),
i_CLKDIV=ClockSignal("helper"),
o_Q1=self.ref_beating
),
Instance("ISERDESE2",
p_DATA_RATE="SDR",
p_DATA_WIDTH=2, # min is 2
p_NUM_CE=1,
i_D=main_clk_se,
i_CE1=1,
i_CLK=ClockSignal("helper"),
i_CLKDIV=ClockSignal("helper"),
o_Q1=self.main_beating,
),
] ]