mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
Merge pull request #2068 from VOGL-electronic/ddrtristate_oe2_optional
build: io: make oe2 of DDRTristate optional
This commit is contained in:
commit
a32096e806
4 changed files with 8 additions and 7 deletions
|
@ -294,7 +294,7 @@ class EfinixDifferentialInput:
|
|||
|
||||
class EfinixDDRTristateImpl(LiteXModule):
|
||||
def __init__(self, io, o1, o2, oe1, oe2, i1, i2, clk):
|
||||
assert oe1 == oe2
|
||||
assert oe2 is None
|
||||
assert_is_signal_or_clocksignal(clk)
|
||||
platform = LiteXContext.platform
|
||||
io_name = platform.get_pin_name(io)
|
||||
|
|
|
@ -190,20 +190,20 @@ class InferedDDRTristate(Module):
|
|||
_oe = Signal()
|
||||
_i = Signal()
|
||||
self.specials += DDROutput(o1, o2, _o, clk)
|
||||
self.specials += DDROutput(oe1, oe2, _oe, clk)
|
||||
self.specials += DDROutput(oe1, oe2, _oe, clk) if oe2 is not None else SDROutput(oe1, _oe, clk)
|
||||
self.specials += DDRInput(_i, i1, i2, clk)
|
||||
self.specials += Tristate(io, _o, _oe, _i)
|
||||
|
||||
class DDRTristate(Special):
|
||||
def __init__(self, io, o1, o2, oe1, oe2, i1, i2, clk=None):
|
||||
def __init__(self, io, o1, o2, oe1, oe2=None, i1=None, i2=None, clk=None):
|
||||
Special.__init__(self)
|
||||
self.io = io
|
||||
self.o1 = o1
|
||||
self.o2 = o2
|
||||
self.oe1 = oe1
|
||||
self.oe2 = oe2
|
||||
self.i1 = i1
|
||||
self.i2 = i2
|
||||
self.i1 = i1 if i1 is not None else Signal()
|
||||
self.i2 = i2 if i2 is not None else Signal()
|
||||
self.clk = clk if clk is not None else ClockSignal()
|
||||
|
||||
def iter_expressions(self):
|
||||
|
|
|
@ -324,11 +324,12 @@ class LatticeNXDDROutput:
|
|||
|
||||
class LatticeNXDDRTristateImpl(Module):
|
||||
def __init__(self, io, o1, o2, oe1, oe2, i1, i2, clk):
|
||||
assert oe2 is None
|
||||
_o = Signal()
|
||||
_oe = Signal()
|
||||
_i = Signal()
|
||||
self.specials += DDROutput(o1, o2, _o, clk)
|
||||
self.specials += SDROutput(oe1 | oe2, _oe, clk)
|
||||
self.specials += SDROutput(oe1, _oe, clk)
|
||||
self.specials += DDRInput(_i, i1, i2, clk)
|
||||
self.specials += Tristate(io, _o, _oe, _i)
|
||||
_oe.attr.add("syn_useioff")
|
||||
|
|
|
@ -164,7 +164,7 @@ class XilinxDDRTristateImpl(Module):
|
|||
_oe_n = Signal()
|
||||
_i = Signal()
|
||||
self.specials += DDROutput(o1, o2, _o, clk)
|
||||
self.specials += DDROutput(~oe1, ~oe2, _oe_n, clk)
|
||||
self.specials += DDROutput(~oe1, ~oe2, _oe_n, clk) if oe2 is not None else SDROutput(~oe1, _oe_n, clk)
|
||||
self.specials += DDRInput(_i, i1, i2, clk)
|
||||
self.specials += Instance("IOBUF",
|
||||
io_IO = io,
|
||||
|
|
Loading…
Reference in a new issue