mirror of
https://github.com/verilator/verilator.git
synced 2025-01-23 06:44:02 +00:00
118 lines
3.0 KiB
Makefile
118 lines
3.0 KiB
Makefile
|
# $Id$ */
|
||
|
#*****************************************************************************
|
||
|
#
|
||
|
# DESCRIPTION: Verilator Example: Makefile for inside source directory
|
||
|
#
|
||
|
# This calls the object directory makefile. That allows the objects to
|
||
|
# be placed in the "current directory" which simplifies the Makefile.
|
||
|
#
|
||
|
# Copyright 2003 by Wilson Snyder. This program is free software; you can
|
||
|
# redistribute it and/or modify it under the terms of either the GNU
|
||
|
# General Public License or the Perl Artistic License.
|
||
|
#
|
||
|
#****************************************************************************/
|
||
|
|
||
|
# This must point to the root of the VERILATOR kit
|
||
|
VERILATOR_ROOT := $(shell pwd)/..
|
||
|
export VERILATOR_ROOT
|
||
|
PERL = perl
|
||
|
PWD := $(shell pwd)
|
||
|
|
||
|
VERILATOR_SW +=
|
||
|
ifeq ($(VERILATOR_NO_DEBUG),)
|
||
|
VERILATOR_SW += --debug
|
||
|
endif
|
||
|
|
||
|
PERL_PACKAGES_OK := $(shell $(PERL) -e 'eval "use Bit::Vector; print 1;";')
|
||
|
|
||
|
######################################################################
|
||
|
|
||
|
default: test
|
||
|
|
||
|
ifneq ($(PERL_PACKAGES_OK),1)
|
||
|
test:: nopackages
|
||
|
else
|
||
|
ifneq ($(VCS_HOME),)
|
||
|
test:: vcs
|
||
|
else
|
||
|
test:: novcs
|
||
|
endif
|
||
|
|
||
|
ifneq ($(NC_ROOT),)
|
||
|
test:: nc
|
||
|
else
|
||
|
test:: nonc
|
||
|
endif
|
||
|
|
||
|
test:: v3
|
||
|
endif
|
||
|
|
||
|
vgen.v: ./vgen.pl
|
||
|
$(PERL) vgen.pl $(VGEN_FLAGS)
|
||
|
|
||
|
# We ulimit cpu time, as some cases make gcc 3.3.4 hang
|
||
|
random:
|
||
|
-rm -rf obj_dir/Vgen* obj_dir/simx
|
||
|
$(PERL) vgen.pl --seed=0 --numops=1000 --depth=4 --raise=4
|
||
|
VERILATOR_NO_DEBUG=1 CPPFLAGS_ADD=-Wno-error VCS_HOME= NC_ROOT= bash -c "ulimit -t 120; $(MAKE) test"
|
||
|
# $(MAKE) nc
|
||
|
|
||
|
random_forever:
|
||
|
while ( $(MAKE) random ) ; do \
|
||
|
echo ; \
|
||
|
done
|
||
|
|
||
|
######################################################################
|
||
|
|
||
|
nopackages:
|
||
|
@echo "No perl Bit::Vector package installed."
|
||
|
@echo "Not running regression test."
|
||
|
|
||
|
novcs:
|
||
|
@echo "No VCS simulator installed."
|
||
|
@echo "Not running VCS regression test."
|
||
|
|
||
|
vcs: vcs_passed.log
|
||
|
|
||
|
simv: vgen.v sim_main.v
|
||
|
vcs +cli -I +define+vcs+1 +v2k -q vgen.v sim_main.v
|
||
|
|
||
|
vcs_passed.log : simv
|
||
|
-rm -f vcs_passed.log
|
||
|
./simv -l sim.log
|
||
|
grep -q Finished sim.log && grep Finished sim.log > vcs_passed.log
|
||
|
|
||
|
######################################################################
|
||
|
|
||
|
nonc:
|
||
|
@echo "No NC-Verilog simulator installed."
|
||
|
@echo "Not running NC-Verilog regression test."
|
||
|
|
||
|
nc: nc_passed.log
|
||
|
|
||
|
nc_passed.log: vgen.v sim_main.v
|
||
|
ncverilog +licqueue +define+ncverilog=1 -q vgen.v sim_main.v
|
||
|
-rm -f nc_passed.log
|
||
|
grep -q Finished ncverilog.log && grep Finished ncverilog.log > nc_passed.log
|
||
|
|
||
|
######################################################################
|
||
|
|
||
|
v3: prep compile v3_passed.log
|
||
|
|
||
|
prep: vgen.v $(VERILATOR_ROOT)/bin/verilator
|
||
|
$(PERL) $(VERILATOR_ROOT)/bin/verilator $(VERILATOR_SW) --cc vgen.v
|
||
|
|
||
|
compile:
|
||
|
cd obj_dir ; $(MAKE) -j 3 -f ../Makefile_obj
|
||
|
|
||
|
v3_passed.log v3_run: prep compile
|
||
|
-rm -f v3_passed.log sim.log
|
||
|
obj_dir/simx | tee sim.log
|
||
|
grep -q Finished sim.log && grep Finished sim.log > v3_passed.log
|
||
|
|
||
|
######################################################################
|
||
|
maintainer-copy::
|
||
|
clean mostlyclean distclean maintainer-clean::
|
||
|
-rm -rf obj_dir *.log *.dmp *.vpd simv* *.key vgen.v csrc INCA_libs
|
||
|
|