Skip to content

scenario-CoupledL2 #126

scenario-CoupledL2

scenario-CoupledL2 #126

name: scenario-CoupledL2
on:
push:
branches: [ master ]
pull_request:
branches: [ master ]
workflow_dispatch:
schedule:
- cron: '0 0 * * 0'
env:
CI_OS_NAME: linux
CI_COMMIT: ${{ github.sha }}
INSTALL_DIR: ${{ github.workspace }}/install
defaults:
run:
shell: bash
working-directory: repo
concurrency:
group: ${{ github.workflow }}-${{ github.event_name == 'pull_reqeust' && github.ref || github.run_id }}
cancel-in-progress: true
jobs:
prebuild-ootb-coupledL2:
strategy:
fail-fast: false
matrix:
os: [ubuntu-22.04]
case:
- { id: l2l3, name: L2-L3 }
- { id: l2l3l2, name: L2-L3-L2 }
runs-on: ${{ matrix.os }}
name: Pre-Build | ${{ matrix.case.name }} | OOTB CoupledL2
env:
COUPLEDL2_ARCHIVE: coupledL2-${{ matrix.case.id }}-${{ github.sha }}.tar.gz
steps:
- name: Checkout
uses: actions/checkout@v4
with:
path: repo
- name: Checkout CoupledL2
run: git submodule update --init dut/CoupledL2
- name: Extract submodule SHA
id: get_sha_CoupledL2
run: |
cd dut/CoupledL2
CURRENT_HASH=$(git rev-parse HEAD)
echo "${CURRENT_HASH}"
echo "CURRENT_HASH=${CURRENT_HASH}" >> $GITHUB_ENV
cd ../..
- name: Cache CoupledL2 Build
id: cache
uses: actions/cache@v4
env:
cache-name: coupledL2-cache-${{ env.CURRENT_HASH }}
with:
path: ${{ github.workspace }}/${{ env.COUPLEDL2_ARCHIVE }}
key: coupledL2-cache-${{ env.CURRENT_HASH }}
- name: Checkout submodules
if: steps.cache.outputs.cache-hit != 'true'
run: git submodule update --init --recursive
- name: Setup Scala
if: steps.cache.outputs.cache-hit != 'true'
uses: olafurpg/setup-scala@v10
- name: Setup Mill
if: steps.cache.outputs.cache-hit != 'true'
run: |
sh -c "curl -L https://github.com/com-lihaoyi/mill/releases/download/0.11.1/0.11.1 > /usr/local/bin/mill && chmod +x /usr/local/bin/mill"
- name: Compile
if: steps.cache.outputs.cache-hit != 'true'
run: |
make coupledL2-compile
- name: Build verilog
if: steps.cache.outputs.cache-hit != 'true'
run: |
make coupledL2-verilog-test-top-${{ matrix.case.id }}
- name: Tar up repository
if: steps.cache.outputs.cache-hit != 'true'
working-directory: ${{ github.workspace }}
run: tar -zcf ${{ env.COUPLEDL2_ARCHIVE }} repo/dut/CoupledL2/build
setup-verilator:
strategy:
matrix:
os: [ubuntu-20.04, ubuntu-22.04]
compiler:
- { cc: clang-16, cxx: clang++-16 }
- { cc: gcc, cxx: g++ }
exclude:
- { os: ubuntu-20.04, compiler: { cc: gcc, cxx: g++ } }
runs-on: ${{ matrix.os }}
name: Verilator | ${{ matrix.os }} | ${{ matrix.compiler.cc }}
env:
CI_BUILD_STAGE_NAME: build
CI_RUNS_ON: ${{ matrix.os }}
CC: ${{ matrix.compiler.cc }}
CXX: ${{ matrix.compiler.cxx }}
VERILATOR_ARCHIVE: verilator-${{ matrix.os }}-${{ matrix.compiler.cc }}.tar.gz
steps:
- name: Cache Verilator
id: cache
uses: actions/cache@v4
env:
cache-name: verilator-cache-${{ matrix.os }}-${{ matrix.compiler.cc }}
with:
path: ${{ github.workspace }}/${{ env.VERILATOR_ARCHIVE }}
key: verilator-cache-${{ matrix.os }}-${{ matrix.compiler.cc }}
- name: Setup Clang 16
if: steps.cache.outputs.cache-hit != 'true' && matrix.compiler.cc == 'clang-16'
working-directory: ${{ github.workspace }}
run: |
wget https://apt.llvm.org/llvm.sh
chmod u+x llvm.sh
sudo ./llvm.sh 16
- name: Build Verilator
if: steps.cache.outputs.cache-hit != 'true'
working-directory: ${{ github.workspace }}
run: |
sudo apt-get install -y git help2man perl python3 make autoconf g++ flex bison clang
sudo apt-get install -y libfl2 # Ubuntu only (ignore if gives error)
sudo apt-get install -y libfl-dev # Ubuntu only (ignore if gives error)
sudo apt-get install -y zlib1g zlib1g-dev # Ubuntu only (ignore if gives error)
git clone https://github.com/verilator/verilator
unset VERILATOR_ROOT
cd verilator
git checkout v5.020
autoconf
./configure CC=${{ matrix.compiler.cc }} CXX=${{ matrix.compiler.cxx }} LINK=${{ matrix.compiler.cxx }}
make -j4
- name: Tar-up Verilator
if: steps.cache.outputs.cache-hit != 'true'
working-directory: ${{ github.workspace }}
run: tar -zcf ${{ env.VERILATOR_ARCHIVE }} verilator
build:
needs:
- prebuild-ootb-coupledL2
- setup-verilator
strategy:
fail-fast: false
matrix:
os: [ubuntu-20.04, ubuntu-22.04]
case:
- { id: l2l3, name: L2-L3 }
- { id: l2l3l2, name: L2-L3-L2 }
compiler:
- { cc: clang-16, cxx: clang++-16 }
- { cc: gcc, cxx: g++ }
exclude:
- { os: ubuntu-20.04, compiler: { cc: gcc, cxx: g++ } }
runs-on: ${{ matrix.os }}
name: Build | ${{ matrix.case.name }} | ${{ matrix.os }} | ${{ matrix.compiler.cc }}
env:
CI_BUILD_STAGE_NAME: build
CI_RUNS_ON: ${{ matrix.os }}
CC: ${{ matrix.compiler.cc }}
CXX: ${{ matrix.compiler.cxx }}
COUPLEDL2_ARCHIVE: coupledL2-${{ matrix.case.id }}-${{ github.sha }}.tar.gz
TLTEST_ARCHIVE: tl-test-new-${{ matrix.case.id }}-${{ github.sha }}-${{ matrix.os }}-${{ matrix.compiler.cc }}.tar.gz
VERILATOR_ARCHIVE: verilator-${{ matrix.os }}-${{ matrix.compiler.cc }}.tar.gz
steps:
- name: Checkout
uses: actions/checkout@v4
with:
path: repo
- name: Checkout CoupledL2
run: git submodule update --init dut/CoupledL2
- name: Setup Clang 16
if: matrix.compiler.cc == 'clang-16'
working-directory: ${{ github.workspace }}
run: |
wget https://apt.llvm.org/llvm.sh
chmod u+x llvm.sh
sudo ./llvm.sh 16
- name: Fetch cached Verilator
uses: actions/cache/restore@v4
env:
cache-name: verilator-cache-${{ matrix.os }}-${{ matrix.compiler.cc }}
with:
path: ${{ github.workspace }}/${{ env.VERILATOR_ARCHIVE }}
key: verilator-cache-${{ matrix.os }}-${{ matrix.compiler.cc }}
fail-on-cache-miss: true
- name: Install Verilator
working-directory: ${{ github.workspace }}
run: |
tar -zxf ${{ env.VERILATOR_ARCHIVE }}
cd verilator
sudo make install
verilator --version
- name: Extract submodule SHA
id: get_sha_CoupledL2
working-directory: ${{ github.workspace }}
run: |
cd repo/dut/CoupledL2
CURRENT_HASH=$(git rev-parse HEAD)
echo "${CURRENT_HASH}"
echo "CURRENT_HASH=${CURRENT_HASH}" >> $GITHUB_ENV
- name: Fetch cached CoupledL2
id: cache
uses: actions/cache/restore@v4
env:
cache-name: coupledL2-cache-${{ env.CURRENT_HASH }}
with:
path: ${{ github.workspace }}/${{ env.COUPLEDL2_ARCHIVE }}
key: coupledL2-cache-${{ env.CURRENT_HASH }}
fail-on-cache-miss: true
- name: Unpack CoupledL2 artifact
working-directory: ${{ github.workspace }}
run: tar -zxf ${{ env.COUPLEDL2_ARCHIVE }}
- name: Verilate CoupledL2
run: |
make THREADS_BUILD=4 coupledL2-verilate
- name: Configurate TL-Test-New for CoupledL2
run: |
make THREADS_BUILD=4 tltest-config-coupledL2-test-${{ matrix.case.id }}
- name: Build TL-Test-New for CoupledL2
run: |
make THREADS_BUILD=4 tltest-build-all-coupledL2
- name: Tar up repository
working-directory: ${{ github.workspace }}
run: tar -zcf ${{ env.TLTEST_ARCHIVE }} repo/main/build repo/configs repo/scripts repo/Makefile
- name: Upload artifact
uses: actions/upload-artifact@v4
with:
path: ${{ github.workspace }}/${{ env.TLTEST_ARCHIVE }}
name: ${{ env.TLTEST_ARCHIVE }}
run:
needs: build
strategy:
fail-fast: false
matrix:
os: [ubuntu-20.04, ubuntu-22.04]
case:
- { id: l2l3, name: L2-L3 , mode: FUZZ_ARI }
- { id: l2l3l2, name: L2-L3-L2, mode: FUZZ_ARI }
- { id: l2l3, name: L2-L3 , mode: FUZZ_STREAM }
- { id: l2l3l2, name: L2-L3-L2, mode: FUZZ_STREAM }
compiler:
- { cc: clang-16, cxx: clang++-16 }
- { cc: gcc, cxx: g++ }
exclude:
- { os: ubuntu-20.04, compiler: { cc: gcc, cxx: g++ } }
runs-on: ${{ matrix.os }}
name: Run | ${{ matrix.case.name }} | ${{ matrix.case.mode }} | ${{ matrix.os }} | ${{ matrix.compiler.cc }}
env:
CI_BUILD_STAGE_NAME: build
CI_RUNS_ON: ${{ matrix.os }}
CC: ${{ matrix.compiler.cc }}
CXX: ${{ matrix.compiler.cxx }}
TLTEST_ARCHIVE: tl-test-new-${{ matrix.case.id }}-${{ github.sha }}-${{ matrix.os }}-${{ matrix.compiler.cc }}.tar.gz
RUN_ARCHIVE: tl-test-new-run-${{ matrix.case.id }}-${{ github.sha }}-${{ matrix.os }}-${{ matrix.compiler.cc }}.tar.gz
steps:
- name: Download artifact
uses: actions/download-artifact@v4
with:
name: ${{ env.TLTEST_ARCHIVE }}
path: ${{ github.workspace }}
- name: Unpack artifact
working-directory: ${{ github.workspace }}
run: tar -zxvf ${{ env.TLTEST_ARCHIVE }}
- name: Setup mode configuration FUZZ_ARI
if: matrix.case.mode == 'FUZZ_ARI'
run: |
pwd
ls
sed -i 's/mode.0.*/mode.0 = FUZZ_ARI/g' ./configs/user.tltest.ini
sed -i 's/mode.1.*/mode.1 = FUZZ_ARI/g' ./configs/user.tltest.ini
cat ./configs/user.tltest.ini
- name: Setup mode configuration FUZZ_STREAM
if: matrix.case.mode == 'FUZZ_STREAM'
run: |
pwd
ls
sed -i 's/mode.0.*/mode.0 = FUZZ_STREAM/g' ./configs/user.tltest.ini
sed -i 's/mode.1.*/mode.1 = FUZZ_STREAM/g' ./configs/user.tltest.ini
cat ./configs/user.tltest.ini
- name: Run TL-Test-New for CoupledL2
run: |
make run
# - name: Tar up repository
# working-directory: ${{ github.workspace }}
# run: tar -zcf ${{ env.RUN_ARCHIVE }} repo
# - name: Upload artifact
# uses: actions/upload-artifact@v4
# with:
# path: ${{ github.workspace }}/${{ env.RUN_ARCHIVE }}
# name: ${{ env.RUN_ARCHIVE }}