mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
cores/jtag: Make primitive selection more flexible (and simplify new devices support).
This commit is contained in:
parent
b59fdae588
commit
78ecf50ad5
1 changed files with 56 additions and 33 deletions
|
@ -235,13 +235,42 @@ class AlteraJTAG(Module):
|
||||||
]
|
]
|
||||||
self.sync.jtag_inv += tdouser.eq(tdo)
|
self.sync.jtag_inv += tdouser.eq(tdo)
|
||||||
|
|
||||||
class MAX10JTAG(AlteraJTAG):
|
@staticmethod
|
||||||
def __init__(self, *args, **kwargs):
|
def get_primitive(device):
|
||||||
AlteraJTAG.__init__(self, "fiftyfivenm_jtag", *args, **kwargs)
|
# TODO: Add support for all devices.
|
||||||
|
prim_dict = {
|
||||||
class Cyclone10LPJTAG(AlteraJTAG):
|
# Primitive Name Ðevice (startswith)
|
||||||
def __init__(self, *args, **kwargs):
|
"arriaii_jtag" : [],
|
||||||
AlteraJTAG.__init__(self, "cyclone10lp_jtag", *args, **kwargs)
|
"arriaiigz_jtag" : [],
|
||||||
|
"arriav_jtag" : [],
|
||||||
|
"arriavgz_jtag" : [],
|
||||||
|
"cyclone_jtag" : [],
|
||||||
|
"cyclone10lp_jtag" : ["10cl"],
|
||||||
|
"cycloneii_jtag" : [],
|
||||||
|
"cycloneiii_jtag" : [],
|
||||||
|
"cycloneiiils_jtag" : [],
|
||||||
|
"cycloneiv_jtag" : [],
|
||||||
|
"cycloneive_jtag" : ["ep4c"],
|
||||||
|
"cyclonev_jtag" : ["5c"],
|
||||||
|
"fiftyfivenm_jtag" : ["10m"],
|
||||||
|
"maxii_jtag" : [],
|
||||||
|
"maxv_jtag" : [],
|
||||||
|
"stratix_jtag" : [],
|
||||||
|
"stratixgx_jtag" : [],
|
||||||
|
"stratixii_jtag" : [],
|
||||||
|
"stratixiigx_jtag" : [],
|
||||||
|
"stratixiii_jtag" : [],
|
||||||
|
"stratixiv_jtag" : [],
|
||||||
|
"stratixv_jtag" : [],
|
||||||
|
"twentynm_jtagblock" : [],
|
||||||
|
"twentynm_jtag" : [],
|
||||||
|
"twentynm_hps_interface_jtag" : [],
|
||||||
|
}
|
||||||
|
for prim, prim_devs in prim_dict.items():
|
||||||
|
for prim_dev in prim_devs:
|
||||||
|
if device.lower().startswith(prim_dev):
|
||||||
|
return prim
|
||||||
|
return None
|
||||||
|
|
||||||
# Xilinx JTAG --------------------------------------------------------------------------------------
|
# Xilinx JTAG --------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
@ -273,19 +302,19 @@ class XilinxJTAG(Module):
|
||||||
i_TDO = self.tdo,
|
i_TDO = self.tdo,
|
||||||
)
|
)
|
||||||
|
|
||||||
class S6JTAG(XilinxJTAG):
|
@staticmethod
|
||||||
def __init__(self, *args, **kwargs):
|
def get_primitive(device):
|
||||||
XilinxJTAG.__init__(self, primitive="BSCAN_SPARTAN6", *args, **kwargs)
|
# TODO: Add support for all devices.
|
||||||
|
prim_dict = {
|
||||||
|
# Primitive Name Ðevice (startswith)
|
||||||
class S7JTAG(XilinxJTAG):
|
"BSCAN_SPARTAN6" : ["xc6"],
|
||||||
def __init__(self, *args, **kwargs):
|
"BSCANE2" : ["xc7", "xcku", "xcvu"],
|
||||||
XilinxJTAG.__init__(self, primitive="BSCANE2", *args, **kwargs)
|
}
|
||||||
|
for prim, prim_devs in prim_dict.items():
|
||||||
|
for prim_dev in prim_devs:
|
||||||
class USJTAG(XilinxJTAG):
|
if device.lower().startswith(prim_dev):
|
||||||
def __init__(self, *args, **kwargs):
|
return prim
|
||||||
XilinxJTAG.__init__(self, primitive="BSCANE2", *args, **kwargs)
|
return None
|
||||||
|
|
||||||
# ECP5 JTAG ----------------------------------------------------------------------------------------
|
# ECP5 JTAG ----------------------------------------------------------------------------------------
|
||||||
|
|
||||||
|
@ -371,24 +400,18 @@ class JTAGPHY(Module):
|
||||||
# JTAG TAP ---------------------------------------------------------------------------------
|
# JTAG TAP ---------------------------------------------------------------------------------
|
||||||
if jtag is None:
|
if jtag is None:
|
||||||
# Xilinx.
|
# Xilinx.
|
||||||
if device[:3] == "xc6":
|
if XilinxJTAG.get_primitive(device) is not None:
|
||||||
jtag = S6JTAG(chain=chain)
|
jtag = XilinxJTAG(primitive=XilinxJTAG.get_primitive(device))
|
||||||
elif device[:3] == "xc7":
|
|
||||||
jtag = S7JTAG(chain=chain)
|
|
||||||
elif device[:4] in ["xcku", "xcvu"]:
|
|
||||||
jtag = USJTAG(chain=chain)
|
|
||||||
|
|
||||||
# Lattice.
|
# Lattice.
|
||||||
elif device[:5] == "LFE5U":
|
elif device[:5] == "LFE5U":
|
||||||
jtag = ECP5JTAG()
|
jtag = ECP5JTAG()
|
||||||
|
|
||||||
# Altera/Intel.
|
# Altera/Intel.
|
||||||
elif device[:3].lower() in ["10m"]:
|
elif AlteraJTAG.get_primitive(device) is not None:
|
||||||
platform.add_reserved_jtag_decls()
|
platform.add_reserved_jtag_decls()
|
||||||
jtag = MAX10JTAG(pads=platform.get_reserved_jtag_pads())
|
jtag = AlteraJTAG(
|
||||||
elif device[:4].lower() in ["10cl"]:
|
primitive = AlteraJTAG.get_primitive(device),
|
||||||
platform.add_reserved_jtag_decls()
|
pads = platform.get_reserved_jtag_pads()
|
||||||
jtag = Cyclone10LPJTAG(pads=platform.get_reserved_jtag_pads())
|
)
|
||||||
else:
|
else:
|
||||||
print(device)
|
print(device)
|
||||||
raise NotImplementedError
|
raise NotImplementedError
|
||||||
|
|
Loading…
Reference in a new issue