targets/sim: add rom-init

This commit is contained in:
Florent Kermarrec 2018-09-20 01:14:00 +02:00
parent 1dbf591e78
commit f62df5023f

View file

@ -144,6 +144,8 @@ def main():
parser = argparse.ArgumentParser(description="Generic LiteX SoC Simulation") parser = argparse.ArgumentParser(description="Generic LiteX SoC Simulation")
builder_args(parser) builder_args(parser)
soc_sdram_args(parser) soc_sdram_args(parser)
parser.add_argument("--rom-init", default=None,
help="rom_init file")
parser.add_argument("--ram-init", default=None, parser.add_argument("--ram-init", default=None,
help="ram_init file") help="ram_init file")
parser.add_argument("--with-sdram", action="store_true", parser.add_argument("--with-sdram", action="store_true",
@ -156,15 +158,17 @@ def main():
help="enable Analyzer support") help="enable Analyzer support")
args = parser.parse_args() args = parser.parse_args()
kwargs = soc_sdram_argdict(args)
sim_config = SimConfig(default_clk="sys_clk") sim_config = SimConfig(default_clk="sys_clk")
sim_config.add_module("serial2console", "serial") sim_config.add_module("serial2console", "serial")
integrated_main_ram_init = [] if args.rom_init:
kwargs["integrated_rom_init"] = get_mem_data(args.rom_init)
kwargs["integrated_main_ram_size"] = 0x10000
if not args.with_sdram: if not args.with_sdram:
if args.ram_init is not None: if args.ram_init is not None:
integrated_main_ram_init = get_mem_data(args.ram_init) kwargs["integrated_main_ram_init"] = get_mem_data(args.ram_init)
integrated_main_ram_size = max(len(integrated_main_ram_init), 0x10000) kwargs["integrated_main_ram_size"] = max(len(kwargs["integrated_main_ram_init"]), 0x10000)
else:
integrated_main_ram_size = 0
if args.with_ethernet: if args.with_ethernet:
sim_config.add_module("ethernet", "eth", args={"interface": "tap0", "ip": "192.168.1.100"}) sim_config.add_module("ethernet", "eth", args={"interface": "tap0", "ip": "192.168.1.100"})
if args.with_etherbone: if args.with_etherbone:
@ -174,9 +178,7 @@ def main():
with_ethernet=args.with_ethernet, with_ethernet=args.with_ethernet,
with_etherbone=args.with_etherbone, with_etherbone=args.with_etherbone,
with_analyzer=args.with_analyzer, with_analyzer=args.with_analyzer,
integrated_main_ram_size=integrated_main_ram_size, **kwargs)
integrated_main_ram_init=integrated_main_ram_init,
**soc_sdram_argdict(args))
builder = Builder(soc, **builder_argdict(args)) builder = Builder(soc, **builder_argdict(args))
builder.build(sim_config=sim_config) builder.build(sim_config=sim_config)