def get_domains(interfacelist, outchannellist, inchannellist): domaindict = {} for interface in sorted(interfacelist, key=lambda x: x.priority, reverse=True): if not interface.domain in domaindict: domaindict[interface.domain] = DomainDefinition(interface.domain) domaindict[interface.domain].append_interface(interface) for outchannel in sorted(outchannellist, key=lambda x: x.name): if not outchannel.domain in domaindict: domaindict[outchannel.domain] = DomainDefinition(outchannel.domain) domaindict[outchannel.domain].append_outchannel(outchannel) for inchannel in sorted(inchannellist, key=lambda x: x.name): if not inchannel.domain in domaindict: domaindict[inchannel.domain] = DomainDefinition(inchannel.domain) domaindict[inchannel.domain].append_inchannel(inchannel) domainlist = list(domaindict.values()) return domainlist
def main(): INFO = "test for system_generator.py" VERSION = "ver.1.0.0" USAGE = "Usage: python system_generator.py name" def showVersion(): print(INFO) print(VERSION) print(USAGE) sys.exit() optparser = OptionParser() optparser.add_option("-v","--version",action="store_true",dest="showversion", default=False,help="Show the version") (options, args) = optparser.parse_args() if options.showversion: showVersion() #if len(args) < 1: # showVersion() domains = [] interface0 = InterfaceDefinition('Core0', 'MCore', 'Node0', mode='readwrite', mask=True, addrlen=20, datawidth=32, maskwidth=4) interface1 = InterfaceDefinition('Core1', 'MCore', 'Node0', mode='readwrite', mask=True, addrlen=20, datawidth=32, maskwidth=4) interface2 = InterfaceDefinition('Core2', 'NCore', 'Node1', mode='readwrite', mask=True, addrlen=20, datawidth=32, maskwidth=4) interface3 = InterfaceDefinition('Core3', 'NCore', 'Node1', mode='readwrite', mask=True, addrlen=20, datawidth=32, maskwidth=4) domain0 = DomainDefinition('MCore') domain0.append_interface( interface0 ) domain0.append_interface( interface1 ) domains.append( domain0 ) domain1 = DomainDefinition('NCore') domain1.append_interface( interface2 ) domain1.append_interface( interface3 ) domains.append( domain1 ) memoryspacelist = [] memoryspace0 = MemorySpaceDefinition('Node0', 128*1024, memtype='cache', mask=True, offset=0, cache_capacity=4*1024, accessors=[]) memoryspace0.append_accessor( interface0.name ) memoryspace0.append_accessor( interface1.name ) memoryspacelist.append( memoryspace0 ) memoryspace1 = MemorySpaceDefinition('Node1', 128*1024, memtype='cache', mask=True, offset=0, cache_capacity=4*1024, accessors=[]) memoryspace1.append_accessor( interface2.name ) memoryspace1.append_accessor( interface3.name ) memoryspacelist.append( memoryspace1 ) offchipmemory = OffchipMemoryDefinition('DRAM', 512*1024*1024) offchipmemory.append_accessor( memoryspace0.name ) offchipmemory.append_accessor( memoryspace1.name ) env = Environment(loader=FileSystemLoader(TEMPLATE_DIR)) systemdef = generate(env, domains, memoryspacelist, offchipmemory) print(systemdef)
def main(): INFO = "test for controller_generator.py" VERSION = "ver.1.0.0" USAGE = "Usage: python controller_generator.py name" def showVersion(): print(INFO) print(VERSION) print(USAGE) sys.exit() optparser = OptionParser() optparser.add_option("-v","--version",action="store_true",dest="showversion", default=False,help="Show the version") (options, args) = optparser.parse_args() if options.showversion: showVersion() #if len(args) < 1: # showVersion() domains = [] interface0 = InterfaceDefinition('Core0', 'MCore', 'Node0', mode='readwrite', mask=True, addrlen=20, datawidth=32, maskwidth=4) interface1 = InterfaceDefinition('Core1', 'MCore', 'Node0', mode='readwrite', mask=True, addrlen=20, datawidth=32, maskwidth=4) interface2 = InterfaceDefinition('Core2', 'NCore', 'Node1', mode='readwrite', mask=True, addrlen=20, datawidth=32, maskwidth=4) interface3 = InterfaceDefinition('Core3', 'NCore', 'Node1', mode='readwrite', mask=True, addrlen=20, datawidth=32, maskwidth=4) domain0 = DomainDefinition('MCore') domain0.append_interface( interface0 ) domain0.append_interface( interface1 ) domains.append( domain0 ) domain1 = DomainDefinition('NCore') domain1.append_interface( interface2 ) domain1.append_interface( interface3 ) domains.append( domain1 ) env = Environment(loader=FileSystemLoader(TEMPLATE_DIR)) controllerdef = generate(env, domains) print(controllerdef)
def main(): INFO = "test for system_generator.py" VERSION = "ver.1.0.0" USAGE = "Usage: python system_generator.py name" def showVersion(): print(INFO) print(VERSION) print(USAGE) sys.exit() optparser = OptionParser() optparser.add_option("-v", "--version", action="store_true", dest="showversion", default=False, help="Show the version") (options, args) = optparser.parse_args() if options.showversion: showVersion() #if len(args) < 1: # showVersion() domains = [] interface0 = InterfaceDefinition('Core0', 'MCore', 'Node0', mode='readwrite', mask=True, addrlen=20, datawidth=32, maskwidth=4) interface1 = InterfaceDefinition('Core1', 'MCore', 'Node0', mode='readwrite', mask=True, addrlen=20, datawidth=32, maskwidth=4) interface2 = InterfaceDefinition('Core2', 'NCore', 'Node1', mode='readwrite', mask=True, addrlen=20, datawidth=32, maskwidth=4) interface3 = InterfaceDefinition('Core3', 'NCore', 'Node1', mode='readwrite', mask=True, addrlen=20, datawidth=32, maskwidth=4) domain0 = DomainDefinition('MCore') domain0.append_interface(interface0) domain0.append_interface(interface1) domains.append(domain0) domain1 = DomainDefinition('NCore') domain1.append_interface(interface2) domain1.append_interface(interface3) domains.append(domain1) memoryspacelist = [] memoryspace0 = MemorySpaceDefinition('Node0', 128 * 1024, memtype='cache', mask=True, offset=0, cache_capacity=4 * 1024, accessors=[]) memoryspace0.append_accessor(interface0.name) memoryspace0.append_accessor(interface1.name) memoryspacelist.append(memoryspace0) memoryspace1 = MemorySpaceDefinition('Node1', 128 * 1024, memtype='cache', mask=True, offset=0, cache_capacity=4 * 1024, accessors=[]) memoryspace1.append_accessor(interface2.name) memoryspace1.append_accessor(interface3.name) memoryspacelist.append(memoryspace1) offchipmemory = OffchipMemoryDefinition('DRAM', 512 * 1024 * 1024) offchipmemory.append_accessor(memoryspace0.name) offchipmemory.append_accessor(memoryspace1.name) env = Environment(loader=FileSystemLoader(TEMPLATE_DIR)) systemdef = generate(env, domains, memoryspacelist, offchipmemory) print(systemdef)