From 2cc322e65d736f99abe36895625574b76f67903d Mon Sep 17 00:00:00 2001 From: Miodrag Milanovic Date: Mon, 22 Nov 2021 19:10:11 +0100 Subject: [PATCH 1/4] Add initial support for Tang Primer board --- litex_boards/platforms/sipeed_tang_primer.py | 53 +++++++++++ litex_boards/targets/sipeed_tang_primer.py | 93 ++++++++++++++++++++ 2 files changed, 146 insertions(+) create mode 100644 litex_boards/platforms/sipeed_tang_primer.py create mode 100755 litex_boards/targets/sipeed_tang_primer.py diff --git a/litex_boards/platforms/sipeed_tang_primer.py b/litex_boards/platforms/sipeed_tang_primer.py new file mode 100644 index 0000000..2b0f6aa --- /dev/null +++ b/litex_boards/platforms/sipeed_tang_primer.py @@ -0,0 +1,53 @@ +# +# This file is part of LiteX-Boards. +# +# Copyright (c) 2021 Miodrag Milanovic +# SPDX-License-Identifier: BSD-2-Clause + +from migen import * + +from litex.build.generic_platform import * +from litex.build.anlogic.platform import AnlogicPlatform +from litex.build.openfpgaloader import OpenFPGALoader + +# IOs ---------------------------------------------------------------------------------------------- + +_io = [ + # Clk / Rst + ("clk24", 0, Pins("K14"), IOStandard("LVCMOS33")), + + # RGB LED + ("user_led", 0, Pins("R3"), IOStandard("LVCMOS33")), # R + ("user_led", 1, Pins("J14"), IOStandard("LVCMOS33")), # G + ("user_led", 2, Pins("P13"), IOStandard("LVCMOS33")), # B + + # Buttons. + ("user_btn", 0, Pins("K16"), IOStandard("LVCMOS33")), # USER_KEY + + # Serial + ("serial", 0, + Subsignal("tx", Pins("J13")), + Subsignal("rx", Pins("H13")), + IOStandard("LVCMOS33") + ), +] + +# Connectors --------------------------------------------------------------------------------------- + +_connectors = [] + +# Platform ----------------------------------------------------------------------------------------- + +class Platform(AnlogicPlatform): + default_clk_name = "clk24" + default_clk_period = 1e9/24e6 + + def __init__(self): + AnlogicPlatform.__init__(self, "EG4S20BG256", _io, _connectors, toolchain="td") + + def create_programmer(self): + return OpenFPGALoader("licheeTang") + + def do_finalize(self, fragment): + AnlogicPlatform.do_finalize(self, fragment) + self.add_period_constraint(self.lookup_request("clk24", loose=True), 1e9/24e6) diff --git a/litex_boards/targets/sipeed_tang_primer.py b/litex_boards/targets/sipeed_tang_primer.py new file mode 100755 index 0000000..df0a981 --- /dev/null +++ b/litex_boards/targets/sipeed_tang_primer.py @@ -0,0 +1,93 @@ +#!/usr/bin/env python3 + +# +# This file is part of LiteX-Boards. +# +# Copyright (c) 2021 Miodrag Milanovic +# SPDX-License-Identifier: BSD-2-Clause + + +import argparse + +from migen import * +from migen.genlib.resetsync import AsyncResetSynchronizer + +from litex_boards.platforms import sipeed_tang_primer + +from litex.build.generic_platform import * + +from litex.soc.cores.clock import * +from litex.soc.integration.soc_core import * +from litex.soc.integration.builder import * +from litex.soc.cores.led import LedChaser + + +# CRG ---------------------------------------------------------------------------------------------- + +class _CRG(Module): + def __init__(self, platform, sys_clk_freq): + self.clock_domains.cd_sys = ClockDomain() + + # # # + + # Clk / Rst. + clk24 = platform.request("clk24") + rst_n = platform.request("user_btn", 0) + + self.comb += self.cd_sys.clk.eq(clk24) + self.specials += AsyncResetSynchronizer(self.cd_sys, ~rst_n) + +# BaseSoC ------------------------------------------------------------------------------------------ + +class BaseSoC(SoCCore): + def __init__(self, sys_clk_freq=int(24e6), with_led_chaser=True, **kwargs): + platform = sipeed_tang_primer.Platform() + + # SoCCore ---------------------------------------------------------------------------------- + SoCCore.__init__(self, platform, sys_clk_freq, + ident = "LiteX SoC on Tang Primer", + ident_version = True, + **kwargs + ) + + # CRG -------------------------------------------------------------------------------------- + self.submodules.crg = _CRG(platform, sys_clk_freq) + + # Leds ------------------------------------------------------------------------------------- + if with_led_chaser: + self.submodules.leds = LedChaser( + pads = platform.request_all("user_led"), + sys_clk_freq = sys_clk_freq) + +# Build -------------------------------------------------------------------------------------------- + +def main(): + parser = argparse.ArgumentParser(description="LiteX SoC on Tang Primer") + parser.add_argument("--build", action="store_true", help="Build bitstream") + parser.add_argument("--load", action="store_true", help="Load bitstream") + parser.add_argument("--flash", action="store_true", help="Flash Bitstream") + parser.add_argument("--sys-clk-freq",default=24e6, help="System clock frequency (default: 24MHz)") + builder_args(parser) + soc_core_args(parser) + args = parser.parse_args() + + soc = BaseSoC( + sys_clk_freq = int(float(args.sys_clk_freq)), + **soc_core_argdict(args) + ) + + builder = Builder(soc, **builder_argdict(args)) + builder.build(run=args.build) + + if args.load: + prog = soc.platform.create_programmer() + prog.load_bitstream(os.path.join(builder.gateware_dir, soc.build_name + ".bit")) + + if args.flash: + prog = soc.platform.create_programmer() + prog.flash(0, os.path.join(builder.gateware_dir, soc.build_name + ".bit")) + + + +if __name__ == "__main__": + main() From b44d9efc1f2b313652627e1e187b14da5b964585 Mon Sep 17 00:00:00 2001 From: Miodrag Milanovic Date: Tue, 23 Nov 2021 14:52:48 +0100 Subject: [PATCH 2/4] Remove from test targets --- test/test_targets.py | 2 ++ 1 file changed, 2 insertions(+) diff --git a/test/test_targets.py b/test/test_targets.py index e1863fb..bfb7dd1 100644 --- a/test/test_targets.py +++ b/test/test_targets.py @@ -21,6 +21,7 @@ class TestTargets(unittest.TestCase): "efinix_trion_t20_bga256_dev_kit", # Reason: Require Efinity toolchain. "efinix_trion_t20_mipi_dev_kit", # Reason: Require Efinity toolchain. "efinix_xyloni_dev_kit", # Reason: Require Efinity toolchain. + "sipeed_tang_primer", # Reason: Require Anlogic toolchain. ] excluded_targets = [ "simple", # Reason: Generic target. @@ -29,6 +30,7 @@ class TestTargets(unittest.TestCase): "efinix_trion_t20_bga256_dev_kit", # Reason: Require Efinity toolchain. "efinix_trion_t20_mipi_dev_kit", # Reason: Require Efinity toolchain. "efinix_xyloni_dev_kit", # Reason: Require Efinity toolchain. + "sipeed_tang_primer", # Reason: Require Anlogic toolchain. ] # Build simple design for all platforms. From b0dcd96964e0e1d968b050819dedd504098dfd1a Mon Sep 17 00:00:00 2001 From: Miodrag Milanovic Date: Tue, 23 Nov 2021 14:58:08 +0100 Subject: [PATCH 3/4] added comments --- litex_boards/platforms/sipeed_tang_primer.py | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/litex_boards/platforms/sipeed_tang_primer.py b/litex_boards/platforms/sipeed_tang_primer.py index 2b0f6aa..b45de67 100644 --- a/litex_boards/platforms/sipeed_tang_primer.py +++ b/litex_boards/platforms/sipeed_tang_primer.py @@ -4,6 +4,14 @@ # Copyright (c) 2021 Miodrag Milanovic # SPDX-License-Identifier: BSD-2-Clause +# +# Tech data: +# https://tang.sipeed.com/en/hardware-overview/lichee-tang/ +# +# Board diagram/pinout: +# https://tang.sipeed.com/hardware-overview/lichee-tang/images/newtang_pinout.png +# https://tang.sipeed.com/hardware-overview/lichee-tang/images/E203_pin.png + from migen import * from litex.build.generic_platform import * From 6954dd25eb6b5edbf5f175a72fc57e57c03af4a4 Mon Sep 17 00:00:00 2001 From: Miodrag Milanovic Date: Tue, 23 Nov 2021 15:26:54 +0100 Subject: [PATCH 4/4] Set minimal core, since full does not work for some reason --- litex_boards/targets/sipeed_tang_primer.py | 4 ++++ 1 file changed, 4 insertions(+) diff --git a/litex_boards/targets/sipeed_tang_primer.py b/litex_boards/targets/sipeed_tang_primer.py index df0a981..4e8a996 100755 --- a/litex_boards/targets/sipeed_tang_primer.py +++ b/litex_boards/targets/sipeed_tang_primer.py @@ -43,6 +43,10 @@ class BaseSoC(SoCCore): def __init__(self, sys_clk_freq=int(24e6), with_led_chaser=True, **kwargs): platform = sipeed_tang_primer.Platform() + # Set CPU variant + if kwargs.get("cpu_type", "vexriscv") == "vexriscv": + kwargs["cpu_variant"] = "minimal" + # SoCCore ---------------------------------------------------------------------------------- SoCCore.__init__(self, platform, sys_clk_freq, ident = "LiteX SoC on Tang Primer",