-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathCMakeLists.txt
151 lines (139 loc) · 4.19 KB
/
CMakeLists.txt
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
cmake_minimum_required(VERSION 3.22)
project(veripython)
set(CMAKE_CXX_STANDARD 20)
string(TOLOWER "${CMAKE_BUILD_TYPE}" build_type)
if (build_type STREQUAL "release")
message(STATUS "We are in Release Mode")
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -O2")
else ()
message(STATUS "We are in Debug Mode, gtest is enabled")
set(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -Wall -g")
include(FetchContent)
FetchContent_Declare(
googletest
GIT_REPOSITORY https://gitee.com/mirrors/googletest.git
GIT_TAG v1.14.0
)
# For Windows: Prevent overriding the parent project's compiler/linker settings
set(gtest_force_shared_crt ON CACHE BOOL "" FORCE)
FetchContent_MakeAvailable(googletest)
endif ()
find_package(FLEX REQUIRED)
set(FLEX_SRC "${CMAKE_SOURCE_DIR}/verilog.l")
set(FLEX_OUT "${CMAKE_BINARY_DIR}/lex.yy.c")
set(FLEX_DIR "${CMAKE_BINARY_DIR}")
add_custom_command(
OUTPUT ${FLEX_OUT}
COMMAND cp ${CMAKE_SOURCE_DIR}/Lexer.h ${FLEX_DIR}
COMMAND ${FLEX_EXECUTABLE} ${FLEX_SRC}
MAIN_DEPENDENCY ${FLEX_SRC} ${CMAKE_SOURCE_DIR}/Lexer.h
COMMENT "Generating lex.yy.c from verilog.l"
)
add_library(lexer OBJECT ${FLEX_OUT})
if (NOT FIRTOOL_LIB_PATH)
set(FIRTOOL_LIB_PATH "/root/circt/firtool-1.93.1/lib")
endif ()
set(FIRTOOL_INSTALL_PATH "${FIRTOOL_LIB_PATH}/cmake")
message(STATUS "FIRTOOL_LIB_PATH is ${FIRTOOL_LIB_PATH}")
find_package(CIRCT REQUIRED CONFIG
HINTS "${FIRTOOL_INSTALL_PATH}/circt")
find_package(MLIR REQUIRED CONFIG
HINTS "${FIRTOOL_INSTALL_PATH}/mlir")
find_package(LLVM REQUIRED CONFIG
HINTS "${FIRTOOL_INSTALL_PATH}/llvm")
message(STATUS "Found CIRCT include dir ${CIRCT_INCLUDE_DIRS}")
include_directories(${CIRCT_INCLUDE_DIRS})
link_directories(${FIRTOOL_LIB_PATH})
set(LLVM_ENABLE_RTTI ON)
set(LLVM_ENABLE_EH ON)
set(BUILD_SHARED_LIBS ON)
add_definitions(${LLVM_DEFINITIONS})
set(circt_libs
CIRCTFIRRTL
CIRCTArc
CIRCTArcTransforms
CIRCTArcToLLVM
CIRCTConvertToArcs
CIRCTCombToArith
CIRCTFirtool
CIRCTTransforms
MLIRIR
MLIRArithDialect
MLIRBuiltinToLLVMIRTranslation
MLIRControlFlowDialect
MLIRDLTIDialect
MLIRFuncDialect
MLIRFuncInlinerExtension
MLIRIndexDialect
MLIRLLVMIRTransforms
MLIRLLVMToLLVMIRTranslation
MLIRSCFDialect
MLIRTargetLLVMIRExport
)
add_executable(veripython
main.cpp
Parser.cpp
Parser.h
Lexer.h
AST.h
AST.cpp
RtlModule.cpp
RtlModule.h
CombLogics.cpp
CombLogics.h
CircuitSymbol.cpp
CircuitSymbol.h
RtlVisualizer.cpp
RtlVisualizer.h
RtlSimulator.cpp
RtlSimulator.h
Lexer.cpp
EmitFIRRTL.cpp
EmitFIRRTL.h
Exceptions.h
FIRToHW.cpp
FIRToHW.h
ArcBackend.cpp
ArcBackend.h
Testbench.cpp
Testbench.h
)
target_link_libraries(veripython PRIVATE lexer -lfl)
target_link_libraries(veripython PRIVATE ${circt_libs})
if (NOT (build_type STREQUAL "release"))
enable_testing()
add_executable(ParserTests
tests/ParserTests.cpp
Parser.cpp
Parser.h
Lexer.h
AST.h
AST.cpp
RtlModule.cpp
RtlModule.h
CircuitSymbol.cpp
CircuitSymbol.h
CombLogics.cpp
CombLogics.h
RtlVisualizer.cpp
RtlVisualizer.h
RtlSimulator.cpp
RtlSimulator.h
EmitFIRRTL.cpp
EmitFIRRTL.h
Exceptions.h
FIRToHW.cpp
FIRToHW.h
ArcBackend.cpp
ArcBackend.h
Testbench.cpp
Testbench.h
)
target_link_libraries(ParserTests PRIVATE GTest::gtest_main)
target_link_libraries(ParserTests PRIVATE lexer -lfl)
target_link_libraries(ParserTests PRIVATE ${circt_libs})
add_executable(AcrilatorHeaderCppTests tests/ArcilatorHeaderCppTests.cpp)
target_link_libraries(AcrilatorHeaderCppTests PRIVATE GTest::gtest_main)
include(GoogleTest)
gtest_discover_tests(ParserTests)
endif ()