clang 23.0.0git
CodeGenOptions.h
Go to the documentation of this file.
1//===--- CodeGenOptions.h ---------------------------------------*- C++ -*-===//
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//
9// This file defines the CodeGenOptions interface.
10//
11//===----------------------------------------------------------------------===//
12
13#ifndef LLVM_CLANG_BASIC_CODEGENOPTIONS_H
14#define LLVM_CLANG_BASIC_CODEGENOPTIONS_H
15
20#include "llvm/ADT/FloatingPointMode.h"
21#include "llvm/Frontend/Debug/Options.h"
22#include "llvm/Frontend/Driver/CodeGenOptions.h"
23#include "llvm/MC/MCTargetOptions.h"
24#include "llvm/Support/CodeGen.h"
25#include "llvm/Support/Hash.h"
26#include "llvm/Support/Regex.h"
27#include "llvm/Target/TargetOptions.h"
28#include "llvm/Transforms/Instrumentation/AddressSanitizerOptions.h"
29#include <map>
30#include <memory>
31#include <string>
32#include <vector>
33
34namespace llvm {
35class PassBuilder;
36}
37namespace clang {
38
39/// Bitfields of CodeGenOptions, split out from CodeGenOptions to ensure
40/// that this large collection of bitfields is a trivial class type.
42 friend class CompilerInvocation;
44
45public:
46 /// For ASTs produced with different option value, signifies their level of
47 /// compatibility.
48 enum class CompatibilityKind {
49 /// Does affect the construction of the AST in a way that does prevent
50 /// module interoperability.
52 /// Does affect the construction of the AST in a way that doesn't prevent
53 /// interoperability (that is, the value can be different between an
54 /// explicit module and the user of that module).
56 /// Does not affect the construction of the AST in any way (that is, the
57 /// value can be different between an implicit module and the user of that
58 /// module).
60 };
61
63 using ProfileInstrKind = llvm::driver::ProfileInstrKind;
65 llvm::AsanDetectStackUseAfterReturnMode;
66 using AsanDtorKind = llvm::AsanDtorKind;
67 using VectorLibrary = llvm::driver::VectorLibrary;
68 using ZeroCallUsedRegsKind = llvm::ZeroCallUsedRegs::ZeroCallUsedRegsKind;
69 using WinX64EHUnwindV2Mode = llvm::WinX64EHUnwindV2Mode;
70
71 using DebugCompressionType = llvm::DebugCompressionType;
72 using EmitDwarfUnwindType = llvm::EmitDwarfUnwindType;
73 using DebugTemplateNamesKind = llvm::codegenoptions::DebugTemplateNamesKind;
74 using DebugInfoKind = llvm::codegenoptions::DebugInfoKind;
75 using DebuggerKind = llvm::DebuggerKind;
76 using RelocSectionSymType = llvm::RelocSectionSymType;
77
78#define CODEGENOPT(Name, Bits, Default, Compatibility) unsigned Name : Bits;
79#define ENUM_CODEGENOPT(Name, Type, Bits, Default, Compatibility)
80#include "clang/Basic/CodeGenOptions.def"
81
82protected:
83#define CODEGENOPT(Name, Bits, Default, Compatibility)
84#define ENUM_CODEGENOPT(Name, Type, Bits, Default, Compatibility) \
85 unsigned Name : Bits;
86#include "clang/Basic/CodeGenOptions.def"
87};
88
89/// CodeGenOptions - Track various options which control how the code
90/// is optimized and passed to the backend.
92public:
94 NormalInlining, // Use the standard function inlining pass.
95 OnlyHintInlining, // Inline only (implicitly) hinted functions.
96 OnlyAlwaysInlining // Only run the always inlining pass.
97 };
98
104
111
113 SRCK_Default, // No special option was passed.
114 SRCK_OnStack, // Small structs on the stack (-fpcc-struct-return).
115 SRCK_InRegs // Small structs in registers (-freg-struct-return).
116 };
117
119 Embed_Off, // No embedded bitcode.
120 Embed_All, // Embed both bitcode and commandline in the output.
121 Embed_Bitcode, // Embed just the bitcode in the output.
122 Embed_Marker // Embed a marker as a placeholder for bitcode.
123 };
124
130
135
142
143 // This field stores one of the allowed values for the option
144 // -fbasic-block-sections=. The allowed values with this option are:
145 // {"all", "list=<file>", "none"}.
146 //
147 // "all" : Generate basic block sections for all basic blocks.
148 // "list=<file>": Generate basic block sections for a subset of basic blocks.
149 // The functions and the machine basic block ids are specified
150 // in the file.
151 // "none": Disable sections for basic blocks.
152 std::string BBSections;
153
154 // If set, override the default value of MCAsmInfo::BinutilsVersion. If
155 // DisableIntegratedAS is specified, the assembly output will consider GNU as
156 // support. "none" means that all ELF features can be used, regardless of
157 // binutils support.
158 std::string BinutilsVersion;
159
160 enum class FramePointerKind {
161 NonLeafNoReserve, // Keep non-leaf frame pointers, allow the FP to be used
162 // as a GPR in leaf functions.
163 None, // Omit all frame pointers.
164 Reserved, // Maintain valid frame pointer chain.
165 NonLeaf, // Keep non-leaf frame pointers, don't allow the FP to be used as a
166 // GPR in leaf functions.
167 All, // Keep all frame pointers.
168 };
169
171 switch (Kind) {
173 return "none";
175 return "reserved";
177 return "non-leaf-no-reserve";
179 return "non-leaf";
181 return "all";
182 }
183
184 llvm_unreachable("invalid FramePointerKind");
185 }
186
187 /// Possible exception handling behavior.
189
191 Auto, // Choose Swift async extended frame info based on deployment target.
192 Always, // Unconditionally emit Swift async extended frame info.
193 Never, // Don't emit Swift async extended frame info.
195 };
196
198 Language, // Not specified, use language standard.
199 Always, // All loops are assumed to be finite.
200 Never, // No loop is assumed to be finite.
201 };
202
208
210 None, ///< Trap Messages are omitted. This offers the smallest debug info
211 ///< size but at the cost of making traps hard to debug.
212 Basic, ///< Trap Message is fixed per SanitizerKind. Produces smaller debug
213 ///< info than `Detailed` but is not as helpful for debugging.
214 Detailed, ///< Trap Message includes more context (e.g. the expression being
215 ///< overflowed). This is more helpful for debugging but produces
216 ///< larger debug info than `Basic`.
217 };
218
219 /// The code model to use (-mcmodel).
220 std::string CodeModel;
221
222 /// The code model-specific large data threshold to use
223 /// (-mlarge-data-threshold).
225
226 /// The filename with path we use for coverage data files. The runtime
227 /// allows further manipulation with the GCOV_PREFIX and GCOV_PREFIX_STRIP
228 /// environment variables.
229 std::string CoverageDataFile;
230
231 /// The filename with path we use for coverage notes files.
232 std::string CoverageNotesFile;
233
234 /// Regexes separated by a semi-colon to filter the files to instrument.
236
237 /// Regexes separated by a semi-colon to filter the files to not instrument.
239
240 /// The version string to put into coverage files.
241 char CoverageVersion[4] = {'0', '0', '0', '0'};
242
243 /// Enable additional debugging information.
244 std::string DebugPass;
245
246 /// The string to embed in debug information as the current working directory.
248
249 /// The string to embed in coverage mapping as the current working directory.
251
252 /// The string to embed in the debug information for the compile unit, if
253 /// non-empty.
254 std::string DwarfDebugFlags;
255
256 /// The string containing the commandline for the llvm.commandline metadata,
257 /// if non-empty.
258 std::string RecordCommandLine;
259
261
262 /// Prefix replacement map for source-based code coverage to remap source
263 /// file paths in coverage mapping.
265
266 /// The ABI to use for passing floating point arguments.
267 std::string FloatABI;
268
269 /// The file to use for dumping bug report by `Debugify` for original
270 /// debug info.
272
273 /// The floating-point denormal mode to use.
274 llvm::DenormalMode FPDenormalMode = llvm::DenormalMode::getIEEE();
275
276 /// The floating-point denormal mode to use, for float.
277 llvm::DenormalMode FP32DenormalMode = llvm::DenormalMode::getIEEE();
278
279 /// The float precision limit to use, if non-empty.
281
283 /// The filename of the bitcode file to link in.
284 std::string Filename;
285 /// If true, we set attributes functions in the bitcode library according to
286 /// our CodeGenOptions, much as we set attrs on functions that we generate
287 /// ourselves.
288 bool PropagateAttrs = false;
289 /// If true, we use LLVM module internalizer.
290 bool Internalize = false;
291 /// Bitwise combination of llvm::Linker::Flags, passed to the LLVM linker.
292 unsigned LinkFlags = 0;
293 };
294
295 /// The files specified here are linked in to the module before optimizations.
296 std::vector<BitcodeFileToLink> LinkBitcodeFiles;
297
298 /// The user provided name for the "main file", if non-empty. This is useful
299 /// in situations where the input file name does not match the original input
300 /// file, for example with -save-temps.
301 std::string MainFileName;
302
303 /// The name for the split debug info file used for the DW_AT_[GNU_]dwo_name
304 /// attribute in the skeleton CU.
305 std::string SplitDwarfFile;
306
307 /// Output filename for the split debug info, not used in the skeleton CU.
308 std::string SplitDwarfOutput;
309
310 /// Output filename used in the COFF debug information.
312
313 /// The name of the relocation model to use.
314 llvm::Reloc::Model RelocationModel;
315
316 /// If not an empty string, trap intrinsics are lowered to calls to this
317 /// function instead of to trap instructions.
318 std::string TrapFuncName;
319
320 /// A list of dependent libraries.
321 std::vector<std::string> DependentLibraries;
322
323 /// A list of linker options to embed in the object file.
324 std::vector<std::string> LinkerOptions;
325
326 /// Name of the profile file to use as output for -fprofile-instr-generate,
327 /// -fprofile-generate, and -fcs-profile-generate.
329
330 /// Name of the patchable function entry section with
331 /// -fpatchable-function-entry.
333
334 /// Name of the profile file to use with -fprofile-sample-use.
335 std::string SampleProfileFile;
336
337 /// Name of the profile file to use as output for with -fmemory-profile.
339
340 /// Name of the profile file to use as input for -fmemory-profile-use.
342
343 /// Name of the profile file to use as input for -fprofile-instr-use
345
346 /// Name of the profile remapping file to apply to the profile data supplied
347 /// by -fprofile-sample-use or -fprofile-instr-use.
349
350 /// Name of the function summary index file to use for ThinLTO function
351 /// importing.
352 std::string ThinLTOIndexFile;
353
354 /// Name of a file that can optionally be written with minimized bitcode
355 /// to be used as input for the ThinLTO thin link step, which only needs
356 /// the summary and module symbol table (and not, e.g. any debug metadata).
358
359 /// Prefix to use for -save-temps output.
361
362 /// Name of file passed with -fcuda-include-gpubinary option to forward to
363 /// CUDA runtime back-end for incorporating them into host-side object file.
365
366 /// List of filenames passed in using the -fembed-offload-object option. These
367 /// are offloading binaries containing device images and metadata.
368 std::vector<std::string> OffloadObjects;
369
370 /// The name of the file to which the backend should save YAML optimization
371 /// records.
372 std::string OptRecordFile;
373
374 /// The regex that filters the passes that should be saved to the optimization
375 /// records.
376 std::string OptRecordPasses;
377
378 /// The format used for serializing remarks (default: YAML)
379 std::string OptRecordFormat;
380
381 /// The name of the partition that symbols are assigned to, specified with
382 /// -fsymbol-partition (see https://lld.llvm.org/Partitions.html).
383 std::string SymbolPartition;
384
385 /// If non-empty, allow the compiler to assume that the given source file
386 /// identifier is unique at link time.
388
390 RK_Missing, // Remark argument not present on the command line.
391 RK_Enabled, // Remark enabled via '-Rgroup'.
392 RK_EnabledEverything, // Remark enabled via '-Reverything'.
393 RK_Disabled, // Remark disabled via '-Rno-group'.
394 RK_DisabledEverything, // Remark disabled via '-Rno-everything'.
395 RK_WithPattern, // Remark pattern specified via '-Rgroup=regexp'.
396 };
397
398 /// Optimization remark with an optional regular expression pattern.
399 struct OptRemark {
401 std::string Pattern;
402 std::shared_ptr<llvm::Regex> Regex;
403
404 /// By default, optimization remark is missing.
405 OptRemark() = default;
406
407 /// Returns true iff the optimization remark holds a valid regular
408 /// expression.
409 bool hasValidPattern() const { return Regex != nullptr; }
410
411 /// Matches the given string against the regex, if there is some.
412 bool patternMatches(StringRef String) const {
413 return hasValidPattern() && Regex->match(String);
414 }
415 };
416
417 /// Selected optimizations for which we should enable optimization remarks.
418 /// Transformation passes whose name matches the contained (optional) regular
419 /// expression (and support this feature), will emit a diagnostic whenever
420 /// they perform a transformation.
422
423 /// Selected optimizations for which we should enable missed optimization
424 /// remarks. Transformation passes whose name matches the contained (optional)
425 /// regular expression (and support this feature), will emit a diagnostic
426 /// whenever they tried but failed to perform a transformation.
428
429 /// Selected optimizations for which we should enable optimization analyses.
430 /// Transformation passes whose name matches the contained (optional) regular
431 /// expression (and support this feature), will emit a diagnostic whenever
432 /// they want to explain why they decided to apply or not apply a given
433 /// transformation.
435
436 /// Set of sanitizer checks that are non-fatal (i.e. execution should be
437 /// continued when possible).
439
440 /// Set of sanitizer checks that trap rather than diagnose.
442
443 /// Set of sanitizer checks that can merge handlers (smaller code size at
444 /// the expense of debuggability).
446
447 /// Set of thresholds in a range [0.0, 1.0]: the top hottest code responsible
448 /// for the given fraction of PGO counters will be excluded from sanitization
449 /// (0.0 [default] to skip none, 1.0 to skip all).
451
452 /// Set of sanitizer checks, for which the instrumentation will be annotated
453 /// with extra debug info.
455
456 std::optional<double> AllowRuntimeCheckSkipHotCutoff;
457
458 /// List of backend command-line options for -fembed-bitcode.
459 std::vector<uint8_t> CmdArgs;
460
461 /// A list of all -fno-builtin-* function names (e.g., memset).
462 std::vector<std::string> NoBuiltinFuncs;
463
464 std::vector<std::string> Reciprocals;
465
466 /// Configuration for pointer-signing.
468
469 /// The preferred width for auto-vectorization transforms. This is intended to
470 /// override default transforms based on the width of the architected vector
471 /// registers.
472 std::string PreferVectorWidth;
473
474 /// Set of XRay instrumentation kinds to emit.
476
477 std::vector<std::string> DefaultFunctionAttrs;
478
479 /// List of dynamic shared object files to be loaded as pass plugins.
480 std::vector<std::string> PassPlugins;
481
482 /// List of pass builder callbacks.
483 std::vector<std::function<void(llvm::PassBuilder &)>> PassBuilderCallbacks;
484
485 /// List of global variables explicitly specified by the user as toc-data.
486 std::vector<std::string> TocDataVarsUserSpecified;
487
488 /// List of global variables that over-ride the toc-data default.
489 std::vector<std::string> NoTocDataVars;
490
491 /// Path to allowlist file specifying which objects
492 /// (files, functions) should exclusively be instrumented
493 /// by sanitizer coverage pass.
494 std::vector<std::string> SanitizeCoverageAllowlistFiles;
495
496 /// The guard style used for stack protector to get a initial value, this
497 /// value usually be gotten from TLS or get from __stack_chk_guard, or some
498 /// other styles we may implement in the future.
500
501 /// The TLS base register when StackProtectorGuard is "tls", or register used
502 /// to store the stack canary for "sysreg".
503 /// On x86 this can be "fs" or "gs".
504 /// On AArch64 this can only be "sp_el0".
506
507 /// Specify a symbol to be the guard value.
509
510 /// Path to ignorelist file specifying which objects
511 /// (files, functions) listed for instrumentation by sanitizer
512 /// coverage pass should actually not be instrumented.
513 std::vector<std::string> SanitizeCoverageIgnorelistFiles;
514
515 /// Path to ignorelist file specifying which objects
516 /// (files, functions) listed for instrumentation by sanitizer
517 /// binary metadata pass should not be instrumented.
518 std::vector<std::string> SanitizeMetadataIgnorelistFiles;
519
520 /// Hash algorithm to use for KCFI type IDs.
521 llvm::KCFIHashAlgorithm SanitizeKcfiHash;
522
523 /// Name of the stack usage file (i.e., .su file) if user passes
524 /// -fstack-usage. If empty, it can be implied that -fstack-usage is not
525 /// passed on the command line.
526 std::string StackUsageFile;
527
528 /// Executable and command-line used to create a given CompilerInvocation.
529 /// Most of the time this will be the full -cc1 command.
530 const char *Argv0 = nullptr;
531 std::vector<std::string> CommandLineArgs;
532
533 /// The minimum hotness value a diagnostic needs in order to be included in
534 /// optimization diagnostics.
535 ///
536 /// The threshold is an Optional value, which maps to one of the 3 states:
537 /// 1. 0 => threshold disabled. All remarks will be printed.
538 /// 2. positive int => manual threshold by user. Remarks with hotness exceed
539 /// threshold will be printed.
540 /// 3. None => 'auto' threshold by user. The actual value is not
541 /// available at command line, but will be synced with
542 /// hotness threshold from profile summary during
543 /// compilation.
544 ///
545 /// If threshold option is not specified, it is disabled by default.
546 std::optional<uint64_t> DiagnosticsHotnessThreshold = 0;
547
548 /// The maximum percentage profiling weights can deviate from the expected
549 /// values in order to be included in misexpect diagnostics.
550 std::optional<uint32_t> DiagnosticsMisExpectTolerance = 0;
551
552 /// The name of a file to use with \c .secure_log_unique directives.
553 std::string AsSecureLogFile;
554
555 /// A list of functions that are replacable by the loader.
556 std::vector<std::string> LoaderReplaceableFunctionNames;
557 /// The name of a file that contains functions which will be compiled for
558 /// hotpatching. See -fms-secure-hotpatch-functions-file.
560
561 /// A list of functions which will be compiled for hotpatching.
562 /// See -fms-secure-hotpatch-functions-list.
563 std::vector<std::string> MSSecureHotPatchFunctionsList;
564
565public:
566 // Define accessors/mutators for code generation options of enumeration type.
567#define CODEGENOPT(Name, Bits, Default, Compatibility)
568#define ENUM_CODEGENOPT(Name, Type, Bits, Default, Compatibility) \
569 Type get##Name() const { return static_cast<Type>(Name); } \
570 void set##Name(Type Value) { Name = static_cast<unsigned>(Value); }
571#include "clang/Basic/CodeGenOptions.def"
572
574
575 const std::vector<std::string> &getNoBuiltinFuncs() const {
576 return NoBuiltinFuncs;
577 }
578
579 bool hasSjLjExceptions() const {
580 return getExceptionHandling() == ExceptionHandlingKind::SjLj;
581 }
582
583 bool hasSEHExceptions() const {
584 return getExceptionHandling() == ExceptionHandlingKind::WinEH;
585 }
586
587 bool hasDWARFExceptions() const {
588 return getExceptionHandling() == ExceptionHandlingKind::DwarfCFI;
589 }
590
591 bool hasWasmExceptions() const {
592 return getExceptionHandling() == ExceptionHandlingKind::Wasm;
593 }
594
595 /// Check if Clang profile instrumenation is on.
596 bool hasProfileClangInstr() const {
597 return getProfileInstr() ==
598 llvm::driver::ProfileInstrKind::ProfileClangInstr;
599 }
600
601 /// Check if IR level profile instrumentation is on.
602 bool hasProfileIRInstr() const {
603 return getProfileInstr() == llvm::driver::ProfileInstrKind::ProfileIRInstr;
604 }
605
606 /// Check if CS IR level profile instrumentation is on.
607 bool hasProfileCSIRInstr() const {
608 return getProfileInstr() ==
609 llvm::driver::ProfileInstrKind::ProfileCSIRInstr;
610 }
611
612 /// Check if any form of instrumentation is on.
613 bool hasProfileInstr() const {
614 return getProfileInstr() != llvm::driver::ProfileInstrKind::ProfileNone;
615 }
616
617 /// Check if Clang profile use is on.
618 bool hasProfileClangUse() const {
619 return getProfileUse() == llvm::driver::ProfileInstrKind::ProfileClangInstr;
620 }
621
622 /// Check if IR level profile use is on.
623 bool hasProfileIRUse() const {
624 return getProfileUse() == llvm::driver::ProfileInstrKind::ProfileIRInstr ||
625 getProfileUse() == llvm::driver::ProfileInstrKind::ProfileCSIRInstr;
626 }
627
628 /// Check if CSIR profile use is on.
629 bool hasProfileCSIRUse() const {
630 return getProfileUse() == llvm::driver::ProfileInstrKind::ProfileCSIRInstr;
631 }
632
633 /// Check if type and variable info should be emitted.
634 bool hasReducedDebugInfo() const {
635 return getDebugInfo() >= llvm::codegenoptions::DebugInfoConstructor;
636 }
637
638 /// Check if maybe unused type info should be emitted.
640 return getDebugInfo() >= llvm::codegenoptions::UnusedTypeInfo;
641 }
642
643 // Check if any one of SanitizeCoverage* is enabled.
644 bool hasSanitizeCoverage() const {
645 return SanitizeCoverageType || SanitizeCoverageIndirectCalls ||
646 SanitizeCoverageTraceCmp || SanitizeCoverageTraceLoads ||
647 SanitizeCoverageTraceStores || SanitizeCoverageControlFlow;
648 }
649
650 // Check if any one of SanitizeBinaryMetadata* is enabled.
652 return SanitizeBinaryMetadataCovered || SanitizeBinaryMetadataAtomics ||
653 SanitizeBinaryMetadataUAR;
654 }
655
656 /// Reset all of the options that are not considered when building a
657 /// module.
658 void resetNonModularOptions(StringRef ModuleFormat);
659
660 // Is the given function name one of the functions that can be replaced by the
661 // loader?
662 bool isLoaderReplaceableFunctionName(StringRef FuncName) const {
663 return llvm::is_contained(LoaderReplaceableFunctionNames, FuncName);
664 }
665};
666
667} // end namespace clang
668
669#endif
Defines the clang::SanitizerKind enum.
Defines the clang::XRayInstrKind enum.
Bitfields of CodeGenOptions, split out from CodeGenOptions to ensure that this large collection of bi...
llvm::driver::ProfileInstrKind ProfileInstrKind
llvm::AsanDtorKind AsanDtorKind
llvm::ZeroCallUsedRegs::ZeroCallUsedRegsKind ZeroCallUsedRegsKind
llvm::codegenoptions::DebugInfoKind DebugInfoKind
llvm::DebuggerKind DebuggerKind
llvm::WinX64EHUnwindV2Mode WinX64EHUnwindV2Mode
llvm::EmitDwarfUnwindType EmitDwarfUnwindType
llvm::AsanDetectStackUseAfterReturnMode AsanDetectStackUseAfterReturnMode
CompatibilityKind
For ASTs produced with different option value, signifies their level of compatibility.
@ NotCompatible
Does affect the construction of the AST in a way that does prevent module interoperability.
@ Compatible
Does affect the construction of the AST in a way that doesn't prevent interoperability (that is,...
@ Benign
Does not affect the construction of the AST in any way (that is, the value can be different between a...
friend class CompilerInvocationBase
llvm::DebugCompressionType DebugCompressionType
llvm::RelocSectionSymType RelocSectionSymType
llvm::driver::VectorLibrary VectorLibrary
llvm::codegenoptions::DebugTemplateNamesKind DebugTemplateNamesKind
clang::CFBranchLabelSchemeKind CFBranchLabelSchemeKind
llvm::SmallVector< std::pair< std::string, std::string >, 0 > CoveragePrefixMap
Prefix replacement map for source-based code coverage to remap source file paths in coverage mapping.
std::string StackProtectorGuardSymbol
Specify a symbol to be the guard value.
SanitizerSet SanitizeMergeHandlers
Set of sanitizer checks that can merge handlers (smaller code size at the expense of debuggability).
std::string StackUsageFile
Name of the stack usage file (i.e., .su file) if user passes -fstack-usage.
std::string UniqueSourceFileIdentifier
If non-empty, allow the compiler to assume that the given source file identifier is unique at link ti...
std::string MSSecureHotPatchFunctionsFile
The name of a file that contains functions which will be compiled for hotpatching.
const std::vector< std::string > & getNoBuiltinFuncs() const
std::vector< std::string > LoaderReplaceableFunctionNames
A list of functions that are replacable by the loader.
llvm::SmallVector< std::pair< std::string, std::string >, 0 > DebugPrefixMap
@ None
Trap Messages are omitted.
@ Detailed
Trap Message includes more context (e.g.
@ Basic
Trap Message is fixed per SanitizerKind.
std::string OptRecordFile
The name of the file to which the backend should save YAML optimization records.
std::string InstrProfileOutput
Name of the profile file to use as output for -fprofile-instr-generate, -fprofile-generate,...
std::string StackProtectorGuard
The guard style used for stack protector to get a initial value, this value usually be gotten from TL...
bool hasDWARFExceptions() const
std::vector< BitcodeFileToLink > LinkBitcodeFiles
The files specified here are linked in to the module before optimizations.
std::string RecordCommandLine
The string containing the commandline for the llvm.commandline metadata, if non-empty.
std::optional< uint64_t > DiagnosticsHotnessThreshold
The minimum hotness value a diagnostic needs in order to be included in optimization diagnostics.
bool hasProfileInstr() const
Check if any form of instrumentation is on.
bool hasProfileIRUse() const
Check if IR level profile use is on.
char CoverageVersion[4]
The version string to put into coverage files.
std::string FloatABI
The ABI to use for passing floating point arguments.
std::string ThinLinkBitcodeFile
Name of a file that can optionally be written with minimized bitcode to be used as input for the Thin...
bool hasProfileCSIRInstr() const
Check if CS IR level profile instrumentation is on.
std::vector< std::string > DependentLibraries
A list of dependent libraries.
std::string DebugPass
Enable additional debugging information.
llvm::Reloc::Model RelocationModel
The name of the relocation model to use.
llvm::DenormalMode FPDenormalMode
The floating-point denormal mode to use.
std::string CoverageNotesFile
The filename with path we use for coverage notes files.
std::string ProfileInstrumentUsePath
Name of the profile file to use as input for -fprofile-instr-use.
std::string SampleProfileFile
Name of the profile file to use with -fprofile-sample-use.
uint64_t LargeDataThreshold
The code model-specific large data threshold to use (-mlarge-data-threshold).
static StringRef getFramePointerKindName(FramePointerKind Kind)
std::string MemoryProfileOutput
Name of the profile file to use as output for with -fmemory-profile.
std::vector< std::function< void(llvm::PassBuilder &)> > PassBuilderCallbacks
List of pass builder callbacks.
std::string LimitFloatPrecision
The float precision limit to use, if non-empty.
std::string CodeModel
The code model to use (-mcmodel).
std::vector< std::string > TocDataVarsUserSpecified
List of global variables explicitly specified by the user as toc-data.
std::string CoverageDataFile
The filename with path we use for coverage data files.
std::vector< std::string > PassPlugins
List of dynamic shared object files to be loaded as pass plugins.
bool hasProfileClangInstr() const
Check if Clang profile instrumenation is on.
std::string DebugCompilationDir
The string to embed in debug information as the current working directory.
std::optional< uint32_t > DiagnosticsMisExpectTolerance
The maximum percentage profiling weights can deviate from the expected values in order to be included...
std::string OptRecordPasses
The regex that filters the passes that should be saved to the optimization records.
std::vector< std::string > SanitizeCoverageAllowlistFiles
Path to allowlist file specifying which objects (files, functions) should exclusively be instrumented...
std::string SaveTempsFilePrefix
Prefix to use for -save-temps output.
std::string PatchableFunctionEntrySection
Name of the patchable function entry section with -fpatchable-function-entry.
XRayInstrSet XRayInstrumentationBundle
Set of XRay instrumentation kinds to emit.
std::vector< std::string > SanitizeCoverageIgnorelistFiles
Path to ignorelist file specifying which objects (files, functions) listed for instrumentation by san...
bool hasSanitizeCoverage() const
std::vector< std::string > Reciprocals
std::string MainFileName
The user provided name for the "main file", if non-empty.
std::string CudaGpuBinaryFileName
Name of file passed with -fcuda-include-gpubinary option to forward to CUDA runtime back-end for inco...
SanitizerSet SanitizeAnnotateDebugInfo
Set of sanitizer checks, for which the instrumentation will be annotated with extra debug info.
PointerAuthOptions PointerAuth
Configuration for pointer-signing.
llvm::DenormalMode FP32DenormalMode
The floating-point denormal mode to use, for float.
bool hasProfileIRInstr() const
Check if IR level profile instrumentation is on.
bool hasProfileCSIRUse() const
Check if CSIR profile use is on.
std::string CoverageCompilationDir
The string to embed in coverage mapping as the current working directory.
SanitizerSet SanitizeTrap
Set of sanitizer checks that trap rather than diagnose.
std::vector< std::string > SanitizeMetadataIgnorelistFiles
Path to ignorelist file specifying which objects (files, functions) listed for instrumentation by san...
SanitizerSet SanitizeRecover
Set of sanitizer checks that are non-fatal (i.e.
std::string ProfileExcludeFiles
Regexes separated by a semi-colon to filter the files to not instrument.
std::string AsSecureLogFile
The name of a file to use with .secure_log_unique directives.
std::string ProfileRemappingFile
Name of the profile remapping file to apply to the profile data supplied by -fprofile-sample-use or -...
bool hasReducedDebugInfo() const
Check if type and variable info should be emitted.
bool hasSanitizeBinaryMetadata() const
OptRemark OptimizationRemark
Selected optimizations for which we should enable optimization remarks.
llvm::KCFIHashAlgorithm SanitizeKcfiHash
Hash algorithm to use for KCFI type IDs.
std::string ThinLTOIndexFile
Name of the function summary index file to use for ThinLTO function importing.
const char * Argv0
Executable and command-line used to create a given CompilerInvocation.
bool hasWasmExceptions() const
bool hasSjLjExceptions() const
std::string TrapFuncName
If not an empty string, trap intrinsics are lowered to calls to this function instead of to trap inst...
SanitizerMaskCutoffs SanitizeSkipHotCutoffs
Set of thresholds in a range [0.0, 1.0]: the top hottest code responsible for the given fraction of P...
std::string SplitDwarfFile
The name for the split debug info file used for the DW_AT_[GNU_]dwo_name attribute in the skeleton CU...
std::string StackProtectorGuardReg
The TLS base register when StackProtectorGuard is "tls", or register used to store the stack canary f...
std::vector< std::string > DefaultFunctionAttrs
std::vector< std::string > NoBuiltinFuncs
A list of all -fno-builtin-* function names (e.g., memset).
std::vector< uint8_t > CmdArgs
List of backend command-line options for -fembed-bitcode.
OptRemark OptimizationRemarkAnalysis
Selected optimizations for which we should enable optimization analyses.
std::optional< double > AllowRuntimeCheckSkipHotCutoff
std::vector< std::string > CommandLineArgs
std::vector< std::string > LinkerOptions
A list of linker options to embed in the object file.
bool hasSEHExceptions() const
std::string MemoryProfileUsePath
Name of the profile file to use as input for -fmemory-profile-use.
std::vector< std::string > MSSecureHotPatchFunctionsList
A list of functions which will be compiled for hotpatching.
void resetNonModularOptions(StringRef ModuleFormat)
Reset all of the options that are not considered when building a module.
ExceptionHandlingKind
Possible exception handling behavior.
std::string OptRecordFormat
The format used for serializing remarks (default: YAML)
bool hasProfileClangUse() const
Check if Clang profile use is on.
std::vector< std::string > OffloadObjects
List of filenames passed in using the -fembed-offload-object option.
std::string SymbolPartition
The name of the partition that symbols are assigned to, specified with -fsymbol-partition (see https:...
std::vector< std::string > NoTocDataVars
List of global variables that over-ride the toc-data default.
std::string ProfileFilterFiles
Regexes separated by a semi-colon to filter the files to instrument.
bool hasMaybeUnusedDebugInfo() const
Check if maybe unused type info should be emitted.
std::string PreferVectorWidth
The preferred width for auto-vectorization transforms.
std::string ObjectFilenameForDebug
Output filename used in the COFF debug information.
std::string SplitDwarfOutput
Output filename for the split debug info, not used in the skeleton CU.
bool isLoaderReplaceableFunctionName(StringRef FuncName) const
std::string DwarfDebugFlags
The string to embed in the debug information for the compile unit, if non-empty.
std::string DIBugsReportFilePath
The file to use for dumping bug report by Debugify for original debug info.
OptRemark OptimizationRemarkMissed
Selected optimizations for which we should enable missed optimization remarks.
The JSON file list parser is used to communicate input to InstallAPI.
Diagnostic wrappers for TextAPI types for error reporting.
Definition Dominators.h:30
int const char * function
Definition c++config.h:31
Optimization remark with an optional regular expression pattern.
std::shared_ptr< llvm::Regex > Regex
bool patternMatches(StringRef String) const
Matches the given string against the regex, if there is some.
OptRemark()=default
By default, optimization remark is missing.
bool hasValidPattern() const
Returns true iff the optimization remark holds a valid regular expression.