Release 18.02
[platform/upstream/armnn.git] / Android.bp
1 //
2 // Copyright © 2017 ARM Ltd. All rights reserved.
3 // See LICENSE file in the project root for full license information.
4 //
5
6 ////////////////////////////////////////////
7 //                                        //
8 //             libarmnn.a                 //
9 //                                        //
10 ////////////////////////////////////////////
11 cc_library_static {
12     name: "libarmnn",
13     export_include_dirs: ["include",
14                           "src/armnnUtils"],
15     local_include_dirs: ["src/armnn"],
16     srcs: [
17         "src/armnnUtils/Logging.cpp",
18         "src/armnnUtils/Permute.cpp",
19         "src/armnn/backends/ArmComputeTensorUtils.cpp",
20         "src/armnn/backends/ClWorkloads/ClActivationFloat32Workload.cpp",
21         "src/armnn/backends/ClWorkloads/ClActivationUint8Workload.cpp",
22         "src/armnn/backends/ClWorkloads/ClAdditionFloat32Workload.cpp",
23         "src/armnn/backends/ClWorkloads/ClBaseConstantWorkload.cpp",
24         "src/armnn/backends/ClWorkloads/ClBatchNormalizationFloat32Workload.cpp",
25         "src/armnn/backends/ClWorkloads/ClConstantFloat32Workload.cpp",
26         "src/armnn/backends/ClWorkloads/ClConstantUint8Workload.cpp",
27         "src/armnn/backends/ClWorkloads/ClConvolution2dFloat32Workload.cpp",
28         "src/armnn/backends/ClWorkloads/ClConvolution2dUint8Workload.cpp",
29         "src/armnn/backends/ClWorkloads/ClDepthwiseConvolutionFloat32Workload.cpp",
30         "src/armnn/backends/ClWorkloads/ClDepthwiseConvolutionUint8Workload.cpp",
31         "src/armnn/backends/ClWorkloads/ClFloorFloat32Workload.cpp",
32         "src/armnn/backends/ClWorkloads/ClFullyConnectedFloat32Workload.cpp",
33         "src/armnn/backends/ClWorkloads/ClL2NormalizationFloat32Workload.cpp",
34         "src/armnn/backends/ClWorkloads/ClMergerFloat32Workload.cpp",
35         "src/armnn/backends/ClWorkloads/ClMergerUint8Workload.cpp",
36         "src/armnn/backends/ClWorkloads/ClMultiplicationFloat32Workload.cpp",
37         "src/armnn/backends/ClWorkloads/ClNormalizationFloat32Workload.cpp",
38         "src/armnn/backends/ClWorkloads/ClPermuteWorkload.cpp",
39         "src/armnn/backends/ClWorkloads/ClPooling2dBaseWorkload.cpp",
40         "src/armnn/backends/ClWorkloads/ClPooling2dFloat32Workload.cpp",
41         "src/armnn/backends/ClWorkloads/ClPooling2dUint8Workload.cpp",
42         "src/armnn/backends/ClWorkloads/ClReshapeFloat32Workload.cpp",
43         "src/armnn/backends/ClWorkloads/ClReshapeUint8Workload.cpp",
44         "src/armnn/backends/ClWorkloads/ClResizeBilinearFloat32Workload.cpp",
45         "src/armnn/backends/ClWorkloads/ClSoftmaxFloat32Workload.cpp",
46         "src/armnn/backends/ClWorkloads/ClSoftmaxUint8Workload.cpp",
47         "src/armnn/backends/ClWorkloads/ClSplitterFloat32Workload.cpp",
48         "src/armnn/backends/ClWorkloads/ClSplitterUint8Workload.cpp",
49         "src/armnn/backends/NeonWorkloads/NeonActivationFloat32Workload.cpp",
50         "src/armnn/backends/NeonWorkloads/NeonActivationUint8Workload.cpp",
51         "src/armnn/backends/NeonWorkloads/NeonAdditionFloat32Workload.cpp",
52         "src/armnn/backends/NeonWorkloads/NeonBatchNormalizationFloat32Workload.cpp",
53         "src/armnn/backends/NeonWorkloads/NeonConstantFloat32Workload.cpp",
54         "src/armnn/backends/NeonWorkloads/NeonConstantUint8Workload.cpp",
55         "src/armnn/backends/NeonWorkloads/NeonConvolution2dBaseWorkload.cpp",
56         "src/armnn/backends/NeonWorkloads/NeonConvolution2dFloat32Workload.cpp",
57         "src/armnn/backends/NeonWorkloads/NeonDepthwiseConvolutionFloat32Workload.cpp",
58         "src/armnn/backends/NeonWorkloads/NeonDepthwiseConvolutionUint8Workload.cpp",
59         "src/armnn/backends/NeonWorkloads/NeonFloorFloat32Workload.cpp",
60         "src/armnn/backends/NeonWorkloads/NeonFullyConnectedFloat32Workload.cpp",
61         "src/armnn/backends/NeonWorkloads/NeonL2NormalizationFloat32Workload.cpp",
62         "src/armnn/backends/NeonWorkloads/NeonMergerFloat32Workload.cpp",
63         "src/armnn/backends/NeonWorkloads/NeonMergerUint8Workload.cpp",
64         "src/armnn/backends/NeonWorkloads/NeonMultiplicationFloat32Workload.cpp",
65         "src/armnn/backends/NeonWorkloads/NeonNormalizationFloat32Workload.cpp",
66         "src/armnn/backends/NeonWorkloads/NeonPermuteWorkload.cpp",
67         "src/armnn/backends/NeonWorkloads/NeonPooling2dBaseWorkload.cpp",
68         "src/armnn/backends/NeonWorkloads/NeonPooling2dFloat32Workload.cpp",
69         "src/armnn/backends/NeonWorkloads/NeonPooling2dUint8Workload.cpp",
70         "src/armnn/backends/NeonWorkloads/NeonReshapeFloat32Workload.cpp",
71         "src/armnn/backends/NeonWorkloads/NeonReshapeUint8Workload.cpp",
72         "src/armnn/backends/NeonWorkloads/NeonSoftmaxFloat32Workload.cpp",
73         "src/armnn/backends/NeonWorkloads/NeonSoftmaxUint8Workload.cpp",
74         "src/armnn/backends/NeonWorkloads/NeonSplitterFloat32Workload.cpp",
75         "src/armnn/backends/NeonWorkloads/NeonSplitterUint8Workload.cpp",
76         "src/armnn/backends/ClWorkloadFactory.cpp",
77         "src/armnn/backends/CpuTensorHandle.cpp",
78         "src/armnn/backends/RefWorkloadFactory.cpp",
79         "src/armnn/backends/RefWorkloads/RefMergerUint8Workload.cpp",
80         "src/armnn/backends/RefWorkloads/RefResizeBilinearUint8Workload.cpp",
81         "src/armnn/backends/RefWorkloads/FullyConnected.cpp",
82         "src/armnn/backends/RefWorkloads/RefFullyConnectedFloat32Workload.cpp",
83         "src/armnn/backends/RefWorkloads/RefSoftmaxFloat32Workload.cpp",
84         "src/armnn/backends/RefWorkloads/RefActivationFloat32Workload.cpp",
85         "src/armnn/backends/RefWorkloads/RefBatchNormalizationUint8Workload.cpp",
86         "src/armnn/backends/RefWorkloads/Multiplication.cpp",
87         "src/armnn/backends/RefWorkloads/RefMultiplicationUint8Workload.cpp",
88         "src/armnn/backends/RefWorkloads/RefBaseConstantWorkload.cpp",
89         "src/armnn/backends/RefWorkloads/RefAdditionUint8Workload.cpp",
90         "src/armnn/backends/RefWorkloads/RefResizeBilinearFloat32Workload.cpp",
91         "src/armnn/backends/RefWorkloads/RefBatchNormalizationFloat32Workload.cpp",
92         "src/armnn/backends/RefWorkloads/Broadcast.cpp",
93         "src/armnn/backends/RefWorkloads/Addition.cpp",
94         "src/armnn/backends/RefWorkloads/RefFakeQuantizationFloat32Workload.cpp",
95         "src/armnn/backends/RefWorkloads/ResizeBilinear.cpp",
96         "src/armnn/backends/RefWorkloads/RefSoftmaxUint8Workload.cpp",
97         "src/armnn/backends/RefWorkloads/RefDepthwiseConvolution2dFloat32Workload.cpp",
98         "src/armnn/backends/RefWorkloads/RefPooling2dUint8Workload.cpp",
99         "src/armnn/backends/RefWorkloads/RefFloorFloat32Workload.cpp",
100         "src/armnn/backends/RefWorkloads/ConvImpl.cpp",
101         "src/armnn/backends/RefWorkloads/Activation.cpp",
102         "src/armnn/backends/RefWorkloads/RefReshapeUint8Workload.cpp",
103         "src/armnn/backends/RefWorkloads/RefL2NormalizationFloat32Workload.cpp",
104         "src/armnn/backends/RefWorkloads/RefConvolution2dFloat32Workload.cpp",
105         "src/armnn/backends/RefWorkloads/RefConvolution2dUint8Workload.cpp",
106         "src/armnn/backends/RefWorkloads/RefSplitterFloat32Workload.cpp",
107         "src/armnn/backends/RefWorkloads/RefActivationUint8Workload.cpp",
108         "src/armnn/backends/RefWorkloads/RefSplitterUint8Workload.cpp",
109         "src/armnn/backends/RefWorkloads/RefPooling2dFloat32Workload.cpp",
110         "src/armnn/backends/RefWorkloads/RefMultiplicationFloat32Workload.cpp",
111         "src/armnn/backends/RefWorkloads/RefReshapeFloat32Workload.cpp",
112         "src/armnn/backends/RefWorkloads/RefNormalizationFloat32Workload.cpp",
113         "src/armnn/backends/RefWorkloads/Softmax.cpp",
114         "src/armnn/backends/RefWorkloads/RefDepthwiseConvolution2dUint8Workload.cpp",
115         "src/armnn/backends/RefWorkloads/RefConstantUint8Workload.cpp",
116         "src/armnn/backends/RefWorkloads/RefConstantFloat32Workload.cpp",
117         "src/armnn/backends/RefWorkloads/Pooling2d.cpp",
118         "src/armnn/backends/RefWorkloads/RefAdditionFloat32Workload.cpp",
119         "src/armnn/backends/RefWorkloads/RefMergerFloat32Workload.cpp",
120         "src/armnn/backends/RefWorkloads/RefFullyConnectedUint8Workload.cpp",
121         "src/armnn/backends/RefWorkloads/RefPermuteWorkload.cpp",
122         "src/armnn/backends/MemCopyWorkload.cpp",
123         "src/armnn/backends/WorkloadData.cpp",
124         "src/armnn/backends/WorkloadFactory.cpp",
125         "src/armnn/Descriptors.cpp",
126         "src/armnn/Exceptions.cpp",
127         "src/armnn/Graph.cpp",
128         "src/armnn/Optimizer.cpp",
129         "src/armnn/Runtime.cpp",
130         "src/armnn/InternalTypes.cpp",
131         "src/armnn/Layer.cpp",
132         "src/armnn/Layers.cpp",
133         "src/armnn/LoadedNetwork.cpp",
134         "src/armnn/Network.cpp",
135         "src/armnn/backends/OutputHandler.cpp",
136         "src/armnn/Profiling.cpp",
137         "src/armnn/Tensor.cpp",
138         "src/armnn/Utils.cpp",
139         "src/armnn/LayerSupport.cpp",
140         "src/armnn/backends/RefLayerSupport.cpp",
141         "src/armnn/backends/ClLayerSupport.cpp",
142         "src/armnn/backends/NeonLayerSupport.cpp",
143         "src/armnn/backends/NeonWorkloadUtils.cpp",
144         "src/armnn/backends/NeonWorkloadFactory.cpp"
145     ],
146     static_libs: [
147         "armnn-arm_compute",
148         "libboost_log",
149         "libboost_system",
150         "libboost_thread"],
151     stl: "libc++",
152     cppflags: [
153         "-fexceptions",
154         "-std=c++14",
155         "-DARMCOMPUTECL_ENABLED",
156         "-DARMCOMPUTENEON_ENABLED",
157         "-Wno-unused-parameter",
158     ],
159     rtti: true,
160 }