mirror of
https://github.com/verilator/verilator.git
synced 2025-01-08 15:47:36 +00:00
a2ffe86a36
git-svn-id: file://localhost/svn/verilator/trunk/verilator@976 77ca24e4-aefa-0310-84f0-b9a241c72d87
60 lines
1.8 KiB
Makefile
60 lines
1.8 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-2008 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.
|
|
#
|
|
#****************************************************************************/
|
|
|
|
default: test_default
|
|
|
|
# This must point to the root of the VERILATOR kit
|
|
VERILATOR_ROOT := $(shell pwd)/..
|
|
export VERILATOR_ROOT
|
|
|
|
# Pick up PERL and other variable settings
|
|
include $(VERILATOR_ROOT)/include/verilated.mk
|
|
|
|
DEBUG_ON = --debug --trace-dups
|
|
#DEBUG = $(DEBUG_ON)
|
|
VALGRIND_ON = $(DEBUG_ON) --gdb "valgrind -v --leak-check=yes"
|
|
|
|
######################################################################
|
|
test_default: prep compile run
|
|
test_debug: prep_dbg compile run
|
|
test_valgrind: prep_vg compile run
|
|
|
|
VERILATOR_FLAGS = --cc -f $(VERILATOR_ROOT)/test_v/input.vc top.v
|
|
#Note turning on traces requires SystemPerl to be installed
|
|
#VERILATOR_FLAGS += --trace
|
|
|
|
prep:
|
|
$(PERL) $(VERILATOR_ROOT)/bin/verilator $(DEBUG) $(VERILATOR_FLAGS)
|
|
prep_dbg:
|
|
$(PERL) $(VERILATOR_ROOT)/bin/verilator $(DEBUG_ON) $(VERILATOR_FLAGS)
|
|
prep_vg:
|
|
$(PERL) $(VERILATOR_ROOT)/bin/verilator $(VALGRIND_ON) $(VERILATOR_FLAGS)
|
|
|
|
compile:
|
|
cd obj_dir ; $(MAKE) -j 3 -f ../Makefile_obj
|
|
|
|
run:
|
|
obj_dir/simx
|
|
|
|
######################################################################
|
|
|
|
obj_dir:
|
|
mkdir $@
|
|
|
|
######################################################################
|
|
|
|
maintainer-copy::
|
|
clean mostlyclean distclean maintainer-clean::
|
|
-rm -rf obj_dir *.log *.dmp *.vpd core
|