mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
cores/clocks/lattice_ecp5: Rename ECP5Delay to ECP5DynamicDelay and adapt style for consistency.
This commit is contained in:
parent
ea6bb3dd80
commit
77c6cdd78e
3 changed files with 55 additions and 44 deletions
|
@ -12,7 +12,7 @@ from litex.soc.cores.clock.intel_cyclone10 import Cyclone10LPPLL
|
|||
|
||||
# Lattice
|
||||
from litex.soc.cores.clock.lattice_ice40 import iCE40PLL
|
||||
from litex.soc.cores.clock.lattice_ecp5 import ECP5PLL, ECP5Delay
|
||||
from litex.soc.cores.clock.lattice_ecp5 import ECP5PLL, ECP5DynamicDelay
|
||||
from litex.soc.cores.clock.lattice_nx import NXOSCA, NXPLL
|
||||
|
||||
# Efinix
|
||||
|
|
|
@ -10,7 +10,7 @@ from migen.genlib.resetsync import AsyncResetSynchronizer
|
|||
|
||||
from litex.soc.cores.clock.common import *
|
||||
|
||||
# Lattice / ECP5 -----------------------------------------------------------------------------------
|
||||
# Lattice / ECP5 PLL -------------------------------------------------------------------------------
|
||||
|
||||
class ECP5PLL(Module):
|
||||
nclkouts_max = 4
|
||||
|
@ -166,50 +166,60 @@ class ECP5PLL(Module):
|
|||
self.params["attr"].append((f"FREQUENCY_PIN_CLKO{n_to_l[n]}", str(f/1e6)))
|
||||
self.specials += Instance("EHXPLLL", **self.params)
|
||||
|
||||
# Lattice / ECP5 Dynamic Delay ---------------------------------------------------------------------
|
||||
|
||||
class ECP5Delay(Module):
|
||||
# from ECP5 docs
|
||||
delay_step_s = 25e-12
|
||||
n_steps = 128
|
||||
class ECP5DynamicDelay(Module):
|
||||
tap_delay = 25e-12
|
||||
ntaps = 128
|
||||
|
||||
def __init__(self):
|
||||
self.i = Signal()
|
||||
self.o = Signal()
|
||||
self.value = Signal(max=self.n_steps)
|
||||
def __init__(self, i=None, o=None, taps=None):
|
||||
self.i = Signal() if i is None else i
|
||||
self.o = Signal() if o is None else o
|
||||
self.taps = Signal(max=self.ntaps) if taps is None else taps
|
||||
|
||||
def do_finalize(self):
|
||||
rst = Signal()
|
||||
move = Signal()
|
||||
current_value = Signal(max=self.n_steps)
|
||||
# # #
|
||||
|
||||
self.specials += Instance(
|
||||
"DELAYF",
|
||||
p_DEL_MODE="USER_DEFINED",
|
||||
p_DEL_VALUE=self.value.reset,
|
||||
i_A=self.i,
|
||||
o_Z=self.o,
|
||||
i_LOADN=~(ResetSignal() | rst),
|
||||
i_MOVE=move,
|
||||
i_DIRECTION=0,
|
||||
o_CFLAG=Signal()
|
||||
rst = Signal()
|
||||
move = Signal()
|
||||
done = Signal()
|
||||
change = Signal()
|
||||
curr_taps = Signal(max=self.ntaps)
|
||||
|
||||
# DELAYF Instance.
|
||||
self.specials += Instance("DELAYF",
|
||||
p_DEL_MODE = "USER_DEFINED",
|
||||
p_DEL_VALUE = self.taps.reset,
|
||||
i_A = self.i,
|
||||
o_Z = self.o,
|
||||
i_LOADN = ~(ResetSignal() | rst),
|
||||
i_MOVE = move,
|
||||
i_DIRECTION = 0,
|
||||
o_CFLAG = Signal()
|
||||
)
|
||||
|
||||
self.submodules.fsm = fsm = FSM()
|
||||
fsm.act("WAIT",
|
||||
If(self.value != current_value,
|
||||
NextState('RST'))
|
||||
# FSM.
|
||||
self.comb += done.eq( self.taps == curr_taps)
|
||||
self.comb += change.eq(self.taps != curr_taps)
|
||||
self.submodules.fsm = fsm = FSM(reset_state="IDLE")
|
||||
fsm.act("IDLE",
|
||||
If(change,
|
||||
NextState("DELAYF-RST")
|
||||
)
|
||||
)
|
||||
fsm.act("DELAYF-RST",
|
||||
rst.eq(1),
|
||||
NextValue(move, 0),
|
||||
NextValue(curr_taps, 0),
|
||||
NextState("DELAYF-MOVE")
|
||||
)
|
||||
fsm.act("DELAYF-MOVE",
|
||||
If(done,
|
||||
NextValue(move, 0),
|
||||
NextState("IDLE")
|
||||
).Else(
|
||||
NextValue(move, ~move),
|
||||
If(move,
|
||||
NextValue(curr_taps, curr_taps + 1)
|
||||
)
|
||||
fsm.act("RST",
|
||||
rst.eq(1),
|
||||
NextValue(current_value, 0),
|
||||
NextState("MOVE")
|
||||
)
|
||||
fsm.act("MOVE",
|
||||
If(current_value == self.value,
|
||||
NextValue(move, 0),
|
||||
NextState("WAIT")
|
||||
).Else(
|
||||
NextValue(move, ~move),
|
||||
If(move,
|
||||
NextValue(current_value, current_value + 1)),
|
||||
))
|
||||
)
|
||||
)
|
||||
|
|
|
@ -130,8 +130,9 @@ class TestClock(unittest.TestCase):
|
|||
pll.create_clkout(ClockDomain("clkout4"), 175e6)
|
||||
pll.compute_config()
|
||||
|
||||
def test_ecp5_delay(self):
|
||||
delay = ECP5Delay()
|
||||
def test_ecp5_dynamic_delay(self):
|
||||
delay = ECP5DynamicDelay(i=Signal(), o=Signal(), taps=Signal(7))
|
||||
delay = ECP5DynamicDelay()
|
||||
|
||||
# Lattice / NX
|
||||
def test_nxpll(self):
|
||||
|
|
Loading…
Reference in a new issue