1//==--- DiagnosticFrontendKinds.td - frontend diagnostics -----------------===//
2//
3// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4// See https://llvm.org/LICENSE.txt for license information.
5// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6//
7//===----------------------------------------------------------------------===//
8
9class BackendInfo : CatBackend, ShowInSystemHeader;
10
11let Component = "Frontend" in {
12
13def err_fe_error_opening : Error<"error opening '%0': %1">;
14def err_fe_error_reading : Error<"error reading '%0'">;
15def err_fe_error_reading_stdin : Error<"error reading stdin: %0">;
16def err_fe_error_backend : Error<"error in backend: %0">, DefaultFatal;
17
18def err_fe_inline_asm : Error<"%0">, CatInlineAsm;
19def warn_fe_inline_asm : Warning<"%0">, CatInlineAsm, InGroup<BackendInlineAsm>;
20def note_fe_inline_asm : Note<"%0">, CatInlineAsm;
21def note_fe_inline_asm_here : Note<"instantiated into assembly here">;
22def err_fe_source_mgr : Error<"%0">, CatSourceMgr;
23def warn_fe_source_mgr : Warning<"%0">, CatSourceMgr, InGroup<BackendSourceMgr>;
24def note_fe_source_mgr : Note<"%0">, CatSourceMgr;
25def err_fe_linking_module : Error<"cannot link module '%0': %1">, DefaultFatal;
26def warn_fe_linking_module : Warning<"linking module '%0': %1">, InGroup<LinkerWarnings>;
27def note_fe_linking_module : Note<"linking module '%0': %1">;
28
29def warn_fe_frame_larger_than : Warning<"stack frame size (%0) exceeds limit (%1) in '%2'">,
30    BackendInfo, InGroup<BackendFrameLargerThan>;
31def warn_fe_backend_frame_larger_than: Warning<"%0">,
32    BackendInfo, InGroup<BackendFrameLargerThan>;
33def err_fe_backend_frame_larger_than: Error<"%0">, BackendInfo;
34def note_fe_backend_frame_larger_than: Note<"%0">, BackendInfo;
35
36def warn_fe_backend_plugin: Warning<"%0">, BackendInfo, InGroup<BackendPlugin>;
37def err_fe_backend_plugin: Error<"%0">, BackendInfo;
38def remark_fe_backend_plugin: Remark<"%0">, BackendInfo, InGroup<RemarkBackendPlugin>;
39def note_fe_backend_plugin: Note<"%0">, BackendInfo;
40
41def warn_fe_override_module : Warning<
42    "overriding the module target triple with %0">,
43    InGroup<DiagGroup<"override-module">>;
44def warn_fe_backend_unsupported_fp_rounding : Warning<
45    "overriding currently unsupported rounding mode on this target">,
46    InGroup<UnsupportedFPOpt>;
47def warn_fe_backend_unsupported_fp_exceptions : Warning<
48    "overriding currently unsupported use of floating point exceptions "
49    "on this target">, InGroup<UnsupportedFPOpt>;
50
51def err_incompatible_fp_eval_method_options : Error<
52    "option 'ffp-eval-method' cannot be used with option "
53    "%select{'fapprox-func'|'mreassociate'|'freciprocal'}0">;
54
55def remark_fe_backend_optimization_remark : Remark<"%0">, BackendInfo,
56    InGroup<BackendOptimizationRemark>;
57def remark_fe_backend_optimization_remark_missed : Remark<"%0">, BackendInfo,
58    InGroup<BackendOptimizationRemarkMissed>;
59def remark_fe_backend_optimization_remark_analysis : Remark<"%0">, BackendInfo,
60    InGroup<BackendOptimizationRemarkAnalysis>;
61def remark_fe_backend_optimization_remark_analysis_fpcommute : Remark<"%0; "
62    "allow reordering by specifying '#pragma clang loop vectorize(enable)' "
63    "before the loop or by providing the compiler option '-ffast-math'.">,
64    BackendInfo, InGroup<BackendOptimizationRemarkAnalysis>;
65def remark_fe_backend_optimization_remark_analysis_aliasing : Remark<"%0; "
66    "allow reordering by specifying '#pragma clang loop vectorize(enable)' "
67    "before the loop. If the arrays will always be independent specify "
68    "'#pragma clang loop vectorize(assume_safety)' before the loop or provide "
69    "the '__restrict__' qualifier with the independent array arguments. "
70    "Erroneous results will occur if these options are incorrectly applied!">,
71    BackendInfo, InGroup<BackendOptimizationRemarkAnalysis>;
72def warn_fe_backend_optimization_failure : Warning<"%0">, BackendInfo,
73    InGroup<BackendOptimizationFailure>, DefaultWarn;
74def note_fe_backend_invalid_loc : Note<"could "
75  "not determine the original source location for %0:%1:%2">, BackendInfo;
76
77def err_fe_backend_unsupported : Error<"%0">, BackendInfo;
78def warn_fe_backend_unsupported : Warning<"%0">, BackendInfo;
79
80def err_fe_backend_error_attr :
81  Error<"call to %0 declared with 'error' attribute: %1">, BackendInfo;
82def warn_fe_backend_warning_attr :
83  Warning<"call to %0 declared with 'warning' attribute: %1">, BackendInfo,
84  InGroup<BackendWarningAttributes>;
85
86def err_fe_invalid_code_complete_file : Error<
87    "cannot locate code-completion file %0">, DefaultFatal;
88def err_fe_dependency_file_requires_MT : Error<
89    "-dependency-file requires at least one -MT or -MQ option">;
90def err_fe_invalid_plugin_name : Error<
91    "unable to find plugin '%0'">;
92def err_fe_expected_compiler_job : Error<
93    "unable to handle compilation, expected exactly one compiler job in '%0'">;
94def err_fe_expected_clang_command : Error<
95    "expected a clang compiler command">;
96def err_fe_remap_missing_to_file : Error<
97    "could not remap file '%0' to the contents of file '%1'">, DefaultFatal;
98def err_fe_remap_missing_from_file : Error<
99    "could not remap from missing file '%0'">, DefaultFatal;
100def err_fe_unable_to_load_pch : Error<
101    "unable to load PCH file">;
102def err_fe_unable_to_load_plugin : Error<
103    "unable to load plugin '%0': '%1'">;
104def err_fe_unable_to_create_target : Error<
105    "unable to create target: '%0'">;
106def err_fe_unable_to_interface_with_target : Error<
107    "unable to interface with target machine">;
108def err_fe_unable_to_open_output : Error<
109    "unable to open output file '%0': '%1'">;
110def warn_fe_macro_contains_embedded_newline : Warning<
111    "macro '%0' contains embedded newline; text after the newline is ignored">;
112def warn_fe_cc_print_header_failure : Warning<
113    "unable to open CC_PRINT_HEADERS file: %0 (using stderr)">;
114def warn_fe_cc_log_diagnostics_failure : Warning<
115    "unable to open CC_LOG_DIAGNOSTICS file: %0 (using stderr)">;
116def warn_fe_unable_to_open_stats_file : Warning<
117    "unable to open statistics output file '%0': '%1'">,
118    InGroup<DiagGroup<"unable-to-open-stats-file">>;
119def err_fe_no_pch_in_dir : Error<
120    "no suitable precompiled header file found in directory '%0'">;
121def err_fe_action_not_available : Error<
122    "action %0 not compiled in">;
123def err_fe_invalid_alignment : Error<
124    "invalid value '%1' in '%0'; alignment must be a power of 2">;
125def err_fe_invalid_exception_model
126   : Error<"invalid exception model '%select{none|sjlj|seh|dwarf|wasm}0' for target '%1'">;
127def warn_fe_concepts_ts_flag : Warning<
128  "-fconcepts-ts is deprecated - use '-std=c++20' for Concepts support">,
129  InGroup<Deprecated>;
130
131def err_fe_unable_to_load_basic_block_sections_file : Error<
132    "unable to load basic block sections function list: '%0'">;
133
134def warn_fe_serialized_diag_merge_failure : Warning<
135    "unable to merge a subprocess's serialized diagnostics">,
136    InGroup<SerializedDiagnostics>;
137def warn_fe_serialized_diag_failure : Warning<
138    "unable to open file %0 for serializing diagnostics (%1)">,
139    InGroup<SerializedDiagnostics>;
140def warn_fe_serialized_diag_failure_during_finalisation : Warning<
141    "Received warning after diagnostic serialization teardown was underway: %0">,
142    InGroup<SerializedDiagnostics>;
143
144def err_verify_missing_line : Error<
145    "missing or invalid line number following '@' in expected %0">;
146def err_verify_missing_file : Error<
147    "file '%0' could not be located in expected %1">;
148def err_verify_invalid_range : Error<
149    "invalid range following '-' in expected %0">;
150def err_verify_ambiguous_marker : Error<
151    "reference to marker '%0' is ambiguous">;
152def note_verify_ambiguous_marker : Note<
153    "ambiguous marker '%0' is defined here">;
154def err_verify_no_such_marker : Error<
155    "use of undefined marker '%0'">;
156def err_verify_missing_start : Error<
157    "cannot find start ('{{') of expected %0">;
158def err_verify_missing_end : Error<
159    "cannot find end ('}}') of expected %0">;
160def err_verify_invalid_content : Error<
161    "invalid expected %0: %1">;
162def err_verify_missing_regex : Error<
163    "cannot find start of regex ('{{') in %0">;
164def err_verify_inconsistent_diags : Error<
165    "'%0' diagnostics %select{expected|seen}1 but not %select{seen|expected}1: "
166    "%2">;
167def err_verify_invalid_no_diags : Error<
168    "%select{expected|'expected-no-diagnostics'}0 directive cannot follow "
169    "%select{'expected-no-diagnostics' directive|other expected directives}0">;
170def err_verify_no_directives : Error<
171    "no expected directives found: consider use of 'expected-no-diagnostics'">;
172def err_verify_nonconst_addrspace : Error<
173  "qualifier 'const' is needed for variables in address space '%0'">;
174
175def note_fixit_applied : Note<"FIX-IT applied suggested code changes">;
176def note_fixit_in_macro : Note<
177    "FIX-IT unable to apply suggested code changes in a macro">;
178def note_fixit_failed : Note<
179    "FIX-IT unable to apply suggested code changes">;
180def note_fixit_unfixed_error : Note<"FIX-IT detected an error it cannot fix">;
181def warn_fixit_no_changes : Note<
182    "FIX-IT detected errors it could not fix; no output will be generated">;
183
184// PCH reader
185def err_relocatable_without_isysroot : Error<
186    "must specify system root with -isysroot when building a relocatable "
187    "PCH file">;
188
189def warn_unknown_diag_option : Warning<
190    "unknown %select{warning|remark}0 option '%1'%select{|; did you mean '%3'?}2">,
191    InGroup<UnknownWarningOption>;
192def warn_unknown_warning_specifier : Warning<
193    "unknown %0 warning specifier: '%1'">,
194    InGroup<UnknownWarningOption>;
195
196def warn_incompatible_analyzer_plugin_api : Warning<
197    "checker plugin '%0' is not compatible with this version of the analyzer">,
198    InGroup<DiagGroup<"analyzer-incompatible-plugin"> >;
199def note_incompatible_analyzer_plugin_api : Note<
200    "current API version is '%0', but plugin was compiled with version '%1'">;
201
202def err_module_build_requires_fmodules : Error<
203  "module compilation requires '-fmodules'">;
204def err_module_interface_requires_cpp_modules : Error<
205  "module interface compilation requires '-std=c++20' or '-fmodules-ts'">;
206def err_header_module_requires_modules : Error<
207  "header module compilation requires '-fmodules', '-std=c++20', or "
208  "'-fmodules-ts'">;
209def warn_module_config_mismatch : Warning<
210  "module file %0 cannot be loaded due to a configuration mismatch with the current "
211  "compilation">, InGroup<DiagGroup<"module-file-config-mismatch">>, DefaultError;
212def err_module_map_not_found : Error<"module map file '%0' not found">,
213  DefaultFatal;
214def err_missing_module_name : Error<
215  "no module name provided; specify one with -fmodule-name=">,
216  DefaultFatal;
217def err_missing_module : Error<
218  "no module named '%0' declared in module map file '%1'">, DefaultFatal;
219def err_no_submodule : Error<"no submodule named %0 in module '%1'">;
220def err_no_submodule_suggest : Error<
221  "no submodule named %0 in module '%1'; did you mean '%2'?">;
222def warn_no_priv_submodule_use_toplevel : Warning<
223  "no submodule named %0 in module '%1'; using top level '%2'">,
224  InGroup<PrivateModule>;
225def note_private_top_level_defined : Note<
226  "module defined here">;
227def warn_missing_submodule : Warning<"missing submodule '%0'">,
228  InGroup<IncompleteUmbrella>;
229def note_module_import_here : Note<"module imported here">;
230def err_module_cannot_create_includes : Error<
231  "cannot create includes file for module %0: %1">;
232def warn_module_config_macro_undef : Warning<
233  "%select{definition|#undef}0 of configuration macro '%1' has no effect on "
234  "the import of '%2'; pass '%select{-D%1=...|-U%1}0' on the command line "
235  "to configure the module">,
236  InGroup<ConfigMacros>;
237def note_module_def_undef_here : Note<
238  "macro was %select{defined|#undef'd}0 here">;
239def remark_module_build : Remark<"building module '%0' as '%1'">,
240  InGroup<ModuleBuild>;
241def remark_module_build_done : Remark<"finished building module '%0'">,
242  InGroup<ModuleBuild>;
243def remark_module_lock : Remark<"locking '%0' to build module '%1'">,
244  InGroup<ModuleLock>;
245def err_modules_embed_file_not_found :
246  Error<"file '%0' specified by '-fmodules-embed-file=' not found">,
247  DefaultFatal;
248def err_module_header_file_not_found :
249  Error<"module header file '%0' not found">, DefaultFatal;
250
251def err_test_module_file_extension_version : Error<
252  "test module file extension '%0' has different version (%1.%2) than expected "
253  "(%3.%4)">;
254
255def err_missing_vfs_overlay_file : Error<
256  "virtual filesystem overlay file '%0' not found">, DefaultFatal;
257def err_invalid_vfs_overlay : Error<
258  "invalid virtual filesystem overlay file '%0'">, DefaultFatal;
259
260def warn_option_invalid_ocl_version : Warning<
261  "%0 does not support the option '%1'">, InGroup<Deprecated>;
262
263def err_builtin_needs_feature : Error<"%0 needs target feature %1">;
264def err_function_needs_feature : Error<
265  "always_inline function %1 requires target feature '%2', but would "
266  "be inlined into function %0 that is compiled without support for '%2'">;
267
268def warn_avx_calling_convention
269    : Warning<"AVX vector %select{return|argument}0 of type %1 without '%2' "
270              "enabled changes the ABI">,
271      InGroup<DiagGroup<"psabi">>;
272def err_avx_calling_convention : Error<warn_avx_calling_convention.Text>;
273
274def err_alias_to_undefined : Error<
275  "%select{alias|ifunc}0 must point to a defined "
276  "%select{variable or |}1function">;
277def warn_alias_to_weak_alias : Warning<
278  "%select{alias|ifunc}2 will always resolve to %0 even if weak definition of "
279  "%1 is overridden">,
280  InGroup<IgnoredAttributes>;
281def err_duplicate_mangled_name : Error<
282  "definition with same mangled name '%0' as another definition">;
283def err_cyclic_alias : Error<
284  "%select{alias|ifunc}0 definition is part of a cycle">;
285def err_ifunc_resolver_return : Error<
286  "ifunc resolver function must return a pointer">;
287
288def warn_atomic_op_misaligned : Warning<
289  "misaligned atomic operation may incur "
290  "significant performance penalty"
291  "; the expected alignment (%0 bytes) exceeds the actual alignment (%1 bytes)">,
292  InGroup<AtomicAlignment>;
293
294def warn_atomic_op_oversized : Warning<
295  "large atomic operation may incur "
296  "significant performance penalty"
297  "; the access size (%0 bytes) exceeds the max lock-free size (%1  bytes)">,
298InGroup<AtomicAlignment>;
299
300def warn_alias_with_section : Warning<
301  "%select{alias|ifunc}1 will not be in section '%0' but in the same section "
302  "as the %select{aliasee|resolver}2">,
303  InGroup<IgnoredAttributes>;
304
305let CategoryName = "Instrumentation Issue" in {
306def warn_profile_data_out_of_date : Warning<
307  "profile data may be out of date: of %0 function%s0, %1 %plural{1:has|:have}1"
308  " mismatched data that will be ignored">,
309  InGroup<ProfileInstrOutOfDate>;
310def warn_profile_data_missing : Warning<
311  "profile data may be incomplete: of %0 function%s0, %1 %plural{1:has|:have}1"
312  " no data">,
313  InGroup<ProfileInstrMissing>,
314  DefaultIgnore;
315def warn_profile_data_unprofiled : Warning<
316  "no profile data available for file \"%0\"">,
317  InGroup<ProfileInstrUnprofiled>;
318def warn_profile_data_misexpect : Warning<
319  "Potential performance regression from use of __builtin_expect(): "
320  "Annotation was correct on %0 of profiled executions.">,
321  BackendInfo,
322  InGroup<MisExpect>;
323} // end of instrumentation issue category
324
325}
326