mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
build/xilinx: cleanup Vivado/ISE special_overrides
This commit is contained in:
parent
8ee3874088
commit
fd2997bf4a
2 changed files with 48 additions and 9 deletions
|
@ -42,27 +42,52 @@ def settings(path, ver=None, sub=None):
|
|||
raise OSError("no settings file found")
|
||||
|
||||
|
||||
class XilinxNoRetimingImpl(Module):
|
||||
class XilinxNoRetimingVivadoImpl(Module):
|
||||
def __init__(self, reg):
|
||||
reg.attribute += " OPTIMIZE =\"OFF\"," # XXX "register balancing is no" equivalent?
|
||||
pass # No equivalent in Vivado
|
||||
|
||||
|
||||
class XilinxNoRetiming:
|
||||
class XilinxNoRetimingVivado:
|
||||
@staticmethod
|
||||
def lower(dr):
|
||||
return XilinxNoRetimingImpl(dr.reg)
|
||||
return XilinxNoRetimingVivadoImpl(dr.reg)
|
||||
|
||||
class XilinxMultiRegImpl(MultiRegImpl):
|
||||
|
||||
class XilinxNoRetimingISEImpl(Module):
|
||||
def __init__(self, reg):
|
||||
self.specials += SynthesisDirective("attribute register_balancing of {r} is no", r=reg)
|
||||
|
||||
|
||||
class XilinxNoRetimingISE:
|
||||
@staticmethod
|
||||
def lower(dr):
|
||||
return XilinxNoRetimingISEImpl(dr.reg)
|
||||
|
||||
|
||||
class XilinxMultiRegVivadoImpl(MultiRegImpl):
|
||||
def __init__(self, *args, **kwargs):
|
||||
MultiRegImpl.__init__(self, *args, **kwargs)
|
||||
for reg in self.regs:
|
||||
reg.attribute += " SHIFT_EXTRACT=\"NO\", ASYNC_REG=\"TRUE\","
|
||||
|
||||
|
||||
class XilinxMultiReg:
|
||||
class XilinxMultiRegVivado:
|
||||
@staticmethod
|
||||
def lower(dr):
|
||||
return XilinxMultiRegImpl(dr.i, dr.o, dr.odomain, dr.n)
|
||||
return XilinxMultiRegVivadoImpl(dr.i, dr.o, dr.odomain, dr.n)
|
||||
|
||||
|
||||
class XilinxMultiRegISEImpl(MultiRegImpl):
|
||||
def __init__(self, *args, **kwargs):
|
||||
MultiRegImpl.__init__(self, *args, **kwargs)
|
||||
self.specials += [SynthesisDirective("attribute shreg_extract of {r} is no", r=r)
|
||||
for r in self.regs]
|
||||
|
||||
|
||||
class XilinxMultiRegISE:
|
||||
@staticmethod
|
||||
def lower(dr):
|
||||
return XilinxMultiRegISEImpl(dr.i, dr.o, dr.odomain, dr.n)
|
||||
|
||||
|
||||
class XilinxAsyncResetSynchronizerImpl(Module):
|
||||
|
@ -120,8 +145,6 @@ class XilinxDDROutput:
|
|||
|
||||
|
||||
xilinx_special_overrides = {
|
||||
NoRetiming: XilinxNoRetiming,
|
||||
MultiReg: XilinxMultiReg,
|
||||
AsyncResetSynchronizer: XilinxAsyncResetSynchronizer,
|
||||
DifferentialInput: XilinxDifferentialInput,
|
||||
DifferentialOutput: XilinxDifferentialOutput,
|
||||
|
@ -129,6 +152,18 @@ xilinx_special_overrides = {
|
|||
}
|
||||
|
||||
|
||||
xilinx_vivado_special_overrides = {
|
||||
NoRetiming: XilinxNoRetimingVivado,
|
||||
MultiReg: XilinxMultiRegVivado
|
||||
}
|
||||
|
||||
|
||||
xilinx_ise_special_overrides = {
|
||||
NoRetiming: XilinxNoRetimingISE,
|
||||
MultiReg: XilinxMultiRegISE
|
||||
}
|
||||
|
||||
|
||||
class XilinxDDROutputImplS7(Module):
|
||||
def __init__(self, i1, i2, o, clk):
|
||||
self.specials += Instance("ODDR",
|
||||
|
|
|
@ -18,6 +18,10 @@ class XilinxPlatform(GenericPlatform):
|
|||
so = dict(common.xilinx_special_overrides)
|
||||
if self.device[:3] == "xc7":
|
||||
so.update(common.xilinx_s7_special_overrides)
|
||||
if self.toolchain == "ise":
|
||||
so.update(common.xilinx_vivado_special_overrides)
|
||||
else:
|
||||
so.update(common.xilinx_ise_special_overrides)
|
||||
so.update(special_overrides)
|
||||
return GenericPlatform.get_verilog(self, *args, special_overrides=so, **kwargs)
|
||||
|
||||
|
|
Loading…
Reference in a new issue