blob: df8cc8a670030f60f63e3bc7a19e0e62484ed598 [file] [log] [blame]
telsoa014fcda012018-03-09 14:13:49 +00001#
2# Copyright © 2017 ARM Ltd. All rights reserved.
David Beckecb56cd2018-09-05 12:52:57 +01003# SPDX-License-Identifier: MIT
telsoa014fcda012018-03-09 14:13:49 +00004#
5
6LOCAL_PATH := $(call my-dir)
7
8# Configure these paths if you move the source or Khronos headers
surmeh013537c2c2018-05-18 16:31:43 +01009OPENCL_HEADER_PATH := $(LOCAL_PATH)/../clframework/include
telsoa014fcda012018-03-09 14:13:49 +000010NN_HEADER_PATH := $(LOCAL_PATH)/../../../../frameworks/ml/nn/runtime/include
11ARMNN_HEADER_PATH := $(LOCAL_PATH)/include
Sadik Armagana97a0be2020-03-03 10:44:56 +000012ARMNN_PROFILING_INCLUDE_PATH := $(LOCAL_PATH)/profiling
Finn Williams0c8cb992020-05-07 10:38:15 +010013ARMNN_PROFILING_COMMON_INCLUDE_PATH := $(LOCAL_PATH)/profiling/common/include
Jim Flynn4e755a52020-03-29 17:48:26 +010014ARMNN_TIMELINE_DECODER_INCLUDE_PATH := $(LOCAL_PATH)/src/timelineDecoder
Jim Flynnc9631102020-06-24 11:11:20 +010015ARMNN_THIRD_PARTY_INCLUDE_PATH := $(LOCAL_PATH)/third-party
David Beck10b4dfd2018-09-19 12:03:20 +010016ARMNN_MAIN_HEADER_PATH := $(LOCAL_PATH)/src
telsoa014fcda012018-03-09 14:13:49 +000017ARMNN_SOURCE_HEADER_PATH := $(LOCAL_PATH)/src/armnn
surmeh014c7098b2018-07-05 14:03:08 +010018ARMNN_SOURCE_UTILS_HEADER_PATH := $(LOCAL_PATH)/src/armnnUtils
Sadik Armagana097d2a2021-11-24 15:47:28 +000019ARMNN_TEST_UTILS_SOURCE_PATH := $(LOCAL_PATH)/src/armnnTestUtils
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +000020ARMNN_BACKENDS_HEADER_PATH := $(LOCAL_PATH)/src/backends
janeil0155e488a2019-11-08 12:03:58 +000021ARMNN_PROFILING_HEADER_PATH := $(LOCAL_PATH)/src/profiling
Sadik Armagan97bf84f2021-01-13 15:06:38 +000022ARMNN_SERIALIZER_HEADER_PATH := $(LOCAL_PATH)/src/armnnSerializer
23ARMNN_DESERIALIZER_HEADER_PATH := $(LOCAL_PATH)/src/armnnDeserializer
surmeh014c7098b2018-07-05 14:03:08 +010024
David Beckb30c5332018-09-28 16:51:01 +010025# find the common.mk and backend.mk files in the backend source folders
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +000026ARMNN_BACKEND_COMMON_MAKEFILE_LOCAL_PATHS := $(wildcard $(LOCAL_PATH)/src/backends/*/common.mk)
David Beckb30c5332018-09-28 16:51:01 +010027ARMNN_BACKEND_COMMON_MAKEFILE_PATHS := $(subst $(LOCAL_PATH),,$(ARMNN_BACKEND_COMMON_MAKEFILE_LOCAL_PATHS))
28ARMNN_BACKEND_COMMON_MAKEFILE_DIRS := $(subst /common.mk,,$(ARMNN_BACKEND_COMMON_MAKEFILE_PATHS))
29
David Beck2ca46962018-09-21 15:48:23 +010030ARMNN_BACKEND_MAKEFILE_LOCAL_PATHS := $(wildcard $(LOCAL_PATH)/src/backends/*/backend.mk)
31ARMNN_BACKEND_MAKEFILE_PATHS := $(subst $(LOCAL_PATH),,$(ARMNN_BACKEND_MAKEFILE_LOCAL_PATHS))
32ARMNN_BACKEND_MAKEFILE_DIRS := $(subst /backend.mk,,$(ARMNN_BACKEND_MAKEFILE_PATHS))
33
surmeh014c7098b2018-07-05 14:03:08 +010034##############
35# libarmnn.a #
36##############
37include $(CLEAR_VARS)
38
39LOCAL_MODULE := libarmnn
Sadik Armagan96a709d2019-06-26 09:47:51 +010040ifeq ($(Q_OR_LATER),1)
Sadik Armaganbab26262019-05-15 12:52:19 +010041# "eng" is deprecated in Android Q
42LOCAL_MODULE_TAGS := optional
43else
surmeh014c7098b2018-07-05 14:03:08 +010044LOCAL_MODULE_TAGS := eng optional
Sadik Armaganbab26262019-05-15 12:52:19 +010045endif
surmeh014c7098b2018-07-05 14:03:08 +010046LOCAL_ARM_MODE := arm
47LOCAL_PROPRIETARY_MODULE := true
48
Zingo Andersen14173562021-10-27 06:58:19 +020049# Placeholder to hold all backend source files and include paths, common and specific to the backends
David Beck2ca46962018-09-21 15:48:23 +010050ARMNN_BACKEND_SOURCES :=
Zingo Andersen14173562021-10-27 06:58:19 +020051ARMNN_BACKEND_INCLUDES :=
David Beck2ca46962018-09-21 15:48:23 +010052
53#
Zingo Andersen14173562021-10-27 06:58:19 +020054# Iterate through the backend common and specific include paths, include them into the
David Beckb30c5332018-09-28 16:51:01 +010055# current makefile and append the sources held by the COMMON_SOURCES and BACKEND_SOURCES variable
56# (included from the given makefile) to the ARMNN_BACKEND_SOURCES list
Zingo Andersen14173562021-10-27 06:58:19 +020057# and optional include paths set by BACKEND_INCLUDES to the ARMNN_BACKEND_INCLUDES list
David Beck2ca46962018-09-21 15:48:23 +010058#
David Beckb30c5332018-09-28 16:51:01 +010059$(foreach mkPath,$(ARMNN_BACKEND_COMMON_MAKEFILE_DIRS),\
Matteo Martincigh21350152018-11-28 16:22:22 +000060 $(eval include $(LOCAL_PATH)/$(mkPath)/common.mk)\
Matteo Martincighe67edb22019-08-14 14:05:46 +010061 $(eval ARMNN_BACKEND_SOURCES := $(ARMNN_BACKEND_SOURCES)\
62 $(patsubst %,$(mkPath)/%,$(COMMON_SOURCES))))
David Beckb30c5332018-09-28 16:51:01 +010063
David Beck2ca46962018-09-21 15:48:23 +010064$(foreach mkPath,$(ARMNN_BACKEND_MAKEFILE_DIRS),\
Matteo Martincigh21350152018-11-28 16:22:22 +000065 $(eval include $(LOCAL_PATH)/$(mkPath)/backend.mk)\
Matteo Martincighe67edb22019-08-14 14:05:46 +010066 $(eval ARMNN_BACKEND_SOURCES := $(ARMNN_BACKEND_SOURCES)\
67 $(patsubst %,$(mkPath)/%,$(BACKEND_SOURCES))))
David Beck2ca46962018-09-21 15:48:23 +010068
Zingo Andersen14173562021-10-27 06:58:19 +020069$(foreach mkPath,$(ARMNN_BACKEND_MAKEFILE_DIRS),\
70 $(eval include $(LOCAL_PATH)/$(mkPath)/backend.mk)\
71 $(eval ARMNN_BACKEND_INCLUDES += $(BACKEND_INCLUDES)))
72
David Beck2ca46962018-09-21 15:48:23 +010073# Mark source files as dependent on Android.mk and backend makefiles
74LOCAL_ADDITIONAL_DEPENDENCIES := $(LOCAL_PATH)/Android.mk \
75 $(ARMNN_BACKEND_MAKEFILE_LOCAL_PATHS)
surmeh014c7098b2018-07-05 14:03:08 +010076
77LOCAL_EXPORT_C_INCLUDES := \
David Beck10b4dfd2018-09-19 12:03:20 +010078 $(ARMNN_MAIN_HEADER_PATH) \
surmeh014c7098b2018-07-05 14:03:08 +010079 $(ARMNN_SOURCE_HEADER_PATH) \
Sadik Armagana97a0be2020-03-03 10:44:56 +000080 $(ARMNN_PROFILING_INCLUDE_PATH) \
Finn Williams0c8cb992020-05-07 10:38:15 +010081 $(ARMNN_PROFILING_COMMON_INCLUDE_PATH) \
Jim Flynn4e755a52020-03-29 17:48:26 +010082 $(ARMNN_TIMELINE_DECODER_INCLUDE_PATH) \
Jim Flynnc9631102020-06-24 11:11:20 +010083 $(ARMNN_THIRD_PARTY_INCLUDE_PATH) \
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +000084 $(ARMNN_SOURCE_UTILS_HEADER_PATH) \
janeil0155e488a2019-11-08 12:03:58 +000085 $(ARMNN_PROFILING_HEADER_PATH) \
Sadik Armagan97bf84f2021-01-13 15:06:38 +000086 $(ARMNN_BACKENDS_HEADER_PATH) \
87 $(ARMNN_SERIALIZER_HEADER_PATH) \
88 $(ARMNN_DESERIALIZER_HEADER_PATH)
surmeh014c7098b2018-07-05 14:03:08 +010089
90LOCAL_C_INCLUDES := \
Matteo Martincigh21350152018-11-28 16:22:22 +000091 $(OPENCL_HEADER_PATH) \
92 $(NN_HEADER_PATH) \
93 $(ARMNN_HEADER_PATH) \
Sadik Armagana97a0be2020-03-03 10:44:56 +000094 $(ARMNN_PROFILING_INCLUDE_PATH) \
Finn Williams0c8cb992020-05-07 10:38:15 +010095 $(ARMNN_PROFILING_COMMON_INCLUDE_PATH) \
Jim Flynn4e755a52020-03-29 17:48:26 +010096 $(ARMNN_TIMELINE_DECODER_INCLUDE_PATH) \
Jim Flynnc9631102020-06-24 11:11:20 +010097 $(ARMNN_THIRD_PARTY_INCLUDE_PATH) \
Matteo Martincigh21350152018-11-28 16:22:22 +000098 $(ARMNN_MAIN_HEADER_PATH) \
99 $(ARMNN_SOURCE_HEADER_PATH) \
100 $(ARMNN_SOURCE_UTILS_HEADER_PATH) \
janeil0155e488a2019-11-08 12:03:58 +0000101 $(ARMNN_PROFILING_HEADER_PATH) \
Sadik Armagan97bf84f2021-01-13 15:06:38 +0000102 $(ARMNN_BACKENDS_HEADER_PATH) \
103 $(ARMNN_SERIALIZER_HEADER_PATH) \
Zingo Andersen14173562021-10-27 06:58:19 +0200104 $(ARMNN_DESERIALIZER_HEADER_PATH) \
105 $(ARMNN_BACKEND_INCLUDES)
surmeh014c7098b2018-07-05 14:03:08 +0100106
107LOCAL_SRC_FILES := \
David Beck2ca46962018-09-21 15:48:23 +0100108 $(ARMNN_BACKEND_SOURCES) \
Jim Flynnbbfe6032020-07-20 16:57:44 +0100109 profiling/common/src/CommandHandlerFunctor.cpp \
110 profiling/common/src/CommandHandlerKey.cpp \
111 profiling/common/src/CommandHandlerRegistry.cpp \
112 profiling/common/src/CommonProfilingUtils.cpp \
Finn Williams9937f932020-04-29 12:00:24 +0100113 profiling/common/src/NetworkSockets.cpp \
Jim Flynnbbfe6032020-07-20 16:57:44 +0100114 profiling/common/src/PacketVersionResolver.cpp \
115 profiling/common/src/SwTrace.cpp \
Nikhil Raj77fe76b2021-06-09 14:55:32 +0100116 profiling/common/src/LabelsAndEventClasses.cpp \
Jim Flynnbbfe6032020-07-20 16:57:44 +0100117 profiling/server/src/timelineDecoder/TimelineCaptureCommandHandler.cpp \
118 profiling/server/src/timelineDecoder/TimelineDecoder.cpp \
119 profiling/server/src/timelineDecoder/TimelineDirectoryCaptureCommandHandler.cpp \
Matteo Martincighe67edb22019-08-14 14:05:46 +0100120 src/armnn/BackendHelper.cpp \
Matteo Martincighc601aa62019-10-29 15:03:22 +0000121 src/armnn/BackendRegistry.cpp \
Matteo Martincighe67edb22019-08-14 14:05:46 +0100122 src/armnn/Descriptors.cpp \
123 src/armnn/Exceptions.cpp \
124 src/armnn/Graph.cpp \
125 src/armnn/InternalTypes.cpp \
126 src/armnn/JsonPrinter.cpp \
127 src/armnn/Layer.cpp \
128 src/armnn/LayerSupport.cpp \
129 src/armnn/LoadedNetwork.cpp \
Matthew Benthamd3a07832020-01-15 17:21:38 +0000130 src/armnn/Logging.cpp \
Matteo Martincighe67edb22019-08-14 14:05:46 +0100131 src/armnn/Network.cpp \
132 src/armnn/NetworkUtils.cpp \
133 src/armnn/Observable.cpp \
134 src/armnn/Optimizer.cpp \
Matteo Martincighe5b8eb92019-11-28 15:45:42 +0000135 src/armnn/OutputHandler.cpp \
Matteo Martincighe67edb22019-08-14 14:05:46 +0100136 src/armnn/ProfilingEvent.cpp \
137 src/armnn/Profiling.cpp \
138 src/armnn/Runtime.cpp \
139 src/armnn/SerializeLayerParameters.cpp \
140 src/armnn/SubgraphView.cpp \
141 src/armnn/SubgraphViewSelector.cpp \
142 src/armnn/Tensor.cpp \
Finn Williamsf364d532021-06-09 17:07:33 +0100143 src/armnn/Threadpool.cpp \
Matteo Martincighe67edb22019-08-14 14:05:46 +0100144 src/armnn/TypesUtils.cpp \
145 src/armnn/Utils.cpp \
146 src/armnn/WallClockTimer.cpp \
Mike Kelly386ff1a2021-03-29 15:04:50 +0100147 src/armnn/WorkingMemHandle.cpp \
Sadik Armagan1342bed2021-11-17 15:01:00 +0000148 src/armnnUtils/CompatibleTypes.cpp \
Matteo Martincigh21350152018-11-28 16:22:22 +0000149 src/armnnUtils/DataLayoutIndexed.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100150 src/armnnUtils/DotSerializer.cpp \
151 src/armnnUtils/FloatingPointConverter.cpp \
Matteo Martincigh21350152018-11-28 16:22:22 +0000152 src/armnnUtils/HeapProfiling.cpp \
153 src/armnnUtils/LeakChecking.cpp \
Sadik Armagan479045b2018-10-01 11:51:37 +0100154 src/armnnUtils/ParserHelper.cpp \
Matteo Martincigh21350152018-11-28 16:22:22 +0000155 src/armnnUtils/Permute.cpp \
Nina Drozdd41b2592018-11-19 13:03:36 +0000156 src/armnnUtils/TensorUtils.cpp \
Matteo Martincigh21350152018-11-28 16:22:22 +0000157 src/armnnUtils/VerificationHelpers.cpp \
Rob Hughesbdee4262020-01-07 17:05:24 +0000158 src/armnnUtils/Filesystem.cpp \
159 src/armnnUtils/Processes.cpp \
Jim Flynn1fdeb992020-07-09 07:28:37 +0100160 src/armnnUtils/Threads.cpp \
Mike Kellyc9ea45a2020-02-28 18:11:58 +0000161 src/armnnUtils/Transpose.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100162 src/armnn/layers/ActivationLayer.cpp \
163 src/armnn/layers/AdditionLayer.cpp \
Nikhil Rajee391d52019-09-05 17:50:44 +0100164 src/armnn/layers/ArgMinMaxLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100165 src/armnn/layers/BatchNormalizationLayer.cpp \
Éanna Ó Catháin4e1e1362018-11-12 11:36:34 +0000166 src/armnn/layers/BatchToSpaceNdLayer.cpp \
mathad01b392e982021-04-07 12:07:30 +0100167 src/armnn/layers/CastLayer.cpp \
Simon Obute51f67772021-09-03 15:50:13 +0100168 src/armnn/layers/ChannelShuffleLayer.cpp \
Aron Virginas-Tar77bfb5e2019-10-16 17:45:38 +0100169 src/armnn/layers/ComparisonLayer.cpp \
Jim Flynne242f2d2019-05-22 14:24:13 +0100170 src/armnn/layers/ConcatLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100171 src/armnn/layers/ConstantLayer.cpp \
172 src/armnn/layers/Convolution2dLayer.cpp \
Matthew Sloyanb63a3112021-09-08 13:05:51 +0100173 src/armnn/layers/Convolution3dLayer.cpp \
Narumol Prangnawarat7ddbbae2020-03-13 10:26:05 +0000174 src/armnn/layers/ConvertBf16ToFp32Layer.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100175 src/armnn/layers/ConvertFp16ToFp32Layer.cpp \
Narumol Prangnawaratea54a012020-03-16 16:36:10 +0000176 src/armnn/layers/ConvertFp32ToBf16Layer.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100177 src/armnn/layers/ConvertFp32ToFp16Layer.cpp \
Nattapat Chaimanowonga9a1cf12018-12-03 16:06:49 +0000178 src/armnn/layers/DebugLayer.cpp \
Aron Virginas-Tardd6247f2019-09-19 14:31:17 +0100179 src/armnn/layers/DepthToSpaceLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100180 src/armnn/layers/DepthwiseConvolution2dLayer.cpp \
Nattapat Chaimanowonge4294fd2019-03-28 09:56:53 +0000181 src/armnn/layers/DequantizeLayer.cpp \
Narumol Prangnawarat94dd5d82019-01-23 18:06:26 +0000182 src/armnn/layers/DetectionPostProcessLayer.cpp \
Matteo Martincigh49124022019-01-11 13:25:59 +0000183 src/armnn/layers/DivisionLayer.cpp \
Matteo Martincigh59a950c2018-12-13 12:48:25 +0000184 src/armnn/layers/ElementwiseBaseLayer.cpp \
josh minor4a3c6102020-01-06 16:40:46 -0600185 src/armnn/layers/ElementwiseUnaryLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100186 src/armnn/layers/FakeQuantizationLayer.cpp \
Ryan OSheaec6c6802020-06-05 17:17:06 +0100187 src/armnn/layers/FillLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100188 src/armnn/layers/FloorLayer.cpp \
189 src/armnn/layers/FullyConnectedLayer.cpp \
narpra01b89b05f2019-01-16 09:53:09 +0000190 src/armnn/layers/GatherLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100191 src/armnn/layers/InputLayer.cpp \
Kevin Mayce5045a2019-10-02 14:07:47 +0100192 src/armnn/layers/InstanceNormalizationLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100193 src/armnn/layers/L2NormalizationLayer.cpp \
James Conroyaba90cd2020-11-06 16:28:18 +0000194 src/armnn/layers/LogicalBinaryLayer.cpp \
Aron Virginas-Tarf982dea2019-10-11 14:07:53 +0100195 src/armnn/layers/LogSoftmaxLayer.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100196 src/armnn/layers/LstmLayer.cpp \
Jim Flynn68db06f2020-10-06 10:14:50 +0100197 src/armnn/layers/MapLayer.cpp \
Nattapat Chaimanowong5a4304a2018-11-28 10:44:37 +0000198 src/armnn/layers/MaximumLayer.cpp \
narpra0132b90462018-09-13 11:07:48 +0100199 src/armnn/layers/MeanLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100200 src/armnn/layers/MemCopyLayer.cpp \
Derek Lambertif674aa02019-08-01 15:56:25 +0100201 src/armnn/layers/MemImportLayer.cpp \
Nattapat Chaimanowong1f886302019-04-05 13:37:19 +0100202 src/armnn/layers/MergeLayer.cpp \
kevmay0190539692018-11-29 08:40:19 +0000203 src/armnn/layers/MinimumLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100204 src/armnn/layers/MultiplicationLayer.cpp \
205 src/armnn/layers/NormalizationLayer.cpp \
206 src/armnn/layers/OutputLayer.cpp \
Mohamed Nour Abouelseoud5662c202018-09-24 13:30:09 +0100207 src/armnn/layers/PadLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100208 src/armnn/layers/PermuteLayer.cpp \
209 src/armnn/layers/Pooling2dLayer.cpp \
Tamás Nyíri7b885b32021-10-26 14:47:57 +0100210 src/armnn/layers/Pooling3dLayer.cpp \
Matteo Martincigh49124022019-01-11 13:25:59 +0000211 src/armnn/layers/PreCompiledLayer.cpp \
Matteo Martincigh0e406ee2019-06-12 15:42:18 +0100212 src/armnn/layers/PreluLayer.cpp \
James Conroy586a9aa2020-03-20 08:49:33 +0000213 src/armnn/layers/QLstmLayer.cpp \
Derek Lambertia9cca6a2019-03-25 15:41:58 +0000214 src/armnn/layers/QuantizeLayer.cpp \
James Conroyee18dc82019-07-17 11:27:46 +0100215 src/armnn/layers/QuantizedLstmLayer.cpp \
Finn Williams2605b232020-06-10 15:53:46 +0100216 src/armnn/layers/RankLayer.cpp \
Sadik Armagan0c3ea5b2021-02-03 09:29:30 +0000217 src/armnn/layers/ReduceLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100218 src/armnn/layers/ReshapeLayer.cpp \
Teresa Charlina9075df2019-06-27 15:41:57 +0100219 src/armnn/layers/ResizeLayer.cpp \
Keith Davis3ae3f972021-05-21 16:33:48 +0100220 src/armnn/layers/ShapeLayer.cpp \
Aron Virginas-Tar636ab402019-09-16 14:27:45 +0100221 src/armnn/layers/SliceLayer.cpp \
222 src/armnn/layers/SoftmaxLayer.cpp \
Mohamed Nour Abouelseouda1d3c6a2018-12-27 12:39:16 +0000223 src/armnn/layers/SpaceToBatchNdLayer.cpp \
Aron Virginas-Tar972af152019-06-11 14:14:03 +0100224 src/armnn/layers/SpaceToDepthLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100225 src/armnn/layers/SplitterLayer.cpp \
Matthew Jackson2b8c1da2019-07-04 14:59:16 +0100226 src/armnn/layers/StackLayer.cpp \
Derek Lamberti013c3902019-10-21 10:46:16 +0100227 src/armnn/layers/StandInLayer.cpp \
Conor Kennedy430b5d82018-11-14 15:28:28 +0000228 src/armnn/layers/StridedSliceLayer.cpp \
Mohamed Nour Abouelseouda1d3c6a2018-12-27 12:39:16 +0000229 src/armnn/layers/SubtractionLayer.cpp \
Sadik Armaganeff363d2019-04-05 15:25:46 +0100230 src/armnn/layers/SwitchLayer.cpp \
Jim Flynnc4728ad2019-10-07 15:15:12 +0100231 src/armnn/layers/TransposeConvolution2dLayer.cpp \
Mike Kellyc9ea45a2020-02-28 18:11:58 +0000232 src/armnn/layers/TransposeLayer.cpp \
Narumol Prangnawarat8ed39ae2021-07-15 16:16:25 +0100233 src/armnn/layers/UnidirectionalSequenceLstmLayer.cpp \
Jim Flynn3a40ea52020-10-08 11:42:30 +0100234 src/armnn/layers/UnmapLayer.cpp \
Keith Davis33ed2212020-03-30 10:43:41 +0100235 src/profiling/ActivateTimelineReportingCommandHandler.cpp \
Jim Flynnc4728ad2019-10-07 15:15:12 +0100236 src/profiling/BufferManager.cpp \
237 src/profiling/CommandHandler.cpp \
Jim Flynnc4728ad2019-10-07 15:15:12 +0100238 src/profiling/ConnectionAcknowledgedCommandHandler.cpp \
239 src/profiling/CounterDirectory.cpp \
Jim Flynn8e0c7a62020-01-30 14:10:55 +0000240 src/profiling/CounterIdMap.cpp \
Keith Davis33ed2212020-03-30 10:43:41 +0100241 src/profiling/DeactivateTimelineReportingCommandHandler.cpp \
Jim Flynn4e755a52020-03-29 17:48:26 +0100242 src/profiling/DirectoryCaptureCommandHandler.cpp \
Keith Davis3201eea2019-10-24 17:30:41 +0100243 src/profiling/FileOnlyProfilingConnection.cpp \
Jim Flynnc4728ad2019-10-07 15:15:12 +0100244 src/profiling/Holder.cpp \
245 src/profiling/PacketBuffer.cpp \
Jim Flynnc4728ad2019-10-07 15:15:12 +0100246 src/profiling/PeriodicCounterCapture.cpp \
247 src/profiling/PeriodicCounterSelectionCommandHandler.cpp \
Matteo Martincigh994b5342019-10-11 17:19:56 +0100248 src/profiling/PerJobCounterSelectionCommandHandler.cpp \
Jim Flynnc4728ad2019-10-07 15:15:12 +0100249 src/profiling/ProfilingConnectionDumpToFileDecorator.cpp \
250 src/profiling/ProfilingConnectionFactory.cpp \
251 src/profiling/ProfilingService.cpp \
252 src/profiling/ProfilingStateMachine.cpp \
253 src/profiling/ProfilingUtils.cpp \
Jim Flynn97897022020-02-02 12:52:59 +0000254 src/profiling/RegisterBackendCounters.cpp \
Jim Flynnc4728ad2019-10-07 15:15:12 +0100255 src/profiling/RequestCounterDirectoryCommandHandler.cpp \
256 src/profiling/SendCounterPacket.cpp \
Sadik Armagan3896b472020-02-10 12:24:15 +0000257 src/profiling/SendThread.cpp \
Matteo Martincighcdfb9412019-11-08 11:23:06 +0000258 src/profiling/SendTimelinePacket.cpp \
Matteo Martincigh830101c2019-10-22 11:07:45 +0100259 src/profiling/SocketProfilingConnection.cpp \
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000260 src/profiling/TimelinePacketWriterFactory.cpp \
Colm Donelan1aff3932020-02-05 17:48:59 +0000261 src/profiling/TimelineUtilityMethods.cpp \
Sadik Armagan97bf84f2021-01-13 15:06:38 +0000262 src/profiling/backends/BackendProfiling.cpp \
263 src/armnnSerializer/Serializer.cpp \
264 src/armnnSerializer/SerializerUtils.cpp \
265 src/armnnDeserializer/Deserializer.cpp
surmeh014c7098b2018-07-05 14:03:08 +0100266
267LOCAL_STATIC_LIBRARIES := \
Matthew Sloyan80fbcd52021-01-07 13:28:47 +0000268 libflatbuffers-framework \
James Ward5ea9f312020-10-29 16:19:02 +0000269 arm_compute_library
surmeh014c7098b2018-07-05 14:03:08 +0100270
271LOCAL_SHARED_LIBRARIES := \
272 liblog
273
274LOCAL_CFLAGS := \
Sadik Armagan96a709d2019-06-26 09:47:51 +0100275 -std=$(CPP_VERSION) \
surmeh014c7098b2018-07-05 14:03:08 +0100276 -fexceptions \
surmeh014c7098b2018-07-05 14:03:08 +0100277 -Wno-unused-parameter \
Jan Eilersba3ef182020-09-25 08:36:44 +0100278 -frtti \
279 -DFMT_HEADER_ONLY
Guillaume Gardet5ae78292019-10-15 08:47:26 +0200280
Matteo Martincighd95e9062019-01-31 15:35:59 +0000281# The variable to enable/disable the CL backend (ARMNN_COMPUTE_CL_ENABLED) is declared in android-nn-driver/Android.mk
282ifeq ($(ARMNN_COMPUTE_CL_ENABLED),1)
283LOCAL_CFLAGS += \
284 -DARMCOMPUTECL_ENABLED
285endif # ARMNN_COMPUTE_CL_ENABLED == 1
286# The variable to enable/disable the NEON backend (ARMNN_COMPUTE_NEON_ENABLED) is declared in android-nn-driver/Android.mk
287ifeq ($(ARMNN_COMPUTE_NEON_ENABLED),1)
288LOCAL_CFLAGS += \
289 -DARMCOMPUTENEON_ENABLED
290endif # ARMNN_COMPUTE_NEON_ENABLED == 1
Matteo Martincighedd6fdc2019-08-29 18:27:18 +0100291# The variable to enable/disable the REFERENCE backend (ARMNN_REF_ENABLED) is declared in android-nn-driver/Android.mk
292ifeq ($(ARMNN_REF_ENABLED),1)
Matteo Martincighe67edb22019-08-14 14:05:46 +0100293LOCAL_CFLAGS += \
Matteo Martincighdb16dd32019-08-27 16:41:11 +0100294 -DARMNNREF_ENABLED
Matteo Martincighedd6fdc2019-08-29 18:27:18 +0100295endif # ARMNN_REF_ENABLED == 1
surmeh014c7098b2018-07-05 14:03:08 +0100296
Sadik Armagan96a709d2019-06-26 09:47:51 +0100297ifeq ($(Q_OR_LATER),1)
298LOCAL_CFLAGS += \
James Ward9b01ed22020-10-30 12:36:19 +0000299 -DARMNN_MIXED_PRECISION_FP16_POOLING
Sadik Armagan96a709d2019-06-26 09:47:51 +0100300endif # PLATFORM_VERSION == Q or later
301
surmeh014c7098b2018-07-05 14:03:08 +0100302include $(BUILD_STATIC_LIBRARY)
telsoa014fcda012018-03-09 14:13:49 +0000303
telsoa01c577f2c2018-08-31 09:22:23 +0100304###############
305# armnn-tests #
306###############
telsoa014fcda012018-03-09 14:13:49 +0000307include $(CLEAR_VARS)
308
telsoa01c577f2c2018-08-31 09:22:23 +0100309LOCAL_MODULE := armnn-tests
Sadik Armagan96a709d2019-06-26 09:47:51 +0100310ifeq ($(Q_OR_LATER),1)
Sadik Armaganbab26262019-05-15 12:52:19 +0100311# "eng" is deprecated in Android Q
312LOCAL_MODULE_TAGS := optional
313else
telsoa01c577f2c2018-08-31 09:22:23 +0100314LOCAL_MODULE_TAGS := eng optional
Sadik Armaganbab26262019-05-15 12:52:19 +0100315endif
telsoa01c577f2c2018-08-31 09:22:23 +0100316LOCAL_ARM_MODE := arm
317LOCAL_PROPRIETARY_MODULE := true
318
Aron Virginas-Tarceae3aa2018-10-18 10:39:38 +0100319# placeholder to hold all backend unit test source files
320ARMNN_BACKEND_TEST_SOURCES :=
Zingo Andersenbc2e2172021-12-14 14:02:46 +0100321ARMNN_BACKEND_TEST_INCLUDES :=
Aron Virginas-Tarceae3aa2018-10-18 10:39:38 +0100322
323#
324# iterate through the backend common and specific include paths, include them into the current
325# makefile and append the sources held by the COMMON_TEST_SOURCES and BACKEND_TEST_SOURCES
326# (included from the given makefile) to the ARMNN_BACKEND_TEST_SOURCES list
327#
328$(foreach mkPath,$(ARMNN_BACKEND_COMMON_MAKEFILE_DIRS), \
Matteo Martincigh21350152018-11-28 16:22:22 +0000329 $(eval include $(LOCAL_PATH)/$(mkPath)/common.mk) \
330 $(eval ARMNN_BACKEND_TEST_SOURCES := $(ARMNN_BACKEND_TEST_SOURCES) \
331 $(patsubst %,$(mkPath)/%,$(COMMON_TEST_SOURCES))))
Aron Virginas-Tarceae3aa2018-10-18 10:39:38 +0100332
333$(foreach mkPath,$(ARMNN_BACKEND_MAKEFILE_DIRS), \
Matteo Martincigh21350152018-11-28 16:22:22 +0000334 $(eval include $(LOCAL_PATH)/$(mkPath)/backend.mk) \
335 $(eval ARMNN_BACKEND_TEST_SOURCES := $(ARMNN_BACKEND_TEST_SOURCES) \
336 $(patsubst %,$(mkPath)/%,$(BACKEND_TEST_SOURCES))))
Aron Virginas-Tarceae3aa2018-10-18 10:39:38 +0100337
Zingo Andersenbc2e2172021-12-14 14:02:46 +0100338$(foreach mkPath,$(ARMNN_BACKEND_MAKEFILE_DIRS),\
339 $(eval include $(LOCAL_PATH)/$(mkPath)/backend.mk)\
340 $(eval ARMNN_BACKEND_TEST_INCLUDES += $(BACKEND_TEST_INCLUDES)))
341
342# Placeholder to hold all backend link files.
343ARMNN_BACKEND_TEST_STATIC_LIBRARIES :=
344ARMNN_BACKEND_TEST_SHARED_LIBRARIES :=
345
346# Iterate through the Arm NN backends and specific include paths, include them into the
347# current makefile and append the linkfiles held by
348# the optional BACKEND_STATIC_LIBRARIES and optional BACKEND_SHARED_LIBRARIES variable
349# (included from the given makefile) to
350# the ARMNN_BACKEND_STATIC_LIBRARIES and ARMNN_BACKEND_SHARED_LIBRARIES lists
351
352$(foreach mkPath,$(ARMNN_BACKEND_MAKEFILE_DIRS),\
353 $(eval include $(LOCAL_PATH)/$(mkPath)/backend.mk)\
354 $(eval ARMNN_BACKEND_TEST_STATIC_LIBRARIES += $(BACKEND_TEST_STATIC_LIBRARIES)))
355
356$(foreach mkPath,$(ARMNN_BACKEND_MAKEFILE_DIRS),\
357 $(eval include $(LOCAL_PATH)/$(mkPath)/backend.mk)\
358 $(eval ARMNN_BACKEND_TEST_SHARED_LIBRARIES += $(BACKEND_TEST_SHARED_LIBRARIES)))
359
360
telsoa01c577f2c2018-08-31 09:22:23 +0100361# Mark source files as dependent on Android.mk
362LOCAL_ADDITIONAL_DEPENDENCIES := $(LOCAL_PATH)/Android.mk
363
364LOCAL_C_INCLUDES := \
Matteo Martincigh21350152018-11-28 16:22:22 +0000365 $(OPENCL_HEADER_PATH) \
366 $(NN_HEADER_PATH) \
367 $(ARMNN_HEADER_PATH) \
Sadik Armagana97a0be2020-03-03 10:44:56 +0000368 $(ARMNN_PROFILING_INCLUDE_PATH) \
Finn Williams0c8cb992020-05-07 10:38:15 +0100369 $(ARMNN_PROFILING_COMMON_INCLUDE_PATH) \
Jim Flynn4e755a52020-03-29 17:48:26 +0100370 $(ARMNN_TIMELINE_DECODER_INCLUDE_PATH) \
Jim Flynnc9631102020-06-24 11:11:20 +0100371 $(ARMNN_THIRD_PARTY_INCLUDE_PATH) \
Matteo Martincigh21350152018-11-28 16:22:22 +0000372 $(ARMNN_MAIN_HEADER_PATH) \
373 $(ARMNN_SOURCE_HEADER_PATH) \
374 $(ARMNN_SOURCE_UTILS_HEADER_PATH) \
Sadik Armagana097d2a2021-11-24 15:47:28 +0000375 $(ARMNN_TEST_UTILS_SOURCE_PATH) \
janeil0155e488a2019-11-08 12:03:58 +0000376 $(ARMNN_PROFILING_HEADER_PATH) \
Sadik Armagan97bf84f2021-01-13 15:06:38 +0000377 $(ARMNN_BACKENDS_HEADER_PATH) \
378 $(ARMNN_SERIALIZER_HEADER_PATH) \
Zingo Andersenbc2e2172021-12-14 14:02:46 +0100379 $(ARMNN_DESERIALIZER_HEADER_PATH) \
380 $(ARMNN_BACKEND_INCLUDES)
381
telsoa014fcda012018-03-09 14:13:49 +0000382
383LOCAL_CFLAGS := \
Sadik Armagan96a709d2019-06-26 09:47:51 +0100384 -std=$(CPP_VERSION) \
Matteo Martincigh21350152018-11-28 16:22:22 +0000385 -fexceptions \
386 -frtti \
Guillaume Gardet5ae78292019-10-15 08:47:26 +0200387
Matteo Martincighd95e9062019-01-31 15:35:59 +0000388# The variable to enable/disable the CL backend (ARMNN_COMPUTE_CL_ENABLED) is declared in android-nn-driver/Android.mk
389ifeq ($(ARMNN_COMPUTE_CL_ENABLED),1)
390LOCAL_CFLAGS += \
391 -DARMCOMPUTECL_ENABLED
392endif # ARMNN_COMPUTE_CL_ENABLED == 1
393# The variable to enable/disable the NEON backend (ARMNN_COMPUTE_NEON_ENABLED) is declared in android-nn-driver/Android.mk
394ifeq ($(ARMNN_COMPUTE_NEON_ENABLED),1)
395LOCAL_CFLAGS += \
Matteo Martincigh21350152018-11-28 16:22:22 +0000396 -DARMCOMPUTENEON_ENABLED
Matteo Martincighd95e9062019-01-31 15:35:59 +0000397endif # ARMNN_COMPUTE_NEON_ENABLED == 1
Matteo Martincighedd6fdc2019-08-29 18:27:18 +0100398# The variable to enable/disable the REFERENCE backend (ARMNN_REF_ENABLED) is declared in android-nn-driver/Android.mk
399ifeq ($(ARMNN_REF_ENABLED),1)
Matteo Martincighe67edb22019-08-14 14:05:46 +0100400LOCAL_CFLAGS += \
Matteo Martincighdb16dd32019-08-27 16:41:11 +0100401 -DARMNNREF_ENABLED
Matteo Martincighedd6fdc2019-08-29 18:27:18 +0100402endif # ARMNN_REF_ENABLED == 1
telsoa014fcda012018-03-09 14:13:49 +0000403
telsoa01c577f2c2018-08-31 09:22:23 +0100404LOCAL_SRC_FILES := \
Aron Virginas-Tarceae3aa2018-10-18 10:39:38 +0100405 $(ARMNN_BACKEND_TEST_SOURCES) \
Colm Donelancf34f512020-02-20 14:31:49 +0000406 src/armnn/test/ConstTensorLayerVisitor.cpp \
Matteo Martincigh21350152018-11-28 16:22:22 +0000407 src/armnn/test/EndToEndTest.cpp \
Colm Donelancf34f512020-02-20 14:31:49 +0000408 src/armnn/ExecutionFrame.cpp \
409 src/armnn/test/ExecutionFrameTest.cpp \
410 src/armnn/test/FloatingPointConverterTest.cpp \
411 src/armnn/test/FlowControl.cpp \
Matteo Martincigh21350152018-11-28 16:22:22 +0000412 src/armnn/test/GraphTests.cpp \
Matteo Martincighbf0e7222019-06-20 17:17:45 +0100413 src/armnn/test/InferOutputTests.cpp \
Matteo Martincigh21350152018-11-28 16:22:22 +0000414 src/armnn/test/InstrumentTests.cpp \
Colm Donelancf34f512020-02-20 14:31:49 +0000415 src/armnnUtils/ModelAccuracyChecker.cpp \
416 src/armnn/test/ModelAccuracyCheckerTest.cpp \
Matteo Martincighe67edb22019-08-14 14:05:46 +0100417 src/armnn/test/NetworkTests.cpp \
Matteo Martincigh21350152018-11-28 16:22:22 +0000418 src/armnn/test/ObservableTest.cpp \
Narumol Prangnawaratbc7ffb52020-03-20 15:01:01 +0000419 src/armnn/test/optimizations/ConvertConstantsBFloatTests.cpp \
Colm Donelancf34f512020-02-20 14:31:49 +0000420 src/armnn/test/optimizations/ConvertConstantsFloatToHalfTests.cpp \
421 src/armnn/test/optimizations/ConvertConstantsHalfToFloatTests.cpp \
Narumol Prangnawaratbc7ffb52020-03-20 15:01:01 +0000422 src/armnn/test/optimizations/Fp32NetworkToBf16ConverterTests.cpp \
Colm Donelancf34f512020-02-20 14:31:49 +0000423 src/armnn/test/optimizations/Fp32NetworkToFp16ConverterTests.cpp \
Mike Kelly07810fc2020-11-12 10:58:48 +0000424 src/armnn/test/optimizations/FuseActivationTests.cpp \
Colm Donelancf34f512020-02-20 14:31:49 +0000425 src/armnn/test/optimizations/InsertDebugLayerTests.cpp \
426 src/armnn/test/optimizations/MovePermuteUpTests.cpp \
427 src/armnn/test/optimizations/OptimizeConsecutiveReshapesTests.cpp \
428 src/armnn/test/optimizations/OptimizeInverseConversionsTests.cpp \
429 src/armnn/test/optimizations/OptimizeInversePermutesTests.cpp \
430 src/armnn/test/optimizations/PermuteAndBatchToSpaceAsDepthToSpaceTests.cpp \
431 src/armnn/test/optimizations/PermuteAsReshapeTests.cpp \
Matthew Sloyan33f89872021-06-30 10:20:17 +0100432 src/armnn/test/optimizations/RedirectMembersToConstantInputsTests.cpp \
Matthew Sloyan5fc0fd62021-05-03 12:22:03 +0100433 src/armnn/test/optimizations/ReduceMultipleAxesTests.cpp \
Colm Donelancf34f512020-02-20 14:31:49 +0000434 src/armnn/test/optimizations/SquashEqualSiblingsTests.cpp \
Mike Kelly490b7be2020-03-03 12:39:09 +0000435 src/armnn/test/optimizations/TransposeAsReshapeTests.cpp \
Colm Donelancf34f512020-02-20 14:31:49 +0000436 src/armnn/test/OptimizerTests.cpp \
Matteo Martincighbf0e7222019-06-20 17:17:45 +0100437 src/armnn/test/OptionalTest.cpp \
Colm Donelancf34f512020-02-20 14:31:49 +0000438 src/armnn/test/ProfilerTests.cpp \
Matteo Martincighe67edb22019-08-14 14:05:46 +0100439 src/armnn/test/ProfilingEventTest.cpp \
Colm Donelancf34f512020-02-20 14:31:49 +0000440 src/armnnUtils/PrototxtConversions.cpp \
441 src/armnnUtils/test/PrototxtConversionsTest.cpp \
Matteo Martincighe67edb22019-08-14 14:05:46 +0100442 src/armnn/test/SubgraphViewTests.cpp \
443 src/armnn/test/TensorHandleStrategyTest.cpp \
444 src/armnn/test/TensorTest.cpp \
Colm Donelancf34f512020-02-20 14:31:49 +0000445 src/armnn/test/TestInputOutputLayerVisitor.cpp \
446 src/armnn/test/TestLayerVisitor.cpp \
447 src/armnn/test/TestNameAndDescriptorLayerVisitor.cpp \
448 src/armnn/test/TestNameOnlyLayerVisitor.cpp \
Narumol Prangnawaratdf31cfe2019-11-22 11:26:06 +0000449 src/armnn/test/UtilsTests.cpp \
Colm Donelancf34f512020-02-20 14:31:49 +0000450 src/armnnUtils/test/ParserHelperTest.cpp \
451 src/armnnUtils/test/QuantizeHelperTest.cpp \
452 src/armnnUtils/test/TensorUtilsTest.cpp \
Sadik Armagana097d2a2021-11-24 15:47:28 +0000453 src/armnnTestUtils/CommonTestUtils.cpp \
454 src/armnnTestUtils/GraphUtils.cpp \
455 src/armnnTestUtils/TensorCopyUtils.cpp \
456 src/armnnTestUtils/TestUtils.cpp \
457 src/armnnTestUtils/UnitTests.cpp \
Colm Donelancf34f512020-02-20 14:31:49 +0000458 src/profiling/test/BufferTests.cpp \
459 src/profiling/test/FileOnlyProfilingDecoratorTests.cpp \
Jim Flynn4e755a52020-03-29 17:48:26 +0100460 src/profiling/test/PrintPacketHeaderHandler.cpp \
Colm Donelancf34f512020-02-20 14:31:49 +0000461 src/profiling/test/ProfilingConnectionDumpToFileDecoratorTests.cpp \
462 src/profiling/test/ProfilingGuidTest.cpp \
463 src/profiling/test/ProfilingTests.cpp \
464 src/profiling/test/ProfilingTestUtils.cpp \
465 src/profiling/test/SendCounterPacketTests.cpp \
466 src/profiling/test/SendTimelinePacketTests.cpp \
Jim Flynn4e755a52020-03-29 17:48:26 +0100467 src/profiling/test/TestTimelinePacketHandler.cpp \
468 src/profiling/test/TimelineModel.cpp \
Colm Donelancf34f512020-02-20 14:31:49 +0000469 src/profiling/test/TimelinePacketTests.cpp \
Sadik Armagan97bf84f2021-01-13 15:06:38 +0000470 src/profiling/test/TimelineUtilityMethodsTests.cpp \
471 src/armnnSerializer/test/ActivationSerializationTests.cpp \
Finn Williamsb454c5c2021-02-09 15:56:23 +0000472 src/armnnSerializer/test/ComparisonSerializationTests.cpp \
473 src/armnnSerializer/test/LstmSerializationTests.cpp \
474 src/armnnSerializer/test/SerializerTests.cpp \
475 src/armnnSerializer/test/SerializerTestUtils.cpp
Matteo Martincighe67edb22019-08-14 14:05:46 +0100476
Matteo Martincighedd6fdc2019-08-29 18:27:18 +0100477ifeq ($(ARMNN_REF_ENABLED),1)
Matteo Martincighe67edb22019-08-14 14:05:46 +0100478LOCAL_SRC_FILES += \
479 src/armnn/test/DebugCallbackTest.cpp \
480 src/armnn/test/RuntimeTests.cpp
481endif
telsoa014fcda012018-03-09 14:13:49 +0000482
483LOCAL_STATIC_LIBRARIES := \
Matteo Martincigh21350152018-11-28 16:22:22 +0000484 libneuralnetworks_common \
Matthew Sloyan80fbcd52021-01-07 13:28:47 +0000485 libflatbuffers-framework \
Zingo Andersenbc2e2172021-12-14 14:02:46 +0100486 arm_compute_library \
487 $(ARMNN_BACKEND_TEST_STATIC_LIBRARIES)
telsoa014fcda012018-03-09 14:13:49 +0000488
David Beck3cc9a622018-10-12 10:38:31 +0100489LOCAL_WHOLE_STATIC_LIBRARIES := libarmnn
490
telsoa01c577f2c2018-08-31 09:22:23 +0100491LOCAL_SHARED_LIBRARIES := \
Matteo Martincigh21350152018-11-28 16:22:22 +0000492 libbase \
493 libhidlbase \
494 libhidltransport \
495 libhidlmemory \
496 liblog \
497 libutils \
498 android.hardware.neuralnetworks@1.0 \
499 android.hidl.allocator@1.0 \
Zingo Andersenbc2e2172021-12-14 14:02:46 +0100500 android.hidl.memory@1.0 \
501 $(ARMNN_BACKEND_TEST_SHARED_LIBRARIES)
Sadik Armaganbab26262019-05-15 12:52:19 +0100502
alered01c7e39722020-04-03 15:37:13 +0100503ifeq ($(ARMNN_INCLUDE_LIBOPENCL),1)
Sadik Armaganbab26262019-05-15 12:52:19 +0100504LOCAL_SHARED_LIBRARIES += \
Matteo Martincigh21350152018-11-28 16:22:22 +0000505 libOpenCL
Sadik Armaganbab26262019-05-15 12:52:19 +0100506endif
telsoa014fcda012018-03-09 14:13:49 +0000507
telsoa014fcda012018-03-09 14:13:49 +0000508include $(BUILD_EXECUTABLE)