[chiselsim] Better fix for CIRCT 1.66- and 1.66+ (backport #3893) (#3… #6697
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
name: Continuous Integration | |
on: | |
workflow_dispatch: | |
pull_request: | |
push: | |
tags: | |
- '*' | |
branches: | |
- main | |
- '*.x' | |
jobs: | |
ci: | |
name: ci | |
strategy: | |
matrix: | |
system: ["ubuntu-20.04"] | |
jvm: ["8"] | |
scala: ["2.13.10", "2.12.17"] | |
espresso: ["2.4"] | |
circt: ["firtool-1.43.0"] | |
runs-on: ${{ matrix.system }} | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
- name: Install Tabby OSS Cad Suite | |
uses: ./.github/workflows/setup-oss-cad-suite | |
- name: Install Espresso | |
uses: ./.github/workflows/install-espresso | |
with: | |
version: ${{ matrix.espresso }} | |
- name: Setup Scala | |
uses: actions/setup-java@v3 | |
with: | |
distribution: 'adopt' | |
java-version: ${{ matrix.jvm }} | |
cache: 'sbt' | |
- name: Install CIRCT | |
uses: ./.github/workflows/install-circt | |
with: | |
version: ${{ matrix.circt }} | |
- name: Test | |
run: sbt ++${{ matrix.scala }} test | |
- name: Binary compatibility | |
# TODO either make this also check the plugin or decide that we don't | |
# support binary compatibility for the plugin | |
run: sbt ++${{ matrix.scala }} unipublish/mimaReportBinaryIssues | |
mill: | |
name: compile project with mill | |
runs-on: ubuntu-20.04 | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
- name: Install Mill | |
uses: jodersky/[email protected] | |
with: | |
mill-version: 0.11.0 | |
- name: Install CIRCT | |
uses: ./.github/workflows/install-circt | |
- name: Compile Mill | |
run: mill __.compile | |
doc: | |
name: Formatting | |
runs-on: ubuntu-20.04 | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
- name: Setup Scala | |
uses: actions/setup-java@v3 | |
with: | |
distribution: 'adopt' | |
java-version: '11' | |
cache: 'sbt' | |
- name: Install CIRCT | |
uses: ./.github/workflows/install-circt | |
- name: Check Formatting | |
run: sbt fmtCheck | |
integration: | |
name: Integration Tests | |
runs-on: ubuntu-20.04 | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
- name: Install Tabby OSS Cad Suite | |
uses: ./.github/workflows/setup-oss-cad-suite | |
- name: Install Espresso | |
uses: ./.github/workflows/install-espresso | |
- name: Setup Scala | |
uses: actions/setup-java@v3 | |
with: | |
distribution: 'adopt' | |
java-version: '11' | |
cache: 'sbt' | |
- name: Install CIRCT | |
uses: ./.github/workflows/install-circt | |
- name: Integration Tests | |
run: sbt integrationTests/test | |
std: | |
name: Standard Library Tests | |
runs-on: ubuntu-20.04 | |
strategy: | |
matrix: | |
scala: [ "2.13.10", "2.12.17" ] | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
- name: Install Tabby OSS Cad Suite | |
uses: ./.github/workflows/setup-oss-cad-suite | |
- name: Setup Scala | |
uses: actions/setup-java@v3 | |
with: | |
distribution: 'adopt' | |
java-version: '11' | |
cache: 'sbt' | |
- name: Check Formatting (Scala 2.12 only) | |
if: startsWith(matrix.scala, '2.12') | |
run: sbt ++${{ matrix.scala }} standardLibrary/scalafmtCheckAll | |
- name: Unit Tests | |
run: sbt ++${{ matrix.scala }} standardLibrary/test | |
website: | |
name: Build Mdoc & Website | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
- name: Setup Scala | |
uses: actions/setup-java@v3 | |
with: | |
distribution: 'adopt' | |
java-version: '11' | |
cache: 'sbt' | |
- name: Setup Ruby | |
uses: ruby/setup-ruby@v1 | |
with: | |
ruby-version: '2.7.8' | |
- name: Setup Jekyll | |
run: | | |
gem install jekyll -v 4.2.0 | |
gem install jekyll-redirect-from | |
- name: Install CIRCT | |
uses: ./.github/workflows/install-circt | |
#TODO: make the microsite building include building ScalaDoc | |
- name: Build the docs | |
run: sbt doc | |
- name: Build the microsite | |
run: make -C website | |
env: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
- name: Tar built website | |
run: tar zcf website.tar.gz website/docs/target/site | |
- name: Share Built Website | |
uses: actions/upload-artifact@v3 | |
with: | |
name: website | |
path: website.tar.gz | |
scala-cli-example: | |
name: Test Chisel Scala-CLI Example | |
runs-on: ubuntu-latest | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
# Need to fetch full history for deriving version | |
with: | |
fetch-depth: 0 | |
- name: Build and Test Chisel Scala-CLI Example | |
uses: ./.github/workflows/build-scala-cli-example | |
# Sentinel job to simplify how we specify which checks need to pass in branch | |
# protection and in Mergify. This job checks that all jobs were successful. | |
# | |
# When adding new jobs, please add them to `needs` below | |
check-tests: | |
name: "check tests" | |
needs: [mill, ci, std, integration, doc, website, scala-cli-example] | |
runs-on: ubuntu-20.04 | |
if: success() # only run if all tests have passed | |
outputs: | |
success: ${{ steps.setoutput.outputs.success }} | |
steps: | |
- id: setoutput | |
run: echo "success=true" >> $GITHUB_OUTPUT | |
# Related to check-tests above, this job _always_ runs (even if tests fail | |
# and thus check-steps is skipped). This two sentinel job approach avoids an | |
# issue where failing tests causes a single sentinel job to be skipped which | |
# counts as passing for purposes of branch protection. | |
# | |
# See: https://brunoscheufler.com/blog/2022-04-09-the-required-github-status-check-that-wasnt | |
all_tests_passed: | |
name: "all tests passed" | |
runs-on: ubuntu-20.04 | |
if: always() # Always run so that we never skip this check | |
needs: check-tests | |
# Pass only if check-tests set its output value | |
steps: | |
- run: | | |
PASSED="${{ needs.check-tests.outputs.success }}" | |
if [[ $PASSED == "true" ]]; then | |
echo "### All tests passed! :rocket:" >> $GITHUB_STEP_SUMMARY | |
exit 0 | |
else | |
echo "### One or more tests FAILED! :bangbang:" >> $GITHUB_STEP_SUMMARY | |
exit 1 | |
fi | |
# sbt ci-release publishes all cross versions so this job needs to be | |
# separate from a Scala versions build matrix to avoid duplicate publishing | |
publish: | |
needs: [all_tests_passed] | |
runs-on: ubuntu-20.04 | |
if: github.event_name == 'push' | |
steps: | |
- name: Checkout | |
uses: actions/checkout@v3 | |
with: | |
fetch-depth: 0 | |
- name: Install CIRCT | |
uses: ./.github/workflows/install-circt | |
- name: Setup Scala | |
uses: actions/setup-java@v3 | |
with: | |
distribution: 'adopt' | |
java-version: '8' | |
cache: 'sbt' | |
- name: Setup GPG (for Publish) | |
uses: olafurpg/setup-gpg@v3 | |
- name: Publish | |
run: sbt ci-release | |
env: | |
CI_SNAPSHOT_RELEASE: "+unipublish/publish" | |
CI_SONATYPE_RELEASE: "+unipublish/publishSigned" | |
PGP_PASSPHRASE: ${{ secrets.PGP_PASSPHRASE }} | |
PGP_SECRET: ${{ secrets.PGP_SECRET }} | |
SONATYPE_PASSWORD: ${{ secrets.CHIPSALLIANCE_SONATYPE_PASSWORD }} | |
SONATYPE_USERNAME: ${{ secrets.CHIPSALLIANCE_SONATYPE_USERNAME }} | |
deploy_website: | |
name: Deploy Website | |
runs-on: ubuntu-latest | |
needs: [all_tests_passed] | |
# Only Deploy website on pushes to main, may change to a stable branch | |
if: (github.event_name == 'push') && (github.ref_name == 'main') | |
steps: | |
- name: Download built website | |
uses: actions/download-artifact@v3 | |
with: | |
name: website | |
- name: Untar built website | |
run: tar zxf website.tar.gz | |
- name: Deploy Website to GitHub Pages (From Main Branch) | |
uses: JamesIves/[email protected] | |
with: | |
GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} | |
BRANCH: gh-pages | |
FOLDER: website/docs/target/site |