From bfe8d8a83f23af04d2b4959889c7de3cf6012486 Mon Sep 17 00:00:00 2001 From: Avimitin Date: Fri, 12 Apr 2024 01:03:51 +0800 Subject: [PATCH] [script] support multiple config release - Fix path as config - Fix multiple config release name collision Signed-off-by: Avimitin --- .github/workflows/release.yml | 39 +++++++++++++++++++++++--------- README.md | 4 +++- nix/t1/default.nix | 4 +--- nix/t1/release/default.nix | 12 +++++++--- nix/t1/release/doc.typ | 21 +++++++++-------- nix/t1/release/docker-layers.nix | 3 ++- script/src/Main.scala | 15 +++++++----- 7 files changed, 64 insertions(+), 34 deletions(-) diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 70de682d6..662b99229 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -12,8 +12,13 @@ jobs: matrix: config: - blastoise + - machamp + - sandslash outputs: - cache-key: ${{ steps.build.outputs.cache-key }} + # I hate copy-paste too, but this is GitHub Action, blame them. + cache-key-blastoise: ${{ steps.build.outputs.cache-key-blastoise }} + cache-key-machamp: ${{ steps.build.outputs.cache-key-machamp }} + cache-key-sandslash: ${{ steps.build.outputs.cache-key-sandslash }} steps: - uses: actions/checkout@v4 with: @@ -24,25 +29,37 @@ jobs: run: | closure="$(nix build -L '.#t1.${{ matrix.config }}.release.docker-layers.final-image' --no-link --print-out-paths)" echo "path: $closure" - cp "$closure/image.tar" /tmp/t1-image.tar - echo "cache-key=$(nix hash file --base32 /tmp/t1-image.tar)" > $GITHUB_OUTPUT + cp "$closure/image.tar" /tmp/t1-${{ matrix.config }}-image.tar + echo "cache-key-${{ matrix.config }}=$(nix hash file --base32 $closure/image.tar)" > $GITHUB_OUTPUT + nix build -L '.#t1.${{ matrix.config }}.release.doc' --out-link docs - name: Upload to cache uses: actions/cache/save@v4 with: - path: /tmp/t1-image.tar - key: ${{ steps.build.outputs.cache-key }} + path: /tmp/t1-${{ matrix.config }}-image.tar + key: ${{ steps.build.outputs[format('cache-key-{0}', matrix.config)] }} + - uses: actions/upload-artifact@v4 + with: + name: docs-${{ matrix.config }}.pdf + path: | + docs/*.pdf upload: runs-on: ubuntu-latest needs: [build] + strategy: + matrix: + config: + - blastoise + - machamp + - sandslash steps: - - name: Restore from cache + - name: Restore ${{ matrix.config }} from cache uses: actions/cache/restore@v4 id: cache with: - path: /tmp/t1-image.tar + path: /tmp/t1-${{ matrix.config }}-image.tar fail-on-cache-miss: true - key: ${{ needs.build.outputs.cache-key }} + key: ${{ needs.build.outputs[format('cache-key-{0}', matrix.config)] }} - name: Login to GHCR dot IO uses: docker/login-action@v2 with: @@ -51,6 +68,6 @@ jobs: password: ${{ secrets.GITHUB_TOKEN }} - name: Load and push run: | - docker load < /tmp/t1-image.tar - docker tag t1/release:latest ghcr.io/chipsalliance/t1:latest - docker push ghcr.io/chipsalliance/t1:latest + docker load < /tmp/t1-${{ matrix.config }}-image.tar + docker tag chipsalliance/t1-${{ matrix.config }}:latest ghcr.io/chipsalliance/t1-${{ matrix.config }}:latest + docker push ghcr.io/chipsalliance/t1-${{ matrix.config }}:latest diff --git a/README.md b/README.md index d913bc84f..f72f3c43c 100644 --- a/README.md +++ b/README.md @@ -67,7 +67,9 @@ We have a IP emulator under the directory `./ipemu`. [Spike](https://github.com/ ### Docker images ```bash -docker pull ghcr.io/chipsalliance/t1:latest +docker pull ghcr.io/chipsalliance/t1-$config:latest +# For example, config with dlen 256 vlen 512 support +docker pull ghcr.io/chipsalliance/t1-blastoise:latest ``` ### Nix setup diff --git a/nix/t1/default.nix b/nix/t1/default.nix index 373155df5..e720595ec 100644 --- a/nix/t1/default.nix +++ b/nix/t1/default.nix @@ -85,9 +85,7 @@ lib.makeScope newScope rtl = innerSelf.callPackage ./rtl.nix { mlirbc = innerSelf.subsystem.mlirbc; }; }; - release = innerSelf.callPackage ./release { - ip-emulator = ip.emu-trace; - }; + release = innerSelf.callPackage ./release { }; }) ) ) diff --git a/nix/t1/release/default.nix b/nix/t1/release/default.nix index 0f80a8cd5..3b0ebe9cc 100644 --- a/nix/t1/release/default.nix +++ b/nix/t1/release/default.nix @@ -10,13 +10,13 @@ , configName , t1-script -, ip-emulator +, ip , cases , elaborateConfigJson }: lib.makeScope newScope (scope: rec { - inherit ip-emulator elaborateConfigJson; + inherit elaborateConfigJson configName; testCases = with cases; [ intrinsic.matmul @@ -34,7 +34,13 @@ lib.makeScope newScope (scope: rec { makeWrapper ${t1-script}/bin/t1-helper $out/bin/ip-emulator \ --add-flags "ipemu" \ --add-flags "--config ${elaborateConfigJson}" \ - --add-flags "--emulator-path ${ip-emulator}/bin/emulator" + --add-flags "--emulator-path ${ip.emu}/bin/emulator" + + makeWrapper ${t1-script}/bin/t1-helper $out/bin/ip-emulator-trace \ + --add-flags "ipemu" \ + --add-flags "--config ${elaborateConfigJson}" \ + --add-flags "--trace" \ + --add-flags "--emulator-path ${ip.emu-trace}/bin/emulator" ''; docker-layers = scope.callPackage ./docker-layers.nix { }; diff --git a/nix/t1/release/doc.typ b/nix/t1/release/doc.typ index 1b721c581..11057f0b5 100644 --- a/nix/t1/release/doc.typ +++ b/nix/t1/release/doc.typ @@ -4,11 +4,13 @@ bash: (name: "Bash", icon: none, color: rgb("#CE412B")), )) +#let config = json("./config.json") + = T1 Docker Image Manual == Released IP configs -#let table-json(config) = { +#{ let name = config.name let param = config.parameter let floatSupport = if param.extensions.first() == "Zve32f" [ True ] else [ False ] @@ -23,8 +25,6 @@ ) } -#table-json(json("./config.json")) - == Address Range #table( @@ -39,12 +39,14 @@ Scalar core cannot access Vector DDR/SRAM, for, users need to access correspondi == How to use the Docker image -```bash +#show raw.where(lang: "t1-docker"): it => { + raw(lang: "bash", it.text.replace("${config}", config.name)) +} +```t1-docker # Load the image into docker registry -docker pull ghcr.io/chipsalliance/t1:latest -# Run the t1/release:latest image with command /bin/bash, name the running container with name "t1", with [i]nterative shell and a working [t]ty. -# The directory `/workspace` will be bind mount on the current directory. The container will be automatically [r]e[m]ove at exit. -docker run --name t1 -it -v $PWD:/workspace --rm t1/release:latest /bin/bash +docker pull ghcr.io/chipsalliance/t1-${config}:latest +# Start the bash shell in t1/release:latest image, and bind the current path to /workspace +docker run --name t1 -it -v $PWD:/workspace --rm ghcr.io/chipsalliance/t1-${config}:latest /bin/bash ``` > It is recommended to build ELF outside of the docker image and bind mount the ELF location into the image. @@ -52,6 +54,7 @@ docker run --name t1 -it -v $PWD:/workspace --rm t1/release:latest /bin/bash == What is inside + IP emulator: `/bin/ip-emulator` ++ IP emulator with trace functionality: `/bin/ip-emulator-trace` + Softmax & Linear Normalization & Matmul test cases: `/workspace/cases` == How to run some workload using IP emulator @@ -64,5 +67,5 @@ ls /workspace/cases ip-emulator --case cases/intrinsic-matmul/bin/intrinsic.matmul.elf # Get waveform trace file -ip-emulator --trace --case ... +ip-emulator-trace --case cases/intrinsic-linear_normalization/bin/intrinsic.linear_normalization.elf ``` diff --git a/nix/t1/release/docker-layers.nix b/nix/t1/release/docker-layers.nix index ce731618b..e8c164f90 100644 --- a/nix/t1/release/docker-layers.nix +++ b/nix/t1/release/docker-layers.nix @@ -13,12 +13,13 @@ , rv32-stdenv , emulator-wrapped , testCases +, configName }: let # Don't use buildImage which relies on KVM feature self = dockerTools.streamLayeredImage { - name = "t1/release"; + name = "chipsalliance/t1-${configName}"; tag = "latest"; contents = with dockerTools; [ diff --git a/script/src/Main.scala b/script/src/Main.scala index a8feca15e..1daf89e07 100644 --- a/script/src/Main.scala +++ b/script/src/Main.scala @@ -115,20 +115,21 @@ object Main: caseName: String ): os.Path = val pathTail = - if (os.exists(os.Path(caseName, os.pwd))) then + if os.exists(os.Path(caseName, os.pwd)) || os.exists(os.Path(config, os.pwd)) then // It is hard to canoncalize user specify path, so here we use date time instead - java.time.LocalDateTime + val now = java.time.LocalDateTime .now() .format( java.time.format.DateTimeFormatter.ofPattern("yy-MM-dd-HH-mm-ss") ) - else caseName + os.RelPath(now) + else os.RelPath(s"$config/$caseName") val path = if (outputDir.isEmpty) then if (outputBaseDir.isEmpty) then - os.pwd / "testrun" / s"${emuType}emu" / config / pathTail - else os.Path(outputBaseDir.get, os.pwd) / config / pathTail + os.pwd / "testrun" / s"${emuType}emu" / pathTail + else os.Path(outputBaseDir.get, os.pwd) / pathTail else os.Path(outputDir.get) os.makeDir.all(path) @@ -142,6 +143,7 @@ object Main: @main def ipemu( @arg( name = "case", + short = 'C', doc = "name alias for loading test case" ) testCase: String, @arg( @@ -206,7 +208,8 @@ object Main: doc = "Force using x86_64 as cross compiling host platform" ) forceX86: Boolean = false, @arg( - name = "dump-cycle", + name = "dump-from-cycle", + short = 'D', doc = "Specify the dump starting point" ) dumpCycle: String = "0.0", @arg(