| from fuzzconfig import FuzzConfig |
| import interconnect |
| import pytrellis |
| |
| jobs = [ |
| { |
| "cfg": FuzzConfig(job="CMUX_45k", family="ECP5", device="LFE5U-45F", ncl="cmux_45k.ncl", |
| tiles=["MIB_R10C39:EBR_CMUX_UL", "MIB_R10C40:CMUX_UL_0", "MIB_R10C41:CMUX_UR_0", |
| "MIB_R10C42:EBR_CMUX_UR", "MIB_R58C39:EBR_CMUX_LL", "MIB_R58C40:CMUX_LL_0", |
| "MIB_R58C41:CMUX_LR_0", "MIB_R58C42:EBR_CMUX_LR"]), |
| "cmux_outputs": ["R22C40_ULPCLK{}", "R22C40_URPCLK{}", "R46C40_LLPCLK{}", "R46C40_LRPCLK{}"], |
| "dcc_loc": "R34C40", |
| "dcs_loc": "R34C40", |
| "prefix": "45K_" |
| }, |
| { |
| "cfg": FuzzConfig(job="CMUX_25k", family="ECP5", device="LFE5U-25F", ncl="cmux_25k.ncl", |
| tiles=["MIB_R13C31:DSP_CMUX_UL", "MIB_R13C31:CMUX_UL_0", |
| "MIB_R13C32:CMUX_UR_0", "MIB_R13C32:DSP_CMUX_UR", |
| "MIB_R37C30:EBR_CMUX_LL_25K", "MIB_R37C31:CMUX_LL_0", |
| "MIB_R37C32:CMUX_LR_0", "MIB_R37C33:EBR_CMUX_LR_25K"]), |
| "cmux_outputs": ["R19C31_ULPCLK{}", "R19C31_URPCLK{}", "R31C31_LLPCLK{}", "R31C31_LRPCLK{}"], |
| "dcc_loc": "R25C31", |
| "dcs_loc": "R25C31", |
| "prefix": "25K_" |
| }, |
| { |
| "cfg": FuzzConfig(job="CMUX_85k", family="ECP5", device="LFE5U-85F", ncl="cmux_85k.ncl", |
| tiles=["MIB_R22C66:EBR_CMUX_UL", "MIB_R22C67:CMUX_UL_0", |
| "MIB_R22C68:CMUX_UR_0", "MIB_R22C69:EBR_CMUX_UR", |
| "MIB_R70C66:EBR_CMUX_LL", "MIB_R70C67:CMUX_LL_0", |
| "MIB_R70C68:CMUX_LR_0", "MIB_R70C69:EBR_CMUX_LR"]), |
| "cmux_outputs": ["R34C67_ULPCLK{}", "R34C67_URPCLK{}", "R58C67_LLPCLK{}", "R58C67_LRPCLK{}"], |
| "dcc_loc": "R46C67", |
| "dcs_loc": "R46C67", |
| "prefix": "85K_" |
| }, |
| ] |
| |
| |
| def get_sinks(job): |
| # Get the sinks to fuzz for a given cmux job |
| sinks = [] |
| for out in job["cmux_outputs"]: |
| sinks += [out.format(i) for i in range(16)] |
| for dcc in ["TL", "TR", "BL", "BR"]: |
| loc = job["dcc_loc"] |
| sinks.append("{}_JCLKI_DCC{}".format(loc, dcc)) |
| sinks.append("{}_JCE_DCC{}".format(loc, dcc)) |
| quad = dcc.replace("T", "U").replace("B", "L") |
| sinks.append("{}_{}CPCLKCIB0".format(loc, quad)) |
| for dcs in range(2): |
| loc = job["dcs_loc"] |
| sinks.append("{}_CLK0_DCS{}".format(loc, dcs)) |
| sinks.append("{}_CLK1_DCS{}".format(loc, dcs)) |
| sinks.append("{}_DCS{}CLK0".format(loc, dcs)) |
| sinks.append("{}_DCS{}CLK1".format(loc, dcs)) |
| sinks.append("{}_DCS{}".format(loc, dcs)) |
| sinks.append("{}_JSEL0_DCS{}".format(loc, dcs)) |
| sinks.append("{}_JSEL1_DCS{}".format(loc, dcs)) |
| sinks.append("{}_JMODESEL_DCS{}".format(loc, dcs)) |
| return sinks |
| |
| |
| def main(): |
| pytrellis.load_database("../../../database") |
| for job in jobs: |
| cfg = job["cfg"] |
| cfg.setup() |
| netnames = get_sinks(job) |
| interconnect.fuzz_interconnect_with_netnames(config=cfg, netnames=netnames, |
| netname_filter_union=False, |
| full_mux_style=True, |
| fc_prefix=job["prefix"]) |
| |
| |
| if __name__ == "__main__": |
| main() |