diff options
| -rw-r--r-- | lib/CodeGen/DwarfWriter.cpp | 16 | ||||
| -rw-r--r-- | lib/CodeGen/LLVMTargetMachine.cpp | 6 | ||||
| -rw-r--r-- | lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp | 21 | ||||
| -rw-r--r-- | lib/Target/PowerPC/PPCAsmPrinter.cpp | 3 | ||||
| -rw-r--r-- | lib/Target/PowerPC/PPCRegisterInfo.cpp | 7 | ||||
| -rw-r--r-- | lib/Target/X86/X86AsmPrinter.cpp | 4 | ||||
| -rw-r--r-- | lib/Target/X86/X86RegisterInfo.cpp | 8 | ||||
| -rw-r--r-- | lib/Transforms/Utils/LowerInvoke.cpp | 9 | 
8 files changed, 25 insertions, 49 deletions
| diff --git a/lib/CodeGen/DwarfWriter.cpp b/lib/CodeGen/DwarfWriter.cpp index 3296e11..e72ff07 100644 --- a/lib/CodeGen/DwarfWriter.cpp +++ b/lib/CodeGen/DwarfWriter.cpp @@ -2778,13 +2778,9 @@ private:    std::vector<FunctionEHFrameInfo> EHFrames; -  /// shouldEmit - Per-function flag to indicate if EH information should -  /// be emitted. +  /// shouldEmit - Flag to indicate if debug information should be emitted. +  ///    bool shouldEmit; - -  /// shouldEmitModule - Per-module flag to indicate if EH information should -  /// be emitted. -  bool shouldEmitModule;    /// EmitCommonEHFrame - Emit the common eh unwind frame.    /// @@ -3372,7 +3368,6 @@ public:    DwarfException(std::ostream &OS, AsmPrinter *A, const TargetAsmInfo *T)    : Dwarf(OS, A, T, "eh")    , shouldEmit(false) -  , shouldEmitModule(false)    {}    virtual ~DwarfException() {} @@ -3392,7 +3387,7 @@ public:    /// EndModule - Emit all exception information that should come after the    /// content.    void EndModule() { -    if (!shouldEmitModule) return; +    if (!shouldEmit) return;      const std::vector<Function *> Personalities = MMI->getPersonalities();      for (unsigned i =0; i < Personalities.size(); ++i) @@ -3408,14 +3403,13 @@ public:    void BeginFunction(MachineFunction *MF) {      this->MF = MF; -    shouldEmit = false; -    if ((ExceptionHandling || !MF->getFunction()->doesNotThrow()) && +    if (MMI && +        ExceptionHandling &&          TAI->doesSupportExceptionHandling()) {        shouldEmit = true;        // Assumes in correct section after the entry point.        EmitLabel("eh_func_begin", ++SubprogramCount);      } -    shouldEmitModule |= shouldEmit;    }    /// EndFunction - Gather and emit post-function exception information. diff --git a/lib/CodeGen/LLVMTargetMachine.cpp b/lib/CodeGen/LLVMTargetMachine.cpp index 67c0e47..bae7140 100644 --- a/lib/CodeGen/LLVMTargetMachine.cpp +++ b/lib/CodeGen/LLVMTargetMachine.cpp @@ -66,7 +66,8 @@ LLVMTargetMachine::addPassesToEmitFile(PassManagerBase &PM,    PM.add(createGCLoweringPass()); -  PM.add(createLowerInvokePass(getTargetLowering())); +  if (!ExceptionHandling) +    PM.add(createLowerInvokePass(getTargetLowering()));    // Make sure that no unreachable blocks are instruction selected.    PM.add(createUnreachableBlockEliminationPass()); @@ -191,7 +192,8 @@ bool LLVMTargetMachine::addPassesToEmitMachineCode(PassManagerBase &PM,    PM.add(createGCLoweringPass()); -  PM.add(createLowerInvokePass(getTargetLowering())); +  if (!ExceptionHandling) +    PM.add(createLowerInvokePass(getTargetLowering()));    // Make sure that no unreachable blocks are instruction selected.    PM.add(createUnreachableBlockEliminationPass()); diff --git a/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp b/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp index ae2b418..80b5c04 100644 --- a/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp +++ b/lib/CodeGen/SelectionDAG/SelectionDAGISel.cpp @@ -169,7 +169,6 @@ namespace llvm {      Function &Fn;      MachineFunction &MF;      MachineRegisterInfo &RegInfo; -    bool needsExceptionHandling;      FunctionLoweringInfo(TargetLowering &TLI, Function &Fn,MachineFunction &MF); @@ -305,10 +304,6 @@ FunctionLoweringInfo::FunctionLoweringInfo(TargetLowering &tli,          BuildMI(MBB, TII->get(TargetInstrInfo::PHI), PHIReg+i);      }    } - -  // Figure out whether we need to generate EH info.  Currently we do this for -  // all functions not marked no-unwind, or if requested via -enable-eh. -  needsExceptionHandling = ExceptionHandling || !Fn.doesNotThrow();  }  /// CreateRegForValue - Allocate the appropriate number of virtual registers of @@ -2832,7 +2827,7 @@ SelectionDAGLowering::visitIntrinsicCall(CallInst &I, unsigned Intrinsic) {    }    case Intrinsic::eh_exception: { -    if (FuncInfo.needsExceptionHandling) { +    if (ExceptionHandling) {        if (!CurMBB->isLandingPad()) {          // FIXME: Mark exception register as live in.  Hack for PR1508.          unsigned Reg = TLI.getExceptionAddressRegister(); @@ -2857,7 +2852,7 @@ SelectionDAGLowering::visitIntrinsicCall(CallInst &I, unsigned Intrinsic) {      MVT::ValueType VT = (Intrinsic == Intrinsic::eh_selector_i32 ?                           MVT::i32 : MVT::i64); -    if (FuncInfo.needsExceptionHandling && MMI) { +    if (ExceptionHandling && MMI) {        if (CurMBB->isLandingPad())          addCatchInfo(I, MMI, CurMBB);        else { @@ -2907,7 +2902,7 @@ SelectionDAGLowering::visitIntrinsicCall(CallInst &I, unsigned Intrinsic) {    case Intrinsic::eh_return: {      MachineModuleInfo *MMI = DAG.getMachineModuleInfo(); -    if (MMI && FuncInfo.needsExceptionHandling) { +    if (MMI && ExceptionHandling) {        MMI->setCallsEHReturn(true);        DAG.setRoot(DAG.getNode(ISD::EH_RETURN,                                MVT::Other, @@ -2930,7 +2925,7 @@ SelectionDAGLowering::visitIntrinsicCall(CallInst &I, unsigned Intrinsic) {     }     case Intrinsic::eh_dwarf_cfa: { -     if (FuncInfo.needsExceptionHandling) { +     if (ExceptionHandling) {         MVT::ValueType VT = getValue(I.getOperand(1)).getValueType();         SDOperand CfaArg;         if (MVT::getSizeInBits(VT) > MVT::getSizeInBits(TLI.getPointerTy())) @@ -3181,7 +3176,7 @@ void SelectionDAGLowering::LowerCallTo(CallSite CS, SDOperand Callee,      Args.push_back(Entry);    } -  if (LandingPad && FuncInfo.needsExceptionHandling && MMI) { +  if (LandingPad && ExceptionHandling && MMI) {      // Insert a label before the invoke call to mark the try range.  This can be      // used to detect deletion of the invoke via the MachineModuleInfo.      BeginLabel = MMI->NextLabelID(); @@ -3200,7 +3195,7 @@ void SelectionDAGLowering::LowerCallTo(CallSite CS, SDOperand Callee,      setValue(CS.getInstruction(), Result.first);    DAG.setRoot(Result.second); -  if (LandingPad && FuncInfo.needsExceptionHandling && MMI) { +  if (LandingPad && ExceptionHandling && MMI) {      // Insert a label at the end of the invoke call to mark the try range.  This      // can be used to detect deletion of the invoke via the MachineModuleInfo.      EndLabel = MMI->NextLabelID(); @@ -4619,7 +4614,7 @@ bool SelectionDAGISel::runOnFunction(Function &Fn) {    FunctionLoweringInfo FuncInfo(TLI, Fn, MF); -  if (FuncInfo.needsExceptionHandling) +  if (ExceptionHandling)      for (Function::iterator I = Fn.begin(), E = Fn.end(); I != E; ++I)        if (InvokeInst *Invoke = dyn_cast<InvokeInst>(I->getTerminator()))          // Mark landing pad. @@ -4762,7 +4757,7 @@ void SelectionDAGISel::BuildSelectionDAG(SelectionDAG &DAG, BasicBlock *LLVMBB,    MachineModuleInfo *MMI = DAG.getMachineModuleInfo(); -  if (FuncInfo.needsExceptionHandling && MMI && BB->isLandingPad()) { +  if (ExceptionHandling && MMI && BB->isLandingPad()) {      // Add a label to mark the beginning of the landing pad.  Deletion of the      // landing pad can thus be detected via the MachineModuleInfo.      unsigned LabelID = MMI->addLandingPad(BB); diff --git a/lib/Target/PowerPC/PPCAsmPrinter.cpp b/lib/Target/PowerPC/PPCAsmPrinter.cpp index 4cc9d2a..2537d67 100644 --- a/lib/Target/PowerPC/PPCAsmPrinter.cpp +++ b/lib/Target/PowerPC/PPCAsmPrinter.cpp @@ -1086,9 +1086,8 @@ bool DarwinAsmPrinter::doFinalization(Module &M) {    O << "\n"; -  if (TAI->doesSupportExceptionHandling() && MMI) { +  if (ExceptionHandling && TAI->doesSupportExceptionHandling() && MMI) {      // Add the (possibly multiple) personalities to the set of global values. -    // Only referenced functions get into the Personalities list.      const std::vector<Function *>& Personalities = MMI->getPersonalities();      for (std::vector<Function *>::const_iterator I = Personalities.begin(), diff --git a/lib/Target/PowerPC/PPCRegisterInfo.cpp b/lib/Target/PowerPC/PPCRegisterInfo.cpp index cc3b583..0e6bc69 100644 --- a/lib/Target/PowerPC/PPCRegisterInfo.cpp +++ b/lib/Target/PowerPC/PPCRegisterInfo.cpp @@ -20,7 +20,6 @@  #include "PPCFrameInfo.h"  #include "PPCSubtarget.h"  #include "llvm/Constants.h" -#include "llvm/Function.h"  #include "llvm/Type.h"  #include "llvm/CodeGen/ValueTypes.h"  #include "llvm/CodeGen/MachineInstrBuilder.h" @@ -947,8 +946,6 @@ PPCRegisterInfo::emitPrologue(MachineFunction &MF) const {    MachineBasicBlock::iterator MBBI = MBB.begin();    MachineFrameInfo *MFI = MF.getFrameInfo();    MachineModuleInfo *MMI = MFI->getMachineModuleInfo(); -  bool needsFrameInfo = (MMI && MMI->hasDebugInfo()) || -       ExceptionHandling || !MF.getFunction()->doesNotThrow();    // Prepare for frame info.    unsigned FrameLabelId = 0; @@ -1022,7 +1019,7 @@ PPCRegisterInfo::emitPrologue(MachineFunction &MF) const {    unsigned TargetAlign = MF.getTarget().getFrameInfo()->getStackAlignment();    unsigned MaxAlign = MFI->getMaxAlignment(); -  if (needsFrameInfo) { +  if (MMI && MMI->needsFrameInfo()) {      // Mark effective beginning of when frame pointer becomes valid.      FrameLabelId = MMI->NextLabelID();      BuildMI(MBB, MBBI, TII.get(PPC::LABEL)).addImm(FrameLabelId).addImm(0); @@ -1098,7 +1095,7 @@ PPCRegisterInfo::emitPrologue(MachineFunction &MF) const {      }    } -  if (needsFrameInfo) { +  if (MMI && MMI->needsFrameInfo()) {      std::vector<MachineMove> &Moves = MMI->getFrameMoves();      if (NegFrameSize) { diff --git a/lib/Target/X86/X86AsmPrinter.cpp b/lib/Target/X86/X86AsmPrinter.cpp index e1bc65f..98e7d9c 100644 --- a/lib/Target/X86/X86AsmPrinter.cpp +++ b/lib/Target/X86/X86AsmPrinter.cpp @@ -381,9 +381,9 @@ bool X86SharedAsmPrinter::doFinalization(Module &M) {      O << "\n"; -    if (TAI->doesSupportExceptionHandling() && MMI && !Subtarget->is64Bit()) { +    if (ExceptionHandling && TAI->doesSupportExceptionHandling() && MMI && +        !Subtarget->is64Bit()) {        // Add the (possibly multiple) personalities to the set of global values. -      // Only referenced functions get into the Personalities list.        const std::vector<Function *>& Personalities = MMI->getPersonalities();        for (std::vector<Function *>::const_iterator I = Personalities.begin(), diff --git a/lib/Target/X86/X86RegisterInfo.cpp b/lib/Target/X86/X86RegisterInfo.cpp index 95026f2..5cd2fbe 100644 --- a/lib/Target/X86/X86RegisterInfo.cpp +++ b/lib/Target/X86/X86RegisterInfo.cpp @@ -504,8 +504,6 @@ void X86RegisterInfo::emitPrologue(MachineFunction &MF) const {    MachineModuleInfo *MMI = MFI->getMachineModuleInfo();    X86MachineFunctionInfo *X86FI = MF.getInfo<X86MachineFunctionInfo>();    MachineBasicBlock::iterator MBBI = MBB.begin(); -  bool needsFrameInfo = (MMI && MMI->hasDebugInfo()) || -      ExceptionHandling || !Fn->doesNotThrow();    // Prepare for frame info.    unsigned FrameLabelId = 0; @@ -538,7 +536,7 @@ void X86RegisterInfo::emitPrologue(MachineFunction &MF) const {        .addReg(FramePtr);      NumBytes -= SlotSize; -    if (needsFrameInfo) { +    if (MMI && MMI->needsFrameInfo()) {        // Mark effective beginning of when frame pointer becomes valid.        FrameLabelId = MMI->NextLabelID();        BuildMI(MBB, MBBI, TII.get(X86::LABEL)).addImm(FrameLabelId).addImm(0); @@ -550,7 +548,7 @@ void X86RegisterInfo::emitPrologue(MachineFunction &MF) const {    }    unsigned ReadyLabelId = 0; -  if (needsFrameInfo) { +  if (MMI && MMI->needsFrameInfo()) {      // Mark effective beginning of when frame pointer is ready.      ReadyLabelId = MMI->NextLabelID();      BuildMI(MBB, MBBI, TII.get(X86::LABEL)).addImm(ReadyLabelId).addImm(0); @@ -609,7 +607,7 @@ void X86RegisterInfo::emitPrologue(MachineFunction &MF) const {      }    } -  if (needsFrameInfo) { +  if (MMI && MMI->needsFrameInfo()) {      std::vector<MachineMove> &Moves = MMI->getFrameMoves();      const TargetData *TD = MF.getTarget().getTargetData(); diff --git a/lib/Transforms/Utils/LowerInvoke.cpp b/lib/Transforms/Utils/LowerInvoke.cpp index f546c33..7f0ef85 100644 --- a/lib/Transforms/Utils/LowerInvoke.cpp +++ b/lib/Transforms/Utils/LowerInvoke.cpp @@ -47,9 +47,6 @@  #include "llvm/Support/CommandLine.h"  #include "llvm/Support/Compiler.h"  #include "llvm/Target/TargetLowering.h" -#include "llvm/Target/TargetOptions.h" -#include "llvm/Target/TargetMachine.h" -#include "llvm/Target/TargetAsmInfo.h"  #include <csetjmp>  #include <set>  using namespace llvm; @@ -595,12 +592,6 @@ bool LowerInvoke::insertExpensiveEHSupport(Function &F) {  }  bool LowerInvoke::runOnFunction(Function &F) { -  // If we will be generating exception info, don't do anything here. -  if ((ExceptionHandling || !F.doesNotThrow()) && -      TLI && -      TLI->getTargetMachine().getTargetAsmInfo()-> -                              doesSupportExceptionHandling()) -    return false;    if (ExpensiveEHSupport)      return insertExpensiveEHSupport(F);    else | 
