Update ACL pin to dda6914c6e923187c2ca2c3bfd71677e9c9e5c68
[platform/upstream/armnn.git] / CMakeLists.txt
1 #
2 # Copyright © 2020 Arm Ltd and Contributors. All rights reserved.
3 # Copyright 2020 NXP
4 # SPDX-License-Identifier: MIT
5 #
6 cmake_minimum_required (VERSION 3.0.2) # 3.0.2 required for return() statement used in AddDllCopyCommands.cmake
7 project(armnn)
8
9 set(additional_cmake_files)
10 list(APPEND additional_cmake_files
11     cmake/ArmnnVersion.cmake
12     cmake/Utils.cmake
13     cmake/GlobalConfig.cmake
14     cmake/AddDllCopyCommands.cmake)
15
16 foreach(cmake_file ${additional_cmake_files})
17     include(${cmake_file})
18 endforeach()
19
20 cmake_policy(SET CMP0057 NEW)
21
22 set(as_subproject Armnn)
23
24 macro(find_package)
25     if(NOT ${ARGV0} IN_LIST as_subproject)
26         _find_package(${ARGV})
27     endif()
28 endmacro()
29
30 if (DYNAMIC_BACKEND_PATHS)
31     # It's expected to have the format: DYNAMIC_BACKEND_PATHS="PATH_1:PATH_2...:PATH_N"
32     add_definitions('-DDYNAMIC_BACKEND_PATHS="${DYNAMIC_BACKEND_PATHS}"')
33 endif()
34
35 include(GNUInstallDirs)
36
37 add_subdirectory(samples)
38 add_subdirectory(src/armnnTfLiteParser)
39 add_subdirectory(src/armnnSerializer)
40 add_subdirectory(src/armnnDeserializer)
41
42
43 if (BUILD_ARMNN_TFLITE_DELEGATE)
44     set(ARMNN_SUB_PROJECT ON)
45     add_subdirectory(delegate)
46     add_definitions(-DARMNN_TF_LITE_DELEGATE)
47 endif()
48
49 if (BUILD_TESTS)
50     add_subdirectory(tests)
51 endif()
52
53 # Include the additional cmake files in their own target so that they will appear nicely in IDEs
54 add_custom_target(AdditionalCMakeFiles SOURCES ${additional_cmake_files})
55
56 set(armnnUtils_sources)
57 list(APPEND armnnUtils_sources
58     include/armnnUtils/DataLayoutIndexed.hpp
59     include/armnnUtils/Permute.hpp
60     include/armnnUtils/FloatingPointComparison.hpp
61     include/armnnUtils/FloatingPointConverter.hpp
62     include/armnnUtils/TensorUtils.hpp
63     include/armnnUtils/Transpose.hpp
64     src/armnnUtils/BFloat16.hpp
65     src/armnnUtils/Filesystem.hpp
66     src/armnnUtils/Filesystem.cpp
67     src/armnnUtils/GraphTopologicalSort.hpp
68     src/armnnUtils/Half.hpp
69     src/armnnUtils/Permute.cpp
70     src/armnnUtils/DataLayoutIndexed.cpp
71     src/armnnUtils/DotSerializer.cpp
72     src/armnnUtils/DotSerializer.hpp
73     src/armnnUtils/HeapProfiling.cpp
74     src/armnnUtils/HeapProfiling.hpp
75     src/armnnUtils/LeakChecking.cpp
76     src/armnnUtils/LeakChecking.hpp
77     src/armnnUtils/ModelAccuracyChecker.cpp
78     src/armnnUtils/ModelAccuracyChecker.hpp
79     src/armnnUtils/FloatingPointConverter.cpp
80     src/armnnUtils/VerificationHelpers.hpp
81     src/armnnUtils/VerificationHelpers.cpp
82     src/armnnUtils/ParserHelper.hpp
83     src/armnnUtils/ParserHelper.cpp
84     src/armnnUtils/ParserPrototxtFixture.hpp
85     src/armnnUtils/Processes.hpp
86     src/armnnUtils/Processes.cpp
87     src/armnnUtils/PrototxtConversions.hpp
88     src/armnnUtils/PrototxtConversions.cpp
89     src/armnnUtils/QuantizeHelper.hpp
90     src/armnnUtils/TensorIOUtils.hpp
91     src/armnnUtils/TensorUtils.cpp
92     src/armnnUtils/Threads.hpp
93     src/armnnUtils/Threads.cpp
94     src/armnnUtils/Transpose.cpp
95     )
96
97 add_library_ex(armnnUtils STATIC ${armnnUtils_sources})
98 target_include_directories(armnnUtils PRIVATE src/backends)
99
100 if(BUILD_CAFFE_PARSER)
101     # ArmNN Parser source files required for all build options
102     set(armnn_caffe_parser_sources)
103     list(APPEND armnn_caffe_parser_sources
104         include/armnnCaffeParser/ICaffeParser.hpp
105         src/armnnCaffeParser/RecordByRecordCaffeParser.hpp
106         src/armnnCaffeParser/RecordByRecordCaffeParser.cpp
107         src/armnnCaffeParser/CaffeParser.hpp
108         src/armnnCaffeParser/CaffeParser.cpp
109         ${CAFFE_GENERATED_SOURCES}/caffe/proto/caffe.pb.cc
110         )
111     # The generated Caffe protobuf .cc file is not warning clean and we can't fix them.
112     if(COMPILER_IS_GNU_LIKE)
113         set_source_files_properties(${CAFFE_GENERATED_SOURCES}/caffe/proto/caffe.pb.cc PROPERTIES COMPILE_FLAGS "-Wno-unused-variable -Wno-unused-parameter -Wno-conversion -Wno-sign-conversion")
114     endif()
115
116     add_library_ex(armnnCaffeParser SHARED ${armnn_caffe_parser_sources})
117     set_target_properties(armnnCaffeParser PROPERTIES COMPILE_FLAGS "${CAFFE_PARSER_ADDITIONAL_COMPILE_FLAGS}")
118
119     target_include_directories(armnnCaffeParser PRIVATE src/armnnUtils)
120
121     target_link_libraries(armnnCaffeParser armnn)
122     target_link_libraries(armnnCaffeParser ${PROTOBUF_LIBRARIES})
123     set_target_properties(armnnCaffeParser PROPERTIES VERSION ${GENERIC_LIB_VERSION} SOVERSION ${GENERIC_LIB_SOVERSION})
124
125 endif()
126
127 if(BUILD_ONNX_PARSER)
128     set(armnn_onnx_parser_sources)
129     list(APPEND armnn_onnx_parser_sources
130         include/armnnOnnxParser/IOnnxParser.hpp
131         src/armnnOnnxParser/OnnxParser.hpp
132         src/armnnOnnxParser/OnnxParser.cpp
133         ${ONNX_GENERATED_SOURCES}/onnx/onnx.pb.cc
134         )
135     # The generated onnx protobuf .cc files are not warning clean and we can't fix them.
136     if(COMPILER_IS_GNU_LIKE)
137         set_source_files_properties(${ONNX_GENERATED_SOURCES}/onnx/onnx.pb.cc PROPERTIES COMPILE_FLAGS "-Wno-conversion -Wno-sign-conversion")
138     endif()
139
140     add_library_ex(armnnOnnxParser SHARED ${armnn_onnx_parser_sources})
141
142     target_include_directories(armnnOnnxParser PRIVATE src/armnnUtils)
143
144     target_link_libraries(armnnOnnxParser armnn)
145
146     # Protobuf
147     target_link_libraries(armnnOnnxParser ${PROTOBUF_LIBRARIES})
148     set_target_properties(armnnOnnxParser PROPERTIES VERSION ${GENERIC_LIB_VERSION} SOVERSION ${GENERIC_LIB_SOVERSION})
149 endif()
150
151 if(BUILD_TF_PARSER)
152     set(armnn_tf_parser_sources)
153     list(APPEND armnn_tf_parser_sources
154         include/armnnTfParser/ITfParser.hpp
155         src/armnnTfParser/TfParser.hpp
156         src/armnnTfParser/TfParser.cpp
157         ${TF_PROTOBUFS}
158         )
159     # The generated tensorflow protobuf .cc files are not warning clean and we can't fix them.
160     if(COMPILER_IS_GNU_LIKE)
161         set_source_files_properties(${TF_PROTOBUFS} PROPERTIES COMPILE_FLAGS "-Wno-unused-variable -Wno-unused-parameter -Wno-conversion -Wno-sign-conversion  -Wno-error=deprecated-declarations")
162     endif()
163
164     add_library_ex(armnnTfParser SHARED ${armnn_tf_parser_sources})
165
166     target_include_directories(armnnTfParser PRIVATE src/armnnUtils)
167
168     target_link_libraries(armnnTfParser armnn)
169
170     # Protobuf (use the specific version tensorflow wants)
171     target_link_libraries(armnnTfParser ${PROTOBUF_LIBRARIES})
172     set_target_properties(armnnTfParser PROPERTIES VERSION ${GENERIC_LIB_VERSION} SOVERSION ${GENERIC_LIB_SOVERSION})
173 endif()
174
175 if(BUILD_ARMNN_QUANTIZER AND ARMNNREF)
176     if(NOT BUILD_ARMNN_SERIALIZER)
177         message(ERROR, "In order to build the ArmNN Quantization Tool you must set BUILD_ARMNN_SERIALIZER = YES")
178     endif()
179
180     set(armnn_quantizer_sources)
181     list(APPEND armnn_quantizer_sources
182         src/armnnQuantizer/QuantizationDataSet.hpp
183         src/armnnQuantizer/QuantizationDataSet.cpp
184         src/armnnQuantizer/QuantizationInput.hpp
185         src/armnnQuantizer/QuantizationInput.cpp
186         src/armnnQuantizer/CommandLineProcessor.hpp
187         src/armnnQuantizer/CommandLineProcessor.cpp
188         )
189
190     add_library_ex(armnnQuantizer SHARED ${armnn_quantizer_sources})
191
192     target_include_directories(armnnQuantizer PRIVATE include/armnnDeserializer)
193     target_include_directories(armnnQuantizer PRIVATE src/armnnUtils)
194     target_include_directories(armnnQuantizer PRIVATE src/armnn)
195     target_include_directories(armnnQuantizer PRIVATE third-party)
196
197     include_directories(SYSTEM "${FLATBUFFERS_INCLUDE_PATH}")
198     set_target_properties(armnnQuantizer PROPERTIES LIBRARY_OUTPUT_DIRECTORY ${PROJECT_BINARY_DIR})
199
200     target_link_libraries(armnnQuantizer armnn)
201
202     add_executable_ex(ArmnnQuantizerMain
203         src/armnnQuantizer/ArmNNQuantizerMain.cpp)
204
205     # cmake does not allow same executable and library name
206     # workaround that by rename that using set_target_properties
207     set_target_properties(ArmnnQuantizerMain
208         PROPERTIES OUTPUT_NAME ArmnnQuantizer)
209
210     target_include_directories(ArmnnQuantizerMain PRIVATE include/armnnDeserializer)
211     target_include_directories(ArmnnQuantizerMain PRIVATE src/armnn)
212
213     target_link_libraries(ArmnnQuantizerMain
214             armnnQuantizer
215             armnnSerializer
216             armnn
217             armnnUtils
218             ${FLATBUFFERS_LIBRARY})
219
220     if(Threads_FOUND AND (NOT ("${CMAKE_SYSTEM_NAME}" STREQUAL Android)))
221         target_link_libraries(ArmnnQuantizerMain pthread)
222     endif()
223
224     set_target_properties(armnnQuantizer PROPERTIES VERSION ${GENERIC_LIB_VERSION} SOVERSION ${GENERIC_LIB_SOVERSION})
225
226 endif()
227
228
229 list(APPEND armnn_sources
230     include/armnn/ArmNN.hpp
231     include/armnn/BackendHelper.hpp
232     include/armnn/BackendId.hpp
233     include/armnn/BackendOptions.hpp
234     include/armnn/BackendRegistry.hpp
235     include/armnn/Conversion.hpp
236     include/armnn/Deprecated.hpp
237     include/armnn/Descriptors.hpp
238     include/armnn/DescriptorsFwd.hpp
239     include/armnn/Exceptions.hpp
240     include/armnn/ILayerSupport.hpp
241     include/armnn/ILayerVisitor.hpp
242     include/armnn/INetwork.hpp
243     include/armnn/IProfiler.hpp
244     include/armnn/IRuntime.hpp
245     include/armnn/LayerSupport.hpp
246     include/armnn/LayerVisitorBase.hpp
247     include/armnn/Logging.hpp
248     include/armnn/LstmParams.hpp
249     include/armnn/MemorySources.hpp
250     include/armnn/NetworkFwd.hpp
251     include/armnn/Optional.hpp
252     include/armnn/QuantizedLstmParams.hpp
253     include/armnn/Tensor.hpp
254     include/armnn/TensorFwd.hpp
255     include/armnn/Types.hpp
256     include/armnn/TypesUtils.hpp
257     include/armnn/Utils.hpp
258     include/armnn/Version.hpp
259     include/armnn/profiling/IProfilingGuidGenerator.hpp
260     include/armnn/profiling/ISendTimelinePacket.hpp
261     include/armnn/utility/Assert.hpp
262     include/armnn/utility/IgnoreUnused.hpp
263     include/armnn/utility/NumericCast.hpp
264     include/armnn/utility/PolymorphicDowncast.hpp
265     include/armnn/utility/StringUtils.hpp
266     include/armnn/utility/TransformIterator.hpp
267     src/armnn/layers/LayerCloneBase.hpp
268     src/armnn/layers/LayerWithParameters.hpp
269     src/armnn/layers/ActivationLayer.hpp
270     src/armnn/layers/ActivationLayer.cpp
271     src/armnn/layers/AdditionLayer.hpp
272     src/armnn/layers/AdditionLayer.cpp
273     src/armnn/layers/ArgMinMaxLayer.hpp
274     src/armnn/layers/ArgMinMaxLayer.cpp
275     src/armnn/layers/BatchNormalizationLayer.hpp
276     src/armnn/layers/BatchNormalizationLayer.cpp
277     src/armnn/layers/BatchToSpaceNdLayer.hpp
278     src/armnn/layers/BatchToSpaceNdLayer.cpp
279     src/armnn/layers/ComparisonLayer.hpp
280     src/armnn/layers/ComparisonLayer.cpp
281     src/armnn/layers/ConcatLayer.hpp
282     src/armnn/layers/ConcatLayer.cpp
283     src/armnn/layers/ConstantLayer.hpp
284     src/armnn/layers/ConstantLayer.cpp
285     src/armnn/layers/Convolution2dLayer.hpp
286     src/armnn/layers/Convolution2dLayer.cpp
287     src/armnn/layers/ConvertBf16ToFp32Layer.cpp
288     src/armnn/layers/ConvertBf16ToFp32Layer.hpp
289     src/armnn/layers/ConvertFp16ToFp32Layer.hpp
290     src/armnn/layers/ConvertFp16ToFp32Layer.cpp
291     src/armnn/layers/ConvertFp32ToBf16Layer.hpp
292     src/armnn/layers/ConvertFp32ToBf16Layer.cpp
293     src/armnn/layers/ConvertFp32ToFp16Layer.hpp
294     src/armnn/layers/ConvertFp32ToFp16Layer.cpp
295     src/armnn/layers/DebugLayer.hpp
296     src/armnn/layers/DebugLayer.cpp
297     src/armnn/layers/DepthToSpaceLayer.hpp
298     src/armnn/layers/DepthToSpaceLayer.cpp
299     src/armnn/layers/DepthwiseConvolution2dLayer.hpp
300     src/armnn/layers/DepthwiseConvolution2dLayer.cpp
301     src/armnn/layers/DequantizeLayer.hpp
302     src/armnn/layers/DequantizeLayer.cpp
303     src/armnn/layers/DetectionPostProcessLayer.hpp
304     src/armnn/layers/DetectionPostProcessLayer.cpp
305     src/armnn/layers/ElementwiseBaseLayer.hpp
306     src/armnn/layers/ElementwiseBaseLayer.cpp
307     src/armnn/layers/ElementwiseUnaryLayer.hpp
308     src/armnn/layers/ElementwiseUnaryLayer.cpp
309     src/armnn/layers/FakeQuantizationLayer.hpp
310     src/armnn/layers/FakeQuantizationLayer.cpp
311     src/armnn/layers/FillLayer.hpp
312     src/armnn/layers/FillLayer.cpp
313     src/armnn/layers/FloorLayer.hpp
314     src/armnn/layers/FloorLayer.cpp
315     src/armnn/layers/FullyConnectedLayer.hpp
316     src/armnn/layers/FullyConnectedLayer.cpp
317     src/armnn/layers/GatherLayer.cpp
318     src/armnn/layers/GatherLayer.hpp
319     src/armnn/layers/InputLayer.hpp
320     src/armnn/layers/InputLayer.cpp
321     src/armnn/layers/InstanceNormalizationLayer.hpp
322     src/armnn/layers/InstanceNormalizationLayer.cpp
323     src/armnn/layers/L2NormalizationLayer.hpp
324     src/armnn/layers/L2NormalizationLayer.cpp
325     src/armnn/layers/LogicalBinaryLayer.hpp
326     src/armnn/layers/LogicalBinaryLayer.cpp
327     src/armnn/layers/LogSoftmaxLayer.hpp
328     src/armnn/layers/LogSoftmaxLayer.cpp
329     src/armnn/layers/LstmLayer.cpp
330     src/armnn/layers/LstmLayer.hpp
331     src/armnn/layers/MapLayer.cpp
332     src/armnn/layers/MapLayer.hpp
333     src/armnn/layers/MaximumLayer.cpp
334     src/armnn/layers/MaximumLayer.hpp
335     src/armnn/layers/MeanLayer.hpp
336     src/armnn/layers/MeanLayer.cpp
337     src/armnn/layers/MemCopyLayer.hpp
338     src/armnn/layers/MemCopyLayer.cpp
339     src/armnn/layers/MemImportLayer.hpp
340     src/armnn/layers/MemImportLayer.cpp
341     src/armnn/layers/MergeLayer.hpp
342     src/armnn/layers/MergeLayer.cpp
343     src/armnn/layers/MinimumLayer.cpp
344     src/armnn/layers/MinimumLayer.hpp
345     src/armnn/layers/MultiplicationLayer.hpp
346     src/armnn/layers/MultiplicationLayer.cpp
347     src/armnn/layers/NormalizationLayer.hpp
348     src/armnn/layers/NormalizationLayer.cpp
349     src/armnn/layers/OutputLayer.hpp
350     src/armnn/layers/OutputLayer.cpp
351     src/armnn/layers/PadLayer.hpp
352     src/armnn/layers/PadLayer.cpp
353     src/armnn/layers/PermuteLayer.hpp
354     src/armnn/layers/PermuteLayer.cpp
355     src/armnn/layers/Pooling2dLayer.hpp
356     src/armnn/layers/Pooling2dLayer.cpp
357     src/armnn/layers/QuantizeLayer.cpp
358     src/armnn/layers/QuantizeLayer.hpp
359     src/armnn/layers/QLstmLayer.hpp
360     src/armnn/layers/QLstmLayer.cpp
361     src/armnn/layers/QuantizedLstmLayer.hpp
362     src/armnn/layers/QuantizedLstmLayer.cpp
363     src/armnn/layers/DivisionLayer.cpp
364     src/armnn/layers/DivisionLayer.hpp
365     src/armnn/layers/PreCompiledLayer.hpp
366     src/armnn/layers/PreCompiledLayer.cpp
367     src/armnn/layers/PreluLayer.hpp
368     src/armnn/layers/PreluLayer.cpp
369     src/armnn/layers/RankLayer.hpp
370     src/armnn/layers/RankLayer.cpp
371     src/armnn/layers/ReduceLayer.hpp
372     src/armnn/layers/ReduceLayer.cpp
373     src/armnn/layers/ReshapeLayer.hpp
374     src/armnn/layers/ReshapeLayer.cpp
375     src/armnn/layers/ResizeLayer.hpp
376     src/armnn/layers/ResizeLayer.cpp
377     src/armnn/layers/SliceLayer.cpp
378     src/armnn/layers/SliceLayer.hpp
379     src/armnn/layers/SoftmaxLayer.hpp
380     src/armnn/layers/SoftmaxLayer.cpp
381     src/armnn/layers/SpaceToBatchNdLayer.hpp
382     src/armnn/layers/SpaceToBatchNdLayer.cpp
383     src/armnn/layers/SpaceToDepthLayer.hpp
384     src/armnn/layers/SpaceToDepthLayer.cpp
385     src/armnn/layers/SplitterLayer.hpp
386     src/armnn/layers/SplitterLayer.cpp
387     src/armnn/layers/StackLayer.hpp
388     src/armnn/layers/StackLayer.cpp
389     src/armnn/layers/StandInLayer.cpp
390     src/armnn/layers/StandInLayer.hpp
391     src/armnn/layers/StridedSliceLayer.cpp
392     src/armnn/layers/StridedSliceLayer.hpp
393     src/armnn/layers/SubtractionLayer.cpp
394     src/armnn/layers/SubtractionLayer.hpp
395     src/armnn/layers/SwitchLayer.cpp
396     src/armnn/layers/SwitchLayer.hpp
397     src/armnn/layers/TransposeConvolution2dLayer.cpp
398     src/armnn/layers/TransposeConvolution2dLayer.hpp
399     src/armnn/layers/TransposeLayer.hpp
400     src/armnn/layers/TransposeLayer.cpp
401     src/armnn/layers/UnmapLayer.cpp
402     src/armnn/layers/UnmapLayer.hpp
403     src/armnn/BackendRegistry.cpp
404     src/armnn/BackendSettings.hpp
405     src/armnn/BackendHelper.cpp
406     src/armnn/CompatibleTypes.hpp
407     src/armnn/Descriptors.cpp
408     src/armnn/DeviceSpec.hpp
409     src/armnn/DllExport.hpp
410     src/armnn/DynamicQuantizationVisitor.cpp
411     src/armnn/DynamicQuantizationVisitor.hpp
412     src/armnn/Exceptions.cpp
413     src/armnn/ExecutionFrame.cpp
414     src/armnn/ExecutionFrame.hpp
415     src/armnn/Graph.cpp
416     src/armnn/Graph.hpp
417     src/armnn/IGraphObservable.hpp
418     src/armnn/Instrument.hpp
419     src/armnn/InternalTypes.cpp
420     src/armnn/InternalTypes.hpp
421     src/armnn/ISubgraphViewConverter.hpp
422     src/armnn/JsonPrinter.cpp
423     src/armnn/JsonPrinter.hpp
424     src/armnn/Layer.cpp
425     src/armnn/LayerFwd.hpp
426     src/armnn/Layer.hpp
427     src/armnn/LayersFwd.hpp
428     src/armnn/LayerSupportCommon.hpp
429     src/armnn/LayerSupport.cpp
430     src/armnn/LoadedNetwork.cpp
431     src/armnn/LoadedNetwork.hpp
432     src/armnn/Logging.cpp
433     src/armnn/Network.cpp
434     src/armnn/Network.hpp
435     src/armnn/NetworkQuantizationScheme.hpp
436     src/armnn/NetworkQuantizer.cpp
437     src/armnn/NetworkQuantizer.hpp
438     src/armnn/NetworkQuantizerUtils.cpp
439     src/armnn/NetworkQuantizerUtils.hpp
440     src/armnn/NetworkUtils.cpp
441     src/armnn/NetworkUtils.hpp
442     src/armnn/Observable.cpp
443     src/armnn/Observable.hpp
444     src/armnn/Optimizer.cpp
445     src/armnn/Optimizer.hpp
446     src/armnn/OutputHandler.cpp
447     src/armnn/OutputHandler.hpp
448     src/armnn/OverrideInputRangeVisitor.cpp
449     src/armnn/OverrideInputRangeVisitor.hpp
450     src/armnn/Profiling.cpp
451     src/armnn/ProfilingEvent.cpp
452     src/armnn/ProfilingEvent.hpp
453     src/armnn/Profiling.hpp
454     src/armnn/QuantizerVisitor.cpp
455     src/armnn/QuantizerVisitor.hpp
456     src/armnn/Runtime.cpp
457     src/armnn/Runtime.hpp
458     src/armnn/RangeTracker.cpp
459     src/armnn/RangeTracker.hpp
460     src/armnn/ResolveType.hpp
461     src/armnn/SerializeLayerParameters.cpp
462     src/armnn/SerializeLayerParameters.hpp
463     src/armnn/StaticRangeVisitor.cpp
464     src/armnn/StaticRangeVisitor.hpp
465     src/armnn/SubgraphView.cpp
466     src/armnn/SubgraphView.hpp
467     src/armnn/SubgraphViewSelector.cpp
468     src/armnn/SubgraphViewSelector.hpp
469     src/armnn/Tensor.cpp
470     src/armnn/TypesUtils.cpp
471     src/armnn/Utils.cpp
472     src/armnn/WallClockTimer.cpp
473     src/armnn/WallClockTimer.hpp
474     src/armnn/optimizations/AddBroadcastReshapeLayer.hpp
475     src/armnn/optimizations/AddDebug.hpp
476     src/armnn/optimizations/All.hpp
477     src/armnn/optimizations/ConvertConstants.hpp
478     src/armnn/optimizations/ConvertFp32NetworkToBf16.hpp
479     src/armnn/optimizations/ConvertFp32NetworkToFp16.hpp
480     src/armnn/optimizations/FoldPadIntoConvolution2d.hpp
481     src/armnn/optimizations/MovePermuteUp.hpp
482     src/armnn/optimizations/MoveTransposeUp.hpp
483     src/armnn/optimizations/Optimization.hpp
484     src/armnn/optimizations/OptimizeConsecutiveReshapes.hpp
485     src/armnn/optimizations/OptimizeInverseConversions.hpp
486     src/armnn/optimizations/OptimizeInversePermutes.hpp
487     src/armnn/optimizations/PermuteAndBatchToSpaceAsDepthToSpace.hpp
488     src/armnn/optimizations/PermuteAsReshape.hpp
489     src/armnn/optimizations/SquashEqualSiblings.hpp
490     src/profiling/ActivateTimelineReportingCommandHandler.cpp
491     src/profiling/ActivateTimelineReportingCommandHandler.hpp
492     src/profiling/BufferManager.cpp
493     src/profiling/BufferManager.hpp
494     src/profiling/CommandHandler.cpp
495     src/profiling/CommandHandler.hpp
496     src/profiling/ConnectionAcknowledgedCommandHandler.cpp
497     src/profiling/ConnectionAcknowledgedCommandHandler.hpp
498     src/profiling/CounterDirectory.cpp
499     src/profiling/CounterDirectory.hpp
500     src/profiling/CounterIdMap.cpp
501     src/profiling/CounterIdMap.hpp
502     src/profiling/DeactivateTimelineReportingCommandHandler.cpp
503     src/profiling/DeactivateTimelineReportingCommandHandler.hpp
504     src/profiling/DirectoryCaptureCommandHandler.cpp
505     src/profiling/DirectoryCaptureCommandHandler.hpp
506     src/profiling/FileOnlyProfilingConnection.cpp
507     src/profiling/FileOnlyProfilingConnection.hpp
508     src/profiling/Holder.cpp
509     src/profiling/Holder.hpp
510     src/profiling/IBufferManager.hpp
511     src/profiling/IConsumer.hpp
512     src/profiling/ICounterDirectory.hpp
513     src/profiling/ICounterRegistry.hpp
514     src/profiling/ICounterValues.hpp
515     src/profiling/INotifyBackends.hpp
516     src/profiling/IReportStructure.hpp
517     src/profiling/ISendCounterPacket.hpp
518     src/profiling/ISendThread.hpp
519     src/profiling/IPacketBuffer.hpp
520     src/profiling/IPeriodicCounterCapture.hpp
521     src/profiling/IProfilingConnection.hpp
522     src/profiling/IProfilingConnectionFactory.hpp
523     src/profiling/LabelsAndEventClasses.cpp
524     src/profiling/LabelsAndEventClasses.hpp
525     src/profiling/NullProfilingConnection.hpp
526     src/profiling/PacketBuffer.cpp
527     src/profiling/PacketBuffer.hpp
528     src/profiling/PeriodicCounterCapture.hpp
529     src/profiling/PeriodicCounterCapture.cpp
530     src/profiling/PeriodicCounterSelectionCommandHandler.cpp
531     src/profiling/PeriodicCounterSelectionCommandHandler.hpp
532     src/profiling/PerJobCounterSelectionCommandHandler.cpp
533     src/profiling/PerJobCounterSelectionCommandHandler.hpp
534     src/profiling/ProfilingConnectionDumpToFileDecorator.cpp
535     src/profiling/ProfilingConnectionDumpToFileDecorator.hpp
536     src/profiling/ProfilingConnectionFactory.cpp
537     src/profiling/ProfilingConnectionFactory.hpp
538     src/profiling/ProfilingGuidGenerator.hpp
539     src/profiling/ProfilingService.cpp
540     src/profiling/ProfilingService.hpp
541     src/profiling/ProfilingStateMachine.cpp
542     src/profiling/ProfilingStateMachine.hpp
543     src/profiling/ProfilingUtils.cpp
544     src/profiling/ProfilingUtils.hpp
545     src/profiling/RegisterBackendCounters.cpp
546     src/profiling/RegisterBackendCounters.hpp
547     src/profiling/RequestCounterDirectoryCommandHandler.cpp
548     src/profiling/RequestCounterDirectoryCommandHandler.hpp
549     src/profiling/SendCounterPacket.cpp
550     src/profiling/SendCounterPacket.hpp
551     src/profiling/SendThread.cpp
552     src/profiling/SendThread.hpp
553     src/profiling/SendTimelinePacket.cpp
554     src/profiling/SendTimelinePacket.hpp
555     src/profiling/SocketProfilingConnection.cpp
556     src/profiling/SocketProfilingConnection.hpp
557     src/profiling/TimelinePacketWriterFactory.cpp
558     src/profiling/TimelinePacketWriterFactory.hpp
559     src/profiling/TimelineUtilityMethods.cpp
560     src/profiling/TimelineUtilityMethods.hpp
561     src/profiling/backends/BackendProfiling.cpp
562     src/profiling/backends/BackendProfiling.hpp
563     third-party/cxxopts/cxxopts.hpp
564     third-party/ghc/filesystem.hpp
565     third-party/half/half.hpp
566     third-party/mapbox/optional.hpp
567     third-party/mapbox/recursive_wrapper.hpp
568     third-party/mapbox/variant.hpp
569     third-party/mapbox/variant_cast.hpp
570     third-party/mapbox/variant_io.hpp
571     third-party/mapbox/variant_visitor.hpp
572     )
573
574 # Files used for Streamline-based profiling backend
575 if(PROFILING_BACKEND_STREAMLINE)
576     list(APPEND armnn_sources
577         ${GATOR_ROOT}/annotate/streamline_annotate.h
578         ${GATOR_ROOT}/annotate/streamline_annotate.c)
579 endif()
580
581 # the backends under src/backends extend the list of
582 # object libs armnn to include in the build
583 include(src/backends/backends.cmake)
584 foreach(lib ${armnnLibraries})
585     message(STATUS "Adding object library dependency to armnn: ${lib}")
586     list(APPEND armnn_sources $<TARGET_OBJECTS:${lib}>)
587 endforeach()
588
589 add_library_ex(armnn SHARED ${armnn_sources})
590
591 target_compile_definitions(armnn PRIVATE "ARMNN_COMPILING_DLL")
592
593 target_include_directories(armnn
594     PUBLIC
595         $<INSTALL_INTERFACE:include>
596         $<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>
597     PRIVATE
598         src/armnn
599         src/armnnUtils
600         src/backends
601         src/profiling
602         profiling/common/include
603 )
604
605 target_link_libraries(armnn armnnUtils)
606 # only link pipeCommon if it has been built
607 if(BUILD_TIMELINE_DECODER)
608     target_link_libraries(armnn pipeCommon)
609 endif()
610
611 target_link_libraries(armnn ${CMAKE_DL_LIBS})
612 if ("${CMAKE_SYSTEM_NAME}" STREQUAL Windows)
613     target_link_libraries(armnn Ws2_32.lib)
614 endif()
615
616 # Link fmt third-party library
617 add_subdirectory(third-party/fmt)
618 target_link_libraries(armnn fmt)
619
620 if(BUILD_CAFFE_PARSER)
621     install(TARGETS armnnCaffeParser
622             LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
623             RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
624 endif()
625 if(BUILD_ONNX_PARSER)
626     install(TARGETS armnnOnnxParser
627             LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
628             RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
629 endif()
630 if(BUILD_TF_PARSER)
631     install(TARGETS armnnTfParser
632             LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
633             RUNTIME DESTINATION ${CMAKE_INSTALL_BINDIR})
634 endif()
635
636 install(DIRECTORY include/ DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
637
638 if(ARMCOMPUTENEON OR ARMCOMPUTECL)
639     target_link_libraries(armnn ${ARMCOMPUTE_LIBRARIES})
640 endif()
641
642 if(PROFILING_BACKEND_STREAMLINE AND (NOT ("${CMAKE_SYSTEM_NAME}" STREQUAL Android)))
643     target_link_libraries(armnn pthread)
644 endif()
645
646 set_target_properties(armnn PROPERTIES VERSION ${GENERIC_LIB_VERSION} SOVERSION ${GENERIC_LIB_SOVERSION})
647
648 if(BUILD_UNIT_TESTS)
649     set(unittest_sources)
650     list(APPEND unittest_sources
651         src/armnn/test/ConstTensorLayerVisitor.hpp
652         src/armnn/test/ConstTensorLayerVisitor.cpp
653         src/armnn/test/CreateWorkload.hpp
654         src/armnn/test/EndToEndTest.cpp
655         src/armnn/test/ExecutionFrameTest.cpp
656         src/armnn/test/FloatingPointConverterTest.cpp
657         src/armnn/test/FlowControl.cpp
658         src/armnn/test/GraphTests.cpp
659         src/armnn/test/GraphUtils.cpp
660         src/armnn/test/GraphUtils.hpp
661         src/armnn/test/InstrumentTests.cpp
662         src/armnn/test/InferOutputTests.cpp
663         src/armnn/test/InferOutputTests.hpp
664         src/armnn/test/ModelAccuracyCheckerTest.cpp
665         src/armnn/test/NetworkTests.cpp
666         src/armnn/test/ObservableTest.cpp
667         src/armnn/test/OptimizerTests.cpp
668         src/armnn/test/optimizations/AddBroadcastReshapeLayerTests.cpp
669         src/armnn/test/optimizations/ConvertConstantsBFloatTests.cpp
670         src/armnn/test/optimizations/ConvertConstantsFloatToHalfTests.cpp
671         src/armnn/test/optimizations/ConvertConstantsHalfToFloatTests.cpp
672         src/armnn/test/optimizations/Fp32NetworkToBf16ConverterTests.cpp
673         src/armnn/test/optimizations/Fp32NetworkToFp16ConverterTests.cpp
674         src/armnn/test/optimizations/FuseActivationTests.cpp
675         src/armnn/test/optimizations/FuseBatchNormTests.cpp
676         src/armnn/test/optimizations/InsertDebugLayerTests.cpp
677         src/armnn/test/optimizations/MovePermuteUpTests.cpp
678         src/armnn/test/optimizations/MoveTransposeUpTests.cpp
679         src/armnn/test/optimizations/OptimizeConsecutiveReshapesTests.cpp
680         src/armnn/test/optimizations/OptimizeInverseConversionsTests.cpp
681         src/armnn/test/optimizations/OptimizeInversePermutesTests.cpp
682         src/armnn/test/optimizations/PermuteAndBatchToSpaceAsDepthToSpaceTests.cpp
683         src/armnn/test/optimizations/PermuteAsReshapeTests.cpp
684         src/armnn/test/optimizations/SquashEqualSiblingsTests.cpp
685         src/armnn/test/optimizations/TransposeAsReshapeTests.cpp
686         src/armnn/test/OptionalTest.cpp
687         src/armnn/test/ProfilerTests.cpp
688         src/armnn/test/ProfilingEventTest.cpp
689         src/armnn/test/ShapeInferenceTests.cpp
690         src/armnn/test/SubgraphViewTests.cpp
691         src/armnn/test/TensorHandleStrategyTest.cpp
692         src/armnn/test/TensorHelpers.hpp
693         src/armnn/test/TensorTest.cpp
694         src/armnn/test/TestInputOutputLayerVisitor.cpp
695         src/armnn/test/TestInputOutputLayerVisitor.hpp
696         src/armnn/test/TestLayerVisitor.cpp
697         src/armnn/test/TestLayerVisitor.hpp
698         src/armnn/test/TestNameOnlyLayerVisitor.cpp
699         src/armnn/test/TestNameOnlyLayerVisitor.hpp
700         src/armnn/test/TestNameAndDescriptorLayerVisitor.hpp
701         src/armnn/test/TestNameAndDescriptorLayerVisitor.cpp
702         src/armnn/test/TestUtils.cpp
703         src/armnn/test/TestUtils.hpp
704         src/armnn/test/UtilityTests.cpp
705         src/armnn/test/UnitTests.cpp
706         src/armnn/test/UnitTests.hpp
707         src/armnn/test/UtilsTests.cpp
708         src/armnnUtils/test/FloatingPointComparisonTest.cpp
709         src/armnnUtils/test/ParserHelperTest.cpp
710         src/armnnUtils/test/PrototxtConversionsTest.cpp
711         src/armnnUtils/test/QuantizeHelperTest.cpp
712         src/armnnUtils/test/TensorUtilsTest.cpp
713         src/armnnUtils/test/TransformIteratorTest.cpp
714         src/profiling/test/BufferTests.cpp
715         src/profiling/test/FileOnlyProfilingDecoratorTests.cpp
716         src/profiling/test/PrintPacketHeaderHandler.cpp
717         src/profiling/test/PrintPacketHeaderHandler.hpp
718         src/profiling/test/ProfilingConnectionDumpToFileDecoratorTests.cpp
719         src/profiling/test/ProfilingGuidTest.cpp
720         src/profiling/test/ProfilingMocks.hpp
721         src/profiling/test/ProfilingTests.cpp
722         src/profiling/test/ProfilingTests.hpp
723         src/profiling/test/ProfilingTestUtils.cpp
724         src/profiling/test/ProfilingTestUtils.hpp
725         src/profiling/test/RequestCountersPacketHandler.cpp
726         src/profiling/test/RequestCountersPacketHandler.hpp
727         src/profiling/test/SendCounterPacketTests.cpp
728         src/profiling/test/SendCounterPacketTests.hpp
729         src/profiling/test/TestTimelinePacketHandler.cpp
730         src/profiling/test/TestTimelinePacketHandler.hpp
731         src/profiling/test/TimelineModel.cpp
732         src/profiling/test/TimelineModel.hpp
733         src/profiling/test/SendTimelinePacketTests.cpp
734         src/profiling/test/TimelinePacketTests.cpp
735         src/profiling/test/TimelineUtilityMethodsTests.cpp
736         )
737
738     if(ARMNNREF)
739         list(APPEND unittest_sources
740             src/armnn/test/DebugCallbackTest.cpp
741             src/armnn/test/QuantizerTest.cpp
742             src/armnn/test/RuntimeTests.cpp
743             src/armnn/test/RuntimeTests.hpp
744             )
745     endif()
746
747     if(BUILD_TF_PARSER AND ARMNNREF)
748         list(APPEND unittest_sources
749             src/armnnTfParser/test/Activations.cpp
750             src/armnnTfParser/test/Addition.cpp
751             src/armnnTfParser/test/AddN.cpp
752             src/armnnTfParser/test/Assert.cpp
753             src/armnnTfParser/test/BiasAdd.cpp
754             src/armnnTfParser/test/BroadcastForAdd.cpp
755             src/armnnTfParser/test/Convolution2d.cpp
756             src/armnnTfParser/test/Concat.cpp
757             src/armnnTfParser/test/ConcatOfConcats.cpp
758             src/armnnTfLiteParser/test/DepthToSpace.cpp
759             src/armnnTfParser/test/DepthwiseConvolution2d.cpp
760             src/armnnTfParser/test/Equal.cpp
761             src/armnnTfParser/test/ExpandDims.cpp
762             src/armnnTfParser/test/FusedBatchNorm.cpp
763             src/armnnTfParser/test/Gather.cpp
764             src/armnnTfParser/test/Greater.cpp
765             src/armnnTfParser/test/Identity.cpp
766             src/armnnTfParser/test/LocalResponseNormalization.cpp
767             src/armnnTfParser/test/Maximum.cpp
768             src/armnnTfParser/test/MaximumForLeakyRelu.cpp
769             src/armnnTfParser/test/Mean.cpp
770             src/armnnTfParser/test/Minimum.cpp
771             src/armnnTfParser/test/Multiplication.cpp
772             src/armnnTfParser/test/Pad.cpp
773             src/armnnTfParser/test/MultiOutput.cpp
774             src/armnnTfParser/test/PassThru.cpp
775             src/armnnTfParser/test/Pooling.cpp
776             src/armnnTfParser/test/RealDiv.cpp
777             src/armnnTfParser/test/Reshape.cpp
778             src/armnnTfParser/test/ResizeBilinear.cpp
779             src/armnnTfParser/test/Rsqrt.cpp
780             src/armnnTfParser/test/Shape.cpp
781             src/armnnTfParser/test/Softmax.cpp
782             src/armnnTfParser/test/TestDependencies.cpp
783             src/armnnTfParser/test/FullyConnected.cpp
784             src/armnnTfParser/test/Constant.cpp
785             src/armnnTfParser/test/TestMultiInputsOutputs.cpp
786             src/armnnTfParser/test/Split.cpp
787             src/armnnTfParser/test/Squeeze.cpp
788             src/armnnTfParser/test/Stack.cpp
789             src/armnnTfParser/test/Sub.cpp
790             src/armnnTfParser/test/StridedSlice.cpp
791             src/armnnTfParser/test/Transpose.cpp
792             )
793
794     endif()
795
796     if(BUILD_TF_LITE_PARSER AND ARMNNREF)
797         list(APPEND unittest_sources
798              src/armnnTfLiteParser/test/Activations.cpp
799              src/armnnTfLiteParser/test/Addition.cpp
800              src/armnnTfLiteParser/test/AvgPool2D.cpp
801              src/armnnTfLiteParser/test/BatchToSpaceND.cpp
802              src/armnnTfLiteParser/test/Concatenation.cpp
803              src/armnnTfLiteParser/test/Constant.cpp
804              src/armnnTfLiteParser/test/Conv2D.cpp
805              src/armnnTfLiteParser/test/DepthwiseConvolution2D.cpp
806              src/armnnTfLiteParser/test/Dequantize.cpp
807              src/armnnTfLiteParser/test/DetectionPostProcess.cpp
808              src/armnnTfLiteParser/test/Div.cpp
809              src/armnnTfLiteParser/test/Exp.cpp
810              src/armnnTfLiteParser/test/FullyConnected.cpp
811              src/armnnTfLiteParser/test/Gather.cpp
812              src/armnnTfLiteParser/test/L2Normalization.cpp
813              src/armnnTfLiteParser/test/LeakyRelu.cpp
814              src/armnnTfLiteParser/test/LoadScopeDynamicTensor.cpp
815              src/armnnTfLiteParser/test/Maximum.cpp
816              src/armnnTfLiteParser/test/MaxPool2D.cpp
817              src/armnnTfLiteParser/test/Mean.cpp
818              src/armnnTfLiteParser/test/Minimum.cpp
819              src/armnnTfLiteParser/test/Multiplication.cpp
820              src/armnnTfLiteParser/test/Neg.cpp
821              src/armnnTfLiteParser/test/Pack.cpp
822              src/armnnTfLiteParser/test/Pad.cpp
823              src/armnnTfLiteParser/test/Reshape.cpp
824              src/armnnTfLiteParser/test/ResizeBilinear.cpp
825              src/armnnTfLiteParser/test/ResizeNearestNeighbor.cpp
826              src/armnnTfLiteParser/test/Softmax.cpp
827              src/armnnTfLiteParser/test/SpaceToBatchND.cpp
828              src/armnnTfLiteParser/test/Slice.cpp
829              src/armnnTfLiteParser/test/Split.cpp
830              src/armnnTfLiteParser/test/SplitV.cpp
831              src/armnnTfLiteParser/test/Squeeze.cpp
832              src/armnnTfLiteParser/test/StridedSlice.cpp
833              src/armnnTfLiteParser/test/Sub.cpp
834              src/armnnTfLiteParser/test/Sum.cpp
835              src/armnnTfLiteParser/test/TransposeConv.cpp
836              src/armnnTfLiteParser/test/Transpose.cpp
837              src/armnnTfLiteParser/test/Unpack.cpp
838              src/armnnTfLiteParser/test/Unsupported.cpp
839              src/armnnTfLiteParser/test/LoadModel.cpp
840              src/armnnTfLiteParser/test/GetBuffer.cpp
841              src/armnnTfLiteParser/test/OutputShapeOfSqueeze.cpp
842              src/armnnTfLiteParser/test/InputOutputTensorNames.cpp
843              src/armnnTfLiteParser/test/GetTensorIds.cpp
844              src/armnnTfLiteParser/test/GetSubgraphInputsOutputs.cpp
845              src/armnnTfLiteParser/test/GetInputsOutputs.cpp
846              src/armnnTfLiteParser/test/TfLiteParser.cpp
847              )
848
849         # Generate SchemaText.cpp file which contains the TfLite schema text as a
850         # static C-array of bytes. This is needed at runtime for TfLite parser tests.
851         add_custom_command(
852             OUTPUT  SchemaText.cpp
853             COMMAND cp ${TF_LITE_SCHEMA_INCLUDE_PATH}/schema.fbs g_TfLiteSchemaText
854             COMMAND xxd -i g_TfLiteSchemaText SchemaText.cpp
855             WORKING_DIRECTORY ${CMAKE_CURRENT_BINARY_DIR}
856             DEPENDS ${TF_LITE_SCHEMA_INCLUDE_PATH}/schema.fbs
857         )
858         list(APPEND unittest_sources ${CMAKE_CURRENT_BINARY_DIR}/SchemaText.cpp)
859     endif()
860
861     if(BUILD_CAFFE_PARSER AND ARMNNREF)
862         list(APPEND unittest_sources
863             src/armnnCaffeParser/test/TestAdd.cpp
864             src/armnnCaffeParser/test/TestConcat.cpp
865             src/armnnCaffeParser/test/TestConvolution.cpp
866             src/armnnCaffeParser/test/TestDropout.cpp
867             src/armnnCaffeParser/test/TestInputs.cpp
868             src/armnnCaffeParser/test/TestMul.cpp
869             src/armnnCaffeParser/test/TestPooling2d.cpp
870             src/armnnCaffeParser/test/TestInPlace.cpp
871             src/armnnCaffeParser/test/TestMultiInputsOutputs.cpp
872             src/armnnCaffeParser/test/TestSplit.cpp
873             )
874     endif()
875
876     if(BUILD_ONNX_PARSER AND ARMNNREF)
877         list(APPEND unittest_sources
878             src/armnnOnnxParser/test/Addition.cpp
879             src/armnnOnnxParser/test/BatchNorm.cpp
880             src/armnnOnnxParser/test/Clip.cpp
881             src/armnnOnnxParser/test/Const.cpp
882             src/armnnOnnxParser/test/Constructor.cpp
883             src/armnnOnnxParser/test/Conv2D.cpp
884             src/armnnOnnxParser/test/CreateNetwork.cpp
885             src/armnnOnnxParser/test/DepthConv.cpp
886             src/armnnOnnxParser/test/Flatten.cpp
887             src/armnnOnnxParser/test/FullyConnected.cpp
888             src/armnnOnnxParser/test/GetInputsOutputs.cpp
889             src/armnnOnnxParser/test/Pooling.cpp
890             src/armnnOnnxParser/test/ProtoxtFixture.cpp
891             src/armnnOnnxParser/test/Relu.cpp
892             src/armnnOnnxParser/test/Reshape.cpp
893             )
894     endif()
895
896     if(BUILD_ARMNN_QUANTIZER AND ARMNNREF)
897         list(APPEND unittest_sources
898              src/armnnQuantizer/test/QuantizationDataSetTests.cpp
899              )
900     endif()
901
902     if(BUILD_ARMNN_SERIALIZER AND ARMNNREF)
903         enable_language(ASM)
904         list(APPEND unittest_sources
905             src/armnnSerializer/test/ActivationSerializationTests.cpp
906             src/armnnSerializer/test/SerializerTests.cpp
907             src/armnnDeserializer/test/DeserializeAbs.cpp
908             src/armnnDeserializer/test/DeserializeActivation.cpp
909             src/armnnDeserializer/test/DeserializeAdd.cpp
910             src/armnnDeserializer/test/DeserializeBatchToSpaceNd.cpp
911             src/armnnDeserializer/test/DeserializeBatchNormalization.cpp
912             src/armnnDeserializer/test/DeserializeComparison.cpp
913             src/armnnDeserializer/test/DeserializeConstant.cpp
914             src/armnnDeserializer/test/DeserializeConvolution2d.cpp
915             src/armnnDeserializer/test/DeserializeDepthToSpace.cpp
916             src/armnnDeserializer/test/DeserializeDivision.cpp
917             src/armnnDeserializer/test/DeserializeFill.cpp
918             src/armnnDeserializer/test/DeserializeFloor.cpp
919             src/armnnDeserializer/test/DeserializeFullyConnected.cpp
920             src/armnnDeserializer/test/DeserializeGather.cpp
921             src/armnnDeserializer/test/DeserializeInstanceNormalization.cpp
922             src/armnnDeserializer/test/DeserializeL2Normalization.cpp
923             src/armnnDeserializer/test/DeserializeLogSoftmax.cpp
924             src/armnnDeserializer/test/DeserializeMean.cpp
925             src/armnnDeserializer/test/DeserializeMultiplication.cpp
926             src/armnnDeserializer/test/DeserializeNormalization.cpp
927             src/armnnDeserializer/test/DeserializePad.cpp
928             src/armnnDeserializer/test/DeserializePermute.cpp
929             src/armnnDeserializer/test/DeserializePooling2d.cpp
930             src/armnnDeserializer/test/DeserializeRank.cpp
931             src/armnnDeserializer/test/DeserializeReduceSum.cpp
932             src/armnnDeserializer/test/DeserializeReshape.cpp
933             src/armnnDeserializer/test/DeserializeResizeBilinear.cpp
934             src/armnnDeserializer/test/DeserializeRsqrt.cpp
935             src/armnnDeserializer/test/DeserializeSlice.cpp
936             src/armnnDeserializer/test/DeserializeSpaceToBatchNd.cpp
937             src/armnnDeserializer/test/DeserializeStridedSlice.cpp
938             src/armnnDeserializer/test/DeserializeSubtraction.cpp
939             src/armnnDeserializer/test/ParserFlatbuffersSerializeFixture.hpp
940             src/armnnDeserializer/test/SchemaSerialize.s
941             )
942         set_source_files_properties(src/armnnDeserializer/test/SchemaSerialize.s PROPERTIES COMPILE_FLAGS "-x assembler-with-cpp")
943     endif()
944
945     if(BUILD_GATORD_MOCK)
946         list(APPEND unittest_sources
947             tests/profiling/gatordmock/tests/GatordMockTests.cpp
948             )
949     endif()
950
951     if(BUILD_TIMELINE_DECODER)
952         list(APPEND unittest_sources
953              src/timelineDecoder/tests/JSONTimelineDecoderTests.cpp
954              profiling/server/src/timelineDecoder/tests/TimelineTests.cpp
955              )
956     endif()
957
958     if(BUILD_BASE_PIPE_SERVER)
959         list(APPEND unittest_sources
960                 profiling/server/src/basePipeServer/tests/BasePipeServerTests.cpp
961                 )
962     endif()
963
964     foreach(lib ${armnnUnitTestLibraries})
965         message(STATUS "Adding object library dependency to UnitTests: ${lib}")
966         list(APPEND unittest_sources $<TARGET_OBJECTS:${lib}>)
967     endforeach()
968
969     add_executable(UnitTests ${unittest_sources})
970     target_include_directories(UnitTests PRIVATE src/armnn)
971     target_include_directories(UnitTests PRIVATE src/armnnUtils)
972     target_include_directories(UnitTests PRIVATE src/backends)
973     target_include_directories(UnitTests PRIVATE src/profiling)
974
975     if(VALGRIND_FOUND)
976         if(HEAP_PROFILING OR LEAK_CHECKING)
977             message(STATUS "Valgrind is disabled for heap profiling and leak checking builds.")
978         else()
979             # Valgrind works with gperftools version number <= 2.4
980             target_compile_definitions(UnitTests PRIVATE "WITH_VALGRIND=1")
981         endif()
982     endif()
983
984     target_link_libraries(UnitTests ${CMAKE_THREAD_LIBS_INIT})
985     target_link_libraries(UnitTests ${Boost_UNIT_TEST_FRAMEWORK_LIBRARY})
986
987     target_link_libraries(UnitTests armnn)
988     target_link_libraries(UnitTests armnnUtils)
989
990     if(BUILD_TF_PARSER)
991         target_link_libraries(UnitTests armnnTfParser)
992     endif()
993
994     if(BUILD_GATORD_MOCK)
995         target_link_libraries(UnitTests gatordMockService)
996     endif()
997
998     if(BUILD_TIMELINE_DECODER)
999         target_link_libraries(UnitTests timelineDecoder)
1000         target_link_libraries(UnitTests timelineDecoderJson)
1001     endif()
1002
1003     if(BUILD_TF_LITE_PARSER)
1004         target_include_directories(UnitTests SYSTEM PRIVATE "${TF_LITE_SCHEMA_INCLUDE_PATH}")
1005         target_include_directories(UnitTests SYSTEM PRIVATE "${FLATBUFFERS_INCLUDE_PATH}")
1006         target_link_libraries(UnitTests armnnTfLiteParser)
1007     endif()
1008
1009     if(BUILD_CAFFE_PARSER)
1010         target_link_libraries(UnitTests armnnCaffeParser)
1011     endif()
1012
1013     if(BUILD_ARMNN_SERIALIZER AND ARMNNREF)
1014         target_include_directories(UnitTests SYSTEM PRIVATE ${CMAKE_CURRENT_BINARY_DIR}/src/armnnSerializer)
1015         target_include_directories(UnitTests SYSTEM PRIVATE "${FLATBUFFERS_INCLUDE_PATH}")
1016         target_link_libraries(UnitTests armnnSerializer)
1017     endif()
1018
1019     if(BUILD_ARMNN_QUANTIZER AND ARMNNREF)
1020         target_include_directories(UnitTests SYSTEM PRIVATE ${CMAKE_CURRENT_BINARY_DIR}/src/armnnQuantizer)
1021         target_include_directories(UnitTests SYSTEM PRIVATE "${FLATBUFFERS_INCLUDE_PATH}")
1022         target_link_libraries(UnitTests armnnQuantizer armnnSerializer)
1023     endif()
1024
1025     if(BUILD_ONNX_PARSER)
1026         target_link_libraries(UnitTests armnnOnnxParser)
1027     endif()
1028
1029     if(BUILD_BASE_PIPE_SERVER)
1030         target_link_libraries(UnitTests armnnBasePipeServer)
1031     endif()
1032
1033     addDllCopyCommands(UnitTests)
1034 endif()
1035
1036 if (BUILD_ARMNN_SERIALIZER AND (BUILD_TF_PARSER OR BUILD_TF_LITE_PARSER OR BUILD_ONNX_PARSER OR BUILD_CAFFE_PARSER) AND ARMNNREF)
1037     set(ArmnnConverter_sources
1038         src/armnnConverter/ArmnnConverter.cpp)
1039
1040     add_executable_ex(ArmnnConverter ${ArmnnConverter_sources})
1041     target_include_directories(ArmnnConverter PRIVATE src/armnn)
1042     target_include_directories(ArmnnConverter PRIVATE src/armnnUtils)
1043
1044     if(BUILD_CAFFE_PARSER)
1045         target_link_libraries(ArmnnConverter armnnCaffeParser)
1046     endif()
1047
1048     if(BUILD_ONNX_PARSER)
1049         target_link_libraries(ArmnnConverter armnnOnnxParser)
1050     endif()
1051
1052     if(BUILD_TF_PARSER)
1053         target_link_libraries(ArmnnConverter armnnTfParser)
1054     endif()
1055
1056     if(BUILD_TF_LITE_PARSER)
1057         target_link_libraries(ArmnnConverter armnnTfLiteParser)
1058     endif()
1059
1060     target_link_libraries(ArmnnConverter armnnSerializer)
1061
1062     target_link_libraries(ArmnnConverter armnn)
1063     target_link_libraries(ArmnnConverter ${CMAKE_THREAD_LIBS_INIT})
1064     addDllCopyCommands(ArmnnConverter)
1065 endif()
1066
1067 if(BUILD_BASE_PIPE_SERVER)
1068     add_subdirectory(profiling/server/src/basePipeServer)
1069 endif()
1070
1071 if(BUILD_TIMELINE_DECODER)
1072     add_subdirectory(profiling/server/src/timelineDecoder)
1073     add_subdirectory(profiling/common/src)
1074     add_subdirectory(src/timelineDecoder)
1075 endif()
1076
1077 if(BUILD_GATORD_MOCK AND NOT BUILD_BASE_PIPE_SERVER)
1078     message(ERROR, "In order to build GatordMock you must set BUILD_BASE_PIPE_SERVER = YES")
1079 endif()
1080
1081 if(BUILD_GATORD_MOCK AND NOT BUILD_TIMELINE_DECODER)
1082     message(ERROR, "In order to build GatordMock you must set BUILD_TIMELINE_DECODER = YES")
1083 endif()
1084
1085 if(BUILD_GATORD_MOCK)
1086     set(gatord_mock_sources)
1087     list(APPEND gatord_mock_sources
1088         tests/profiling/gatordmock/CommandFileParser.hpp
1089         tests/profiling/gatordmock/CommandFileParser.cpp
1090         tests/profiling/gatordmock/CommandLineProcessor.hpp
1091         tests/profiling/gatordmock/CommandLineProcessor.cpp
1092         tests/profiling/gatordmock/GatordMockService.hpp
1093         tests/profiling/gatordmock/GatordMockService.cpp
1094         tests/profiling/gatordmock/PeriodicCounterCaptureCommandHandler.cpp
1095         tests/profiling/gatordmock/PeriodicCounterCaptureCommandHandler.hpp
1096         tests/profiling/gatordmock/PeriodicCounterSelectionResponseHandler.cpp
1097         tests/profiling/gatordmock/PeriodicCounterSelectionResponseHandler.hpp
1098         tests/profiling/gatordmock/StreamMetadataCommandHandler.cpp
1099         tests/profiling/gatordmock/StreamMetadataCommandHandler.hpp
1100         tests/profiling/gatordmock/StubCommandHandler.hpp
1101         )
1102
1103     add_library_ex(gatordMockService STATIC ${gatord_mock_sources})
1104
1105     target_include_directories(gatordMockService PRIVATE profiling/common/include
1106                                                          profiling/server/src/basePipeServer
1107                                                          src/armnnUtils
1108                                                          src/profiling
1109                                                          src/timelineDecoder)
1110
1111     if(BUILD_UNIT_TESTS)
1112         target_include_directories(UnitTests PRIVATE tests/profiling/gatordmock)
1113         target_include_directories(UnitTests PRIVATE src/backends/backendsCommon/test)
1114     endif()
1115
1116     add_executable_ex(GatordMock tests/profiling/gatordmock/GatordMockMain.cpp)
1117
1118     target_include_directories(GatordMock PRIVATE profiling/common/include
1119                                                   profiling/server/src/basePipeServer
1120                                                   src/armnnUtils
1121                                                   src/profiling
1122                                                   src/timelineDecoder)
1123
1124     target_link_libraries(GatordMock
1125                           armnn
1126                           armnnBasePipeServer
1127                           timelineDecoder
1128                           gatordMockService)
1129
1130     if(Threads_FOUND AND (NOT ("${CMAKE_SYSTEM_NAME}" STREQUAL Android)))
1131         target_link_libraries(GatordMock ${CMAKE_THREAD_LIBS_INIT})
1132     endif()
1133
1134 endif()
1135
1136 ####################################################
1137 # export targets
1138 set(armnn_export_targets)
1139 list(APPEND armnn_export_targets
1140     armnn
1141     armnnUtils
1142 )
1143
1144 install(
1145     TARGETS ${armnn_export_targets}
1146     EXPORT  armnn-targets
1147     LIBRARY DESTINATION ${CMAKE_INSTALL_LIBDIR}
1148     ARCHIVE DESTINATION ${CMAKE_INSTALL_LIBDIR}
1149 )
1150
1151 ####################################################
1152 ## Set export alias
1153 set_target_properties(armnn
1154     PROPERTIES
1155     EXPORT_NAME Armnn
1156 )
1157
1158 ## Export target scrips
1159 install(
1160     EXPORT      armnn-targets
1161     FILE        ArmnnTargets.cmake
1162     NAMESPACE   Armnn::
1163     DESTINATION ${CMAKE_INSTALL_LIBDIR}/cmake/${PROJECT_NAME}
1164 )
1165
1166 ####################################################
1167 ## Create ArmnnConfig.cmake
1168 include(CMakePackageConfigHelpers)
1169 set(INSTALL_CONFIGDIR ${CMAKE_INSTALL_LIBDIR})
1170
1171 message(STATUS "CMAKE_CURRENT_LIST_DIR ${CMAKE_CURRENT_LIST_DIR}" )
1172 message(STATUS "CMAKE_CURRENT_BINARY_DIR ${CMAKE_CURRENT_BINARY_DIR}" )
1173 configure_package_config_file(
1174     ${CMAKE_CURRENT_LIST_DIR}/cmake/ArmnnConfig.cmake.in
1175     ${CMAKE_CURRENT_BINARY_DIR}/ArmnnConfig.cmake
1176     INSTALL_DESTINATION ${CMAKE_INSTALL_LIBDIR}/cmake/${PROJECT_NAME}
1177 )
1178
1179 ####################################################
1180 ## Install Armnn config file
1181 install(
1182     FILES
1183     ${CMAKE_CURRENT_BINARY_DIR}/ArmnnConfig.cmake
1184     DESTINATION ${CMAKE_INSTALL_LIBDIR}/cmake/${PROJECT_NAME}
1185 )
1186
1187 ####################################################
1188 ## Export from build tree
1189 export(
1190     EXPORT      armnn-targets
1191     FILE        ${CMAKE_CURRENT_BINARY_DIR}/ArmnnTargets.cmake
1192     NAMESPACE   Armnn::
1193 )
1194
1195 add_library(Armnn::Armnn ALIAS armnn)
1196 add_library(Armnn::armnnUtils ALIAS armnnUtils)
1197
1198 ####################################################
1199 ## Build Python bindings
1200 if (BUILD_PYTHON_WHL OR BUILD_PYTHON_SRC)
1201     add_subdirectory(python/pyarmnn)
1202 endif()