Travis fixes

This commit is contained in:
Todd Strader 2019-11-14 17:54:57 -05:00
parent a250decfaa
commit 30c2e53f9e
2 changed files with 48 additions and 21 deletions

View File

@ -4,15 +4,17 @@
# redistribute it and/or modify it under the terms of either the GNU Lesser # 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. # General Public License Version 3 or the Perl Artistic License Version 2.0.
language: cpp version: ~> 1.0
os: linux
language: cpp
cache: ccache cache: ccache
env: env:
global: global:
- VERILATOR_CACHE=$HOME/verilator_cache - VERILATOR_CACHE=$HOME/verilator_cache
- VERILATOR_ROOT=$PWD - VERILATOR_ROOT=$PWD
- VERILATOR_NUM_JOBS=$((`nproc` + 1)) - VERILATOR_NUM_JOBS=$(echo `nproc` + 1 | bc)
- VERILATOR_CONFIG_FLAGS="--enable-maintainer-mode --enable-longtests" - VERILATOR_CONFIG_FLAGS="--enable-maintainer-mode --enable-longtests"
- OBJCACHE=ccache - OBJCACHE=ccache
@ -23,7 +25,7 @@ cache:
before_install: before_install:
# Perl modules needed for testing # Perl modules needed for testing
- yes yes | sudo cpan -fi Unix::Processors Parallel::Forker Bit::Vector - yes yes | sudo cpan -fi Unix::Processors Parallel::Forker Bit::Vector
- sudo apt-get install gdb - sudo apt-get install gdb gtkwave
before_script: before_script:
- bash -x ci/build_verilator.sh - bash -x ci/build_verilator.sh
after_script: after_script:
@ -38,75 +40,79 @@ jobs:
- if: type != cron - if: type != cron
stage: "Build Verilator" stage: "Build Verilator"
name: Build Verilator name: Build Verilator
os: linux
compiler: gcc compiler: gcc
script: echo "Done building Verilator" script: echo "Done building Verilator"
# Non-cron build will just run on whatever linux flavor we get # Non-cron build will just run on whatever linux flavor we get
- if: type != cron - if: type != cron
stage: test stage: test
name: Dist test name: Dist test
os: linux
compiler: gcc compiler: gcc
script: ci/test.sh dist script: ci/test.sh dist
- if: type != cron - if: type != cron
stage: test stage: test
name: Vlt test name: Vlt test
os: linux
compiler: gcc compiler: gcc
script: ci/test.sh vlt script: ci/test.sh vlt
- if: type != cron - if: type != cron
stage: test stage: test
name: Vltmt test name: Vltmt test
os: linux
compiler: gcc compiler: gcc
script: ci/test.sh vltmt script: ci/test.sh vltmt
# Cron builds try different OS/compiler combinations # Cron builds try different OS/compiler combinations
- if: type = cron - if: type = cron
stage: "Build Verilator" stage: "Build Verilator"
name: Build xenial gcc Verilator name: Build xenial gcc Verilator
os: xenial os: linux
dist: xenial
compiler: gcc compiler: gcc
script: echo "Done building Verilator" script: echo "Done building Verilator"
- if: type = cron - if: type = cron
stage: test stage: test
name: Xenail gcc dist test name: Xenail gcc dist test
os: xenial os: linux
dist: xenial
compiler: gcc compiler: gcc
script: ci/test.sh dist script: ci/test.sh dist
- if: type = cron - if: type = cron
stage: test stage: test
name: Xenail gcc vlt test name: Xenail gcc vlt test
os: xenial os: linux
dist: xenial
compiler: gcc compiler: gcc
script: ci/test.sh vlt script: ci/test.sh vlt
- if: type = cron - if: type = cron
stage: test stage: test
name: Xenail gcc vltmt test name: Xenail gcc vltmt test
os: xenial os: linux
dist: xenial
compiler: gcc compiler: gcc
script: ci/test.sh vltmt script: ci/test.sh vltmt
- if: type = cron - if: type = cron
stage: "Build Verilator" stage: "Build Verilator"
name: Build xenial clang Verilator name: Build xenial clang Verilator
os: xenial os: linux
dist: xenial
compiler: clang compiler: clang
script: echo "Done building Verilator" script: echo "Done building Verilator"
- if: type = cron - if: type = cron
stage: test stage: test
name: Xenail clang dist test name: Xenail clang dist test
os: xenial os: linux
dist: xenial
compiler: clang compiler: clang
script: ci/test.sh dist script: ci/test.sh dist
- if: type = cron - if: type = cron
stage: test stage: test
name: Xenail clang vlt test name: Xenail clang vlt test
os: xenial os: linux
dist: xenial
compiler: clang compiler: clang
script: ci/test.sh vlt script: ci/test.sh vlt
- if: type = cron - if: type = cron
stage: test stage: test
name: Xenail clang vltmt test name: Xenail clang vltmt test
os: xenial os: linux
dist: xenial
compiler: clang compiler: clang
script: ci/test.sh vltmt script: ci/test.sh vltmt
# - if: type = cron # - if: type = cron
@ -125,37 +131,45 @@ jobs:
# stage: test # stage: test
# name: OSX gcc vlt test # name: OSX gcc vlt test
# os: osx # os: osx
# os: osx
# compiler: gcc # compiler: gcc
# script: ci/test.sh vlt # script: ci/test.sh vlt
# - if: type = cron # - if: type = cron
# stage: test # stage: test
# name: OSX gcc vltmt test # name: OSX gcc vltmt test
# os: osx # os: osx
# os: osx
# compiler: gcc # compiler: gcc
# script: ci/test.sh vltmt # script: ci/test.sh vltmt
- if: type = cron - if: type = cron
stage: "Build Verilator" stage: "Build Verilator"
name: Build trusty gcc Verilator name: Build trusty gcc Verilator
os: trusty os: linux
dist: trusty
compiler: gcc compiler: gcc
script: echo "Done building Verilator" script: echo "Done building Verilator"
- if: type = cron - if: type = cron
stage: test stage: test
name: Trusty gcc dist test name: Trusty gcc dist test
os: trusty os: linux
dist: trusty
compiler: gcc compiler: gcc
script: ci/test.sh dist script: ci/test.sh dist
- if: type = cron - if: type = cron
stage: test stage: test
name: Trusty gcc vlt test name: Trusty gcc vlt test
os: trusty os: linux
dist: trusty
compiler: gcc compiler: gcc
script: ci/test.sh vlt script: ci/test.sh vlt
- if: type = cron - if: type = cron
stage: test stage: test
os: trusty os: linux
dist: trusty
name: Trusty gcc vltmt test name: Trusty gcc vltmt test
compiler: gcc compiler: gcc
script: ci/test.sh vltmt script: ci/test.sh vltmt
notifications:
email:
if: repo = verilator/verilator
recipients:
- todd.strader@gmail.com

View File

@ -25,7 +25,20 @@ endif
DOT = dot DOT = dot
PYTHON = python3 PYTHON = python3
PYTHON_VERSION := $(shell ${PYTHON} --version 2>&1)
PYTHON_VERSION_FULL := $(wordlist 2,4,$(subst ., ,${PYTHON_VERSION}))
PYTHON_VERSION_MAJOR := $(word 1,${PYTHON_VERSION_FULL})
PYTHON_VERSION_MINOR := $(word 2,${PYTHON_VERSION_FULL})
PYTHON_GE_3_5 := $(shell [ ${PYTHON_VERSION_MAJOR} -eq 3 -a ${PYTHON_VERSION_MINOR} -ge 5 ] && echo true)
ifeq (${PYTHON_GE_3_5},true)
default: test default: test
else
default: python_message
endif
python_message:
@echo "Found Python version ${PYTHON_VERSION}, but require >= 3.5"
test: \ test: \
test-vl_file_copy \ test-vl_file_copy \