|
|
@ -2,15 +2,9 @@
|
|
|
|
|
|
|
|
|
|
|
|
from litex.build.tools import write_to_file
|
|
|
|
from litex.build.tools import write_to_file
|
|
|
|
from litex.build.tools import replace_in_file
|
|
|
|
from litex.build.tools import replace_in_file
|
|
|
|
from litex.build.generic_platform import *
|
|
|
|
|
|
|
|
from litex.build.xilinx import XilinxPlatform
|
|
|
|
|
|
|
|
from litex.build.lattice import LatticePlatform
|
|
|
|
|
|
|
|
from litex.soc.integration.builder import *
|
|
|
|
|
|
|
|
from litedram.gen import *
|
|
|
|
from litedram.gen import *
|
|
|
|
import subprocess
|
|
|
|
import subprocess
|
|
|
|
import os
|
|
|
|
import os
|
|
|
|
import sys
|
|
|
|
|
|
|
|
import yaml
|
|
|
|
|
|
|
|
import shutil
|
|
|
|
import shutil
|
|
|
|
|
|
|
|
|
|
|
|
def make_new_dir(base, added):
|
|
|
|
def make_new_dir(base, added):
|
|
|
@ -27,9 +21,6 @@ gen_src_dir = os.path.join(base_dir, "gen-src")
|
|
|
|
gen_dir = make_new_dir(base_dir, "generated")
|
|
|
|
gen_dir = make_new_dir(base_dir, "generated")
|
|
|
|
|
|
|
|
|
|
|
|
# Build the init code for microwatt-initialized DRAM
|
|
|
|
# Build the init code for microwatt-initialized DRAM
|
|
|
|
#
|
|
|
|
|
|
|
|
# XXX Not working yet
|
|
|
|
|
|
|
|
#
|
|
|
|
|
|
|
|
def build_init_code(build_dir, is_sim):
|
|
|
|
def build_init_code(build_dir, is_sim):
|
|
|
|
|
|
|
|
|
|
|
|
# More path fudging
|
|
|
|
# More path fudging
|
|
|
@ -76,48 +67,17 @@ def generate_one(t):
|
|
|
|
print("Generating target:", t)
|
|
|
|
print("Generating target:", t)
|
|
|
|
|
|
|
|
|
|
|
|
# Is it a simulation ?
|
|
|
|
# Is it a simulation ?
|
|
|
|
is_sim = t is "sim"
|
|
|
|
is_sim = "sim" in t
|
|
|
|
|
|
|
|
|
|
|
|
# Muck with directory path
|
|
|
|
# Muck with directory path
|
|
|
|
build_dir = make_new_dir(build_top_dir, t)
|
|
|
|
build_dir = make_new_dir(build_top_dir, t)
|
|
|
|
t_dir = make_new_dir(gen_dir, t)
|
|
|
|
t_dir = make_new_dir(gen_dir, t)
|
|
|
|
|
|
|
|
|
|
|
|
# Grab config file
|
|
|
|
cmd = ["litedram_gen", "--output-dir=%s" % build_dir]
|
|
|
|
cfile = os.path.join(gen_src_dir, t + ".yml")
|
|
|
|
|
|
|
|
core_config = yaml.load(open(cfile).read(), Loader=yaml.Loader)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
### TODO: Make most stuff below a function in litedram gen.py and
|
|
|
|
|
|
|
|
### call it rather than duplicate it
|
|
|
|
|
|
|
|
###
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Convert YAML elements to Python/LiteX
|
|
|
|
|
|
|
|
for k, v in core_config.items():
|
|
|
|
|
|
|
|
replaces = {"False": False, "True": True, "None": None}
|
|
|
|
|
|
|
|
for r in replaces.keys():
|
|
|
|
|
|
|
|
if v == r:
|
|
|
|
|
|
|
|
core_config[k] = replaces[r]
|
|
|
|
|
|
|
|
if "clk_freq" in k:
|
|
|
|
|
|
|
|
core_config[k] = float(core_config[k])
|
|
|
|
|
|
|
|
if k == "sdram_module":
|
|
|
|
|
|
|
|
core_config[k] = getattr(litedram_modules, core_config[k])
|
|
|
|
|
|
|
|
if k == "sdram_phy":
|
|
|
|
|
|
|
|
core_config[k] = getattr(litedram_phys, core_config[k])
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Generate core
|
|
|
|
|
|
|
|
if is_sim:
|
|
|
|
if is_sim:
|
|
|
|
platform = SimPlatform("", io=[])
|
|
|
|
cmd.append("--sim")
|
|
|
|
elif core_config["sdram_phy"] in [litedram_phys.ECP5DDRPHY]:
|
|
|
|
cmd.append("%s.yml" % t)
|
|
|
|
platform = LatticePlatform("LFE5UM5G-45F-8BG381C", io=[], toolchain="trellis")
|
|
|
|
subprocess.check_call(cmd)
|
|
|
|
elif core_config["sdram_phy"] in [litedram_phys.A7DDRPHY, litedram_phys.K7DDRPHY, litedram_phys.V7DDRPHY]:
|
|
|
|
|
|
|
|
platform = XilinxPlatform("", io=[], toolchain="vivado")
|
|
|
|
|
|
|
|
else:
|
|
|
|
|
|
|
|
raise ValueError("Unsupported SDRAM PHY: {}".format(core_config["sdram_phy"]))
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
soc = LiteDRAMCore(platform, core_config, is_sim = is_sim, integrated_rom_size=0x6000)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Build into build_dir
|
|
|
|
|
|
|
|
builder = Builder(soc, output_dir=build_dir, compile_gateware=False)
|
|
|
|
|
|
|
|
vns = builder.build(build_name="litedram_core", regular_comb=False)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
# Grab generated gatewar dir
|
|
|
|
# Grab generated gatewar dir
|
|
|
|
gw_dir = os.path.join(build_dir, "gateware")
|
|
|
|
gw_dir = os.path.join(build_dir, "gateware")
|
|
|
|