2019-10-17 23:44:10 +00:00
|
|
|
######################################################################
|
|
|
|
#
|
|
|
|
# DESCRIPTION: Verilator CMake example usage
|
|
|
|
#
|
|
|
|
# This file shows usage of the CMake script.
|
|
|
|
# This makefile is here for testing the examples and should
|
|
|
|
# generally not be added to a CMake project.
|
|
|
|
#
|
2020-03-21 15:24:24 +00:00
|
|
|
# Copyright 2003-2020 by Wilson Snyder. This program is free software; you
|
|
|
|
# can redistribute it and/or modify it under the terms of either the GNU
|
2019-10-17 23:44:10 +00:00
|
|
|
# Lesser General Public License Version 3 or the Perl Artistic License
|
|
|
|
# Version 2.0.
|
2020-03-21 15:24:24 +00:00
|
|
|
# SPDX-License-Identifier: LGPL-3.0-only OR Artistic-2.0
|
2019-10-17 23:44:10 +00:00
|
|
|
#
|
|
|
|
######################################################################
|
|
|
|
|
|
|
|
######################################################################
|
|
|
|
# Set up variables
|
|
|
|
|
|
|
|
# If $VERILATOR_ROOT isn't in the environment, we assume it is part of a
|
|
|
|
# package install, and verilator is in your path. Otherwise find the
|
|
|
|
# binary relative to $VERILATOR_ROOT (such as when inside the git sources).
|
|
|
|
|
|
|
|
ifeq ($(VERILATOR_ROOT),)
|
|
|
|
VERILATOR_COVERAGE = verilator_coverage
|
|
|
|
else
|
|
|
|
export VERILATOR_ROOT
|
|
|
|
VERILATOR_COVERAGE = $(VERILATOR_ROOT)/bin/verilator_coverage
|
|
|
|
endif
|
|
|
|
######################################################################
|
|
|
|
|
|
|
|
# Check if CMake is installed and of correct version
|
|
|
|
ifeq ($(shell which cmake),)
|
|
|
|
TARGET := nocmake
|
|
|
|
else
|
|
|
|
CMAKE_VERSION := $(shell cmake --version | grep -Po '(\d[\.\d]+)')
|
|
|
|
CMAKE_MAJOR := $(shell echo $(CMAKE_VERSION) | cut -f1 -d.)
|
|
|
|
CMAKE_MINOR := $(shell echo $(CMAKE_VERSION) | cut -f2 -d.)
|
|
|
|
CMAKE_GT_3_8 := $(shell [ $(CMAKE_MAJOR) -gt 3 -o \( $(CMAKE_MAJOR) -eq 3 -a $(CMAKE_MINOR) -ge 8 \) ] && echo true)
|
|
|
|
ifneq ($(CMAKE_GT_3_8),true)
|
|
|
|
TARGET := oldcmake
|
|
|
|
else
|
|
|
|
|
|
|
|
# Test existence of SYSTEMC_INCLUDE and SYSTEMC_LIBDIR environment variabless
|
|
|
|
ifneq (,$(SYSTEMC_INCLUDE))
|
|
|
|
ifneq (,${SYSTEMC_LIBDIR})
|
|
|
|
SYSTEMC_SET := true
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
# Test existence of SYSTEMC_ROOT environment variable
|
|
|
|
ifneq (SYSTEMC_SET, true)
|
|
|
|
ifneq (,${SYSTEMC_ROOT})
|
|
|
|
SYSTEMC_SET := true
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
# Test existence of SYSTEMC environment variable
|
|
|
|
ifneq (SYSTEMC_SET, true)
|
|
|
|
ifneq (,${SYSTEMC})
|
|
|
|
SYSTEMC_SET := true
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
# Test whether SystemC is installed with CMake support
|
|
|
|
# This will print a CMake error about processing arguments that can (currently) be ignored.
|
|
|
|
ifneq (SYSTEMC_SET, true)
|
|
|
|
FINDSC := $(shell mkdir -p build && cd build && cmake --find-package -DNAME=SystemCLanguage -DCMAKE_USE_PTHREADS_INIT=ON -DCOMPILER_ID=GNU -DLANGUAGE=CXX -DMODE=EXIST -DThreads_FOUND=ON)
|
|
|
|
ifneq (,$(findstring SystemCLanguage found,$(FINDSC)))
|
|
|
|
SYSTEMC_SET := true
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
ifeq ($(SYSTEMC_SET), true)
|
|
|
|
TARGET := run
|
|
|
|
else
|
|
|
|
TARGET := nosc
|
|
|
|
endif
|
|
|
|
|
|
|
|
endif
|
|
|
|
endif
|
|
|
|
|
|
|
|
default: $(TARGET)
|
|
|
|
|
|
|
|
run:
|
|
|
|
@echo
|
|
|
|
@echo "-- Verilator CMake SystemC hello-world simple example"
|
|
|
|
|
|
|
|
@echo
|
|
|
|
@echo "-- CMake ----------------"
|
|
|
|
mkdir -p build && cd build && cmake ..
|
|
|
|
|
|
|
|
@echo
|
|
|
|
@echo "-- COMPILE -----------------"
|
|
|
|
cmake --build build
|
|
|
|
|
|
|
|
@echo
|
|
|
|
@echo "-- RUN ---------------------"
|
|
|
|
@mkdir -p logs
|
|
|
|
build/example
|
|
|
|
|
|
|
|
@echo "-- DONE --------------------"
|
|
|
|
@echo "Note: Once this example is understood, see examples/cmake_tracing_sc."
|
|
|
|
@echo "Note: Also see the EXAMPLE section in the verilator manpage/document."
|
|
|
|
|
|
|
|
clean mostlyclean distclean maintainer-clean:
|
|
|
|
@rm -rf build logs
|
|
|
|
|
|
|
|
nocmake:
|
|
|
|
@echo
|
|
|
|
@echo "%Skip: CMake has not been found"
|
|
|
|
@echo
|
|
|
|
|
|
|
|
oldcmake:
|
|
|
|
@echo
|
|
|
|
@echo "%Skip: CMake version is too old (need at least 3.8)"
|
|
|
|
@echo
|
|
|
|
|
|
|
|
nosc:
|
|
|
|
@echo
|
|
|
|
@echo "%Skip: CMake could not find SystemC."
|
|
|
|
@echo "% Make sure that either:"
|
|
|
|
@echo "% - The environment variables SYSTEMC_INCLUDE and SYSTEMC_LIBDIR are exported."
|
|
|
|
@echo "% - Or, the environment variable SYSTEMC_ROOT is exported."
|
|
|
|
@echo "% - Or, The environment variable SYSTEMC is exported."
|
|
|
|
@echo "% - Or, if the SystemC installation provides CMake support,"
|
|
|
|
@echo "% that its installation prefix is in CMAKE_PREFIX_PATH."
|
|
|
|
@echo "% Also that the C++ standard of the SystemC library is the same as this example."
|
|
|
|
@echo "% Please see the Verilator documentation's CMake section for more information."
|
|
|
|
@echo
|