blob: d57e486b994ee2f173b0a1dfbf50e64faa6b8f75 [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
9#
surmeh013537c2c2018-05-18 16:31:43 +010010OPENCL_HEADER_PATH := $(LOCAL_PATH)/../clframework/include
telsoa014fcda012018-03-09 14:13:49 +000011NN_HEADER_PATH := $(LOCAL_PATH)/../../../../frameworks/ml/nn/runtime/include
12ARMNN_HEADER_PATH := $(LOCAL_PATH)/include
David Beck10b4dfd2018-09-19 12:03:20 +010013ARMNN_MAIN_HEADER_PATH := $(LOCAL_PATH)/src
telsoa014fcda012018-03-09 14:13:49 +000014ARMNN_SOURCE_HEADER_PATH := $(LOCAL_PATH)/src/armnn
surmeh014c7098b2018-07-05 14:03:08 +010015ARMNN_SOURCE_UTILS_HEADER_PATH := $(LOCAL_PATH)/src/armnnUtils
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +000016ARMNN_BACKENDS_HEADER_PATH := $(LOCAL_PATH)/src/backends
surmeh014c7098b2018-07-05 14:03:08 +010017
David Beckb30c5332018-09-28 16:51:01 +010018# find the common.mk and backend.mk files in the backend source folders
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +000019ARMNN_BACKEND_COMMON_MAKEFILE_LOCAL_PATHS := $(wildcard $(LOCAL_PATH)/src/backends/*/common.mk)
David Beckb30c5332018-09-28 16:51:01 +010020ARMNN_BACKEND_COMMON_MAKEFILE_PATHS := $(subst $(LOCAL_PATH),,$(ARMNN_BACKEND_COMMON_MAKEFILE_LOCAL_PATHS))
21ARMNN_BACKEND_COMMON_MAKEFILE_DIRS := $(subst /common.mk,,$(ARMNN_BACKEND_COMMON_MAKEFILE_PATHS))
22
David Beck2ca46962018-09-21 15:48:23 +010023ARMNN_BACKEND_MAKEFILE_LOCAL_PATHS := $(wildcard $(LOCAL_PATH)/src/backends/*/backend.mk)
24ARMNN_BACKEND_MAKEFILE_PATHS := $(subst $(LOCAL_PATH),,$(ARMNN_BACKEND_MAKEFILE_LOCAL_PATHS))
25ARMNN_BACKEND_MAKEFILE_DIRS := $(subst /backend.mk,,$(ARMNN_BACKEND_MAKEFILE_PATHS))
26
surmeh014c7098b2018-07-05 14:03:08 +010027##############
28# libarmnn.a #
29##############
30include $(CLEAR_VARS)
31
32LOCAL_MODULE := libarmnn
Sadik Armaganbab26262019-05-15 12:52:19 +010033ifeq ($(PLATFORM_VERSION),Q)
34# "eng" is deprecated in Android Q
35LOCAL_MODULE_TAGS := optional
36else
surmeh014c7098b2018-07-05 14:03:08 +010037LOCAL_MODULE_TAGS := eng optional
Sadik Armaganbab26262019-05-15 12:52:19 +010038endif
surmeh014c7098b2018-07-05 14:03:08 +010039LOCAL_ARM_MODE := arm
40LOCAL_PROPRIETARY_MODULE := true
41
David Beckb30c5332018-09-28 16:51:01 +010042# placeholder to hold all backend source files, common and specific to the backends
David Beck2ca46962018-09-21 15:48:23 +010043ARMNN_BACKEND_SOURCES :=
44
45#
David Beckb30c5332018-09-28 16:51:01 +010046# iterate through the backend common and specific include paths, include them into the
47# current makefile and append the sources held by the COMMON_SOURCES and BACKEND_SOURCES variable
48# (included from the given makefile) to the ARMNN_BACKEND_SOURCES list
David Beck2ca46962018-09-21 15:48:23 +010049#
David Beckb30c5332018-09-28 16:51:01 +010050$(foreach mkPath,$(ARMNN_BACKEND_COMMON_MAKEFILE_DIRS),\
Matteo Martincigh21350152018-11-28 16:22:22 +000051 $(eval include $(LOCAL_PATH)/$(mkPath)/common.mk)\
52 $(eval ARMNN_BACKEND_SOURCES := $(ARMNN_BACKEND_SOURCES) $(patsubst %,$(mkPath)/%,$(COMMON_SOURCES))))
David Beckb30c5332018-09-28 16:51:01 +010053
David Beck2ca46962018-09-21 15:48:23 +010054$(foreach mkPath,$(ARMNN_BACKEND_MAKEFILE_DIRS),\
Matteo Martincigh21350152018-11-28 16:22:22 +000055 $(eval include $(LOCAL_PATH)/$(mkPath)/backend.mk)\
56 $(eval ARMNN_BACKEND_SOURCES := $(ARMNN_BACKEND_SOURCES) $(patsubst %,$(mkPath)/%,$(BACKEND_SOURCES))))
David Beck2ca46962018-09-21 15:48:23 +010057
58# Mark source files as dependent on Android.mk and backend makefiles
59LOCAL_ADDITIONAL_DEPENDENCIES := $(LOCAL_PATH)/Android.mk \
60 $(ARMNN_BACKEND_MAKEFILE_LOCAL_PATHS)
surmeh014c7098b2018-07-05 14:03:08 +010061
62LOCAL_EXPORT_C_INCLUDES := \
David Beck10b4dfd2018-09-19 12:03:20 +010063 $(ARMNN_MAIN_HEADER_PATH) \
surmeh014c7098b2018-07-05 14:03:08 +010064 $(ARMNN_SOURCE_HEADER_PATH) \
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +000065 $(ARMNN_SOURCE_UTILS_HEADER_PATH) \
66 $(ARMNN_BACKENDS_HEADER_PATH)
surmeh014c7098b2018-07-05 14:03:08 +010067
68LOCAL_C_INCLUDES := \
Matteo Martincigh21350152018-11-28 16:22:22 +000069 $(OPENCL_HEADER_PATH) \
70 $(NN_HEADER_PATH) \
71 $(ARMNN_HEADER_PATH) \
72 $(ARMNN_MAIN_HEADER_PATH) \
73 $(ARMNN_SOURCE_HEADER_PATH) \
74 $(ARMNN_SOURCE_UTILS_HEADER_PATH) \
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +000075 $(ARMNN_BACKENDS_HEADER_PATH)
surmeh014c7098b2018-07-05 14:03:08 +010076
77LOCAL_SRC_FILES := \
David Beck2ca46962018-09-21 15:48:23 +010078 $(ARMNN_BACKEND_SOURCES) \
Matteo Martincigh21350152018-11-28 16:22:22 +000079 src/armnnUtils/CsvReader.cpp \
80 src/armnnUtils/DataLayoutIndexed.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +010081 src/armnnUtils/DotSerializer.cpp \
82 src/armnnUtils/FloatingPointConverter.cpp \
Matteo Martincigh21350152018-11-28 16:22:22 +000083 src/armnnUtils/HeapProfiling.cpp \
84 src/armnnUtils/LeakChecking.cpp \
surmeh014c7098b2018-07-05 14:03:08 +010085 src/armnnUtils/Logging.cpp \
Sadik Armagan479045b2018-10-01 11:51:37 +010086 src/armnnUtils/ParserHelper.cpp \
Matteo Martincigh21350152018-11-28 16:22:22 +000087 src/armnnUtils/Permute.cpp \
Nina Drozdd41b2592018-11-19 13:03:36 +000088 src/armnnUtils/TensorUtils.cpp \
Matteo Martincigh21350152018-11-28 16:22:22 +000089 src/armnnUtils/VerificationHelpers.cpp \
surmeh014c7098b2018-07-05 14:03:08 +010090 src/armnn/layers/ActivationLayer.cpp \
91 src/armnn/layers/AdditionLayer.cpp \
92 src/armnn/layers/BatchNormalizationLayer.cpp \
Éanna Ó Catháin4e1e1362018-11-12 11:36:34 +000093 src/armnn/layers/BatchToSpaceNdLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +010094 src/armnn/layers/ConstantLayer.cpp \
95 src/armnn/layers/Convolution2dLayer.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +010096 src/armnn/layers/ConvertFp16ToFp32Layer.cpp \
97 src/armnn/layers/ConvertFp32ToFp16Layer.cpp \
Nattapat Chaimanowonga9a1cf12018-12-03 16:06:49 +000098 src/armnn/layers/DebugLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +010099 src/armnn/layers/DepthwiseConvolution2dLayer.cpp \
Nattapat Chaimanowonge4294fd2019-03-28 09:56:53 +0000100 src/armnn/layers/DequantizeLayer.cpp \
Narumol Prangnawarat94dd5d82019-01-23 18:06:26 +0000101 src/armnn/layers/DetectionPostProcessLayer.cpp \
Matteo Martincigh49124022019-01-11 13:25:59 +0000102 src/armnn/layers/DivisionLayer.cpp \
Matteo Martincigh59a950c2018-12-13 12:48:25 +0000103 src/armnn/layers/ElementwiseBaseLayer.cpp \
FrancisMurtagh20995952018-12-17 12:11:36 +0000104 src/armnn/layers/EqualLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100105 src/armnn/layers/FakeQuantizationLayer.cpp \
106 src/armnn/layers/FloorLayer.cpp \
107 src/armnn/layers/FullyConnectedLayer.cpp \
narpra01b89b05f2019-01-16 09:53:09 +0000108 src/armnn/layers/GatherLayer.cpp \
Matteo Martincigh59a950c2018-12-13 12:48:25 +0000109 src/armnn/layers/GreaterLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100110 src/armnn/layers/InputLayer.cpp \
111 src/armnn/layers/L2NormalizationLayer.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100112 src/armnn/layers/LstmLayer.cpp \
Nattapat Chaimanowong5a4304a2018-11-28 10:44:37 +0000113 src/armnn/layers/MaximumLayer.cpp \
narpra0132b90462018-09-13 11:07:48 +0100114 src/armnn/layers/MeanLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100115 src/armnn/layers/MemCopyLayer.cpp \
Nattapat Chaimanowong1f886302019-04-05 13:37:19 +0100116 src/armnn/layers/MergeLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100117 src/armnn/layers/MergerLayer.cpp \
kevmay0190539692018-11-29 08:40:19 +0000118 src/armnn/layers/MinimumLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100119 src/armnn/layers/MultiplicationLayer.cpp \
120 src/armnn/layers/NormalizationLayer.cpp \
121 src/armnn/layers/OutputLayer.cpp \
Mohamed Nour Abouelseoud5662c202018-09-24 13:30:09 +0100122 src/armnn/layers/PadLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100123 src/armnn/layers/PermuteLayer.cpp \
124 src/armnn/layers/Pooling2dLayer.cpp \
Matteo Martincigh49124022019-01-11 13:25:59 +0000125 src/armnn/layers/PreCompiledLayer.cpp \
Derek Lambertia9cca6a2019-03-25 15:41:58 +0000126 src/armnn/layers/QuantizeLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100127 src/armnn/layers/ReshapeLayer.cpp \
128 src/armnn/layers/ResizeBilinearLayer.cpp \
Mohamed Nour Abouelseouda1d3c6a2018-12-27 12:39:16 +0000129 src/armnn/layers/RsqrtLayer.cpp \
130 src/armnn/layers/SpaceToBatchNdLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100131 src/armnn/layers/SoftmaxLayer.cpp \
132 src/armnn/layers/SplitterLayer.cpp \
Conor Kennedy430b5d82018-11-14 15:28:28 +0000133 src/armnn/layers/StridedSliceLayer.cpp \
Mohamed Nour Abouelseouda1d3c6a2018-12-27 12:39:16 +0000134 src/armnn/layers/SubtractionLayer.cpp \
Sadik Armaganeff363d2019-04-05 15:25:46 +0100135 src/armnn/layers/SwitchLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100136 src/armnn/Descriptors.cpp \
137 src/armnn/Exceptions.cpp \
138 src/armnn/Graph.cpp \
139 src/armnn/Optimizer.cpp \
140 src/armnn/Runtime.cpp \
141 src/armnn/SerializeLayerParameters.cpp \
Derek Lambertiff05cc52019-04-26 13:05:17 +0100142 src/armnn/SubgraphView.cpp \
143 src/armnn/SubgraphViewSelector.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100144 src/armnn/InternalTypes.cpp \
145 src/armnn/Layer.cpp \
146 src/armnn/LoadedNetwork.cpp \
147 src/armnn/Network.cpp \
Aron Virginas-Tar5fdfe822018-11-21 13:14:42 +0000148 src/armnn/NetworkUtils.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100149 src/armnn/WallClockTimer.cpp \
150 src/armnn/ProfilingEvent.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100151 src/armnn/Profiling.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100152 src/armnn/JsonPrinter.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100153 src/armnn/Tensor.cpp \
Aron Virginas-Tard4f0fea2019-04-09 14:08:06 +0100154 src/armnn/TypesUtils.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100155 src/armnn/Utils.cpp \
156 src/armnn/LayerSupport.cpp \
Aron Virginas-Tarf9aeef02018-10-12 15:18:03 +0100157 src/armnn/Observable.cpp
surmeh014c7098b2018-07-05 14:03:08 +0100158
159LOCAL_STATIC_LIBRARIES := \
Matteo Martincigh21350152018-11-28 16:22:22 +0000160 armnn-arm_compute \
surmeh014c7098b2018-07-05 14:03:08 +0100161 libboost_log \
162 libboost_system \
163 libboost_thread
164
165LOCAL_SHARED_LIBRARIES := \
166 liblog
167
168LOCAL_CFLAGS := \
169 -std=c++14 \
170 -fexceptions \
surmeh014c7098b2018-07-05 14:03:08 +0100171 -Wno-unused-parameter \
172 -frtti
Matteo Martincighd95e9062019-01-31 15:35:59 +0000173# The variable to enable/disable the CL backend (ARMNN_COMPUTE_CL_ENABLED) is declared in android-nn-driver/Android.mk
174ifeq ($(ARMNN_COMPUTE_CL_ENABLED),1)
175LOCAL_CFLAGS += \
176 -DARMCOMPUTECL_ENABLED
177endif # ARMNN_COMPUTE_CL_ENABLED == 1
178# The variable to enable/disable the NEON backend (ARMNN_COMPUTE_NEON_ENABLED) is declared in android-nn-driver/Android.mk
179ifeq ($(ARMNN_COMPUTE_NEON_ENABLED),1)
180LOCAL_CFLAGS += \
181 -DARMCOMPUTENEON_ENABLED
182endif # ARMNN_COMPUTE_NEON_ENABLED == 1
surmeh014c7098b2018-07-05 14:03:08 +0100183
184include $(BUILD_STATIC_LIBRARY)
telsoa014fcda012018-03-09 14:13:49 +0000185
telsoa01c577f2c2018-08-31 09:22:23 +0100186###############
187# armnn-tests #
188###############
telsoa014fcda012018-03-09 14:13:49 +0000189include $(CLEAR_VARS)
190
telsoa01c577f2c2018-08-31 09:22:23 +0100191LOCAL_MODULE := armnn-tests
Sadik Armaganbab26262019-05-15 12:52:19 +0100192ifeq ($(PLATFORM_VERSION),Q)
193# "eng" is deprecated in Android Q
194LOCAL_MODULE_TAGS := optional
195else
telsoa01c577f2c2018-08-31 09:22:23 +0100196LOCAL_MODULE_TAGS := eng optional
Sadik Armaganbab26262019-05-15 12:52:19 +0100197endif
telsoa01c577f2c2018-08-31 09:22:23 +0100198LOCAL_ARM_MODE := arm
199LOCAL_PROPRIETARY_MODULE := true
200
Aron Virginas-Tarceae3aa2018-10-18 10:39:38 +0100201# placeholder to hold all backend unit test source files
202ARMNN_BACKEND_TEST_SOURCES :=
203
204#
205# iterate through the backend common and specific include paths, include them into the current
206# makefile and append the sources held by the COMMON_TEST_SOURCES and BACKEND_TEST_SOURCES
207# (included from the given makefile) to the ARMNN_BACKEND_TEST_SOURCES list
208#
209$(foreach mkPath,$(ARMNN_BACKEND_COMMON_MAKEFILE_DIRS), \
Matteo Martincigh21350152018-11-28 16:22:22 +0000210 $(eval include $(LOCAL_PATH)/$(mkPath)/common.mk) \
211 $(eval ARMNN_BACKEND_TEST_SOURCES := $(ARMNN_BACKEND_TEST_SOURCES) \
212 $(patsubst %,$(mkPath)/%,$(COMMON_TEST_SOURCES))))
Aron Virginas-Tarceae3aa2018-10-18 10:39:38 +0100213
214$(foreach mkPath,$(ARMNN_BACKEND_MAKEFILE_DIRS), \
Matteo Martincigh21350152018-11-28 16:22:22 +0000215 $(eval include $(LOCAL_PATH)/$(mkPath)/backend.mk) \
216 $(eval ARMNN_BACKEND_TEST_SOURCES := $(ARMNN_BACKEND_TEST_SOURCES) \
217 $(patsubst %,$(mkPath)/%,$(BACKEND_TEST_SOURCES))))
Aron Virginas-Tarceae3aa2018-10-18 10:39:38 +0100218
telsoa01c577f2c2018-08-31 09:22:23 +0100219# Mark source files as dependent on Android.mk
220LOCAL_ADDITIONAL_DEPENDENCIES := $(LOCAL_PATH)/Android.mk
221
222LOCAL_C_INCLUDES := \
Matteo Martincigh21350152018-11-28 16:22:22 +0000223 $(OPENCL_HEADER_PATH) \
224 $(NN_HEADER_PATH) \
225 $(ARMNN_HEADER_PATH) \
226 $(ARMNN_MAIN_HEADER_PATH) \
227 $(ARMNN_SOURCE_HEADER_PATH) \
228 $(ARMNN_SOURCE_UTILS_HEADER_PATH) \
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +0000229 $(ARMNN_BACKENDS_HEADER_PATH)
telsoa014fcda012018-03-09 14:13:49 +0000230
231LOCAL_CFLAGS := \
Matteo Martincigh21350152018-11-28 16:22:22 +0000232 -std=c++14 \
233 -fexceptions \
234 -frtti \
Matteo Martincighd95e9062019-01-31 15:35:59 +0000235 -isystem vendor/arm/android-nn-driver/boost_1_64_0
236# The variable to enable/disable the CL backend (ARMNN_COMPUTE_CL_ENABLED) is declared in android-nn-driver/Android.mk
237ifeq ($(ARMNN_COMPUTE_CL_ENABLED),1)
238LOCAL_CFLAGS += \
239 -DARMCOMPUTECL_ENABLED
240endif # ARMNN_COMPUTE_CL_ENABLED == 1
241# The variable to enable/disable the NEON backend (ARMNN_COMPUTE_NEON_ENABLED) is declared in android-nn-driver/Android.mk
242ifeq ($(ARMNN_COMPUTE_NEON_ENABLED),1)
243LOCAL_CFLAGS += \
Matteo Martincigh21350152018-11-28 16:22:22 +0000244 -DARMCOMPUTENEON_ENABLED
Matteo Martincighd95e9062019-01-31 15:35:59 +0000245endif # ARMNN_COMPUTE_NEON_ENABLED == 1
telsoa014fcda012018-03-09 14:13:49 +0000246
telsoa01c577f2c2018-08-31 09:22:23 +0100247LOCAL_SRC_FILES := \
Aron Virginas-Tarceae3aa2018-10-18 10:39:38 +0100248 $(ARMNN_BACKEND_TEST_SOURCES) \
Matteo Martincigh21350152018-11-28 16:22:22 +0000249 src/armnn/test/UnitTests.cpp \
250 src/armnn/test/EndToEndTest.cpp \
251 src/armnn/test/UtilsTests.cpp \
252 src/armnn/test/GraphTests.cpp \
narpra016f37f832018-12-21 18:30:00 +0000253 src/armnn/test/GraphUtils.cpp \
Matteo Martincigh21350152018-11-28 16:22:22 +0000254 src/armnn/test/RuntimeTests.cpp \
Derek Lambertiff05cc52019-04-26 13:05:17 +0100255 src/armnn/test/SubgraphViewTests.cpp \
Matteo Martincigh21350152018-11-28 16:22:22 +0000256 src/armnn/test/TensorTest.cpp \
257 src/armnn/test/NetworkTests.cpp \
258 src/armnn/test/InstrumentTests.cpp \
259 src/armnn/test/ProfilingEventTest.cpp \
260 src/armnn/test/ObservableTest.cpp \
261 src/armnn/test/OptionalTest.cpp
telsoa014fcda012018-03-09 14:13:49 +0000262
263LOCAL_STATIC_LIBRARIES := \
Matteo Martincigh21350152018-11-28 16:22:22 +0000264 libneuralnetworks_common \
265 libboost_log \
266 libboost_system \
267 libboost_unit_test_framework \
268 libboost_thread \
269 armnn-arm_compute
telsoa014fcda012018-03-09 14:13:49 +0000270
David Beck3cc9a622018-10-12 10:38:31 +0100271LOCAL_WHOLE_STATIC_LIBRARIES := libarmnn
272
telsoa01c577f2c2018-08-31 09:22:23 +0100273LOCAL_SHARED_LIBRARIES := \
Matteo Martincigh21350152018-11-28 16:22:22 +0000274 libbase \
275 libhidlbase \
276 libhidltransport \
277 libhidlmemory \
278 liblog \
279 libutils \
280 android.hardware.neuralnetworks@1.0 \
281 android.hidl.allocator@1.0 \
Sadik Armaganbab26262019-05-15 12:52:19 +0100282 android.hidl.memory@1.0
283
284ifneq ($(PLATFORM_VERSION),Q)
285LOCAL_SHARED_LIBRARIES += \
Matteo Martincigh21350152018-11-28 16:22:22 +0000286 libOpenCL
Sadik Armaganbab26262019-05-15 12:52:19 +0100287endif
telsoa014fcda012018-03-09 14:13:49 +0000288
telsoa014fcda012018-03-09 14:13:49 +0000289include $(BUILD_EXECUTABLE)