| #!/usr/bin/env python3 | 
 | # -*- coding: utf-8 -*- | 
 | # | 
 | # Copyright (C) 2017-2020  The Project X-Ray Authors. | 
 | # | 
 | # Use of this source code is governed by a ISC-style | 
 | # license that can be found in the LICENSE file or at | 
 | # https://opensource.org/licenses/ISC | 
 | # | 
 | # SPDX-License-Identifier: ISC | 
 |  | 
 | import argparse | 
 |  | 
 | from migen import * | 
 |  | 
 | from litex.boards.platforms import arty | 
 | from litex.soc.integration.soc_core import * | 
 | from litex.soc.integration.builder import * | 
 |  | 
 | from litex.soc.cores.clock import * | 
 |  | 
 | # CRG ---------------------------------------------------------------------------------------------- | 
 |  | 
 |  | 
 | class _CRG(Module): | 
 |     def __init__(self, platform, sys_clk_freq): | 
 |         self.clock_domains.cd_sys = ClockDomain() | 
 |  | 
 |         # # # | 
 |  | 
 |         self.cd_sys.clk.attr.add("keep") | 
 |  | 
 |         self.submodules.pll = pll = S7PLL(speedgrade=-1) | 
 |         self.comb += pll.reset.eq(~platform.request("cpu_reset")) | 
 |         pll_clkin = Signal() | 
 |         pll.register_clkin(pll_clkin, 100e6) | 
 |         pll.create_clkout(self.cd_sys, sys_clk_freq) | 
 |  | 
 |         self.specials += Instance( | 
 |             "BUFG", i_I=platform.request("clk100"), o_O=pll_clkin) | 
 |  | 
 |  | 
 | # BaseSoC ------------------------------------------------------------------------------------------ | 
 |  | 
 |  | 
 | class BaseSoC(SoCCore): | 
 |     def __init__( | 
 |             self, sys_clk_freq=int(50e6), integrated_rom_size=0x8000, | 
 |             **kwargs): | 
 |         platform = arty.Platform() | 
 |         SoCCore.__init__( | 
 |             self, | 
 |             platform, | 
 |             clk_freq=sys_clk_freq, | 
 |             integrated_rom_size=integrated_rom_size, | 
 |             integrated_sram_size=0x8000, | 
 |             ident="MiniLitex", | 
 |             cpu_variant="lite", | 
 |             **kwargs) | 
 |  | 
 |         self.submodules.crg = _CRG(platform, sys_clk_freq) | 
 |  | 
 |  | 
 | # Build -------------------------------------------------------------------------------------------- | 
 |  | 
 |  | 
 | def main(): | 
 |     parser = argparse.ArgumentParser(description="LiteX SoC on Arty") | 
 |     builder_args(parser) | 
 |     soc_core_args(parser) | 
 |     args = parser.parse_args() | 
 |  | 
 |     cls = BaseSoC | 
 |     soc = cls(**soc_core_argdict(args)) | 
 |     builder = Builder(soc, **builder_argdict(args)) | 
 |     builder.build() | 
 |  | 
 |  | 
 | if __name__ == "__main__": | 
 |     main() |