diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2015-06-10 19:12:52 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2015-06-10 19:12:52 +0000 | 
| commit | 97bc6c731eabb6212f094302b94f3f0f9534ebdf (patch) | |
| tree | 471dda8f5419bb81beedeeef3b8975938d7e7340 /contrib/llvm/lib/CodeGen/AsmPrinter/DwarfUnit.cpp | |
| parent | 3adc74c768226112b373d0bcacee73521b0aed2a (diff) | |
| parent | 85d8b2bbe386bcfe669575d05b61482d7be07e5d (diff) | |
Notes
Diffstat (limited to 'contrib/llvm/lib/CodeGen/AsmPrinter/DwarfUnit.cpp')
| -rw-r--r-- | contrib/llvm/lib/CodeGen/AsmPrinter/DwarfUnit.cpp | 77 | 
1 files changed, 22 insertions, 55 deletions
| diff --git a/contrib/llvm/lib/CodeGen/AsmPrinter/DwarfUnit.cpp b/contrib/llvm/lib/CodeGen/AsmPrinter/DwarfUnit.cpp index 04836c614044..907f6706bc6a 100644 --- a/contrib/llvm/lib/CodeGen/AsmPrinter/DwarfUnit.cpp +++ b/contrib/llvm/lib/CodeGen/AsmPrinter/DwarfUnit.cpp @@ -70,7 +70,6 @@ DwarfUnit::DwarfUnit(unsigned UID, dwarf::Tag UnitTag,        DD(DW), DU(DWU), IndexTyDie(nullptr), Section(nullptr) {    assert(UnitTag == dwarf::DW_TAG_compile_unit ||           UnitTag == dwarf::DW_TAG_type_unit); -  DIEIntegerOne = new (DIEValueAllocator) DIEInteger(1);  }  DwarfTypeUnit::DwarfTypeUnit(unsigned UID, DwarfCompileUnit &CU, AsmPrinter *A, @@ -89,11 +88,6 @@ DwarfUnit::~DwarfUnit() {      DIELocs[j]->~DIELoc();  } -DIEEntry *DwarfUnit::createDIEEntry(DIE &Entry) { -  DIEEntry *Value = new (DIEValueAllocator) DIEEntry(Entry); -  return Value; -} -  int64_t DwarfUnit::getDefaultLowerBound() const {    switch (getLanguage()) {    default: @@ -190,18 +184,16 @@ void DwarfUnit::insertDIE(const DINode *Desc, DIE *D) {  void DwarfUnit::addFlag(DIE &Die, dwarf::Attribute Attribute) {    if (DD->getDwarfVersion() >= 4) -    Die.addValue(Attribute, dwarf::DW_FORM_flag_present, DIEIntegerOne); +    Die.addValue(Attribute, dwarf::DW_FORM_flag_present, DIEInteger(1));    else -    Die.addValue(Attribute, dwarf::DW_FORM_flag, DIEIntegerOne); +    Die.addValue(Attribute, dwarf::DW_FORM_flag, DIEInteger(1));  }  void DwarfUnit::addUInt(DIE &Die, dwarf::Attribute Attribute,                          Optional<dwarf::Form> Form, uint64_t Integer) {    if (!Form)      Form = DIEInteger::BestForm(false, Integer); -  DIEValue *Value = Integer == 1 ? DIEIntegerOne : new (DIEValueAllocator) -                        DIEInteger(Integer); -  Die.addValue(Attribute, *Form, Value); +  Die.addValue(Attribute, *Form, DIEInteger(Integer));  }  void DwarfUnit::addUInt(DIE &Block, dwarf::Form Form, uint64_t Integer) { @@ -212,8 +204,7 @@ void DwarfUnit::addSInt(DIE &Die, dwarf::Attribute Attribute,                          Optional<dwarf::Form> Form, int64_t Integer) {    if (!Form)      Form = DIEInteger::BestForm(true, Integer); -  DIEValue *Value = new (DIEValueAllocator) DIEInteger(Integer); -  Die.addValue(Attribute, *Form, Value); +  Die.addValue(Attribute, *Form, DIEInteger(Integer));  }  void DwarfUnit::addSInt(DIELoc &Die, Optional<dwarf::Form> Form, @@ -225,14 +216,12 @@ void DwarfUnit::addString(DIE &Die, dwarf::Attribute Attribute,                            StringRef String) {    Die.addValue(Attribute,                 isDwoUnit() ? dwarf::DW_FORM_GNU_str_index : dwarf::DW_FORM_strp, -               new (DIEValueAllocator)                 DIEString(DU->getStringPool().getEntry(*Asm, String)));  }  void DwarfUnit::addLabel(DIE &Die, dwarf::Attribute Attribute, dwarf::Form Form,                           const MCSymbol *Label) { -  DIEValue *Value = new (DIEValueAllocator) DIELabel(Label); -  Die.addValue(Attribute, Form, Value); +  Die.addValue(Attribute, Form, DIELabel(Label));  }  void DwarfUnit::addLabel(DIELoc &Die, dwarf::Form Form, const MCSymbol *Label) { @@ -265,12 +254,12 @@ void DwarfUnit::addOpAddress(DIELoc &Die, const MCSymbol *Sym) {  void DwarfUnit::addLabelDelta(DIE &Die, dwarf::Attribute Attribute,                                const MCSymbol *Hi, const MCSymbol *Lo) { -  DIEValue *Value = new (DIEValueAllocator) DIEDelta(Hi, Lo); -  Die.addValue(Attribute, dwarf::DW_FORM_data4, Value); +  Die.addValue(Attribute, dwarf::DW_FORM_data4, +               new (DIEValueAllocator) DIEDelta(Hi, Lo));  }  void DwarfUnit::addDIEEntry(DIE &Die, dwarf::Attribute Attribute, DIE &Entry) { -  addDIEEntry(Die, Attribute, createDIEEntry(Entry)); +  addDIEEntry(Die, Attribute, DIEEntry(Entry));  }  void DwarfUnit::addDIETypeSignature(DIE &Die, const DwarfTypeUnit &Type) { @@ -281,13 +270,13 @@ void DwarfUnit::addDIETypeSignature(DIE &Die, const DwarfTypeUnit &Type) {    addFlag(Die, dwarf::DW_AT_declaration);    Die.addValue(dwarf::DW_AT_signature, dwarf::DW_FORM_ref_sig8, -               new (DIEValueAllocator) DIETypeSignature(Type)); +               DIETypeSignature(Type));  }  void DwarfUnit::addDIEEntry(DIE &Die, dwarf::Attribute Attribute, -                            DIEEntry *Entry) { +                            DIEEntry Entry) {    const DIE *DieCU = Die.getUnitOrNull(); -  const DIE *EntryCU = Entry->getEntry().getUnitOrNull(); +  const DIE *EntryCU = Entry.getEntry().getUnitOrNull();    if (!DieCU)      // We assume that Die belongs to this CU, if it is not linked to any CU yet.      DieCU = &getUnitDie(); @@ -301,8 +290,7 @@ void DwarfUnit::addDIEEntry(DIE &Die, dwarf::Attribute Attribute,  DIE &DwarfUnit::createAndAddDIE(unsigned Tag, DIE &Parent, const DINode *N) {    assert(Tag != dwarf::DW_TAG_auto_variable &&           Tag != dwarf::DW_TAG_arg_variable); -  Parent.addChild(make_unique<DIE>((dwarf::Tag)Tag)); -  DIE &Die = *Parent.getChildren().back(); +  DIE &Die = Parent.addChild(make_unique<DIE>((dwarf::Tag)Tag));    if (N)      insertDIE(N, &Die);    return Die; @@ -471,7 +459,7 @@ void DwarfUnit::addBlockByrefAddress(const DbgVariable &DV, DIE &Die,    // Decode the original location, and use that as the start of the byref    // variable's location. -  DIELoc *Loc = new (DIEValueAllocator) DIELoc(); +  DIELoc *Loc = new (DIEValueAllocator) DIELoc;    bool validReg;    if (Location.isReg()) @@ -588,7 +576,7 @@ static uint64_t getBaseTypeSize(DwarfDebug *DD, const DIDerivedType *Ty) {  void DwarfUnit::addConstantFPValue(DIE &Die, const MachineOperand &MO) {    assert(MO.isFPImm() && "Invalid machine operand!"); -  DIEBlock *Block = new (DIEValueAllocator) DIEBlock(); +  DIEBlock *Block = new (DIEValueAllocator) DIEBlock;    APFloat FPImm = MO.getFPImm()->getValueAPF();    // Get the raw data form of the floating point. @@ -644,7 +632,7 @@ void DwarfUnit::addConstantValue(DIE &Die, const APInt &Val, bool Unsigned) {      return;    } -  DIEBlock *Block = new (DIEValueAllocator) DIEBlock(); +  DIEBlock *Block = new (DIEValueAllocator) DIEBlock;    // Get the raw data form of the large APInt.    const uint64_t *Ptr64 = Val.getRawData(); @@ -777,22 +765,7 @@ void DwarfUnit::updateAcceleratorTables(const DIScope *Context,  void DwarfUnit::addType(DIE &Entity, const DIType *Ty,                          dwarf::Attribute Attribute) {    assert(Ty && "Trying to add a type that doesn't exist?"); - -  // Check for pre-existence. -  DIEEntry *Entry = getDIEEntry(Ty); -  // If it exists then use the existing value. -  if (Entry) { -    addDIEEntry(Entity, Attribute, Entry); -    return; -  } - -  // Construct type. -  DIE *Buffer = getOrCreateTypeDIE(Ty); - -  // Set up proxy. -  Entry = createDIEEntry(*Buffer); -  insertDIEEntry(Ty, Entry); -  addDIEEntry(Entity, Attribute, Entry); +  addDIEEntry(Entity, Attribute, DIEEntry(*getOrCreateTypeDIE(Ty)));  }  std::string DwarfUnit::getParentContextString(const DIScope *Context) const { @@ -969,12 +942,6 @@ void DwarfUnit::constructTypeDIE(DIE &Buffer, const DICompositeType *CTy) {          if (unsigned PropertyAttributes = Property->getAttributes())            addUInt(ElemDie, dwarf::DW_AT_APPLE_property_attribute, None,                    PropertyAttributes); - -        DIEEntry *Entry = getDIEEntry(Element); -        if (!Entry) { -          Entry = createDIEEntry(ElemDie); -          insertDIEEntry(Element, Entry); -        }        }      } @@ -1061,7 +1028,7 @@ void DwarfUnit::constructTemplateValueParameterDIE(      else if (GlobalValue *GV = mdconst::dyn_extract<GlobalValue>(Val)) {        // For declaration non-type template parameters (such as global values and        // functions) -      DIELoc *Loc = new (DIEValueAllocator) DIELoc(); +      DIELoc *Loc = new (DIEValueAllocator) DIELoc;        addOpAddress(*Loc, Asm->getSymbol(GV));        // Emit DW_OP_stack_value to use the address as the immediate value of the        // parameter, rather than a pointer to it. @@ -1354,7 +1321,7 @@ void DwarfUnit::constructMemberDIE(DIE &Buffer, const DIDerivedType *DT) {      // expression to extract appropriate offset from vtable.      // BaseAddr = ObAddr + *((*ObAddr) - Offset) -    DIELoc *VBaseLocationDie = new (DIEValueAllocator) DIELoc(); +    DIELoc *VBaseLocationDie = new (DIEValueAllocator) DIELoc;      addUInt(*VBaseLocationDie, dwarf::DW_FORM_data1, dwarf::DW_OP_dup);      addUInt(*VBaseLocationDie, dwarf::DW_FORM_data1, dwarf::DW_OP_deref);      addUInt(*VBaseLocationDie, dwarf::DW_FORM_data1, dwarf::DW_OP_constu); @@ -1393,7 +1360,7 @@ void DwarfUnit::constructMemberDIE(DIE &Buffer, const DIDerivedType *DT) {        OffsetInBytes = DT->getOffsetInBits() >> 3;      if (DD->getDwarfVersion() <= 2) { -      DIELoc *MemLocationDie = new (DIEValueAllocator) DIELoc(); +      DIELoc *MemLocationDie = new (DIEValueAllocator) DIELoc;        addUInt(*MemLocationDie, dwarf::DW_FORM_data1, dwarf::DW_OP_plus_uconst);        addUInt(*MemLocationDie, dwarf::DW_FORM_udata, OffsetInBytes);        addBlock(MemberDie, dwarf::DW_AT_data_member_location, MemLocationDie); @@ -1417,10 +1384,10 @@ void DwarfUnit::constructMemberDIE(DIE &Buffer, const DIDerivedType *DT) {              dwarf::DW_VIRTUALITY_virtual);    // Objective-C properties. -  if (MDNode *PNode = DT->getObjCProperty()) -    if (DIEEntry *PropertyDie = getDIEEntry(PNode)) +  if (DINode *PNode = DT->getObjCProperty()) +    if (DIE *PDie = getDIE(PNode))        MemberDie.addValue(dwarf::DW_AT_APPLE_property, dwarf::DW_FORM_ref4, -                         PropertyDie); +                         DIEEntry(*PDie));    if (DT->isArtificial())      addFlag(MemberDie, dwarf::DW_AT_artificial); | 
