blob: 24467c8a4de3b52fbbbf83e74425cdb4c5a40639 [file] [log] [blame]
Eric Kunzee5e26762020-10-13 16:11:07 -07001cmake_minimum_required (VERSION 3.4)
2
Tai Lya4d748b2023-03-28 22:06:56 +00003# Copyright (c) 2020-2023, ARM Limited.
Eric Kunzee5e26762020-10-13 16:11:07 -07004#
5# Licensed under the Apache License, Version 2.0 (the "License");
6# you may not use this file except in compliance with the License.
7# You may obtain a copy of the License at
8#
9# http://www.apache.org/licenses/LICENSE-2.0
10#
11# Unless required by applicable law or agreed to in writing, software
12# distributed under the License is distributed on an "AS IS" BASIS,
13# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14# See the License for the specific language governing permissions and
15# limitations under the License.
16
Eric Kunzee5e26762020-10-13 16:11:07 -070017project(tosa_reference_model LANGUAGES CXX)
18
19set(CMAKE_CXX_STANDARD 17)
20set(CMAKE_CXX_STANDARD_REQUIRED ON)
21
22if(CMAKE_CXX_COMPILER_ID STREQUAL GNU)
23 set(CMAKE_CXX_FLAGS "-Wall -Wno-ignored-attributes -Wno-format-truncation")
24else()
25 set(CMAKE_CXX_FLAGS "-Wall -Wno-ignored-attributes")
26endif()
27
Matthew Sloyanba5fad32022-09-26 13:31:43 +010028# If Serialization Library path is specified, look for library so it doesn't have to be built again.
29# Otherwise, set the Serialization Library related paths to thirdparty directory.
30if(SERIALIZATION_DIR)
31 find_library(SERIALIZATION_LIB
32 NAMES libtosa_serialization_lib.a tosa_serialization_lib
33 NO_DEFAULT_PATH
34 HINTS ${SERIALIZATION_DIR}
35 PATH_SUFFIXES lib)
Eric Kunzee5e26762020-10-13 16:11:07 -070036
Matthew Sloyanba5fad32022-09-26 13:31:43 +010037 if(NOT SERIALIZATION_LIB)
38 message(FATAL_ERROR "TOSA Serialization Library location was specified but not found at: ${SERIALIZATION_LIB_DIR}")
39 endif()
40else()
41 # Build from third party directory if not found.
42 set(SERIALIZATION_LIB tosa_serialization_lib)
43 set(SERIALIZATION_DIR "../thirdparty/serialization_lib/")
44endif()
45
James Ward8b390432022-08-12 20:48:56 +010046# If Flatbuffers, Eigen, Half path isn't specified, set to thirdparty directory.
Matthew Sloyanba5fad32022-09-26 13:31:43 +010047if(NOT FLATBUFFERS_DIR)
48 set(FLATBUFFERS_DIR "../thirdparty/serialization_lib/third_party/flatbuffers/")
49endif()
50
51if(NOT EIGEN_DIR)
52 set(EIGEN_DIR "../thirdparty/eigen/")
53endif()
54
James Ward8b390432022-08-12 20:48:56 +010055if(NOT HALF_DIR)
56 set(HALF_DIR "../thirdparty/serialization_lib/third_party/half")
57endif()
58
Georgios Pinitas7021ef02023-08-22 08:25:57 +010059if(NOT JSON_DIR)
60 set(JSON_DIR "../thirdparty/json")
61endif()
62
Matthew Sloyanba5fad32022-09-26 13:31:43 +010063include_directories(${CMAKE_CURRENT_SOURCE_DIR}/include)
64
65# Common sources required for TOSA Reference Model library, executable and unit tests
66set(CXX_SOURCE
Matthew Sloyanba5fad32022-09-26 13:31:43 +010067 src/func_debug.cc
Georgios Pinitas41df4282023-05-30 12:20:31 +010068 src/graph_node.cc
69 src/model_runner_impl.cc
70 src/model_runner.cc
Grant Watson64285a12022-11-16 15:32:39 +000071 src/operators.cc
Georgios Pinitas41df4282023-05-30 12:20:31 +010072 src/subgraph_traverser.cc
73 src/tensor.cc
Jeremy Johnsonb20b0c92023-10-04 14:17:55 +010074 src/generate/generate_dot_product_states.cc
75 src/generate/generate_dot_product.cc
Jeremy Johnsond41feb72023-10-12 16:03:15 +010076 src/generate/generate_pseudo_random.cc
Jeremy Johnsonb20b0c92023-10-04 14:17:55 +010077 src/generate/generate_entry.cc
78 src/generate/generate_utils.cc
Georgios Pinitas7021ef02023-08-22 08:25:57 +010079 src/verify/verify_dot_product.cc
80 src/verify/verify_entry.cc
Jack Franklandaafc8502023-09-13 11:03:50 +010081 src/verify/verify_exact.cc
Jack Frankland12ee1a72023-09-20 09:08:34 +010082 src/verify/verify_reduce_product.cc
Jack Frankland62737b12023-09-13 15:47:48 +010083 src/verify/verify_ulp.cc
Georgios Pinitas7021ef02023-08-22 08:25:57 +010084 src/verify/verify_utils.cc
Matthew Sloyanba5fad32022-09-26 13:31:43 +010085 src/ops/op_factory.cc
86 src/ops/tensor_ops.cc
87 src/ops/activation_funcs.cc
88 src/ops/ewise_binary.cc
89 src/ops/ewise_unary.cc
90 src/ops/ewise_ternary.cc
91 src/ops/comparison.cc
92 src/ops/reduction.cc
93 src/ops/data_layout.cc
94 src/ops/scatter_gather.cc
95 src/ops/image.cc
96 src/ops/type_conversion.cc
97 src/ops/data_nodes.cc
98 src/ops/custom.cc
99 src/ops/control_flow.cc
Eric Kunzee5e26762020-10-13 16:11:07 -0700100)
101
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100102set(PUBLIC_INCLUDE_DIRS
Eric Kunzee5e26762020-10-13 16:11:07 -0700103 $<INSTALL_INTERFACE:include>
104 $<BUILD_INTERFACE:${CMAKE_CURRENT_SRC_DIR}/include>
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100105)
106set(PRIVATE_INCLUDE_DIRS
Eric Kunzee5e26762020-10-13 16:11:07 -0700107 ${CMAKE_CURRENT_SOURCE_DIR}/src
108 ${FLATBUFFERS_DIR}/include
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100109 ${EIGEN_DIR}
110 ${EIGEN_DIR}/unsupported/
Kevin Cheng550ccc52021-03-03 11:21:43 -0800111 ${SERIALIZATION_DIR}/include
James Ward8b390432022-08-12 20:48:56 +0100112 ${HALF_DIR}/include
Georgios Pinitas7021ef02023-08-22 08:25:57 +0100113 ${JSON_DIR}/single_include
Eric Kunzee5e26762020-10-13 16:11:07 -0700114)
115
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100116# Build TOSA Reference Model library
117add_library(tosa_reference_model_lib STATIC ${CXX_SOURCE})
118
119target_include_directories(tosa_reference_model_lib
120 PUBLIC
121 ${PUBLIC_INCLUDE_DIRS}
122 PRIVATE
123 ${PRIVATE_INCLUDE_DIRS}
124)
125
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100126target_link_libraries(tosa_reference_model_lib
Eric Kunzee5e26762020-10-13 16:11:07 -0700127 PRIVATE
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100128 ${SERIALIZATION_LIB}
Eric Kunzee5e26762020-10-13 16:11:07 -0700129)
130
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100131set(PUBLIC_HEADERS)
132list(APPEND PUBLIC_HEADERS
133 include/debug_modes.def
134 include/debug_types.h
Tai Lya4d748b2023-03-28 22:06:56 +0000135 include/dtype.h
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100136 include/func_config.h
137 include/func_debug.h
Jeremy Johnsonb20b0c92023-10-04 14:17:55 +0100138 include/generate.h
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100139 include/graph_status.h
140 include/model_common.h
141 include/model_runner.h
Georgios Pinitas7021ef02023-08-22 08:25:57 +0100142 include/types.h
Georgios Pinitas41df4282023-05-30 12:20:31 +0100143 include/verify.h
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100144 include/version.h
145)
146
147set_target_properties(tosa_reference_model_lib PROPERTIES PUBLIC_HEADER "${PUBLIC_HEADERS}")
148
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100149# Build TOSA verification library
150add_library(tosa_reference_verify_lib SHARED
151 src/verify/verify_dot_product.cc
152 src/verify/verify_entry.cc
Jack Franklandaafc8502023-09-13 11:03:50 +0100153 src/verify/verify_exact.cc
Jack Frankland12ee1a72023-09-20 09:08:34 +0100154 src/verify/verify_reduce_product.cc
Jack Frankland62737b12023-09-13 15:47:48 +0100155 src/verify/verify_ulp.cc
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100156 src/verify/verify_utils.cc
157 src/verify/verify_config.cc
158 src/func_debug.cc
159)
160target_include_directories(tosa_reference_verify_lib
161 PUBLIC
162 ${PUBLIC_INCLUDE_DIRS}
163 PRIVATE
164 ${PRIVATE_INCLUDE_DIRS}
165)
166
Jeremy Johnsonb20b0c92023-10-04 14:17:55 +0100167# Build TOSA generator library
168add_library(tosa_reference_generate_lib SHARED
169 src/generate/generate_dot_product_states.cc
170 src/generate/generate_dot_product.cc
Jeremy Johnsond41feb72023-10-12 16:03:15 +0100171 src/generate/generate_pseudo_random.cc
Jeremy Johnsonb20b0c92023-10-04 14:17:55 +0100172 src/generate/generate_entry.cc
173 src/generate/generate_utils.cc
Jeremy Johnson65ba8092023-10-09 16:31:13 +0100174 src/generate/generate_config.cc
Jeremy Johnsonb20b0c92023-10-04 14:17:55 +0100175 src/func_debug.cc
176)
177target_include_directories(tosa_reference_generate_lib
178 PUBLIC
179 ${PUBLIC_INCLUDE_DIRS}
180 PRIVATE
181 ${PRIVATE_INCLUDE_DIRS}
182)
183
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100184# Build TOSA Refererence Model executable
185if(BUILD_TOSA_REFERENCE_MODEL_EXECUTABLE)
186 set(CXX_SOURCE_EX src/main.cpp)
187 list(APPEND CXX_SOURCE_EX ${CXX_SOURCE})
188
189 add_executable(tosa_reference_model ${CXX_SOURCE_EX})
190
191 target_include_directories(tosa_reference_model
192 PUBLIC
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100193 ${PUBLIC_INCLUDE_DIRS}
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100194 PRIVATE
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100195 ${PRIVATE_INCLUDE_DIRS}
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100196 )
197
198 target_link_libraries(tosa_reference_model
199 PRIVATE
200 ${SERIALIZATION_LIB}
201 nlohmann_json::nlohmann_json
202 cxxopts
203 )
204
205 install(TARGETS tosa_reference_model DESTINATION bin)
206endif()
207
208if(BUILD_TOSA_REFERENCE_MODEL_TESTS)
209 # Set definition so unit tests can find examples directory.
210 add_definitions(-DPROJECT_ROOT=\"${CMAKE_CURRENT_SOURCE_DIR}/\")
211
212 # Set doctest location if not specified.
213 if(NOT DOCTEST_DIR)
214 set(DOCTEST_DIR "../thirdparty/doctest/doctest")
215 endif()
216
217 # Sources only required for unit tests.
218 set(CXX_SOURCE_TESTS
Jeremy Johnsonb20b0c92023-10-04 14:17:55 +0100219 test/generate_tests.cpp
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100220 test/model_runner_tests.cpp
Georgios Pinitas41df4282023-05-30 12:20:31 +0100221 test/verify_tests.cpp
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100222 ${DOCTEST_DIR}/doctest.h
223 )
224
225 list(APPEND CXX_SOURCE_TESTS ${CXX_SOURCE})
226
227 add_executable(unit_tests ${CXX_SOURCE_TESTS})
228
229 target_include_directories(unit_tests
230 PUBLIC
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100231 ${PUBLIC_INCLUDE_DIRS}
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100232 PRIVATE
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100233 ${PRIVATE_INCLUDE_DIRS}
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100234 ${DOCTEST_DIR}
235 )
236
237 target_link_libraries(unit_tests
238 PRIVATE
239 ${SERIALIZATION_LIB}
240 )
241endif()
242
243if(BUILD_MODEL_RUNNER_SAMPLE)
244 # Set definition so sample executable can find examples directory.
245 add_definitions(-DPROJECT_ROOT=\"${CMAKE_CURRENT_SOURCE_DIR}/\")
246
247 # Sources only required for example executable.
248 set(CXX_SOURCE_SAMPLE
249 samples/model_runner_simple_sample.cpp
250 )
251
252 list(APPEND CXX_SOURCE_SAMPLE ${CXX_SOURCE})
253
254 add_executable(model_runner_sample ${CXX_SOURCE_SAMPLE})
255
256 target_include_directories(model_runner_sample
257 PUBLIC
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100258 ${PUBLIC_INCLUDE_DIRS}
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100259 PRIVATE
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100260 ${PRIVATE_INCLUDE_DIRS}
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100261 )
262
263 target_link_libraries(model_runner_sample
264 PRIVATE
265 ${SERIALIZATION_LIB}
266 )
267endif()
268
269# Follow GNU packaging norms for installation directory structure.
270include(GNUInstallDirs)
271install(
272 TARGETS tosa_reference_model_lib EXPORT TosaReferenceModelLibTargets
273 PUBLIC_HEADER
274 ARCHIVE
275)
276
277install(EXPORT TosaReferenceModelLibTargets
278 FILE TosaReferenceModelLibTargets.cmake
279 NAMESPACE TosaReference::
280 DESTINATION "${CMAKE_INSTALL_LIBDIR}/cmake/tosa_reference_model_lib"
Jack Franklandaafc8502023-09-13 11:03:50 +0100281)