2017-09-24 01:18:07 +00:00
|
|
|
# -*- Makefile -*-
|
|
|
|
#######################################################################
|
|
|
|
#
|
|
|
|
# DESCRIPTION: Verilator Example: Makefile for inside object directory
|
|
|
|
#
|
|
|
|
# This is executed in the object directory, and called by ../Makefile
|
|
|
|
#
|
2020-05-19 02:23:19 +00:00
|
|
|
# This file ONLY is placed under the Creative Commons Public Domain, for
|
|
|
|
# any use, without warranty, 2020 by Wilson Snyder.
|
|
|
|
# SPDX-License-Identifier: CC0-1.0
|
2017-09-24 01:18:07 +00:00
|
|
|
#
|
|
|
|
#######################################################################
|
|
|
|
|
|
|
|
default: Vtop
|
|
|
|
|
|
|
|
# Include the rules made by Verilator
|
|
|
|
include Vtop.mk
|
|
|
|
|
2018-06-15 11:13:18 +00:00
|
|
|
# Use OBJCACHE (ccache) if using gmake and its installed
|
|
|
|
COMPILE.cc = $(OBJCACHE) $(CXX) $(CXXFLAGS) $(CPPFLAGS) $(TARGET_ARCH) -c
|
|
|
|
|
2017-09-24 01:18:07 +00:00
|
|
|
#######################################################################
|
|
|
|
# Compile flags
|
|
|
|
|
2021-03-27 03:01:58 +00:00
|
|
|
# Turn on creating .d make dependency files
|
2017-09-24 01:18:07 +00:00
|
|
|
CPPFLAGS += -MMD -MP
|
2021-03-27 03:01:58 +00:00
|
|
|
|
|
|
|
# Compile in Verilator runtime debugging, so +verilator+debug works
|
2017-09-24 01:18:07 +00:00
|
|
|
CPPFLAGS += -DVL_DEBUG=1
|
2021-03-27 03:01:58 +00:00
|
|
|
|
|
|
|
# Turn on some more compiler lint flags (when configured appropriately)
|
2017-10-14 18:03:12 +00:00
|
|
|
# For testing inside Verilator, "configure --enable-ccwarn" will do this
|
|
|
|
# automatically; otherwise you may want this unconditionally enabled
|
2023-01-30 03:39:22 +00:00
|
|
|
ifeq ($(CFG_WITH_CCWARN),yes) # Local... Else don't burden users
|
2017-10-14 18:03:12 +00:00
|
|
|
USER_CPPFLAGS_WALL += -W -Werror -Wall
|
2017-09-24 01:18:07 +00:00
|
|
|
endif
|
|
|
|
|
|
|
|
# See the benchmarking section of bin/verilator.
|
|
|
|
# Support class optimizations. This includes the tracing and symbol table.
|
|
|
|
# SystemC takes minutes to optimize, thus it is off by default.
|
|
|
|
OPT_SLOW =
|
2021-03-27 03:01:58 +00:00
|
|
|
|
2017-09-24 01:18:07 +00:00
|
|
|
# Fast path optimizations. Most time is spent in these classes.
|
2020-02-27 12:46:34 +00:00
|
|
|
OPT_FAST = -Os -fstrict-aliasing
|
2017-09-24 01:18:07 +00:00
|
|
|
#OPT_FAST = -O
|
|
|
|
#OPT_FAST =
|
|
|
|
|
|
|
|
######################################################################
|
|
|
|
######################################################################
|
|
|
|
# Automatically understand dependencies
|
|
|
|
|
|
|
|
DEPS := $(wildcard *.d)
|
|
|
|
ifneq ($(DEPS),)
|
|
|
|
include $(DEPS)
|
|
|
|
endif
|