| //===-- TargetMachine.cpp - General Target Information ---------------------==// | 
 | // | 
 | //                     The LLVM Compiler Infrastructure | 
 | // | 
 | // This file is distributed under the University of Illinois Open Source | 
 | // License. See LICENSE.TXT for details. | 
 | // | 
 | //===----------------------------------------------------------------------===// | 
 | // | 
 | // This file describes the general parts of a Target machine. | 
 | // | 
 | //===----------------------------------------------------------------------===// | 
 |  | 
 | #include "llvm/Target/TargetAsmInfo.h" | 
 | #include "llvm/Target/TargetMachine.h" | 
 | #include "llvm/Target/TargetOptions.h" | 
 | #include "llvm/Support/CommandLine.h" | 
 | using namespace llvm; | 
 |  | 
 | //--------------------------------------------------------------------------- | 
 | // Command-line options that tend to be useful on more than one back-end. | 
 | // | 
 |  | 
 | namespace llvm { | 
 |   bool LessPreciseFPMADOption; | 
 |   bool PrintMachineCode; | 
 |   bool NoFramePointerElim; | 
 |   bool NoExcessFPPrecision; | 
 |   bool UnsafeFPMath; | 
 |   bool FiniteOnlyFPMathOption; | 
 |   bool HonorSignDependentRoundingFPMathOption; | 
 |   bool UseSoftFloat; | 
 |   FloatABI::ABIType FloatABIType; | 
 |   bool NoImplicitFloat; | 
 |   bool NoZerosInBSS; | 
 |   bool ExceptionHandling; | 
 |   bool UnwindTablesMandatory; | 
 |   Reloc::Model RelocationModel; | 
 |   CodeModel::Model CMModel; | 
 |   bool PerformTailCallOpt; | 
 |   unsigned StackAlignment; | 
 |   bool RealignStack; | 
 |   bool DisableJumpTables; | 
 |   bool StrongPHIElim; | 
 |   bool AsmVerbosityDefault(false); | 
 | } | 
 |  | 
 | static cl::opt<bool, true> | 
 | PrintCode("print-machineinstrs", | 
 |   cl::desc("Print generated machine code"), | 
 |   cl::location(PrintMachineCode), cl::init(false)); | 
 | static cl::opt<bool, true> | 
 | DisableFPElim("disable-fp-elim", | 
 |   cl::desc("Disable frame pointer elimination optimization"), | 
 |   cl::location(NoFramePointerElim), | 
 |   cl::init(false)); | 
 | static cl::opt<bool, true> | 
 | DisableExcessPrecision("disable-excess-fp-precision", | 
 |   cl::desc("Disable optimizations that may increase FP precision"), | 
 |   cl::location(NoExcessFPPrecision), | 
 |   cl::init(false)); | 
 | static cl::opt<bool, true> | 
 | EnableFPMAD("enable-fp-mad", | 
 |   cl::desc("Enable less precise MAD instructions to be generated"), | 
 |   cl::location(LessPreciseFPMADOption), | 
 |   cl::init(false)); | 
 | static cl::opt<bool, true> | 
 | EnableUnsafeFPMath("enable-unsafe-fp-math", | 
 |   cl::desc("Enable optimizations that may decrease FP precision"), | 
 |   cl::location(UnsafeFPMath), | 
 |   cl::init(false)); | 
 | static cl::opt<bool, true> | 
 | EnableFiniteOnlyFPMath("enable-finite-only-fp-math", | 
 |   cl::desc("Enable optimizations that assumes non- NaNs / +-Infs"), | 
 |   cl::location(FiniteOnlyFPMathOption), | 
 |   cl::init(false)); | 
 | static cl::opt<bool, true> | 
 | EnableHonorSignDependentRoundingFPMath("enable-sign-dependent-rounding-fp-math", | 
 |   cl::Hidden, | 
 |   cl::desc("Force codegen to assume rounding mode can change dynamically"), | 
 |   cl::location(HonorSignDependentRoundingFPMathOption), | 
 |   cl::init(false)); | 
 | static cl::opt<bool, true> | 
 | GenerateSoftFloatCalls("soft-float", | 
 |   cl::desc("Generate software floating point library calls"), | 
 |   cl::location(UseSoftFloat), | 
 |   cl::init(false)); | 
 | static cl::opt<llvm::FloatABI::ABIType, true> | 
 | FloatABIForCalls("float-abi", | 
 |   cl::desc("Choose float ABI type"), | 
 |   cl::location(FloatABIType), | 
 |   cl::init(FloatABI::Default), | 
 |   cl::values( | 
 |     clEnumValN(FloatABI::Default, "default", | 
 |                "Target default float ABI type"), | 
 |     clEnumValN(FloatABI::Soft, "soft", | 
 |                "Soft float ABI (implied by -soft-float)"), | 
 |     clEnumValN(FloatABI::Hard, "hard", | 
 |                "Hard float ABI (uses FP registers)"), | 
 |     clEnumValEnd)); | 
 | static cl::opt<bool, true> | 
 | DontPlaceZerosInBSS("nozero-initialized-in-bss", | 
 |   cl::desc("Don't place zero-initialized symbols into bss section"), | 
 |   cl::location(NoZerosInBSS), | 
 |   cl::init(false)); | 
 | static cl::opt<bool, true> | 
 | EnableExceptionHandling("enable-eh", | 
 |   cl::desc("Emit DWARF exception handling (default if target supports)"), | 
 |   cl::location(ExceptionHandling), | 
 |   cl::init(false)); | 
 | static cl::opt<bool, true> | 
 | EnableUnwindTables("unwind-tables", | 
 |   cl::desc("Generate unwinding tables for all functions"), | 
 |   cl::location(UnwindTablesMandatory), | 
 |   cl::init(false)); | 
 |  | 
 | static cl::opt<llvm::Reloc::Model, true> | 
 | DefRelocationModel("relocation-model", | 
 |   cl::desc("Choose relocation model"), | 
 |   cl::location(RelocationModel), | 
 |   cl::init(Reloc::Default), | 
 |   cl::values( | 
 |     clEnumValN(Reloc::Default, "default", | 
 |                "Target default relocation model"), | 
 |     clEnumValN(Reloc::Static, "static", | 
 |                "Non-relocatable code"), | 
 |     clEnumValN(Reloc::PIC_, "pic", | 
 |                "Fully relocatable, position independent code"), | 
 |     clEnumValN(Reloc::DynamicNoPIC, "dynamic-no-pic", | 
 |                "Relocatable external references, non-relocatable code"), | 
 |     clEnumValEnd)); | 
 | static cl::opt<llvm::CodeModel::Model, true> | 
 | DefCodeModel("code-model", | 
 |   cl::desc("Choose code model"), | 
 |   cl::location(CMModel), | 
 |   cl::init(CodeModel::Default), | 
 |   cl::values( | 
 |     clEnumValN(CodeModel::Default, "default", | 
 |                "Target default code model"), | 
 |     clEnumValN(CodeModel::Small, "small", | 
 |                "Small code model"), | 
 |     clEnumValN(CodeModel::Kernel, "kernel", | 
 |                "Kernel code model"), | 
 |     clEnumValN(CodeModel::Medium, "medium", | 
 |                "Medium code model"), | 
 |     clEnumValN(CodeModel::Large, "large", | 
 |                "Large code model"), | 
 |     clEnumValEnd)); | 
 | static cl::opt<bool, true> | 
 | EnablePerformTailCallOpt("tailcallopt", | 
 |   cl::desc("Turn on tail call optimization."), | 
 |   cl::location(PerformTailCallOpt), | 
 |   cl::init(false)); | 
 | static cl::opt<unsigned, true> | 
 | OverrideStackAlignment("stack-alignment", | 
 |   cl::desc("Override default stack alignment"), | 
 |   cl::location(StackAlignment), | 
 |   cl::init(0)); | 
 | static cl::opt<bool, true> | 
 | EnableRealignStack("realign-stack", | 
 |   cl::desc("Realign stack if needed"), | 
 |   cl::location(RealignStack), | 
 |   cl::init(true)); | 
 | static cl::opt<bool, true> | 
 | DisableSwitchTables(cl::Hidden, "disable-jump-tables",  | 
 |   cl::desc("Do not generate jump tables."), | 
 |   cl::location(DisableJumpTables), | 
 |   cl::init(false)); | 
 | static cl::opt<bool, true> | 
 | EnableStrongPHIElim(cl::Hidden, "strong-phi-elim", | 
 |   cl::desc("Use strong PHI elimination."), | 
 |   cl::location(StrongPHIElim), | 
 |   cl::init(false)); | 
 |  | 
 | //--------------------------------------------------------------------------- | 
 | // TargetMachine Class | 
 | // | 
 |  | 
 | TargetMachine::TargetMachine(const Target &T)  | 
 |   : TheTarget(T), AsmInfo(0) { | 
 |   // Typically it will be subtargets that will adjust FloatABIType from Default | 
 |   // to Soft or Hard. | 
 |   if (UseSoftFloat) | 
 |     FloatABIType = FloatABI::Soft; | 
 | } | 
 |  | 
 | TargetMachine::~TargetMachine() { | 
 |   delete AsmInfo; | 
 | } | 
 |  | 
 | /// getRelocationModel - Returns the code generation relocation model. The | 
 | /// choices are static, PIC, and dynamic-no-pic, and target default. | 
 | Reloc::Model TargetMachine::getRelocationModel() { | 
 |   return RelocationModel; | 
 | } | 
 |  | 
 | /// setRelocationModel - Sets the code generation relocation model. | 
 | void TargetMachine::setRelocationModel(Reloc::Model Model) { | 
 |   RelocationModel = Model; | 
 | } | 
 |  | 
 | /// getCodeModel - Returns the code model. The choices are small, kernel, | 
 | /// medium, large, and target default. | 
 | CodeModel::Model TargetMachine::getCodeModel() { | 
 |   return CMModel; | 
 | } | 
 |  | 
 | /// setCodeModel - Sets the code model. | 
 | void TargetMachine::setCodeModel(CodeModel::Model Model) { | 
 |   CMModel = Model; | 
 | } | 
 |  | 
 | bool TargetMachine::getAsmVerbosityDefault() { | 
 |   return AsmVerbosityDefault; | 
 | } | 
 |  | 
 | void TargetMachine::setAsmVerbosityDefault(bool V) { | 
 |   AsmVerbosityDefault = V; | 
 | } | 
 |  | 
 | namespace llvm { | 
 |   /// LessPreciseFPMAD - This flag return true when -enable-fp-mad option | 
 |   /// is specified on the command line.  When this flag is off(default), the | 
 |   /// code generator is not allowed to generate mad (multiply add) if the | 
 |   /// result is "less precise" than doing those operations individually. | 
 |   bool LessPreciseFPMAD() { return UnsafeFPMath || LessPreciseFPMADOption; } | 
 |  | 
 |   /// FiniteOnlyFPMath - This returns true when the -enable-finite-only-fp-math | 
 |   /// option is specified on the command line. If this returns false (default), | 
 |   /// the code generator is not allowed to assume that FP arithmetic arguments | 
 |   /// and results are never NaNs or +-Infs. | 
 |   bool FiniteOnlyFPMath() { return UnsafeFPMath || FiniteOnlyFPMathOption; } | 
 |    | 
 |   /// HonorSignDependentRoundingFPMath - Return true if the codegen must assume | 
 |   /// that the rounding mode of the FPU can change from its default. | 
 |   bool HonorSignDependentRoundingFPMath() { | 
 |     return !UnsafeFPMath && HonorSignDependentRoundingFPMathOption; | 
 |   } | 
 | } | 
 |  |