blob: 89c8996a42838a5cea50b7b381f4840e068276f4 [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):
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"
return dict(loc=ebrloc, mode=mode, settings=",".join(["{}={}".format(k, v) for k, v in settings.items()]))
loc, ebr, cfg = job
cfg.setup()
empty_bitfile = cfg.build_design(cfg.ncl, {})
cfg.ncl = "ebr.ncl"
nonrouting.fuzz_enum_setting(cfg, "{}.MODE".format(ebr), ["NONE", "PDPW16KD", "DP16KD"],
lambda x: get_substs(mode=x, settings={"GSR": "ENABLED"}), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.PDPW16KD.DATA_WIDTH_R".format(ebr), ["1", "2", "4", "9", "18", "36"],
lambda x: get_substs(mode="PDPW16KD", settings={"DATA_WIDTH_R": x}), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.DP16KD.DATA_WIDTH_A".format(ebr), ["1", "2", "4", "9", "18"],
lambda x: get_substs(mode="DP16KD", settings={"DATA_WIDTH_A": x}), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.DP16KD.DATA_WIDTH_B".format(ebr), ["1", "2", "4", "9", "18"],
lambda x: get_substs(mode="DP16KD", settings={"DATA_WIDTH_B": x}), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.REGMODE_A".format(ebr), ["NOREG", "OUTREG"],
lambda x: get_substs(mode="DP16KD", settings={"REGMODE_A": x}), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.REGMODE_B".format(ebr), ["NOREG", "OUTREG"],
lambda x: get_substs(mode="DP16KD", settings={"REGMODE_B": x}), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.DP16KD.WRITEMODE_A".format(ebr),
["NORMAL", "WRITETHROUGH", "READBEFOREWRITE"],
lambda x: get_substs(mode="DP16KD", settings={"WRITEMODE_A": x}), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.DP16KD.WRITEMODE_B".format(ebr),
["NORMAL", "WRITETHROUGH", "READBEFOREWRITE"],
lambda x: get_substs(mode="DP16KD", settings={"WRITEMODE_B": x}), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.GSR".format(ebr), ["ENABLED", "DISABLED"],
lambda x: get_substs(mode="DP16KD", settings={"GSR": x}), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.RESETMODE".format(ebr), ["SYNC", "ASYNC"],
lambda x: get_substs(mode="DP16KD", settings={"RESETMODE": x}), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.ASYNC_RESET_RELEASE".format(ebr), ["SYNC", "ASYNC"],
lambda x: get_substs(mode="DP16KD", settings={"ASYNC_RESET_RELEASE": x}),
empty_bitfile)
def bitstr(x):
return "0b" + "".join(["1" if z else "0" for z in x])
nonrouting.fuzz_word_setting(cfg, "{}.CSDECODE_A".format(ebr), 3, lambda x: get_substs(mode="DP16KD", settings={
"CSDECODE_A": bitstr(x)}), empty_bitfile)
nonrouting.fuzz_word_setting(cfg, "{}.CSDECODE_B".format(ebr), 3, lambda x: get_substs(mode="DP16KD", settings={
"CSDECODE_B": bitstr(x)}), empty_bitfile)
nonrouting.fuzz_word_setting(cfg, "{}.WID".format(ebr), 9, lambda x: get_substs(mode="DP16KD", settings={
"WID": bitstr(x)}), empty_bitfile)
fuzzloops.parallel_foreach(jobs, per_job)
if __name__ == "__main__":
main()