mirror of
https://github.com/verilator/verilator.git
synced 2025-01-21 05:44:03 +00:00
162 lines
3.8 KiB
YAML
162 lines
3.8 KiB
YAML
# DESCRIPTION: Travis-CI config
|
|
#
|
|
# Copyright 2003-2019 by Todd Strader. Verilator is free software; you can
|
|
# redistribute it and/or modify it under the terms of either the GNU Lesser
|
|
# General Public License Version 3 or the Perl Artistic License Version 2.0.
|
|
|
|
language: cpp
|
|
|
|
cache: ccache
|
|
|
|
env:
|
|
global:
|
|
- VERILATOR_CACHE=$HOME/verilator_cache
|
|
- VERILATOR_ROOT=$PWD
|
|
- VERILATOR_NUM_JOBS=$((`nproc` + 1))
|
|
- VERILATOR_CONFIG_FLAGS="--enable-maintainer-mode --enable-longtests"
|
|
- OBJCACHE=ccache
|
|
|
|
cache:
|
|
directories:
|
|
- $VERILATOR_CACHE
|
|
|
|
before_install:
|
|
# Perl modules needed for testing
|
|
- yes yes | sudo cpan -fi Unix::Processors Parallel::Forker Bit::Vector
|
|
- sudo apt-get install gdb
|
|
before_script:
|
|
- bash -x ci/build_verilator.sh
|
|
after_script:
|
|
- ccache -s
|
|
|
|
stages:
|
|
- "Build Verilator"
|
|
- test
|
|
|
|
jobs:
|
|
include:
|
|
- if: type != cron
|
|
stage: "Build Verilator"
|
|
name: Build Verilator
|
|
os: linux
|
|
compiler: gcc
|
|
script: echo "Done building Verilator"
|
|
# Non-cron build will just run on whatever linux flavor we get
|
|
- if: type != cron
|
|
stage: test
|
|
name: Dist test
|
|
os: linux
|
|
compiler: gcc
|
|
script: ci/test.sh dist
|
|
- if: type != cron
|
|
stage: test
|
|
name: Vlt test
|
|
os: linux
|
|
compiler: gcc
|
|
script: ci/test.sh vlt
|
|
- if: type != cron
|
|
stage: test
|
|
name: Vltmt test
|
|
os: linux
|
|
compiler: gcc
|
|
script: ci/test.sh vltmt
|
|
# Cron builds try different OS/compiler combinations
|
|
- if: type = cron
|
|
stage: "Build Verilator"
|
|
name: Build xenial gcc Verilator
|
|
os: xenial
|
|
compiler: gcc
|
|
script: echo "Done building Verilator"
|
|
- if: type = cron
|
|
stage: test
|
|
name: Xenail gcc dist test
|
|
os: xenial
|
|
compiler: gcc
|
|
script: ci/test.sh dist
|
|
- if: type = cron
|
|
stage: test
|
|
name: Xenail gcc vlt test
|
|
os: xenial
|
|
compiler: gcc
|
|
script: ci/test.sh vlt
|
|
- if: type = cron
|
|
stage: test
|
|
name: Xenail gcc vltmt test
|
|
os: xenial
|
|
compiler: gcc
|
|
script: ci/test.sh vltmt
|
|
- if: type = cron
|
|
stage: "Build Verilator"
|
|
name: Build xenial clang Verilator
|
|
os: xenial
|
|
compiler: clang
|
|
script: echo "Done building Verilator"
|
|
- if: type = cron
|
|
stage: test
|
|
name: Xenail clang dist test
|
|
os: xenial
|
|
compiler: clang
|
|
script: ci/test.sh dist
|
|
- if: type = cron
|
|
stage: test
|
|
name: Xenail clang vlt test
|
|
os: xenial
|
|
compiler: clang
|
|
script: ci/test.sh vlt
|
|
- if: type = cron
|
|
stage: test
|
|
name: Xenail clang vltmt test
|
|
os: xenial
|
|
compiler: clang
|
|
script: ci/test.sh vltmt
|
|
# - if: type = cron
|
|
# stage: "Build Verilator"
|
|
# name: Build OSX gcc Verilator
|
|
# os: osx
|
|
# compiler: gcc
|
|
# script: echo "Done building Verilator"
|
|
# - if: type = cron
|
|
# stage: test
|
|
# name: OSX gcc dist test
|
|
# os: osx
|
|
# compiler: gcc
|
|
# script: ci/test.sh dist
|
|
# - if: type = cron
|
|
# stage: test
|
|
# name: OSX gcc vlt test
|
|
# os: osx
|
|
# os: osx
|
|
# compiler: gcc
|
|
# script: ci/test.sh vlt
|
|
# - if: type = cron
|
|
# stage: test
|
|
# name: OSX gcc vltmt test
|
|
# os: osx
|
|
# os: osx
|
|
# compiler: gcc
|
|
# script: ci/test.sh vltmt
|
|
- if: type = cron
|
|
stage: "Build Verilator"
|
|
name: Build trusty gcc Verilator
|
|
os: trusty
|
|
compiler: gcc
|
|
script: echo "Done building Verilator"
|
|
- if: type = cron
|
|
stage: test
|
|
name: Trusty gcc dist test
|
|
os: trusty
|
|
compiler: gcc
|
|
script: ci/test.sh dist
|
|
- if: type = cron
|
|
stage: test
|
|
name: Trusty gcc vlt test
|
|
os: trusty
|
|
compiler: gcc
|
|
script: ci/test.sh vlt
|
|
- if: type = cron
|
|
stage: test
|
|
os: trusty
|
|
name: Trusty gcc vltmt test
|
|
compiler: gcc
|
|
script: ci/test.sh vltmt
|