From 451b4f4419951e7ac2d9c1d08b6fe9c2eba50e83 Mon Sep 17 00:00:00 2001 From: mwojcik Date: Thu, 5 Dec 2024 14:22:38 +0800 Subject: [PATCH] gateware: add extra ident info, source version --- flake.nix | 4 ++++ src/gateware/config.py | 10 ++++++++++ src/gateware/kasli_soc.py | 8 ++++---- src/gateware/zc706.py | 8 ++++---- 4 files changed, 22 insertions(+), 8 deletions(-) diff --git a/flake.nix b/flake.nix index c9eb581..c98e1b8 100644 --- a/flake.nix +++ b/flake.nix @@ -12,6 +12,7 @@ zynqpkgs = zynq-rs.packages.x86_64-linux; artiqpkgs = artiq.packages.x86_64-linux; llvmPackages_11 = zynq-rs.llvmPackages_11; + zynqRev = self.sourceInfo.rev or "unknown"; rust = zynq-rs.rust; rustPlatform = zynq-rs.rustPlatform; @@ -137,6 +138,7 @@ llvmPackages_11.clang-unwrapped ]; buildPhase = '' + export ZYNQ_REV=${zynqRev} export XARGO_RUST_SRC="${rust}/lib/rustlib/src/rust/library" export CLANG_EXTRA_INCLUDE_DIR="${llvmPackages_11.clang-unwrapped.lib}/lib/clang/11.1.0/include" export CARGO_HOME=$(mktemp -d cargo-home.XXX) @@ -164,6 +166,7 @@ ]; } '' + export ZYNQ_REV=${zynqRev} python ${./src/gateware}/${target}.py -g build ${if json == null then "-V ${variant}" else json} mkdir -p $out $out/nix-support cp build/top.bit $out @@ -384,6 +387,7 @@ artiqpkgs.vivado binutils-arm ]; + ZYNQ_REV="${zynqRev}"; XARGO_RUST_SRC = "${rust}/lib/rustlib/src/rust/library"; CLANG_EXTRA_INCLUDE_DIR = "${llvmPackages_11.clang-unwrapped.lib}/lib/clang/11.1.0/include"; ZYNQ_RS = "${zynq-rs}"; diff --git a/src/gateware/config.py b/src/gateware/config.py index 78f97a4..f13475c 100644 --- a/src/gateware/config.py +++ b/src/gateware/config.py @@ -1,5 +1,15 @@ +import os +from artiq._version import get_version from misoc.integration import cpu_interface + +def generate_ident(variant): + return "{}+{};{}".format( + get_version().split(".")[0], + os.getenv("ZYNQ_REV", default="unknown")[:8], + variant, + ) + def write_csr_file(soc, filename): with open(filename, "w") as f: f.write(cpu_interface.get_csr_rust( diff --git a/src/gateware/kasli_soc.py b/src/gateware/kasli_soc.py index d4fa94b..675a859 100755 --- a/src/gateware/kasli_soc.py +++ b/src/gateware/kasli_soc.py @@ -27,7 +27,7 @@ import analyzer import acpki as acpki_lib import drtio_aux_controller import zynq_clocking -from config import write_csr_file, write_mem_file, write_rustc_cfg_file +from config import generate_ident, write_csr_file, write_mem_file, write_rustc_cfg_file eem_iostandard_dict = { 0: "LVDS_25", @@ -115,7 +115,7 @@ class GenericStandalone(SoCCore): platform.toolchain.bitstream_commands.extend([ "set_property BITSTREAM.GENERAL.COMPRESS True [current_design]", ]) - ident = description["variant"] + ident = generate_ident(description["variant"]) if self.acpki: ident = "acpki_" + ident SoCCore.__init__(self, platform=platform, csr_data_width=32, ident=ident, ps_cd_sys=False) @@ -229,7 +229,7 @@ class GenericMaster(SoCCore): platform.toolchain.bitstream_commands.extend([ "set_property BITSTREAM.GENERAL.COMPRESS True [current_design]", ]) - ident = description["variant"] + ident = generate_ident(description["variant"]) if self.acpki: ident = "acpki_" + ident SoCCore.__init__(self, platform=platform, csr_data_width=32, ident=ident, ps_cd_sys=False) @@ -438,7 +438,7 @@ class GenericSatellite(SoCCore): platform.toolchain.bitstream_commands.extend([ "set_property BITSTREAM.GENERAL.COMPRESS True [current_design]", ]) - ident = description["variant"] + ident = generate_ident(description["variant"]) if self.acpki: ident = "acpki_" + ident SoCCore.__init__(self, platform=platform, csr_data_width=32, ident=ident, ps_cd_sys=False) diff --git a/src/gateware/zc706.py b/src/gateware/zc706.py index 395d6c6..6acc98d 100755 --- a/src/gateware/zc706.py +++ b/src/gateware/zc706.py @@ -25,7 +25,7 @@ import analyzer import acpki import drtio_aux_controller import zynq_clocking -from config import write_csr_file, write_mem_file, write_rustc_cfg_file +from config import generate_ident, write_csr_file, write_mem_file, write_rustc_cfg_file class SMAClkinForward(Module): def __init__(self, platform): @@ -130,7 +130,7 @@ class ZC706(SoCCore): platform = zc706.Platform() prepare_zc706_platform(platform) - ident = self.__class__.__name__ + ident = generate_ident(self.__class__.__name__) if self.acpki: ident = "acpki_" + ident SoCCore.__init__(self, platform=platform, csr_data_width=32, ident=ident, ps_cd_sys=False) @@ -203,7 +203,7 @@ class _MasterBase(SoCCore): platform = zc706.Platform() prepare_zc706_platform(platform) - ident = self.__class__.__name__ + ident = generate_ident(self.__class__.__name__) if self.acpki: ident = "acpki_" + ident SoCCore.__init__(self, platform=platform, csr_data_width=32, ident=ident, ps_cd_sys=False) @@ -344,7 +344,7 @@ class _SatelliteBase(SoCCore): platform = zc706.Platform() prepare_zc706_platform(platform) - ident = self.__class__.__name__ + ident = generate_ident(self.__class__.__name__) if self.acpki: ident = "acpki_" + ident SoCCore.__init__(self, platform=platform, csr_data_width=32, ident=ident, ps_cd_sys=False)