blob: cf9c99e208afcc4ce8428e3dbe9e8785e911072b [file] [log] [blame]
Georgios Pinitas41984a02019-12-11 12:05:17 +00001//
Pablo Marquez Tellof113f372021-07-20 14:03:42 +01002// Copyright © 2020-2021 Arm Ltd. All rights reserved.
Georgios Pinitas41984a02019-12-11 12:05:17 +00003// SPDX-License-Identifier: MIT
4//
5
6package arm_compute_library_nn_driver
7
8import (
9 "android/soong/android"
10 "android/soong/cc"
Michele Di Giorgiof0a4e602020-10-15 11:54:17 +010011 "strings"
Georgios Pinitas41984a02019-12-11 12:05:17 +000012)
13
14func globalFlags(ctx android.BaseContext) []string {
15 var cppflags []string
16
Pablo Marquez Tello6fc7d522021-07-13 11:09:47 +010017 if ctx.AConfig().PlatformVersionName() == "Q" || ctx.AConfig().PlatformVersionName() == "10" ||
Teresa Charlin65d04482021-02-12 12:29:26 +000018 ctx.AConfig().PlatformVersionName() == "R" || ctx.AConfig().PlatformVersionName() == "11" ||
19 ctx.AConfig().PlatformVersionName() == "S" || ctx.AConfig().PlatformVersionName() == "12" {
Georgios Pinitasfec13b82020-02-26 16:11:32 +000020 cppflags = append(cppflags, "-fno-addrsig")
21 }
22
Pablo Marquez Tellodae5e1e2021-07-22 15:07:54 +010023 if ctx.AConfig().PlatformVersionName() == "R" || ctx.AConfig().PlatformVersionName() == "11" {
24 if ctx.AConfig().Targets[Android][0].Arch.ArchType.String() == "armv8-2a" {
Pablo Marquez Tellof113f372021-07-20 14:03:42 +010025 cppflags = append(cppflags, "-march=armv8.2-a+fp16")
26 }
27 }
Pablo Marquez Tello6fc7d522021-07-13 11:09:47 +010028
Michele Di Giorgiof0a4e602020-10-15 11:54:17 +010029 data_types := strings.Split(ctx.AConfig().GetenvWithDefault("COMPUTE_LIB_DATA_TYPE", "ALL"), ",")
30
31 for _, x := range data_types {
Michalis Spyroue9aaacd2021-01-14 13:24:05 +000032 if strings.ToUpper(x) == "ALL" || strings.ToUpper(x) == "INTEGER" {
33 cppflags = append(cppflags, "-DENABLE_INTEGER_KERNELS")
34 }
Michalis Spyrouc4d45552020-10-19 12:41:30 +010035 if strings.ToUpper(x) == "ALL" || strings.ToUpper(x) == "QASYMM8" {
36 cppflags = append(cppflags, "-DENABLE_QASYMM8_KERNELS")
37 }
38 if strings.ToUpper(x) == "ALL" || strings.ToUpper(x) == "QASYMM8_SIGNED" {
39 cppflags = append(cppflags, "-DENABLE_QASYMM8_SIGNED_KERNELS")
40 }
41 if strings.ToUpper(x) == "ALL" || strings.ToUpper(x) == "QASYMM16" {
42 cppflags = append(cppflags, "-DENABLE_QASYMM16_KERNELS")
43 }
Michalis Spyroue5a41282020-11-03 17:00:04 +000044 if strings.ToUpper(x) == "ALL" || strings.ToUpper(x) == "QSYMM16" {
45 cppflags = append(cppflags, "-DENABLE_QSYMM16_KERNELS")
46 }
Michele Di Giorgiof0a4e602020-10-15 11:54:17 +010047 if strings.ToUpper(x) == "ALL" || strings.ToUpper(x) == "FP16" {
48 cppflags = append(cppflags, "-DENABLE_FP16_KERNELS")
49 }
50 if strings.ToUpper(x) == "ALL" || strings.ToUpper(x) == "FP32" {
51 cppflags = append(cppflags, "-DENABLE_FP32_KERNELS")
52 }
53 }
54
Sheri Zhang79144a62021-02-08 17:43:04 +000055 data_layouts := strings.Split(ctx.AConfig().GetenvWithDefault("COMPUTE_LIB_DATA_LAYOUT", "ALL"), ",")
56
57 for _, x := range data_layouts {
58 if strings.ToUpper(x) == "ALL" || strings.ToUpper(x) == "NHWC" {
59 cppflags = append(cppflags, "-DENABLE_NHWC_KERNELS")
60 }
61 if strings.ToUpper(x) == "ALL" || strings.ToUpper(x) == "NCHW" {
62 cppflags = append(cppflags, "-DENABLE_NCHW_KERNELS")
63 }
64 }
65
Georgios Pinitas8a5146f2021-01-12 15:51:07 +000066 cppflags = append(cppflags, "-ARM_COMPUTE_CPU_ENABLED")
67 cppflags = append(cppflags, "-ARM_COMPUTE_OPENCL_ENABLED")
68
Georgios Pinitas41984a02019-12-11 12:05:17 +000069 return cppflags
70}
71
72func clframeworkNNDriverDefaults(ctx android.LoadHookContext) {
73 type props struct {
74 Cppflags []string
75 }
76
77 p := &props{}
78 p.Cppflags = globalFlags(ctx)
79
80 ctx.AppendProperties(p)
81}
82
83func init() {
84
85 android.RegisterModuleType("arm_compute_library_defaults", clframeworkNNDriverDefaultsFactory)
86}
87
88func clframeworkNNDriverDefaultsFactory() android.Module {
89
90 module := cc.DefaultsFactory()
91 android.AddLoadHook(module, clframeworkNNDriverDefaults)
92 return module
93}