blob: 2f883279f0bac96efa1d6a336182fff0caae3d26 [file] [log] [blame]
Colin Crossd00350c2017-11-17 10:55:38 -08001// Copyright 2017 Google Inc. All rights reserved.
2//
3// Licensed under the Apache License, Version 2.0 (the "License");
4// you may not use this file except in compliance with the License.
5// You may obtain a copy of the License at
6//
7// http://www.apache.org/licenses/LICENSE-2.0
8//
9// Unless required by applicable law or agreed to in writing, software
10// distributed under the License is distributed on an "AS IS" BASIS,
11// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12// See the License for the specific language governing permissions and
13// limitations under the License.
14
Colin Crossb98c8b02016-07-29 13:44:28 -070015package config
Colin Cross3f40fa42015-01-30 17:27:36 -080016
17import (
Dan Albertd12afec2020-08-14 16:53:21 -070018 "android/soong/android"
Colin Cross3f40fa42015-01-30 17:27:36 -080019 "sort"
20 "strings"
21)
22
23// Cflags that should be filtered out when compiling with clang
Colin Crossb98c8b02016-07-29 13:44:28 -070024var ClangUnknownCflags = sorted([]string{
Colin Cross3f40fa42015-01-30 17:27:36 -080025 "-finline-functions",
26 "-finline-limit=64",
27 "-fno-canonical-system-headers",
Dan Willemsen3bf6b472015-09-11 17:41:10 -070028 "-Wno-clobbered",
29 "-fno-devirtualize",
Colin Cross3f40fa42015-01-30 17:27:36 -080030 "-fno-tree-sra",
Colin Crossa360e8b2015-03-16 16:22:28 -070031 "-fprefetch-loop-arrays",
Colin Cross3f40fa42015-01-30 17:27:36 -080032 "-funswitch-loops",
Dan Willemsene8c52372016-05-19 16:57:11 -070033 "-Werror=unused-but-set-parameter",
34 "-Werror=unused-but-set-variable",
Colin Cross3f40fa42015-01-30 17:27:36 -080035 "-Wmaybe-uninitialized",
Dan Willemsen3bf6b472015-09-11 17:41:10 -070036 "-Wno-error=clobbered",
Colin Cross3f40fa42015-01-30 17:27:36 -080037 "-Wno-error=maybe-uninitialized",
Colin Cross74d1ec02015-04-28 13:30:13 -070038 "-Wno-error=unused-but-set-parameter",
39 "-Wno-error=unused-but-set-variable",
Chih-Hung Hsieh3ede2942018-01-10 14:30:44 -080040 "-Wno-extended-offsetof",
Colin Cross3f40fa42015-01-30 17:27:36 -080041 "-Wno-free-nonheap-object",
42 "-Wno-literal-suffix",
43 "-Wno-maybe-uninitialized",
44 "-Wno-old-style-declaration",
Colin Cross3f40fa42015-01-30 17:27:36 -080045 "-Wno-unused-but-set-parameter",
Colin Cross74d1ec02015-04-28 13:30:13 -070046 "-Wno-unused-but-set-variable",
Colin Cross3f40fa42015-01-30 17:27:36 -080047 "-Wno-unused-local-typedefs",
Colin Cross62ec5f42015-03-18 17:20:28 -070048 "-Wunused-but-set-parameter",
Colin Cross74d1ec02015-04-28 13:30:13 -070049 "-Wunused-but-set-variable",
Dan Willemsene6540452015-10-20 15:21:33 -070050 "-fdiagnostics-color",
Yabin Cui8ec05ff2020-04-10 13:36:41 -070051 // http://b/153759688
52 "-fuse-init-array",
Colin Cross3f40fa42015-01-30 17:27:36 -080053
Elliott Hughesda3a0712020-03-06 16:55:28 -080054 // arm + arm64
Colin Cross3f40fa42015-01-30 17:27:36 -080055 "-fgcse-after-reload",
56 "-frerun-cse-after-loop",
57 "-frename-registers",
58 "-fno-strict-volatile-bitfields",
59
60 // arm + arm64
61 "-fno-align-jumps",
Colin Cross3f40fa42015-01-30 17:27:36 -080062
63 // arm
64 "-mthumb-interwork",
65 "-fno-builtin-sin",
66 "-fno-caller-saves",
67 "-fno-early-inlining",
68 "-fno-move-loop-invariants",
69 "-fno-partial-inlining",
70 "-fno-tree-copy-prop",
71 "-fno-tree-loop-optimize",
72
Colin Cross3f40fa42015-01-30 17:27:36 -080073 // x86 + x86_64
74 "-finline-limit=300",
75 "-fno-inline-functions-called-once",
76 "-mfpmath=sse",
77 "-mbionic",
Dan Willemsen01f388c2017-11-30 13:31:26 -080078
79 // windows
80 "--enable-stdcall-fixup",
Dan Willemsene6540452015-10-20 15:21:33 -070081})
Colin Cross3f40fa42015-01-30 17:27:36 -080082
Chih-Hung Hsieh1017b372018-12-06 12:12:41 -080083var ClangLibToolingUnknownCflags = sorted([]string{})
Jayant Chowdhary9677e8c2017-06-15 14:45:18 -070084
Dan Albertd12afec2020-08-14 16:53:21 -070085// List of tidy checks that should be disabled globally. When the compiler is
86// updated, some checks enabled by this module may be disabled if they have
87// become more strict, or if they are a new match for a wildcard group like
88// `modernize-*`.
Stephen Hines2210e722020-07-15 11:11:57 -070089var ClangTidyDisableChecks = []string{
90 "misc-no-recursion",
Yabin Cuidb7dda82020-11-30 15:47:45 -080091 "readability-function-cognitive-complexity", // http://b/175055536
Stephen Hines2210e722020-07-15 11:11:57 -070092}
Dan Albertd12afec2020-08-14 16:53:21 -070093
Colin Cross3f40fa42015-01-30 17:27:36 -080094func init() {
Jingwen Chen51a1e1c2021-05-20 13:40:14 +000095 exportStringListStaticVariable("ClangExtraCflags", []string{
Colin Cross3f40fa42015-01-30 17:27:36 -080096 "-D__compiler_offsetof=__builtin_offsetof",
97
Yi Kong1b0ba942019-03-19 20:05:05 -070098 // Emit address-significance table which allows linker to perform safe ICF. Clang does
99 // not emit the table by default on Android since NDK still uses GNU binutils.
100 "-faddrsig",
101
Stephen Hines2210e722020-07-15 11:11:57 -0700102 // Turn on -fcommon explicitly, since Clang now defaults to -fno-common. The cleanup bug
103 // tracking this is http://b/151457797.
104 "-fcommon",
105
Colin Cross3f40fa42015-01-30 17:27:36 -0800106 // Help catch common 32/64-bit errors.
107 "-Werror=int-conversion",
108
Yi Kong2fc32482019-04-22 22:33:23 -0700109 // Enable the new pass manager.
110 "-fexperimental-new-pass-manager",
111
Colin Cross74d1ec02015-04-28 13:30:13 -0700112 // Disable overly aggressive warning for macros defined with a leading underscore
113 // This happens in AndroidConfig.h, which is included nearly everywhere.
Dan Willemsen3bf6b472015-09-11 17:41:10 -0700114 // TODO: can we remove this now?
Colin Cross74d1ec02015-04-28 13:30:13 -0700115 "-Wno-reserved-id-macro",
116
Colin Cross3f40fa42015-01-30 17:27:36 -0800117 // Workaround for ccache with clang.
118 // See http://petereisentraut.blogspot.com/2011/05/ccache-and-clang.html.
119 "-Wno-unused-command-line-argument",
120
Dan Willemsene6540452015-10-20 15:21:33 -0700121 // Force clang to always output color diagnostics. Ninja will strip the ANSI
122 // color codes if it is not running in a terminal.
123 "-fcolor-diagnostics",
Pirama Arumuga Nainarb6572b12016-06-28 10:56:03 -0700124
Chih-Hung Hsieh3ede2942018-01-10 14:30:44 -0800125 // Warnings from clang-7.0
Chih-Hung Hsieh3ede2942018-01-10 14:30:44 -0800126 "-Wno-sign-compare",
Yi Kong53ed59e2018-10-30 15:31:38 -0700127
128 // Warnings from clang-8.0
129 "-Wno-defaulted-function-deleted",
Colin Cross3f40fa42015-01-30 17:27:36 -0800130
Dan Willemsenac5e1cb2016-01-12 16:22:40 -0800131 // Disable -Winconsistent-missing-override until we can clean up the existing
132 // codebase for it.
133 "-Wno-inconsistent-missing-override",
Nick Desaulnierseb207442019-12-12 10:15:42 -0800134
135 // Warnings from clang-10
136 // Nested and array designated initialization is nice to have.
137 "-Wno-c99-designator",
Jiyong Park423e3782020-08-11 09:35:08 +0900138
Chih-Hung Hsieh72e88762021-02-03 17:52:16 -0800139 // Warnings from clang-12
140 "-Wno-gnu-folding-constant",
141
Jiyong Park423e3782020-08-11 09:35:08 +0900142 // Calls to the APIs that are newer than the min sdk version of the caller should be
143 // guarded with __builtin_available.
144 "-Wunguarded-availability",
145 // This macro allows the bionic versioning.h to indirectly determine whether the
146 // option -Wunguarded-availability is on or not.
Elliott Hughes5add0c62021-02-11 13:20:42 -0800147 "-D__ANDROID_UNAVAILABLE_SYMBOLS_ARE_WEAK__",
Jingwen Chenbf61afb2021-05-06 13:31:18 +0000148 })
Pirama Arumuga Nainarb6572b12016-06-28 10:56:03 -0700149
Jingwen Chen51a1e1c2021-05-20 13:40:14 +0000150 exportStringListStaticVariable("ClangExtraCppflags", []string{
Nick Desaulniers4e31fb82019-10-30 13:55:26 -0700151 // -Wimplicit-fallthrough is not enabled by -Wall.
152 "-Wimplicit-fallthrough",
153
Josh Gaoe0b933b2017-04-26 20:26:14 -0700154 // Enable clang's thread-safety annotations in libcxx.
Josh Gaoe0b933b2017-04-26 20:26:14 -0700155 "-D_LIBCPP_ENABLE_THREAD_SAFETY_ANNOTATIONS",
Dan Albertf2ceea72018-02-07 17:24:42 -0800156
157 // libc++'s math.h has an #include_next outside of system_headers.
158 "-Wno-gnu-include-next",
Jingwen Chenbf61afb2021-05-06 13:31:18 +0000159 })
Dan Willemsenac5e1cb2016-01-12 16:22:40 -0800160
Jingwen Chen51a1e1c2021-05-20 13:40:14 +0000161 exportStringListStaticVariable("ClangExtraTargetCflags", []string{"-nostdlibinc"})
Dan Willemsenbe03f342016-03-03 17:21:04 -0800162
Jingwen Chen51a1e1c2021-05-20 13:40:14 +0000163 exportStringListStaticVariable("ClangExtraNoOverrideCflags", []string{
Dan Willemsenbe03f342016-03-03 17:21:04 -0800164 "-Werror=address-of-temporary",
Pirama Arumuga Nainarb6572b12016-06-28 10:56:03 -0700165 // Bug: http://b/29823425 Disable -Wnull-dereference until the
166 // new cases detected by this warning in Clang r271374 are
167 // fixed.
168 //"-Werror=null-dereference",
Dan Willemsenbe03f342016-03-03 17:21:04 -0800169 "-Werror=return-type",
Yi Kong599a6032017-12-06 19:56:34 -0800170
171 // http://b/72331526 Disable -Wtautological-* until the instances detected by these
172 // new warnings are fixed.
Stephen Hinesa42e0a02018-02-06 14:49:42 -0800173 "-Wno-tautological-constant-compare",
Chih-Hung Hsieh3ede2942018-01-10 14:30:44 -0800174 "-Wno-tautological-type-limit-compare",
Nick Desaulnierseb207442019-12-12 10:15:42 -0800175 // http://b/145210666
176 "-Wno-reorder-init-list",
177 // http://b/145211066
178 "-Wno-implicit-int-float-conversion",
Chih-Hung Hsieh9d9555e2020-02-10 19:01:14 -0800179 // New warnings to be fixed after clang-r377782.
Chih-Hung Hsieh5f78d552020-02-14 10:10:22 -0800180 "-Wno-int-in-bool-context", // http://b/148287349
181 "-Wno-sizeof-array-div", // http://b/148815709
182 "-Wno-tautological-overlap-compare", // http://b/148815696
Yabin Cui8ec05ff2020-04-10 13:36:41 -0700183 // New warnings to be fixed after clang-r383902.
184 "-Wno-deprecated-copy", // http://b/153746672
185 "-Wno-range-loop-construct", // http://b/153747076
186 "-Wno-misleading-indentation", // http://b/153746954
187 "-Wno-zero-as-null-pointer-constant", // http://b/68236239
188 "-Wno-deprecated-anon-enum-enum-conversion", // http://b/153746485
189 "-Wno-deprecated-enum-enum-conversion", // http://b/153746563
190 "-Wno-string-compare", // http://b/153764102
191 "-Wno-enum-enum-conversion", // http://b/154138986
192 "-Wno-enum-float-conversion", // http://b/154255917
193 "-Wno-pessimizing-move", // http://b/154270751
Stephen Hines2210e722020-07-15 11:11:57 -0700194 // New warnings to be fixed after clang-r399163
195 "-Wno-non-c-typedef-for-linkage", // http://b/161304145
Yabin Cuidb7dda82020-11-30 15:47:45 -0800196 // New warnings to be fixed after clang-r407598
197 "-Wno-string-concatenation", // http://b/175068488
Jingwen Chenbf61afb2021-05-06 13:31:18 +0000198 })
Yi Kongcc80f8d2018-06-06 14:42:44 -0700199
Yi Kong950e0ba2019-10-08 02:27:17 -0700200 // Extra cflags for external third-party projects to disable warnings that
201 // are infeasible to fix in all the external projects and their upstream repos.
Jingwen Chen51a1e1c2021-05-20 13:40:14 +0000202 exportStringListStaticVariable("ClangExtraExternalCflags", []string{
Yi Kongcf4cbdd2018-06-29 20:20:38 +0000203 "-Wno-enum-compare",
204 "-Wno-enum-compare-switch",
Yi Kong3e88cb02018-12-13 03:55:29 -0800205
206 // http://b/72331524 Allow null pointer arithmetic until the instances detected by
207 // this new warning are fixed.
208 "-Wno-null-pointer-arithmetic",
Yi Kongfae5dac2018-12-17 17:18:37 -0800209
210 // Bug: http://b/29823425 Disable -Wnull-dereference until the
211 // new instances detected by this warning are fixed.
212 "-Wno-null-dereference",
Nick Desaulnierseb207442019-12-12 10:15:42 -0800213
214 // http://b/145211477
215 "-Wno-pointer-compare",
216 // http://b/145211022
217 "-Wno-xor-used-as-pow",
218 // http://b/145211022
219 "-Wno-final-dtor-non-final-class",
Stephen Hines2210e722020-07-15 11:11:57 -0700220
221 // http://b/165945989
222 "-Wno-psabi",
Jingwen Chenbf61afb2021-05-06 13:31:18 +0000223 })
Colin Cross3f40fa42015-01-30 17:27:36 -0800224}
225
Colin Crossb98c8b02016-07-29 13:44:28 -0700226func ClangFilterUnknownCflags(cflags []string) []string {
Dan Albertd12afec2020-08-14 16:53:21 -0700227 result, _ := android.FilterList(cflags, ClangUnknownCflags)
228 return result
229}
230
231func clangTidyNegateChecks(checks []string) []string {
232 ret := make([]string, 0, len(checks))
233 for _, c := range checks {
234 if strings.HasPrefix(c, "-") {
235 ret = append(ret, c)
236 } else {
237 ret = append(ret, "-"+c)
Colin Cross3f40fa42015-01-30 17:27:36 -0800238 }
239 }
Colin Cross3f40fa42015-01-30 17:27:36 -0800240 return ret
241}
242
Dan Albertd12afec2020-08-14 16:53:21 -0700243func ClangRewriteTidyChecks(checks []string) []string {
244 checks = append(checks, clangTidyNegateChecks(ClangTidyDisableChecks)...)
245 // clang-tidy does not allow later arguments to override earlier arguments,
246 // so if we just disabled an argument that was explicitly enabled we must
247 // remove the enabling argument from the list.
248 result, _ := android.FilterList(checks, ClangTidyDisableChecks)
249 return result
250}
Chih-Hung Hsieh02b4da52018-04-03 11:33:34 -0700251
Yo Chiang8aa4e3f2020-11-19 16:30:49 +0800252func ClangLibToolingFilterUnknownCflags(libToolingFlags []string) []string {
253 return android.RemoveListFromList(libToolingFlags, ClangLibToolingUnknownCflags)
254}
255
Dan Willemsene6540452015-10-20 15:21:33 -0700256func sorted(list []string) []string {
257 sort.Strings(list)
258 return list
259}