blob: ee24312156b9e1ef25b27e48ac9b7dd6089ec6af [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
33LOCAL_MODULE_TAGS := eng optional
34LOCAL_ARM_MODE := arm
35LOCAL_PROPRIETARY_MODULE := true
36
David Beckb30c5332018-09-28 16:51:01 +010037# placeholder to hold all backend source files, common and specific to the backends
David Beck2ca46962018-09-21 15:48:23 +010038ARMNN_BACKEND_SOURCES :=
39
40#
David Beckb30c5332018-09-28 16:51:01 +010041# iterate through the backend common and specific include paths, include them into the
42# current makefile and append the sources held by the COMMON_SOURCES and BACKEND_SOURCES variable
43# (included from the given makefile) to the ARMNN_BACKEND_SOURCES list
David Beck2ca46962018-09-21 15:48:23 +010044#
David Beckb30c5332018-09-28 16:51:01 +010045$(foreach mkPath,$(ARMNN_BACKEND_COMMON_MAKEFILE_DIRS),\
46 $(eval include $(LOCAL_PATH)/$(mkPath)/common.mk)\
47 $(eval ARMNN_BACKEND_SOURCES := $(ARMNN_BACKEND_SOURCES) $(patsubst %,$(mkPath)/%,$(COMMON_SOURCES))))
48
David Beck2ca46962018-09-21 15:48:23 +010049$(foreach mkPath,$(ARMNN_BACKEND_MAKEFILE_DIRS),\
50 $(eval include $(LOCAL_PATH)/$(mkPath)/backend.mk)\
51 $(eval ARMNN_BACKEND_SOURCES := $(ARMNN_BACKEND_SOURCES) $(patsubst %,$(mkPath)/%,$(BACKEND_SOURCES))))
52
53# Mark source files as dependent on Android.mk and backend makefiles
54LOCAL_ADDITIONAL_DEPENDENCIES := $(LOCAL_PATH)/Android.mk \
55 $(ARMNN_BACKEND_MAKEFILE_LOCAL_PATHS)
surmeh014c7098b2018-07-05 14:03:08 +010056
57LOCAL_EXPORT_C_INCLUDES := \
David Beck10b4dfd2018-09-19 12:03:20 +010058 $(ARMNN_MAIN_HEADER_PATH) \
surmeh014c7098b2018-07-05 14:03:08 +010059 $(ARMNN_SOURCE_HEADER_PATH) \
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +000060 $(ARMNN_SOURCE_UTILS_HEADER_PATH) \
61 $(ARMNN_BACKENDS_HEADER_PATH)
surmeh014c7098b2018-07-05 14:03:08 +010062
63LOCAL_C_INCLUDES := \
telsoa01c577f2c2018-08-31 09:22:23 +010064 $(OPENCL_HEADER_PATH) \
65 $(NN_HEADER_PATH) \
66 $(ARMNN_HEADER_PATH) \
David Beck10b4dfd2018-09-19 12:03:20 +010067 $(ARMNN_MAIN_HEADER_PATH) \
telsoa01c577f2c2018-08-31 09:22:23 +010068 $(ARMNN_SOURCE_HEADER_PATH) \
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +000069 $(ARMNN_SOURCE_UTILS_HEADER_PATH) \
70 $(ARMNN_BACKENDS_HEADER_PATH)
surmeh014c7098b2018-07-05 14:03:08 +010071
72LOCAL_SRC_FILES := \
David Beck2ca46962018-09-21 15:48:23 +010073 $(ARMNN_BACKEND_SOURCES) \
telsoa01c577f2c2018-08-31 09:22:23 +010074 src/armnnUtils/DotSerializer.cpp \
75 src/armnnUtils/FloatingPointConverter.cpp \
surmeh014c7098b2018-07-05 14:03:08 +010076 src/armnnUtils/Logging.cpp \
77 src/armnnUtils/Permute.cpp \
Sadik Armagan479045b2018-10-01 11:51:37 +010078 src/armnnUtils/ParserHelper.cpp \
surmeh014c7098b2018-07-05 14:03:08 +010079 src/armnn/layers/ActivationLayer.cpp \
80 src/armnn/layers/AdditionLayer.cpp \
Les Bell033626d2018-09-03 16:24:52 +010081 src/armnn/layers/ArithmeticBaseLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +010082 src/armnn/layers/BatchNormalizationLayer.cpp \
83 src/armnn/layers/ConstantLayer.cpp \
84 src/armnn/layers/Convolution2dLayer.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +010085 src/armnn/layers/ConvertFp16ToFp32Layer.cpp \
86 src/armnn/layers/ConvertFp32ToFp16Layer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +010087 src/armnn/layers/DepthwiseConvolution2dLayer.cpp \
88 src/armnn/layers/FakeQuantizationLayer.cpp \
89 src/armnn/layers/FloorLayer.cpp \
90 src/armnn/layers/FullyConnectedLayer.cpp \
91 src/armnn/layers/InputLayer.cpp \
92 src/armnn/layers/L2NormalizationLayer.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +010093 src/armnn/layers/LstmLayer.cpp \
narpra0132b90462018-09-13 11:07:48 +010094 src/armnn/layers/MeanLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +010095 src/armnn/layers/MemCopyLayer.cpp \
96 src/armnn/layers/MergerLayer.cpp \
97 src/armnn/layers/MultiplicationLayer.cpp \
98 src/armnn/layers/NormalizationLayer.cpp \
99 src/armnn/layers/OutputLayer.cpp \
Mohamed Nour Abouelseoud5662c202018-09-24 13:30:09 +0100100 src/armnn/layers/PadLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100101 src/armnn/layers/PermuteLayer.cpp \
102 src/armnn/layers/Pooling2dLayer.cpp \
Francis Murtaghe7a86a42018-08-29 12:42:10 +0100103 src/armnn/layers/DivisionLayer.cpp \
David Beckc2044fe2018-09-05 15:00:38 +0100104 src/armnn/layers/SubtractionLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100105 src/armnn/layers/ReshapeLayer.cpp \
Nattapat Chaimanowong207ef9a2018-11-02 10:57:25 +0000106 src/armnn/layers/SpaceToBatchNdLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100107 src/armnn/layers/ResizeBilinearLayer.cpp \
108 src/armnn/layers/SoftmaxLayer.cpp \
109 src/armnn/layers/SplitterLayer.cpp \
110 src/armnn/Descriptors.cpp \
111 src/armnn/Exceptions.cpp \
112 src/armnn/Graph.cpp \
113 src/armnn/Optimizer.cpp \
114 src/armnn/Runtime.cpp \
115 src/armnn/SerializeLayerParameters.cpp \
David Beckf98d21a2018-10-26 16:03:03 +0100116 src/armnn/SubGraph.cpp \
117 src/armnn/SubGraphSelector.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100118 src/armnn/InternalTypes.cpp \
119 src/armnn/Layer.cpp \
120 src/armnn/LoadedNetwork.cpp \
121 src/armnn/Network.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100122 src/armnn/WallClockTimer.cpp \
123 src/armnn/ProfilingEvent.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100124 src/armnn/Profiling.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100125 src/armnn/JsonPrinter.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100126 src/armnn/Tensor.cpp \
127 src/armnn/Utils.cpp \
128 src/armnn/LayerSupport.cpp \
Aron Virginas-Tarf9aeef02018-10-12 15:18:03 +0100129 src/armnn/Observable.cpp
surmeh014c7098b2018-07-05 14:03:08 +0100130
131LOCAL_STATIC_LIBRARIES := \
telsoa01c577f2c2018-08-31 09:22:23 +0100132 armnn-arm_compute \
surmeh014c7098b2018-07-05 14:03:08 +0100133 libboost_log \
134 libboost_system \
135 libboost_thread
136
137LOCAL_SHARED_LIBRARIES := \
138 liblog
139
140LOCAL_CFLAGS := \
141 -std=c++14 \
142 -fexceptions \
143 -DARMCOMPUTECL_ENABLED \
144 -DARMCOMPUTENEON_ENABLED \
145 -Wno-unused-parameter \
146 -frtti
147
148include $(BUILD_STATIC_LIBRARY)
telsoa014fcda012018-03-09 14:13:49 +0000149
telsoa01c577f2c2018-08-31 09:22:23 +0100150###############
151# armnn-tests #
152###############
telsoa014fcda012018-03-09 14:13:49 +0000153include $(CLEAR_VARS)
154
telsoa01c577f2c2018-08-31 09:22:23 +0100155LOCAL_MODULE := armnn-tests
156LOCAL_MODULE_TAGS := eng optional
157LOCAL_ARM_MODE := arm
158LOCAL_PROPRIETARY_MODULE := true
159
Aron Virginas-Tarceae3aa2018-10-18 10:39:38 +0100160# placeholder to hold all backend unit test source files
161ARMNN_BACKEND_TEST_SOURCES :=
162
163#
164# iterate through the backend common and specific include paths, include them into the current
165# makefile and append the sources held by the COMMON_TEST_SOURCES and BACKEND_TEST_SOURCES
166# (included from the given makefile) to the ARMNN_BACKEND_TEST_SOURCES list
167#
168$(foreach mkPath,$(ARMNN_BACKEND_COMMON_MAKEFILE_DIRS), \
169 $(eval include $(LOCAL_PATH)/$(mkPath)/common.mk) \
170 $(eval ARMNN_BACKEND_TEST_SOURCES := $(ARMNN_BACKEND_TEST_SOURCES) \
171 $(patsubst %,$(mkPath)/%,$(COMMON_TEST_SOURCES))))
172
173$(foreach mkPath,$(ARMNN_BACKEND_MAKEFILE_DIRS), \
174 $(eval include $(LOCAL_PATH)/$(mkPath)/backend.mk) \
175 $(eval ARMNN_BACKEND_TEST_SOURCES := $(ARMNN_BACKEND_TEST_SOURCES) \
176 $(patsubst %,$(mkPath)/%,$(BACKEND_TEST_SOURCES))))
177
telsoa01c577f2c2018-08-31 09:22:23 +0100178# Mark source files as dependent on Android.mk
179LOCAL_ADDITIONAL_DEPENDENCIES := $(LOCAL_PATH)/Android.mk
180
181LOCAL_C_INCLUDES := \
telsoa014fcda012018-03-09 14:13:49 +0000182 $(OPENCL_HEADER_PATH) \
183 $(NN_HEADER_PATH) \
184 $(ARMNN_HEADER_PATH) \
David Beck10b4dfd2018-09-19 12:03:20 +0100185 $(ARMNN_MAIN_HEADER_PATH) \
surmeh014c7098b2018-07-05 14:03:08 +0100186 $(ARMNN_SOURCE_HEADER_PATH) \
Aron Virginas-Tarc9cc8042018-11-01 16:15:57 +0000187 $(ARMNN_SOURCE_UTILS_HEADER_PATH) \
188 $(ARMNN_BACKENDS_HEADER_PATH)
telsoa014fcda012018-03-09 14:13:49 +0000189
190LOCAL_CFLAGS := \
191 -std=c++14 \
192 -fexceptions \
193 -frtti \
194 -isystem vendor/arm/android-nn-driver/boost_1_64_0 \
195 -DARMCOMPUTECL_ENABLED \
196 -DARMCOMPUTENEON_ENABLED
197
telsoa01c577f2c2018-08-31 09:22:23 +0100198LOCAL_SRC_FILES := \
Aron Virginas-Tarceae3aa2018-10-18 10:39:38 +0100199 $(ARMNN_BACKEND_TEST_SOURCES) \
telsoa014fcda012018-03-09 14:13:49 +0000200 src/armnn/test/UnitTests.cpp \
surmeh013537c2c2018-05-18 16:31:43 +0100201 src/armnn/test/EndToEndTest.cpp \
202 src/armnn/test/UtilsTests.cpp \
203 src/armnn/test/GraphTests.cpp \
204 src/armnn/test/RuntimeTests.cpp \
David Beckf98d21a2018-10-26 16:03:03 +0100205 src/armnn/test/SubGraphTests.cpp \
surmeh013537c2c2018-05-18 16:31:43 +0100206 src/armnn/test/TensorTest.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100207 src/armnn/test/NetworkTests.cpp \
208 src/armnn/test/InstrumentTests.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100209 src/armnn/test/ProfilingEventTest.cpp \
210 src/armnn/test/ObservableTest.cpp \
Aron Virginas-Tarceae3aa2018-10-18 10:39:38 +0100211 src/armnn/test/OptionalTest.cpp
telsoa014fcda012018-03-09 14:13:49 +0000212
213LOCAL_STATIC_LIBRARIES := \
214 libneuralnetworks_common \
telsoa014fcda012018-03-09 14:13:49 +0000215 libboost_log \
216 libboost_system \
217 libboost_unit_test_framework \
218 libboost_thread \
219 armnn-arm_compute
220
David Beck3cc9a622018-10-12 10:38:31 +0100221LOCAL_WHOLE_STATIC_LIBRARIES := libarmnn
222
telsoa01c577f2c2018-08-31 09:22:23 +0100223LOCAL_SHARED_LIBRARIES := \
telsoa014fcda012018-03-09 14:13:49 +0000224 libbase \
225 libhidlbase \
226 libhidltransport \
227 libhidlmemory \
228 liblog \
229 libutils \
230 android.hardware.neuralnetworks@1.0 \
231 android.hidl.allocator@1.0 \
232 android.hidl.memory@1.0 \
233 libOpenCL
234
telsoa014fcda012018-03-09 14:13:49 +0000235include $(BUILD_EXECUTABLE)