blob: e83000414f62a04437cbd78160fa46b655650be0 [file] [log] [blame]
telsoa014fcda012018-03-09 14:13:49 +00001#
2# Copyright © 2017 ARM Ltd. All rights reserved.
3# See LICENSE file in the project root for full license information.
4#
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
13ARMNN_SOURCE_HEADER_PATH := $(LOCAL_PATH)/src/armnn
surmeh014c7098b2018-07-05 14:03:08 +010014ARMNN_SOURCE_UTILS_HEADER_PATH := $(LOCAL_PATH)/src/armnnUtils
15
16##############
17# libarmnn.a #
18##############
19include $(CLEAR_VARS)
20
21LOCAL_MODULE := libarmnn
22LOCAL_MODULE_TAGS := eng optional
23LOCAL_ARM_MODE := arm
24LOCAL_PROPRIETARY_MODULE := true
25
26# Mark source files as dependent on Android.mk
27LOCAL_ADDITIONAL_DEPENDENCIES := $(LOCAL_PATH)/Android.mk
28
29LOCAL_EXPORT_C_INCLUDES := \
30 $(ARMNN_SOURCE_HEADER_PATH) \
31 $(ARMNN_SOURCE_UTILS_HEADER_PATH)
32
33LOCAL_C_INCLUDES := \
telsoa01c577f2c2018-08-31 09:22:23 +010034 $(OPENCL_HEADER_PATH) \
35 $(NN_HEADER_PATH) \
36 $(ARMNN_HEADER_PATH) \
37 $(ARMNN_SOURCE_HEADER_PATH) \
38 $(ARMNN_SOURCE_UTILS_HEADER_PATH)
surmeh014c7098b2018-07-05 14:03:08 +010039
40LOCAL_SRC_FILES := \
telsoa01c577f2c2018-08-31 09:22:23 +010041 src/armnnUtils/DotSerializer.cpp \
42 src/armnnUtils/FloatingPointConverter.cpp \
surmeh014c7098b2018-07-05 14:03:08 +010043 src/armnnUtils/Logging.cpp \
44 src/armnnUtils/Permute.cpp \
surmeh014c7098b2018-07-05 14:03:08 +010045 src/armnn/backends/ArmComputeTensorUtils.cpp \
46 src/armnn/backends/ClWorkloads/ClActivationFloat32Workload.cpp \
47 src/armnn/backends/ClWorkloads/ClActivationUint8Workload.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +010048 src/armnn/backends/ClWorkloads/ClAdditionBaseWorkload.cpp \
surmeh014c7098b2018-07-05 14:03:08 +010049 src/armnn/backends/ClWorkloads/ClAdditionFloat32Workload.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +010050 src/armnn/backends/ClWorkloads/ClAdditionUint8Workload.cpp \
surmeh014c7098b2018-07-05 14:03:08 +010051 src/armnn/backends/ClWorkloads/ClBaseConstantWorkload.cpp \
52 src/armnn/backends/ClWorkloads/ClBatchNormalizationFloat32Workload.cpp \
53 src/armnn/backends/ClWorkloads/ClConstantFloat32Workload.cpp \
54 src/armnn/backends/ClWorkloads/ClConstantUint8Workload.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +010055 src/armnn/backends/ClWorkloads/ClConvertFp16ToFp32Workload.cpp \
56 src/armnn/backends/ClWorkloads/ClConvertFp32ToFp16Workload.cpp \
surmeh014c7098b2018-07-05 14:03:08 +010057 src/armnn/backends/ClWorkloads/ClConvolution2dBaseWorkload.cpp \
58 src/armnn/backends/ClWorkloads/ClConvolution2dFloat32Workload.cpp \
59 src/armnn/backends/ClWorkloads/ClConvolution2dUint8Workload.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +010060 src/armnn/backends/ClWorkloads/ClDepthwiseConvolutionBaseWorkload.cpp \
surmeh014c7098b2018-07-05 14:03:08 +010061 src/armnn/backends/ClWorkloads/ClDepthwiseConvolutionFloat32Workload.cpp \
62 src/armnn/backends/ClWorkloads/ClDepthwiseConvolutionUint8Workload.cpp \
63 src/armnn/backends/ClWorkloads/ClFloorFloat32Workload.cpp \
64 src/armnn/backends/ClWorkloads/ClFullyConnectedFloat32Workload.cpp \
65 src/armnn/backends/ClWorkloads/ClL2NormalizationFloat32Workload.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +010066 src/armnn/backends/ClWorkloads/ClLstmFloat32Workload.cpp \
surmeh014c7098b2018-07-05 14:03:08 +010067 src/armnn/backends/ClWorkloads/ClMergerFloat32Workload.cpp \
68 src/armnn/backends/ClWorkloads/ClMergerUint8Workload.cpp \
69 src/armnn/backends/ClWorkloads/ClMultiplicationFloat32Workload.cpp \
70 src/armnn/backends/ClWorkloads/ClNormalizationFloat32Workload.cpp \
71 src/armnn/backends/ClWorkloads/ClPermuteWorkload.cpp \
72 src/armnn/backends/ClWorkloads/ClPooling2dBaseWorkload.cpp \
73 src/armnn/backends/ClWorkloads/ClPooling2dFloat32Workload.cpp \
74 src/armnn/backends/ClWorkloads/ClPooling2dUint8Workload.cpp \
75 src/armnn/backends/ClWorkloads/ClReshapeFloat32Workload.cpp \
76 src/armnn/backends/ClWorkloads/ClReshapeUint8Workload.cpp \
77 src/armnn/backends/ClWorkloads/ClResizeBilinearFloat32Workload.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +010078 src/armnn/backends/ClWorkloads/ClSoftmaxBaseWorkload.cpp \
surmeh014c7098b2018-07-05 14:03:08 +010079 src/armnn/backends/ClWorkloads/ClSoftmaxFloat32Workload.cpp \
80 src/armnn/backends/ClWorkloads/ClSoftmaxUint8Workload.cpp \
81 src/armnn/backends/ClWorkloads/ClSplitterFloat32Workload.cpp \
82 src/armnn/backends/ClWorkloads/ClSplitterUint8Workload.cpp \
83 src/armnn/backends/NeonWorkloads/NeonActivationFloat32Workload.cpp \
84 src/armnn/backends/NeonWorkloads/NeonActivationUint8Workload.cpp \
85 src/armnn/backends/NeonWorkloads/NeonAdditionFloat32Workload.cpp \
86 src/armnn/backends/NeonWorkloads/NeonBatchNormalizationFloat32Workload.cpp \
87 src/armnn/backends/NeonWorkloads/NeonConstantFloat32Workload.cpp \
88 src/armnn/backends/NeonWorkloads/NeonConstantUint8Workload.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +010089 src/armnn/backends/NeonWorkloads/NeonConvertFp16ToFp32Workload.cpp \
90 src/armnn/backends/NeonWorkloads/NeonConvertFp32ToFp16Workload.cpp \
surmeh014c7098b2018-07-05 14:03:08 +010091 src/armnn/backends/NeonWorkloads/NeonConvolution2dBaseWorkload.cpp \
92 src/armnn/backends/NeonWorkloads/NeonConvolution2dFloat32Workload.cpp \
93 src/armnn/backends/NeonWorkloads/NeonConvolution2dUint8Workload.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +010094 src/armnn/backends/NeonWorkloads/NeonDepthwiseConvolutionBaseWorkload.cpp \
surmeh014c7098b2018-07-05 14:03:08 +010095 src/armnn/backends/NeonWorkloads/NeonDepthwiseConvolutionFloat32Workload.cpp \
96 src/armnn/backends/NeonWorkloads/NeonDepthwiseConvolutionUint8Workload.cpp \
97 src/armnn/backends/NeonWorkloads/NeonFloorFloat32Workload.cpp \
98 src/armnn/backends/NeonWorkloads/NeonFullyConnectedFloat32Workload.cpp \
99 src/armnn/backends/NeonWorkloads/NeonL2NormalizationFloat32Workload.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100100 src/armnn/backends/NeonWorkloads/NeonLstmFloat32Workload.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100101 src/armnn/backends/NeonWorkloads/NeonMergerFloat32Workload.cpp \
102 src/armnn/backends/NeonWorkloads/NeonMergerUint8Workload.cpp \
103 src/armnn/backends/NeonWorkloads/NeonMultiplicationFloat32Workload.cpp \
104 src/armnn/backends/NeonWorkloads/NeonNormalizationFloat32Workload.cpp \
105 src/armnn/backends/NeonWorkloads/NeonPermuteWorkload.cpp \
106 src/armnn/backends/NeonWorkloads/NeonPooling2dBaseWorkload.cpp \
107 src/armnn/backends/NeonWorkloads/NeonPooling2dFloat32Workload.cpp \
108 src/armnn/backends/NeonWorkloads/NeonPooling2dUint8Workload.cpp \
109 src/armnn/backends/NeonWorkloads/NeonReshapeFloat32Workload.cpp \
110 src/armnn/backends/NeonWorkloads/NeonReshapeUint8Workload.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100111 src/armnn/backends/NeonWorkloads/NeonSoftmaxBaseWorkload.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100112 src/armnn/backends/NeonWorkloads/NeonSoftmaxFloat32Workload.cpp \
113 src/armnn/backends/NeonWorkloads/NeonSoftmaxUint8Workload.cpp \
114 src/armnn/backends/NeonWorkloads/NeonSplitterFloat32Workload.cpp \
115 src/armnn/backends/NeonWorkloads/NeonSplitterUint8Workload.cpp \
116 src/armnn/backends/ClWorkloadFactory.cpp \
117 src/armnn/backends/ClContextControl.cpp \
118 src/armnn/backends/CpuTensorHandle.cpp \
119 src/armnn/backends/RefWorkloadFactory.cpp \
120 src/armnn/backends/RefWorkloads/RefMergerUint8Workload.cpp \
121 src/armnn/backends/RefWorkloads/RefResizeBilinearUint8Workload.cpp \
122 src/armnn/backends/RefWorkloads/FullyConnected.cpp \
123 src/armnn/backends/RefWorkloads/RefFullyConnectedFloat32Workload.cpp \
124 src/armnn/backends/RefWorkloads/RefSoftmaxFloat32Workload.cpp \
125 src/armnn/backends/RefWorkloads/RefActivationFloat32Workload.cpp \
126 src/armnn/backends/RefWorkloads/RefBatchNormalizationUint8Workload.cpp \
127 src/armnn/backends/RefWorkloads/Multiplication.cpp \
128 src/armnn/backends/RefWorkloads/RefMultiplicationUint8Workload.cpp \
129 src/armnn/backends/RefWorkloads/RefBaseConstantWorkload.cpp \
130 src/armnn/backends/RefWorkloads/RefAdditionUint8Workload.cpp \
131 src/armnn/backends/RefWorkloads/RefResizeBilinearFloat32Workload.cpp \
132 src/armnn/backends/RefWorkloads/RefBatchNormalizationFloat32Workload.cpp \
133 src/armnn/backends/RefWorkloads/Broadcast.cpp \
134 src/armnn/backends/RefWorkloads/Addition.cpp \
135 src/armnn/backends/RefWorkloads/RefFakeQuantizationFloat32Workload.cpp \
136 src/armnn/backends/RefWorkloads/ResizeBilinear.cpp \
137 src/armnn/backends/RefWorkloads/RefSoftmaxUint8Workload.cpp \
138 src/armnn/backends/RefWorkloads/RefDepthwiseConvolution2dFloat32Workload.cpp \
139 src/armnn/backends/RefWorkloads/RefPooling2dUint8Workload.cpp \
140 src/armnn/backends/RefWorkloads/RefFloorFloat32Workload.cpp \
141 src/armnn/backends/RefWorkloads/ConvImpl.cpp \
142 src/armnn/backends/RefWorkloads/Activation.cpp \
143 src/armnn/backends/RefWorkloads/RefReshapeUint8Workload.cpp \
144 src/armnn/backends/RefWorkloads/RefL2NormalizationFloat32Workload.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100145 src/armnn/backends/RefWorkloads/RefLstmFloat32Workload.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100146 src/armnn/backends/RefWorkloads/RefConvolution2dFloat32Workload.cpp \
147 src/armnn/backends/RefWorkloads/RefConvolution2dUint8Workload.cpp \
148 src/armnn/backends/RefWorkloads/RefSplitterFloat32Workload.cpp \
149 src/armnn/backends/RefWorkloads/RefActivationUint8Workload.cpp \
150 src/armnn/backends/RefWorkloads/RefSplitterUint8Workload.cpp \
151 src/armnn/backends/RefWorkloads/RefPooling2dFloat32Workload.cpp \
152 src/armnn/backends/RefWorkloads/RefMultiplicationFloat32Workload.cpp \
153 src/armnn/backends/RefWorkloads/RefReshapeFloat32Workload.cpp \
154 src/armnn/backends/RefWorkloads/RefNormalizationFloat32Workload.cpp \
155 src/armnn/backends/RefWorkloads/Softmax.cpp \
156 src/armnn/backends/RefWorkloads/RefDepthwiseConvolution2dUint8Workload.cpp \
157 src/armnn/backends/RefWorkloads/RefConstantUint8Workload.cpp \
158 src/armnn/backends/RefWorkloads/RefConstantFloat32Workload.cpp \
159 src/armnn/backends/RefWorkloads/Pooling2d.cpp \
160 src/armnn/backends/RefWorkloads/RefAdditionFloat32Workload.cpp \
161 src/armnn/backends/RefWorkloads/RefMergerFloat32Workload.cpp \
162 src/armnn/backends/RefWorkloads/RefFullyConnectedUint8Workload.cpp \
163 src/armnn/backends/RefWorkloads/RefPermuteWorkload.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100164 src/armnn/backends/RefWorkloads/RefConvertFp16ToFp32Workload.cpp \
165 src/armnn/backends/RefWorkloads/RefConvertFp32ToFp16Workload.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100166 src/armnn/backends/MemCopyWorkload.cpp \
167 src/armnn/backends/WorkloadData.cpp \
168 src/armnn/backends/WorkloadFactory.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100169 src/armnn/layers/ActivationLayer.cpp \
170 src/armnn/layers/AdditionLayer.cpp \
171 src/armnn/layers/BatchNormalizationLayer.cpp \
172 src/armnn/layers/ConstantLayer.cpp \
173 src/armnn/layers/Convolution2dLayer.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100174 src/armnn/layers/ConvertFp16ToFp32Layer.cpp \
175 src/armnn/layers/ConvertFp32ToFp16Layer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100176 src/armnn/layers/DepthwiseConvolution2dLayer.cpp \
177 src/armnn/layers/FakeQuantizationLayer.cpp \
178 src/armnn/layers/FloorLayer.cpp \
179 src/armnn/layers/FullyConnectedLayer.cpp \
180 src/armnn/layers/InputLayer.cpp \
181 src/armnn/layers/L2NormalizationLayer.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100182 src/armnn/layers/LstmLayer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100183 src/armnn/layers/MemCopyLayer.cpp \
184 src/armnn/layers/MergerLayer.cpp \
185 src/armnn/layers/MultiplicationLayer.cpp \
186 src/armnn/layers/NormalizationLayer.cpp \
187 src/armnn/layers/OutputLayer.cpp \
188 src/armnn/layers/PermuteLayer.cpp \
189 src/armnn/layers/Pooling2dLayer.cpp \
190 src/armnn/layers/ReshapeLayer.cpp \
191 src/armnn/layers/ResizeBilinearLayer.cpp \
192 src/armnn/layers/SoftmaxLayer.cpp \
193 src/armnn/layers/SplitterLayer.cpp \
194 src/armnn/Descriptors.cpp \
195 src/armnn/Exceptions.cpp \
196 src/armnn/Graph.cpp \
197 src/armnn/Optimizer.cpp \
198 src/armnn/Runtime.cpp \
199 src/armnn/SerializeLayerParameters.cpp \
200 src/armnn/InternalTypes.cpp \
201 src/armnn/Layer.cpp \
202 src/armnn/LoadedNetwork.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100203 src/armnn/NeonInterceptorScheduler.cpp \
204 src/armnn/NeonTimer.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100205 src/armnn/Network.cpp \
206 src/armnn/backends/OutputHandler.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100207 src/armnn/OpenClTimer.cpp \
208 src/armnn/WallClockTimer.cpp \
209 src/armnn/ProfilingEvent.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100210 src/armnn/Profiling.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100211 src/armnn/JsonPrinter.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100212 src/armnn/Tensor.cpp \
213 src/armnn/Utils.cpp \
214 src/armnn/LayerSupport.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100215 src/armnn/Observable.cpp \
surmeh014c7098b2018-07-05 14:03:08 +0100216 src/armnn/backends/RefLayerSupport.cpp \
217 src/armnn/backends/ClLayerSupport.cpp \
218 src/armnn/backends/NeonLayerSupport.cpp \
219 src/armnn/backends/NeonWorkloadUtils.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100220 src/armnn/backends/NeonWorkloadFactory.cpp \
221 src/armnn/memory/BaseMemoryManager.cpp \
222 src/armnn/memory/BlobLifetimeManager.cpp \
223 src/armnn/memory/BlobMemoryPool.cpp \
224 src/armnn/memory/OffsetLifetimeManager.cpp \
225 src/armnn/memory/OffsetMemoryPool.cpp \
226 src/armnn/memory/PoolManager.cpp
surmeh014c7098b2018-07-05 14:03:08 +0100227
228LOCAL_STATIC_LIBRARIES := \
telsoa01c577f2c2018-08-31 09:22:23 +0100229 armnn-arm_compute \
surmeh014c7098b2018-07-05 14:03:08 +0100230 libboost_log \
231 libboost_system \
232 libboost_thread
233
234LOCAL_SHARED_LIBRARIES := \
235 liblog
236
237LOCAL_CFLAGS := \
238 -std=c++14 \
239 -fexceptions \
240 -DARMCOMPUTECL_ENABLED \
241 -DARMCOMPUTENEON_ENABLED \
242 -Wno-unused-parameter \
243 -frtti
244
245include $(BUILD_STATIC_LIBRARY)
telsoa014fcda012018-03-09 14:13:49 +0000246
telsoa01c577f2c2018-08-31 09:22:23 +0100247###############
248# armnn-tests #
249###############
telsoa014fcda012018-03-09 14:13:49 +0000250include $(CLEAR_VARS)
251
telsoa01c577f2c2018-08-31 09:22:23 +0100252LOCAL_MODULE := armnn-tests
253LOCAL_MODULE_TAGS := eng optional
254LOCAL_ARM_MODE := arm
255LOCAL_PROPRIETARY_MODULE := true
256
257# Mark source files as dependent on Android.mk
258LOCAL_ADDITIONAL_DEPENDENCIES := $(LOCAL_PATH)/Android.mk
259
260LOCAL_C_INCLUDES := \
telsoa014fcda012018-03-09 14:13:49 +0000261 $(OPENCL_HEADER_PATH) \
262 $(NN_HEADER_PATH) \
263 $(ARMNN_HEADER_PATH) \
surmeh014c7098b2018-07-05 14:03:08 +0100264 $(ARMNN_SOURCE_HEADER_PATH) \
265 $(ARMNN_SOURCE_UTILS_HEADER_PATH)
telsoa014fcda012018-03-09 14:13:49 +0000266
267LOCAL_CFLAGS := \
268 -std=c++14 \
269 -fexceptions \
270 -frtti \
271 -isystem vendor/arm/android-nn-driver/boost_1_64_0 \
272 -DARMCOMPUTECL_ENABLED \
273 -DARMCOMPUTENEON_ENABLED
274
telsoa01c577f2c2018-08-31 09:22:23 +0100275LOCAL_SRC_FILES := \
telsoa014fcda012018-03-09 14:13:49 +0000276 src/armnn/test/UnitTests.cpp \
surmeh013537c2c2018-05-18 16:31:43 +0100277 src/armnn/test/EndToEndTest.cpp \
278 src/armnn/test/UtilsTests.cpp \
279 src/armnn/test/GraphTests.cpp \
280 src/armnn/test/RuntimeTests.cpp \
281 src/armnn/test/TensorTest.cpp \
telsoa01c577f2c2018-08-31 09:22:23 +0100282 src/armnn/test/NeonTimerTest.cpp \
283 src/armnn/test/NetworkTests.cpp \
284 src/armnn/test/InstrumentTests.cpp \
285 src/armnn/test/OpenClTimerTest.cpp \
286 src/armnn/test/ProfilingEventTest.cpp \
287 src/armnn/test/ObservableTest.cpp \
surmeh013537c2c2018-05-18 16:31:43 +0100288 src/armnn/backends/test/IsLayerSupportedTest.cpp \
289 src/armnn/backends/test/Reference.cpp \
290 src/armnn/backends/test/WorkloadDataValidation.cpp \
291 src/armnn/backends/test/TensorCopyUtils.cpp \
292 src/armnn/backends/test/LayerTests.cpp \
293 src/armnn/backends/test/CreateWorkloadRef.cpp \
telsoa014fcda012018-03-09 14:13:49 +0000294 src/armnn/backends/test/ArmComputeCl.cpp \
295 src/armnn/backends/test/ArmComputeNeon.cpp \
296 src/armnn/backends/test/CreateWorkloadCl.cpp \
297 src/armnn/backends/test/CreateWorkloadNeon.cpp \
298 src/armnn/backends/test/MemCopyTests.cpp
299
300LOCAL_STATIC_LIBRARIES := \
301 libneuralnetworks_common \
302 libarmnn \
303 libboost_log \
304 libboost_system \
305 libboost_unit_test_framework \
306 libboost_thread \
307 armnn-arm_compute
308
telsoa01c577f2c2018-08-31 09:22:23 +0100309LOCAL_SHARED_LIBRARIES := \
telsoa014fcda012018-03-09 14:13:49 +0000310 libbase \
311 libhidlbase \
312 libhidltransport \
313 libhidlmemory \
314 liblog \
315 libutils \
316 android.hardware.neuralnetworks@1.0 \
317 android.hidl.allocator@1.0 \
318 android.hidl.memory@1.0 \
319 libOpenCL
320
telsoa014fcda012018-03-09 14:13:49 +0000321include $(BUILD_EXECUTABLE)
322