diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2015-01-31 19:27:28 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2015-01-31 19:27:28 +0000 | 
| commit | ec304151b74f9254d7029ee4d197ce1f7cbe501a (patch) | |
| tree | 63e4ed55e4fbb581fd4731d44a327a7b3278e0a1 /lib/CodeGen | |
| parent | 67c32a98315f785a9ec9d531c1f571a0196c7463 (diff) | |
Diffstat (limited to 'lib/CodeGen')
| -rw-r--r-- | lib/CodeGen/AsmPrinter/DwarfUnit.cpp | 7 | ||||
| -rw-r--r-- | lib/CodeGen/MachineFunctionPass.cpp | 28 | 
2 files changed, 19 insertions, 16 deletions
| diff --git a/lib/CodeGen/AsmPrinter/DwarfUnit.cpp b/lib/CodeGen/AsmPrinter/DwarfUnit.cpp index 3d3da2ac1d312..455258e81e6d0 100644 --- a/lib/CodeGen/AsmPrinter/DwarfUnit.cpp +++ b/lib/CodeGen/AsmPrinter/DwarfUnit.cpp @@ -626,10 +626,7 @@ static uint64_t getBaseTypeSize(DwarfDebug *DD, DIDerivedType Ty) {    DIType BaseType = DD->resolve(Ty.getTypeDerivedFrom()); -  // If this type is not derived from any type or the type is a declaration then -  // take conservative approach. -  if (!BaseType.isValid() || BaseType.isForwardDecl()) -    return Ty.getSizeInBits(); +  assert(BaseType.isValid());    // If this is a derived type, go ahead and get the base type, unless it's a    // reference then it's just the size of the field. Pointer types have no need @@ -1473,7 +1470,7 @@ void DwarfUnit::constructMemberDIE(DIE &Buffer, DIDerivedType DT) {      uint64_t FieldSize = getBaseTypeSize(DD, DT);      uint64_t OffsetInBytes; -    if (Size != FieldSize) { +    if (FieldSize && Size != FieldSize) {        // Handle bitfield, assume bytes are 8 bits.        addUInt(MemberDie, dwarf::DW_AT_byte_size, None, FieldSize/8);        addUInt(MemberDie, dwarf::DW_AT_bit_size, None, Size); diff --git a/lib/CodeGen/MachineFunctionPass.cpp b/lib/CodeGen/MachineFunctionPass.cpp index 789f2042a0731..2f076b6734d95 100644 --- a/lib/CodeGen/MachineFunctionPass.cpp +++ b/lib/CodeGen/MachineFunctionPass.cpp @@ -11,11 +11,19 @@  //  //===----------------------------------------------------------------------===// -#include "llvm/IR/Function.h" +#include "llvm/CodeGen/MachineFunctionPass.h"  #include "llvm/Analysis/AliasAnalysis.h" +#include "llvm/Analysis/DominanceFrontier.h" +#include "llvm/Analysis/IVUsers.h" +#include "llvm/Analysis/LoopInfo.h" +#include "llvm/Analysis/LoopInfo.h" +#include "llvm/Analysis/MemoryDependenceAnalysis.h" +#include "llvm/Analysis/ScalarEvolution.h"  #include "llvm/CodeGen/MachineFunctionAnalysis.h" -#include "llvm/CodeGen/MachineFunctionPass.h"  #include "llvm/CodeGen/Passes.h" +#include "llvm/CodeGen/StackProtector.h" +#include "llvm/IR/Dominators.h" +#include "llvm/IR/Function.h"  using namespace llvm;  Pass *MachineFunctionPass::createPrinterPass(raw_ostream &O, @@ -43,15 +51,13 @@ void MachineFunctionPass::getAnalysisUsage(AnalysisUsage &AU) const {    // because CodeGen overloads that to mean preserving the MachineBasicBlock    // CFG in addition to the LLVM IR CFG.    AU.addPreserved<AliasAnalysis>(); -  AU.addPreserved("scalar-evolution"); -  AU.addPreserved("iv-users"); -  AU.addPreserved("memdep"); -  AU.addPreserved("live-values"); -  AU.addPreserved("domtree"); -  AU.addPreserved("domfrontier"); -  AU.addPreserved("loops"); -  AU.addPreserved("lda"); -  AU.addPreserved("stack-protector"); +  AU.addPreserved<DominanceFrontier>(); +  AU.addPreserved<DominatorTreeWrapperPass>(); +  AU.addPreserved<IVUsers>(); +  AU.addPreserved<LoopInfo>(); +  AU.addPreserved<MemoryDependenceAnalysis>(); +  AU.addPreserved<ScalarEvolution>(); +  AU.addPreserved<StackProtector>();    FunctionPass::getAnalysisUsage(AU);  } | 
