mirror of
https://github.com/verilator/verilator.git
synced 2025-01-25 07:44:14 +00:00
47 lines
1.5 KiB
CMake
47 lines
1.5 KiB
CMake
|
######################################################################
|
||
|
#
|
||
|
# DESCRIPTION: Verilator CMake Example: Small CMakeLists.txt with SystemC
|
||
|
#
|
||
|
# This is an example cmake script to build a verilog to SystemC project
|
||
|
# using CMake and Verilator.
|
||
|
#
|
||
|
# Copyright 2003-2019 by Wilson Snyder. 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.
|
||
|
#
|
||
|
######################################################################
|
||
|
|
||
|
# This example builds the tracing_sc example using CMake
|
||
|
# To use it, run the following:
|
||
|
|
||
|
# cd /path/to/verilator/examples/cmake_sc
|
||
|
# rm -rf build && mkdir build && cd build
|
||
|
# cmake ..
|
||
|
# cmake --build .
|
||
|
|
||
|
cmake_minimum_required(VERSION 3.8)
|
||
|
project(cmake_hello_sc)
|
||
|
|
||
|
find_package(verilator HINTS $ENV{VERILATOR_ROOT} ${VERILATOR_ROOT})
|
||
|
if (NOT verilator_FOUND)
|
||
|
message(FATAL_ERROR "Verilator was not found. Either install it, or set the VERILATOR_ROOT environment variable")
|
||
|
endif()
|
||
|
|
||
|
# SystemC dependencies
|
||
|
set(THREADS_PREFER_PTHREAD_FLAG ON)
|
||
|
find_package(Threads REQUIRED)
|
||
|
|
||
|
# Find SystemC using SystemC's CMake integration
|
||
|
find_package(SystemCLanguage QUIET)
|
||
|
|
||
|
# Create a new executable target that will contain all your sources
|
||
|
add_executable(example ../make_hello_sc/sc_main.cpp)
|
||
|
|
||
|
# Add the Verilated circuit to the target
|
||
|
verilate(example SYSTEMC
|
||
|
INCLUDE_DIRS "../make_hello_sc"
|
||
|
SOURCES ../make_hello_sc/top.v)
|
||
|
|
||
|
verilator_link_systemc(example)
|