114 lines
4.8 KiB
Groovy
114 lines
4.8 KiB
Groovy
void checkout_project(String repoUrl, String branch = 'develop') {
|
|
checkout([
|
|
$class: 'GitSCM',
|
|
branches: [
|
|
[name: "*/${branch}"]
|
|
],
|
|
extensions: [
|
|
[$class: 'CleanBeforeCheckout'],
|
|
[$class: 'SubmoduleOption', disableSubmodules: false, parentCredentials: true, recursiveSubmodules: true, reference: '', trackingSubmodules: false, shallow: true]
|
|
],
|
|
submoduleCfg: [],
|
|
userRemoteConfigs: [
|
|
[credentialsId: 'gitea-jenkins', url: repoUrl]
|
|
]
|
|
])
|
|
}
|
|
|
|
pipeline {
|
|
agent any
|
|
stages {
|
|
stage("Checkout and build"){
|
|
agent {docker { image 'ubuntu-riscv' }}
|
|
stages{
|
|
stage("Checkout TGC-Compliance and TGC-GEN"){
|
|
steps {
|
|
sh 'rm -rf * .??* '
|
|
checkout_project("https://git.minres.com/TGFS/TGC-ISS.git", "develop")
|
|
dir("TGC-COMPLIANCE"){
|
|
checkout_project("https://git.minres.com/TGFS/TGC-COMPLIANCE.git", "master")
|
|
}
|
|
dir("TGC-GEN"){
|
|
checkout_project("https://git.minres.com/TGFS/TGC-GEN.git", "develop")
|
|
}
|
|
}
|
|
}
|
|
stage("Generate cores and build TGC-ISS"){
|
|
steps {
|
|
sh '''
|
|
for core in TGC5A TGC5B TGC5D TGC5E TGC5F RV32GC; do
|
|
for backend in interp llvm tcc asmjit; do
|
|
TGC-GEN/scripts/generate_iss.sh -o dbt-rise-tgc/ -c $core -b ${backend} TGC-GEN/CoreDSL/${core}.core_desc
|
|
done
|
|
done
|
|
for core in TGC6B TGC6C TGC6D TGC6E RV64GC; do
|
|
for backend in interp llvm asmjit; do
|
|
TGC-GEN/scripts/generate_iss.sh -o dbt-rise-tgc/ -c $core -b ${backend} TGC-GEN/CoreDSL/${core}.core_desc
|
|
done
|
|
done
|
|
'''
|
|
sh 'conan profile new default --detect --force'
|
|
sh 'cmake -S . -B build -DCMAKE_BUILD_TYPE=Release -DWITH_ASMJIT=ON -DWITH_TCC=ON -DWITH_LLVM=ON'
|
|
sh 'cmake --build build -j'
|
|
sh 'build/dbt-rise-tgc/tgc-sim --isa ?'
|
|
}
|
|
}
|
|
}
|
|
}
|
|
stage("Run test suite") {
|
|
agent {
|
|
docker {
|
|
image 'git.minres.com/tooling/riscof_sail:latest'
|
|
args ' -e CONAN_USER_HOME=/var/jenkins_home/workspace/riscof_sail'
|
|
}
|
|
}
|
|
stages {
|
|
stage('ACT 32bit') {
|
|
matrix {
|
|
axes {
|
|
axis {
|
|
name 'CORE'
|
|
values 'TGC5A', 'TGC5B', 'TGC5C', 'TGC5D', 'TGC5E', 'TGC5F', 'RV32GC'
|
|
}
|
|
axis {
|
|
name 'BACKEND'
|
|
values 'interp', 'llvm', 'tcc', 'asmjit'
|
|
}
|
|
}
|
|
stages {
|
|
stage('Run riscof') {
|
|
steps {
|
|
sh "mkdir -p ${BACKEND}"
|
|
sh "python3 TGC-COMPLIANCE/run_act.py -core ${CORE} -sim build/dbt-rise-tgc/tgc-sim -w ${BACKEND} --local --backend ${BACKEND}"
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
stage('ACT 64bit') {
|
|
matrix {
|
|
axes {
|
|
axis {
|
|
name 'CORE'
|
|
values 'TGC6B', 'TGC6C', 'TGC6D', 'TGC6E', 'RV64GC'
|
|
}
|
|
axis {
|
|
name 'BACKEND'
|
|
values 'interp', 'llvm', 'asmjit'
|
|
}
|
|
}
|
|
stages {
|
|
stage('Run riscof') {
|
|
steps {
|
|
sh "mkdir -p ${BACKEND}"
|
|
sh "python3 TGC-COMPLIANCE/run_act.py -core ${CORE} -sim build/dbt-rise-tgc/tgc-sim -w ${BACKEND} --local --backend ${BACKEND}"
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|