2020-03-04 00:47:43 +01:00
|
|
|
//===-- CommandFlags.h - Command Line Flags Interface -----------*- C++ -*-===//
|
|
|
|
//
|
|
|
|
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
|
|
|
|
// See https://llvm.org/LICENSE.txt for license information.
|
|
|
|
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
//
|
|
|
|
// This file contains codegen-specific flags that are shared between different
|
|
|
|
// command line tools. The tools "llc" and "opt" both use this file to prevent
|
|
|
|
// flag duplication.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
2020-03-11 22:12:20 +01:00
|
|
|
#include "llvm/ADT/FloatingPointMode.h"
|
2020-03-04 00:47:43 +01:00
|
|
|
#include "llvm/ADT/StringExtras.h"
|
|
|
|
#include "llvm/IR/Instructions.h"
|
|
|
|
#include "llvm/IR/Intrinsics.h"
|
|
|
|
#include "llvm/MC/MCTargetOptionsCommandFlags.h"
|
|
|
|
#include "llvm/Support/CodeGen.h"
|
|
|
|
#include "llvm/Target/TargetOptions.h"
|
|
|
|
#include <string>
|
2020-05-19 18:12:32 +02:00
|
|
|
#include <vector>
|
2020-03-04 00:47:43 +01:00
|
|
|
|
|
|
|
namespace llvm {
|
|
|
|
|
2020-05-19 18:12:32 +02:00
|
|
|
class Module;
|
|
|
|
|
2020-03-04 00:47:43 +01:00
|
|
|
namespace codegen {
|
|
|
|
|
|
|
|
std::string getMArch();
|
|
|
|
|
|
|
|
std::string getMCPU();
|
|
|
|
|
|
|
|
std::vector<std::string> getMAttrs();
|
|
|
|
|
|
|
|
Reloc::Model getRelocModel();
|
|
|
|
Optional<Reloc::Model> getExplicitRelocModel();
|
|
|
|
|
|
|
|
ThreadModel::Model getThreadModel();
|
|
|
|
|
|
|
|
CodeModel::Model getCodeModel();
|
|
|
|
Optional<CodeModel::Model> getExplicitCodeModel();
|
|
|
|
|
|
|
|
llvm::ExceptionHandling getExceptionModel();
|
|
|
|
|
|
|
|
CodeGenFileType getFileType();
|
|
|
|
Optional<CodeGenFileType> getExplicitFileType();
|
|
|
|
|
|
|
|
CodeGenFileType getFileType();
|
|
|
|
|
|
|
|
llvm::FramePointer::FP getFramePointerUsage();
|
|
|
|
|
|
|
|
bool getEnableUnsafeFPMath();
|
|
|
|
|
|
|
|
bool getEnableNoInfsFPMath();
|
|
|
|
|
|
|
|
bool getEnableNoNaNsFPMath();
|
|
|
|
|
|
|
|
bool getEnableNoSignedZerosFPMath();
|
|
|
|
|
|
|
|
bool getEnableNoTrappingFPMath();
|
|
|
|
|
2020-03-11 22:12:20 +01:00
|
|
|
DenormalMode::DenormalModeKind getDenormalFPMath();
|
2019-12-04 10:04:14 +01:00
|
|
|
DenormalMode::DenormalModeKind getDenormalFP32Math();
|
2020-03-04 00:47:43 +01:00
|
|
|
|
|
|
|
bool getEnableHonorSignDependentRoundingFPMath();
|
|
|
|
|
|
|
|
llvm::FloatABI::ABIType getFloatABIForCalls();
|
|
|
|
|
|
|
|
llvm::FPOpFusion::FPOpFusionMode getFuseFPOps();
|
|
|
|
|
|
|
|
bool getDontPlaceZerosInBSS();
|
|
|
|
|
|
|
|
bool getEnableGuaranteedTailCallOpt();
|
|
|
|
|
|
|
|
bool getDisableTailCalls();
|
|
|
|
|
|
|
|
bool getStackSymbolOrdering();
|
|
|
|
|
|
|
|
unsigned getOverrideStackAlignment();
|
|
|
|
|
|
|
|
bool getStackRealign();
|
|
|
|
|
|
|
|
std::string getTrapFuncName();
|
|
|
|
|
|
|
|
bool getUseCtors();
|
|
|
|
|
|
|
|
bool getRelaxELFRelocations();
|
|
|
|
|
|
|
|
bool getDataSections();
|
|
|
|
Optional<bool> getExplicitDataSections();
|
|
|
|
|
|
|
|
bool getFunctionSections();
|
|
|
|
Optional<bool> getExplicitFunctionSections();
|
|
|
|
|
|
|
|
std::string getBBSections();
|
|
|
|
|
|
|
|
unsigned getTLSSize();
|
|
|
|
|
|
|
|
bool getEmulatedTLS();
|
|
|
|
|
|
|
|
bool getUniqueSectionNames();
|
|
|
|
|
2020-06-02 08:17:29 +02:00
|
|
|
bool getUniqueBasicBlockSectionNames();
|
2020-03-04 00:47:43 +01:00
|
|
|
|
|
|
|
llvm::EABI getEABIVersion();
|
|
|
|
|
|
|
|
llvm::DebuggerKind getDebuggerTuningOpt();
|
|
|
|
|
|
|
|
bool getEnableStackSizeSection();
|
|
|
|
|
|
|
|
bool getEnableAddrsig();
|
|
|
|
|
|
|
|
bool getEmitCallSiteInfo();
|
|
|
|
|
|
|
|
bool getEnableDebugEntryValues();
|
|
|
|
|
|
|
|
bool getForceDwarfFrameSection();
|
|
|
|
|
|
|
|
/// Create this object with static storage to register codegen-related command
|
|
|
|
/// line options.
|
|
|
|
struct RegisterCodeGenFlags {
|
|
|
|
RegisterCodeGenFlags();
|
|
|
|
};
|
|
|
|
|
|
|
|
llvm::BasicBlockSection getBBSectionsMode(llvm::TargetOptions &Options);
|
|
|
|
|
|
|
|
// Common utility function tightly tied to the options listed here. Initializes
|
|
|
|
// a TargetOptions object with CodeGen flags and returns it.
|
|
|
|
TargetOptions InitTargetOptionsFromCodeGenFlags();
|
|
|
|
|
|
|
|
std::string getCPUStr();
|
|
|
|
|
|
|
|
std::string getFeaturesStr();
|
|
|
|
|
|
|
|
std::vector<std::string> getFeatureList();
|
|
|
|
|
|
|
|
void renderBoolStringAttr(AttrBuilder &B, StringRef Name, bool Val);
|
|
|
|
|
|
|
|
/// Set function attributes of function \p F based on CPU, Features, and command
|
|
|
|
/// line flags.
|
|
|
|
void setFunctionAttributes(StringRef CPU, StringRef Features, Function &F);
|
|
|
|
|
|
|
|
/// Set function attributes of functions in Module M based on CPU,
|
|
|
|
/// Features, and command line flags.
|
|
|
|
void setFunctionAttributes(StringRef CPU, StringRef Features, Module &M);
|
|
|
|
} // namespace codegen
|
|
|
|
} // namespace llvm
|