mirror of
https://github.com/verilator/verilator.git
synced 2025-01-09 16:17:36 +00:00
525c79bd0a
This adds files to build and run two Docker images: - run: Build a Docker container that can be used as an executable drop-in for verilator. This can be useful to test behavior of older versions or a development version. The functionality is pretty simplistic at the moment for a start. - buildenv: Everything needed to build and test Verilator. Useful to run quick tests in the cloud or try other compilers. It can also serve as basis for further CI integration.
31 lines
848 B
Bash
Executable File
31 lines
848 B
Bash
Executable File
#!/bin/bash -e
|
|
# DESCRIPTION: Build Verilator (inside container)
|
|
#
|
|
# Copyright 2020 by Stefan Wallentowitz. This program 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.
|
|
|
|
: "${REPO:=https://github.com/verilator/verilator}"
|
|
: "${REV:=master}"
|
|
: "${CC:=gcc}"
|
|
: "${CXX:=g++}"
|
|
|
|
GCCVERSION=$(${CC} --version | grep gcc | awk '{print $4}')
|
|
|
|
export SYSTEMC_INCLUDE="/usr/local/systemc-2.3.3-gcc${GCCVERSION}/include"
|
|
export SYSTEMC_LIBDIR="/usr/local/systemc-2.3.3-gcc${GCCVERSION}/lib-linux64"
|
|
export LD_LIBRARY_PATH=${SYSTEMC_LIBDIR}
|
|
|
|
SRCS=$PWD/verilator
|
|
|
|
git clone "$REPO" "$SRCS"
|
|
cd "$SRCS"
|
|
git checkout "$REV"
|
|
autoconf
|
|
./configure --enable-longtests
|
|
make -j $(nproc)
|
|
if [ "${1:-''}" == "test" ]; then
|
|
make test
|
|
fi
|