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")
|
raise OSError("no settings file found")
|
||||||
|
|
||||||
|
|
||||||
class XilinxNoRetimingImpl(Module):
|
class XilinxNoRetimingVivadoImpl(Module):
|
||||||
def __init__(self, reg):
|
def __init__(self, reg):
|
||||||
reg.attribute += " OPTIMIZE =\"OFF\"," # XXX "register balancing is no" equivalent?
|
pass # No equivalent in Vivado
|
||||||
|
|
||||||
|
|
||||||
class XilinxNoRetiming:
|
class XilinxNoRetimingVivado:
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def lower(dr):
|
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):
|
def __init__(self, *args, **kwargs):
|
||||||
MultiRegImpl.__init__(self, *args, **kwargs)
|
MultiRegImpl.__init__(self, *args, **kwargs)
|
||||||
for reg in self.regs:
|
for reg in self.regs:
|
||||||
reg.attribute += " SHIFT_EXTRACT=\"NO\", ASYNC_REG=\"TRUE\","
|
reg.attribute += " SHIFT_EXTRACT=\"NO\", ASYNC_REG=\"TRUE\","
|
||||||
|
|
||||||
|
|
||||||
class XilinxMultiReg:
|
class XilinxMultiRegVivado:
|
||||||
@staticmethod
|
@staticmethod
|
||||||
def lower(dr):
|
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):
|
class XilinxAsyncResetSynchronizerImpl(Module):
|
||||||
|
@ -120,8 +145,6 @@ class XilinxDDROutput:
|
||||||
|
|
||||||
|
|
||||||
xilinx_special_overrides = {
|
xilinx_special_overrides = {
|
||||||
NoRetiming: XilinxNoRetiming,
|
|
||||||
MultiReg: XilinxMultiReg,
|
|
||||||
AsyncResetSynchronizer: XilinxAsyncResetSynchronizer,
|
AsyncResetSynchronizer: XilinxAsyncResetSynchronizer,
|
||||||
DifferentialInput: XilinxDifferentialInput,
|
DifferentialInput: XilinxDifferentialInput,
|
||||||
DifferentialOutput: XilinxDifferentialOutput,
|
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):
|
class XilinxDDROutputImplS7(Module):
|
||||||
def __init__(self, i1, i2, o, clk):
|
def __init__(self, i1, i2, o, clk):
|
||||||
self.specials += Instance("ODDR",
|
self.specials += Instance("ODDR",
|
||||||
|
|
|
@ -18,6 +18,10 @@ class XilinxPlatform(GenericPlatform):
|
||||||
so = dict(common.xilinx_special_overrides)
|
so = dict(common.xilinx_special_overrides)
|
||||||
if self.device[:3] == "xc7":
|
if self.device[:3] == "xc7":
|
||||||
so.update(common.xilinx_s7_special_overrides)
|
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)
|
so.update(special_overrides)
|
||||||
return GenericPlatform.get_verilog(self, *args, special_overrides=so, **kwargs)
|
return GenericPlatform.get_verilog(self, *args, special_overrides=so, **kwargs)
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue