//===-- TargetOptionsImpl.cpp - Options that apply to all targets ----------==// // // The LLVM Compiler Infrastructure // // This file is distributed under the University of Illinois Open Source // License. See LICENSE.TXT for details. // //===----------------------------------------------------------------------===// // // This file implements the methods in the TargetOptions. // //===----------------------------------------------------------------------===// #include "llvm/IR/Function.h" #include "llvm/IR/Module.h" #include "llvm/CodeGen/MachineFrameInfo.h" #include "llvm/CodeGen/MachineFunction.h" #include "llvm/Target/TargetFrameLowering.h" #include "llvm/Target/TargetOptions.h" #include "llvm/Target/TargetSubtargetInfo.h" using namespace llvm; /// DisableFramePointerElim - This returns true if frame pointer elimination /// optimization should be disabled for the given machine function. bool TargetOptions::DisableFramePointerElim(const MachineFunction &MF) const { // Check to see if we should eliminate all frame pointers. if (MF.getSubtarget().getFrameLowering()->noFramePointerElim(MF)) return true; // Check to see if we should eliminate non-leaf frame pointers. if (MF.getFunction()->hasFnAttribute("no-frame-pointer-elim-non-leaf")) return MF.getFrameInfo()->hasCalls(); return false; } /// 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 TargetOptions::LessPreciseFPMAD() const { return UnsafeFPMath || LessPreciseFPMADOption; } /// HonorSignDependentRoundingFPMath - Return true if the codegen must assume /// that the rounding mode of the FPU can change from its default. bool TargetOptions::HonorSignDependentRoundingFPMath() const { return !UnsafeFPMath && HonorSignDependentRoundingFPMathOption; } /// getTrapFunctionName - If this returns a non-empty string, this means isel /// should lower Intrinsic::trap to a call to the specified function name /// instead of an ISD::TRAP node. StringRef TargetOptions::getTrapFunctionName() const { return TrapFuncName; } void llvm::setFunctionAttributes(StringRef CPU, StringRef Features, const TargetOptions &Options, Module &M, bool AlwaysRecordAttrs) { for (auto &F : M) { auto &Ctx = F.getContext(); AttributeSet Attrs = F.getAttributes(), NewAttrs; if (!CPU.empty()) NewAttrs = NewAttrs.addAttribute(Ctx, AttributeSet::FunctionIndex, "target-cpu", CPU); if (!Features.empty()) NewAttrs = NewAttrs.addAttribute(Ctx, AttributeSet::FunctionIndex, "target-features", Features); if (Options.NoFramePointerElimOverride || AlwaysRecordAttrs) NewAttrs = NewAttrs.addAttribute( Ctx, AttributeSet::FunctionIndex, "no-frame-pointer-elim", Options.NoFramePointerElim ? "true" : "false"); // Let NewAttrs override Attrs. NewAttrs = Attrs.addAttributes(Ctx, AttributeSet::FunctionIndex, NewAttrs); F.setAttributes(NewAttrs); } }