blob: 5af238e2f8d0f4ee2c52dd64924fff24bd6db962 [file] [log] [blame]
from fuzzconfig import FuzzConfig
import nonrouting
import pytrellis
import fuzzloops
dsp_tiles = [
"MIB_R13C4:MIB_DSP0", "MIB_R13C4:MIB2_DSP0",
"MIB_R13C5:MIB_DSP1", "MIB_R13C5:MIB2_DSP1",
"MIB_R13C6:MIB_DSP2", "MIB_R13C6:MIB2_DSP2",
"MIB_R13C7:MIB_DSP3", "MIB_R13C7:MIB2_DSP3",
"MIB_R13C8:MIB_DSP4", "MIB_R13C8:MIB2_DSP4",
"MIB_R13C9:MIB_DSP5", "MIB_R13C9:MIB2_DSP5",
"MIB_R13C10:MIB_DSP6", "MIB_R13C10:MIB2_DSP6",
"MIB_R13C11:MIB_DSP7", "MIB_R13C11:MIB2_DSP7",
"MIB_R13C12:MIB_DSP8", "MIB_R13C12:MIB2_DSP8",
]
jobs = [
("ALU54_R13C7", "ALU54_3", FuzzConfig(job="ALU54_3", family="ECP5", device="LFE5U-25F", ncl="empty.ncl",
tiles=dsp_tiles)),
("ALU54_R13C11", "ALU54_7", FuzzConfig(job="ALU54_7", family="ECP5", device="LFE5U-25F", ncl="empty.ncl",
tiles=dsp_tiles)),
]
def b2hex(x):
res = 0
for i in range(len(x)):
if x[i]:
res |= 1 << i
return "0x{:014x}".format(res)
def main():
pytrellis.load_database("../../../database")
def per_job(job):
def get_substs(settings, mode="ALU54B"):
if mode == "NONE":
comment = "//"
else:
comment = ""
return dict(loc=loc, mode=mode, settings=",".join(["{}={}".format(k, v) for k, v in settings.items()]),
comment=comment)
loc, mult, cfg = job
cfg.setup()
empty_bitfile = cfg.build_design(cfg.ncl, {})
cfg.ncl = "dspconfig.ncl"
nonrouting.fuzz_enum_setting(cfg, "{}.MODE".format(mult), ["NONE", "ALU54B"],
lambda x: get_substs(settings={}, mode=x), empty_bitfile, False)
regs = ["INPUTC0", "INPUTC1",
"OPCODEOP0_0", "OPCODEOP0_1", "OPCODEOP1_0", "OPCODEOP1_1",
"OPCODEIN_0", "OPCODEIN_1",
"OUTPUT0", "OUTPUT1", "FLAG"]
clks = ["NONE", "CLK0", "CLK1", "CLK2", "CLK3"]
cens = ["CE0", "CE1", "CE2", "CE3"]
rsts = ["RST0", "RST1", "RST2", "RST3"]
for reg in regs:
nonrouting.fuzz_enum_setting(cfg, "{}.REG_{}_CLK".format(mult, reg), clks,
lambda x: get_substs(settings={"REG_{}_CLK".format(reg): x}), empty_bitfile,
False)
if not reg.startswith("OPCODEOP1"):
nonrouting.fuzz_enum_setting(cfg, "{}.REG_{}_CE".format(mult, reg), cens,
lambda x: get_substs(settings={"REG_{}_CE".format(reg): x}), empty_bitfile,
False)
nonrouting.fuzz_enum_setting(cfg, "{}.REG_{}_RST".format(mult, reg), rsts,
lambda x: get_substs(settings={"REG_{}_RST".format(reg): x}),
empty_bitfile,
False)
for clk in ["CLK0", "CLK1", "CLK2", "CLK3"]:
nonrouting.fuzz_enum_setting(cfg, "{}.{}_DIV".format(mult, clk), ["ENABLED", "DISABLED"],
lambda x: get_substs(settings={"{}_DIV".format(clk): x}), empty_bitfile, False)
nonrouting.fuzz_enum_setting(cfg, "{}.MCPAT_SOURCE".format(mult), ["STATIC", "DYNAMIC"],
lambda x: get_substs(settings={"MCPAT_SOURCE": x}), empty_bitfile, False)
nonrouting.fuzz_enum_setting(cfg, "{}.MASKPAT_SOURCE".format(mult), ["STATIC", "DYNAMIC"],
lambda x: get_substs(settings={"MASKPAT_SOURCE": x}), empty_bitfile, False)
nonrouting.fuzz_word_setting(cfg, "{}.MASK01".format(mult), 56,
lambda x: get_substs(settings={"MASK01": b2hex(x)}), empty_bitfile)
nonrouting.fuzz_word_setting(cfg, "{}.MCPAT".format(mult), 56,
lambda x: get_substs(settings={"MCPAT": b2hex(x)}), empty_bitfile)
nonrouting.fuzz_word_setting(cfg, "{}.MASKPAT".format(mult), 56,
lambda x: get_substs(settings={"MASKPAT": b2hex(x)}), empty_bitfile)
nonrouting.fuzz_word_setting(cfg, "{}.RNDPAT".format(mult), 56,
lambda x: get_substs(settings={"RNDPAT": b2hex(x)}), empty_bitfile)
nonrouting.fuzz_enum_setting(cfg, "{}.GSR".format(mult), ["DISABLED", "ENABLED"],
lambda x: get_substs(settings={"GSR": x}), empty_bitfile, False)
nonrouting.fuzz_enum_setting(cfg, "{}.RESETMODE".format(mult), ["SYNC", "ASYNC"],
lambda x: get_substs(settings={"RESETMODE": x}), empty_bitfile, False)
nonrouting.fuzz_enum_setting(cfg, "{}.MULT9_MODE".format(mult), ["DISABLED", "ENABLED"],
lambda x: get_substs(settings={"MULT9_MODE": x}), empty_bitfile, False)
nonrouting.fuzz_enum_setting(cfg, "{}.FORCE_ZERO_BARREL_SHIFT".format(mult), ["DISABLED", "ENABLED"],
lambda x: get_substs(settings={"FORCE_ZERO_BARREL_SHIFT": x}), empty_bitfile,
False)
nonrouting.fuzz_enum_setting(cfg, "{}.LEGACY".format(mult), ["DISABLED", "ENABLED"],
lambda x: get_substs(settings={"LEGACY": x}), empty_bitfile, False)
fuzzloops.parallel_foreach(jobs, per_job)
if __name__ == "__main__":
main()