| #!/usr/bin/env python3 |
| |
| # This file is Copyright (c) 2015-2020 Florent Kermarrec <florent@enjoy-digital.fr> |
| # License: BSD |
| |
| import argparse |
| |
| from migen import Module, ClockDomain |
| |
| from litex_boards.platforms import arty |
| from litex.build.xilinx import VivadoProgrammer |
| |
| from litex.soc.cores.clock import S7PLL, S7IDELAYCTRL |
| from litex.soc.integration.soc_sdram import SoCSDRAM |
| from litex.soc.integration.builder import Builder |
| |
| from litedram.init import get_sdram_phy_py_header |
| from litedram.modules import MT41K128M16 |
| from litedram.phy import s7ddrphy |
| |
| # CRG ---------------------------------------------------------------------------------------------- |
| |
| |
| class _CRG(Module): |
| def __init__(self, platform, sys_clk_freq): |
| self.clock_domains.cd_sys = ClockDomain() |
| self.clock_domains.cd_sys4x = ClockDomain(reset_less=True) |
| self.clock_domains.cd_sys4x_dqs = ClockDomain(reset_less=True) |
| self.clock_domains.cd_clk200 = ClockDomain() |
| |
| # # # |
| |
| self.submodules.pll = pll = S7PLL(speedgrade=-1) |
| self.comb += pll.reset.eq(~platform.request("cpu_reset")) |
| pll.register_clkin(platform.request("clk100"), 100e6) |
| pll.create_clkout(self.cd_sys, sys_clk_freq) |
| pll.create_clkout(self.cd_sys4x, 4 * sys_clk_freq) |
| pll.create_clkout(self.cd_sys4x_dqs, 4 * sys_clk_freq, phase=90) |
| pll.create_clkout(self.cd_clk200, 200e6) |
| |
| self.submodules.idelayctrl = S7IDELAYCTRL(self.cd_clk200) |
| |
| |
| # BaseSoC ------------------------------------------------------------------------------------------ |
| |
| |
| class BaseSoC(SoCSDRAM): |
| def __init__(self): |
| platform = arty.Platform() |
| sys_clk_freq = int(50e6) |
| |
| # SoCSDRAM --------------------------------------------------------------------------------- |
| SoCSDRAM.__init__( |
| self, |
| platform, |
| clk_freq=sys_clk_freq, |
| ident="Minimal Arty DDR3 Design for tests with Project X-Ray", |
| ident_version=True, |
| cpu_type=None, |
| l2_size=16, |
| uart_name="bridge" |
| ) |
| |
| # CRG -------------------------------------------------------------------------------------- |
| self.submodules.crg = _CRG(platform, sys_clk_freq) |
| |
| # DDR3 SDRAM ------------------------------------------------------------------------------- |
| if not self.integrated_main_ram_size: |
| self.submodules.ddrphy = s7ddrphy.A7DDRPHY( |
| platform.request("ddram"), |
| memtype="DDR3", |
| nphases=4, |
| sys_clk_freq=sys_clk_freq |
| ) |
| self.add_csr("ddrphy") |
| sdram_module = MT41K128M16(sys_clk_freq, "1:4") |
| self.register_sdram( |
| self.ddrphy, |
| geom_settings=sdram_module.geom_settings, |
| timing_settings=sdram_module.timing_settings |
| ) |
| |
| def generate_sdram_phy_py_header(self): |
| f = open("sdram_init.py", "w") |
| f.write( |
| get_sdram_phy_py_header( |
| self.sdram.controller.settings.phy, |
| self.sdram.controller.settings.timing |
| ) |
| ) |
| f.close() |
| |
| |
| # Load --------------------------------------------------------------------------------------------- |
| |
| |
| def load(): |
| prog = VivadoProgrammer() |
| prog.load_bitstream("build/gateware/top.bit") |
| |
| |
| # Build -------------------------------------------------------------------------------------------- |
| |
| |
| def main(): |
| parser = argparse.ArgumentParser( |
| description="Minimal Arty DDR3 Design for tests with Project X-Ray" |
| ) |
| parser.add_argument("--build", action="store_true", help="Build bitstream") |
| parser.add_argument("--load", action="store_true", help="Load bitstream") |
| args = parser.parse_args() |
| |
| if args.load: |
| load() |
| soc = BaseSoC() |
| builder = Builder(soc, output_dir="build", csr_csv="csr.csv") |
| builder.build(run=args.build) |
| soc.generate_sdram_phy_py_header() |
| |
| |
| if __name__ == "__main__": |
| main() |