blob: 490b8d5898fd00e7d9bfe4814e60a4dc39d4271e [file] [log] [blame]
from fuzzconfig import FuzzConfig
import nonrouting
import pytrellis
import fuzzloops
jobs = [
("R25C22", "EBR0", FuzzConfig(job="EBROUTE0", family="ECP5", device="LFE5U-25F", ncl="empty.ncl",
tiles=["MIB_R25C22:MIB_EBR0", "MIB_R25C23:MIB_EBR1"])),
("R25C24", "EBR1", FuzzConfig(job="EBROUTE1", family="ECP5", device="LFE5U-25F", ncl="empty.ncl",
tiles=["MIB_R25C24:MIB_EBR2", "MIB_R25C25:MIB_EBR3", "MIB_R25C26:MIB_EBR4"])),
("R25C26", "EBR2", FuzzConfig(job="EBROUTE2", family="ECP5", device="LFE5U-25F", ncl="empty.ncl",
tiles=["MIB_R25C26:MIB_EBR4", "MIB_R25C27:MIB_EBR5", "MIB_R25C28:MIB_EBR6"])),
("R25C28", "EBR3", FuzzConfig(job="EBROUTE3", family="ECP5", device="LFE5U-25F", ncl="empty.ncl",
tiles=["MIB_R25C28:MIB_EBR6", "MIB_R25C29:MIB_EBR7", "MIB_R25C30:MIB_EBR8"])),
]
def main():
pytrellis.load_database("../../../database")
def per_job(job):
def get_substs(mode, settings, muxes = None):
ebrloc = loc
if mode == "NONE":
# easier to move EBR out the way than remove it
ebrloc = "R25C60"
mode = "PDPW16KD"
if mode == "PDPW16KD" and "DATA_WIDTH_R" not in settings:
settings["DATA_WIDTH_R"] = "18"
if mode == "PDPW16KD" and "DATA_WIDTH_W" not in settings:
settings["DATA_WIDTH_W"] = "36"
if mode == "PDPW16KD" and "CSDECODE_W" not in settings:
settings["CSDECODE_W"] = "0b111"
if mode == "PDPW16KD" and "CSDECODE_R" not in settings:
settings["CSDECODE_R"] = "0b111"
if mode == "DP16KD" and "CSDECODE_A" not in settings:
settings["CSDECODE_A"] = "0b111"
if mode == "DP16KD" and "CSDECODE_B" not in settings:
settings["CSDECODE_B"] = "0b111"
setting_text = ",".join(["{}={}".format(k, v) for k, v in settings.items()])
if muxes is not None:
setting_text += ":" + ",".join(["{}={}".format(k, v) for k, v in muxes.items()])
return dict(loc=ebrloc, mode=mode, settings=setting_text)
def get_muxval(sig, val):
if val == sig:
return None
elif val == "INV":
return {sig: "#INV"}
else:
assert False
loc, ebr, cfg = job
cfg.setup()
empty_bitfile = cfg.build_design(cfg.ncl, {})
cfg.ncl = "ebr.ncl"
nonrouting.fuzz_enum_setting(cfg, "{}.CLKAMUX".format(ebr), ["CLKA", "INV"],
lambda x: get_substs("DP16KD", {}, get_muxval("CLKA", x)), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.CLKBMUX".format(ebr), ["CLKB", "INV"],
lambda x: get_substs("DP16KD", {}, get_muxval("CLKB", x)), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.RSTAMUX".format(ebr), ["RSTA", "INV"],
lambda x: get_substs("DP16KD", {}, get_muxval("RSTA", x)), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.RSTBMUX".format(ebr), ["RSTB", "INV"],
lambda x: get_substs("DP16KD", {}, get_muxval("RSTB", x)), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.OCEAMUX".format(ebr), ["OCEA", "INV"],
lambda x: get_substs("DP16KD", {}, get_muxval("OCEA", x)), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.OCEBMUX".format(ebr), ["OCEB", "INV"],
lambda x: get_substs("DP16KD", {}, get_muxval("OCEB", x)), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.WEAMUX".format(ebr), ["WEA", "INV"],
lambda x: get_substs("DP16KD", {}, get_muxval("WEA", x)), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.WEBMUX".format(ebr), ["WEB", "INV"],
lambda x: get_substs("DP16KD", {}, get_muxval("WEB", x)), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.CEAMUX".format(ebr), ["CEA", "INV"],
lambda x: get_substs("DP16KD", {}, get_muxval("CEA", x)), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.CEBMUX".format(ebr), ["CEB", "INV"],
lambda x: get_substs("DP16KD", {}, get_muxval("CEB", x)), empty_bitfile)
for p in ("A", "B"):
for i in range(4 if p == "A" else 2):
sig = "AD{}{}".format(p, i)
nonrouting.fuzz_enum_setting(cfg, "{}.{}MUX".format(ebr, sig), [sig, "INV"],
lambda x: get_substs("DP16KD", {}, get_muxval(sig, x)), empty_bitfile)
fuzzloops.parallel_foreach(jobs, per_job)
if __name__ == "__main__":
main()