blob: 3dd6127bd4f6bb06a779b9655a2862694d0db333 [file] [log] [blame]
from fuzzconfig import FuzzConfig
import nonrouting
import fuzzloops
import nets
import pytrellis
import re
cfg = FuzzConfig(job="PLC2REG", family="MachXO2", device="LCMXO2-1200HC", ncl="empty.ncl", tiles=["R10C6:PLC"])
def main():
pytrellis.load_database("../../../database")
cfg.setup()
empty_bitfile = cfg.build_design(cfg.ncl, {})
cfg.ncl = "lsr.ncl"
def per_lsr(lsrn):
slices = { "0" : "A",
"1" : "B",
"2" : "C",
"3" : "D"
}
def get_substs(lsrmux="LSR", srmode="LSR_OVER_CE", lsronmux="0"):
if lsrmux == "INV":
lsrmux = "LSR:::LSR=#INV"
return dict(s=slices[lsrn], l=lsrn, lsrmux=lsrmux, srmode=srmode, lsronmux=lsronmux)
nonrouting.fuzz_enum_setting(cfg, "LSR{}.LSRMUX".format(lsrn), ["LSR", "INV"],
lambda x: get_substs(lsrmux=x),
empty_bitfile, True)
nonrouting.fuzz_enum_setting(cfg, "LSR{}.SRMODE".format(lsrn), ["LSR_OVER_CE", "ASYNC"],
lambda x: get_substs(srmode=x),
empty_bitfile, True)
nonrouting.fuzz_enum_setting(cfg, "LSR{}.LSRONMUX".format(lsrn), ["0", "LSRMUX"],
lambda x: get_substs(lsronmux=x),
empty_bitfile, True)
fuzzloops.parallel_foreach(["0", "1", "2", "3"], per_lsr)
if __name__ == "__main__":
main()