blob: 0f806fc0b9f0996b4ec647301331260714315c6e [file] [log] [blame]
Eric Kunze89ff71d2024-01-10 00:23:43 +00001cmake_minimum_required (VERSION 3.16)
Eric Kunzee5e26762020-10-13 16:11:07 -07002
Dmitrii Agibov2936f132024-01-02 15:41:01 +00003# Copyright (c) 2020-2024, 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
Georgios Pinitas41df4282023-05-30 12:20:31 +010071 src/subgraph_traverser.cc
72 src/tensor.cc
Jeremy Johnsonb20b0c92023-10-04 14:17:55 +010073 src/generate/generate_dot_product_states.cc
74 src/generate/generate_dot_product.cc
Jeremy Johnsond41feb72023-10-12 16:03:15 +010075 src/generate/generate_pseudo_random.cc
Won Jeon64e4bfe2024-01-18 06:31:55 +000076 src/generate/generate_fixed_data.cc
Jeremy Johnsonb20b0c92023-10-04 14:17:55 +010077 src/generate/generate_entry.cc
78 src/generate/generate_utils.cc
Jeremy Johnson9a758382023-11-07 16:27:35 +000079 src/verify/verify_abs_error.cc
Georgios Pinitas7021ef02023-08-22 08:25:57 +010080 src/verify/verify_dot_product.cc
81 src/verify/verify_entry.cc
Jack Franklandaafc8502023-09-13 11:03:50 +010082 src/verify/verify_exact.cc
Jack Frankland12ee1a72023-09-20 09:08:34 +010083 src/verify/verify_reduce_product.cc
Jeremy Johnson32d0b5a2024-02-01 15:54:07 +000084 src/verify/verify_relative.cc
Jack Frankland62737b12023-09-13 15:47:48 +010085 src/verify/verify_ulp.cc
Georgios Pinitas7021ef02023-08-22 08:25:57 +010086 src/verify/verify_utils.cc
Matthew Sloyanba5fad32022-09-26 13:31:43 +010087 src/ops/op_factory.cc
88 src/ops/tensor_ops.cc
89 src/ops/activation_funcs.cc
90 src/ops/ewise_binary.cc
91 src/ops/ewise_unary.cc
92 src/ops/ewise_ternary.cc
93 src/ops/comparison.cc
94 src/ops/reduction.cc
95 src/ops/data_layout.cc
96 src/ops/scatter_gather.cc
97 src/ops/image.cc
98 src/ops/type_conversion.cc
99 src/ops/data_nodes.cc
100 src/ops/custom.cc
101 src/ops/control_flow.cc
Tai Ly8690a082023-12-18 20:40:24 +0000102 src/ops/shape.cc
Eric Kunzee5e26762020-10-13 16:11:07 -0700103)
104
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100105set(PUBLIC_INCLUDE_DIRS
Eric Kunzee5e26762020-10-13 16:11:07 -0700106 $<INSTALL_INTERFACE:include>
107 $<BUILD_INTERFACE:${CMAKE_CURRENT_SRC_DIR}/include>
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100108)
109set(PRIVATE_INCLUDE_DIRS
Eric Kunzee5e26762020-10-13 16:11:07 -0700110 ${CMAKE_CURRENT_SOURCE_DIR}/src
111 ${FLATBUFFERS_DIR}/include
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100112 ${EIGEN_DIR}
113 ${EIGEN_DIR}/unsupported/
Kevin Cheng550ccc52021-03-03 11:21:43 -0800114 ${SERIALIZATION_DIR}/include
James Ward8b390432022-08-12 20:48:56 +0100115 ${HALF_DIR}/include
Georgios Pinitas7021ef02023-08-22 08:25:57 +0100116 ${JSON_DIR}/single_include
Eric Kunzee5e26762020-10-13 16:11:07 -0700117)
118
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100119# Build TOSA Reference Model library
120add_library(tosa_reference_model_lib STATIC ${CXX_SOURCE})
121
122target_include_directories(tosa_reference_model_lib
123 PUBLIC
124 ${PUBLIC_INCLUDE_DIRS}
125 PRIVATE
126 ${PRIVATE_INCLUDE_DIRS}
127)
128
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100129target_link_libraries(tosa_reference_model_lib
Eric Kunzee5e26762020-10-13 16:11:07 -0700130 PRIVATE
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100131 ${SERIALIZATION_LIB}
Eric Kunzee5e26762020-10-13 16:11:07 -0700132)
133
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100134set(PUBLIC_HEADERS)
135list(APPEND PUBLIC_HEADERS
Jerry Ge5637a862023-10-30 10:18:45 -0700136 include/custom_op_interface.h
137 include/custom_registry.h
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100138 include/debug_modes.def
139 include/debug_types.h
Tai Lya4d748b2023-03-28 22:06:56 +0000140 include/dtype.h
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100141 include/func_config.h
142 include/func_debug.h
Jeremy Johnsonb20b0c92023-10-04 14:17:55 +0100143 include/generate.h
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100144 include/graph_status.h
145 include/model_common.h
146 include/model_runner.h
Georgios Pinitas7021ef02023-08-22 08:25:57 +0100147 include/types.h
Georgios Pinitas41df4282023-05-30 12:20:31 +0100148 include/verify.h
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100149 include/version.h
150)
151
152set_target_properties(tosa_reference_model_lib PROPERTIES PUBLIC_HEADER "${PUBLIC_HEADERS}")
153
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100154# Build TOSA verification library
155add_library(tosa_reference_verify_lib SHARED
Jeremy Johnson9a758382023-11-07 16:27:35 +0000156 src/verify/verify_abs_error.cc
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100157 src/verify/verify_dot_product.cc
158 src/verify/verify_entry.cc
Jack Franklandaafc8502023-09-13 11:03:50 +0100159 src/verify/verify_exact.cc
Jack Frankland12ee1a72023-09-20 09:08:34 +0100160 src/verify/verify_reduce_product.cc
Jeremy Johnson32d0b5a2024-02-01 15:54:07 +0000161 src/verify/verify_relative.cc
Jack Frankland62737b12023-09-13 15:47:48 +0100162 src/verify/verify_ulp.cc
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100163 src/verify/verify_utils.cc
164 src/verify/verify_config.cc
165 src/func_debug.cc
166)
167target_include_directories(tosa_reference_verify_lib
168 PUBLIC
169 ${PUBLIC_INCLUDE_DIRS}
170 PRIVATE
171 ${PRIVATE_INCLUDE_DIRS}
172)
173
Jeremy Johnsonb20b0c92023-10-04 14:17:55 +0100174# Build TOSA generator library
175add_library(tosa_reference_generate_lib SHARED
176 src/generate/generate_dot_product_states.cc
177 src/generate/generate_dot_product.cc
Jeremy Johnsond41feb72023-10-12 16:03:15 +0100178 src/generate/generate_pseudo_random.cc
Won Jeon64e4bfe2024-01-18 06:31:55 +0000179 src/generate/generate_fixed_data.cc
Jeremy Johnsonb20b0c92023-10-04 14:17:55 +0100180 src/generate/generate_entry.cc
181 src/generate/generate_utils.cc
Jeremy Johnson65ba8092023-10-09 16:31:13 +0100182 src/generate/generate_config.cc
Jeremy Johnsonb20b0c92023-10-04 14:17:55 +0100183 src/func_debug.cc
184)
185target_include_directories(tosa_reference_generate_lib
186 PUBLIC
187 ${PUBLIC_INCLUDE_DIRS}
188 PRIVATE
189 ${PRIVATE_INCLUDE_DIRS}
190)
191
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100192# Build TOSA Refererence Model executable
193if(BUILD_TOSA_REFERENCE_MODEL_EXECUTABLE)
194 set(CXX_SOURCE_EX src/main.cpp)
195 list(APPEND CXX_SOURCE_EX ${CXX_SOURCE})
196
197 add_executable(tosa_reference_model ${CXX_SOURCE_EX})
198
199 target_include_directories(tosa_reference_model
200 PUBLIC
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100201 ${PUBLIC_INCLUDE_DIRS}
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100202 PRIVATE
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100203 ${PRIVATE_INCLUDE_DIRS}
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100204 )
205
206 target_link_libraries(tosa_reference_model
207 PRIVATE
208 ${SERIALIZATION_LIB}
209 nlohmann_json::nlohmann_json
210 cxxopts
Jerry Ge5637a862023-10-30 10:18:45 -0700211 ${CMAKE_DL_LIBS}
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100212 )
213
214 install(TARGETS tosa_reference_model DESTINATION bin)
215endif()
216
217if(BUILD_TOSA_REFERENCE_MODEL_TESTS)
218 # Set definition so unit tests can find examples directory.
219 add_definitions(-DPROJECT_ROOT=\"${CMAKE_CURRENT_SOURCE_DIR}/\")
220
221 # Set doctest location if not specified.
222 if(NOT DOCTEST_DIR)
223 set(DOCTEST_DIR "../thirdparty/doctest/doctest")
224 endif()
225
226 # Sources only required for unit tests.
227 set(CXX_SOURCE_TESTS
Jeremy Johnsonb20b0c92023-10-04 14:17:55 +0100228 test/generate_tests.cpp
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100229 test/model_runner_tests.cpp
Georgios Pinitas41df4282023-05-30 12:20:31 +0100230 test/verify_tests.cpp
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100231 ${DOCTEST_DIR}/doctest.h
232 )
233
234 list(APPEND CXX_SOURCE_TESTS ${CXX_SOURCE})
235
236 add_executable(unit_tests ${CXX_SOURCE_TESTS})
237
238 target_include_directories(unit_tests
239 PUBLIC
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100240 ${PUBLIC_INCLUDE_DIRS}
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100241 PRIVATE
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100242 ${PRIVATE_INCLUDE_DIRS}
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100243 ${DOCTEST_DIR}
244 )
245
246 target_link_libraries(unit_tests
247 PRIVATE
248 ${SERIALIZATION_LIB}
249 )
250endif()
251
252if(BUILD_MODEL_RUNNER_SAMPLE)
253 # Set definition so sample executable can find examples directory.
254 add_definitions(-DPROJECT_ROOT=\"${CMAKE_CURRENT_SOURCE_DIR}/\")
255
256 # Sources only required for example executable.
257 set(CXX_SOURCE_SAMPLE
258 samples/model_runner_simple_sample.cpp
259 )
260
261 list(APPEND CXX_SOURCE_SAMPLE ${CXX_SOURCE})
262
263 add_executable(model_runner_sample ${CXX_SOURCE_SAMPLE})
264
265 target_include_directories(model_runner_sample
266 PUBLIC
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100267 ${PUBLIC_INCLUDE_DIRS}
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100268 PRIVATE
Jeremy Johnson48df8c72023-09-12 14:52:34 +0100269 ${PRIVATE_INCLUDE_DIRS}
Matthew Sloyanba5fad32022-09-26 13:31:43 +0100270 )
271
272 target_link_libraries(model_runner_sample
273 PRIVATE
274 ${SERIALIZATION_LIB}
275 )
276endif()
277
278# Follow GNU packaging norms for installation directory structure.
279include(GNUInstallDirs)
280install(
281 TARGETS tosa_reference_model_lib EXPORT TosaReferenceModelLibTargets
282 PUBLIC_HEADER
283 ARCHIVE
284)
285
286install(EXPORT TosaReferenceModelLibTargets
287 FILE TosaReferenceModelLibTargets.cmake
288 NAMESPACE TosaReference::
289 DESTINATION "${CMAKE_INSTALL_LIBDIR}/cmake/tosa_reference_model_lib"
Jack Franklandaafc8502023-09-13 11:03:50 +0100290)