Skip to content
  1. Oct 05, 2013
    • Manman Ren's avatar
      Debug Info: In DIBuilder, the derived-from field of a DW_TAG_pointer_type · b3388601
      Manman Ren authored
      is updated to use DITypeRef.
      
      Move isUnsignedDIType and getOriginalTypeSize from DebugInfo.h to be static
      helper functions in DwarfCompileUnit. We already have a static helper function
      "isTypeSigned" in DwarfCompileUnit, and a pointer to DwarfDebug is added to
      resolve the derived-from field. All three functions need to go across link
      for derived-from fields, so we need to get hold of a type identifier map.
      
      A pointer to DwarfDebug is also added to DbgVariable in order to resolve the
      derived-from field.
      
      Debug info verifier is updated to check a derived-from field is a TypeRef.
      Verifier will not go across link for derived-from fields, in debug info finder,
      we go across the link to add derived-from fields to types.
      
      Function getDICompositeType is only used by dragonegg and since dragonegg does
      not generate identifier for types, we use an empty map to resolve the
      derived-from field.
      
      When printing a derived-from field, we use DITypeRef::getName to either return
      the type identifier or getName of the DIType.
      
      A paired commit at clang is required due to changes to DIBuilder.
      
      llvm-svn: 192018
      b3388601
  2. Oct 04, 2013
  3. Oct 03, 2013
    • David Blaikie's avatar
      DebugInfo: Avoid redundantly adding child DIEs to parents. · 811bfe63
      David Blaikie authored
      DIE::addChild had a shortcircuit that silently no-op'd when a child was
      readded to the same parent. This hid some quirky/redundant code in
      DwarfDebug/CompileUnit. By removing that functionality and replacing it
      with an assert I was able to find and cleanup those cases, mostly
      centering around adding members to types in various circumstances.
      
      1) The original oddity I noticed while working on type units (which
      actually was helping me in the short term, by accident) was the
      addToContextOwner call in constructTypeDIE. This call was completely
      bogus (why was it only done for non-virtual types? what relevance does
      that have at all) and redundant with the more uniform addToContextOwner
      made in getOrCreateTypeDIE.
      
      2) If a member function definition was visited (createSubprogramDIE), it
      would attempt to build the member function declaration. The declaration
      DIE would then be added to its context, but in building the context (the
      type for which this function is a member) the members of the type would
      be added to the type automatically, so by the time the context was
      constructed, the member function was already associated with it.
      
      3) The same as (2) but without the member function being constructed
      first. Whenever a type was constructed, the members would be created and
      member functions would be created by getOrCreateSubprogramDIE - this
      would lead to the subprogram being added to the (incomplete) type
      already, then the general member-construction code would add it again.
      
      llvm-svn: 191928
      811bfe63
    • Eric Christopher's avatar
      Make sure we emit a section for pubnames even if that section is · c948b9df
      Eric Christopher authored
      going to be empty. This is particularly important for the gnu
      pubnames case since we're emitting a relocation to the section.
      
      llvm-svn: 191915
      c948b9df
    • Eric Christopher's avatar
      Fix cut and paste typo. · f976c77e
      Eric Christopher authored
      llvm-svn: 191914
      f976c77e
    • Alexey Samsonov's avatar
      Remove wild .debug_aranges entries generated from unimportant labels · 4436bf03
      Alexey Samsonov authored
      r191052 added emitting .debug_aranges to Clang, but this
      functionality is broken: it uses all MC labels added in DWARF Asm
      printer, including the labels for build relocations between
      different DWARF sections, like .Lsection_line or .Ldebug_loc0.
      
      As a result, if any DIE .debug_info would contain "DW_AT_location=0x123"
      attribute, .debug_aranges would also contain a range starting from 0x123,
      breaking tools that rely on this section.
      
      This patch fixes this by using only MC labels that corresponds to the
      addresses in the user program.
      
      llvm-svn: 191884
      4436bf03
  4. Oct 02, 2013
    • Manman Ren's avatar
      Debug Info: In DIBuilder, the derived-from field of a DW_TAG_pointer_type · 9a0a6703
      Manman Ren authored
      is updated to use DITypeRef.
      
      Move isUnsignedDIType and getOriginalTypeSize from DebugInfo.h to be static
      helper functions in DwarfCompileUnit. We already have a static helper function
      "isTypeSigned" in DwarfCompileUnit, and a pointer to DwarfDebug is added to
      resolve the derived-from field. All three functions need to go across link
      for derived-from fields, so we need to get hold of a type identifier map.
      
      A pointer to DwarfDebug is also added to DbgVariable in order to resolve the
      derived-from field.
      
      Debug info verifier is updated to check a derived-from field is a TypeRef.
      Verifier will not go across link for derived-from fields, in debug info finder,
      we go across the link to add derived-from fields to types.
      
      Function getDICompositeType is only used by dragonegg and since dragonegg does
      not generate identifier for types, we use an empty map to resolve the
      derived-from field.
      
      When printing a derived-from field, we use DITypeRef::getName to either return
      the type identifier or getName of the DIType.
      
      A paired commit at clang is required due to changes to DIBuilder.
      
      llvm-svn: 191800
      9a0a6703
  5. Oct 01, 2013
    • Manman Ren's avatar
      Debug Info: remove duplication of DIEs when a DIE is part of the type system · 8990d7ee
      Manman Ren authored
      and it is shared across CUs.
      
      We add a few maps in DwarfDebug to map MDNodes for the type system to the
      corresponding DIEs: MDTypeNodeToDieMap, MDSPNodeToDieMap, and
      MDStaticMemberNodeToDieMap. These DIEs can be shared across CUs, that is why we
      keep the maps in DwarfDebug instead of CompileUnit.
      
      Sometimes, when we try to add an attribute to a DIE, the DIE is not yet added
      to its owner yet, so we don't know whether we should use ref_addr or ref4.
      We create a worklist that will be processed during finalization to add
      attributes with the correct form (ref_addr or ref4).
      
      We add addDIEEntry to DwarfDebug to be a wrapper around DIE->addValue. It checks
      whether we know the correct form, if not, we update the worklist
      (DIEEntryWorklist).
      
      A testing case is added to show that we only create a single DIE for a type
      MDNode and we use ref_addr to refer to the type DIE.
      
      llvm-svn: 191792
      8990d7ee
    • Eric Christopher's avatar
      Add the DW_AT_GNU_ranges_base attribute if we've emitted any ranges · 9a08f9e5
      Eric Christopher authored
      into the debug_ranges section.
      
      llvm-svn: 191721
      9a08f9e5
    • Eric Christopher's avatar
      Update comments. · 1d06eb5d
      Eric Christopher authored
      llvm-svn: 191720
      1d06eb5d
    • Eric Christopher's avatar
      The DW_AT_GNU_pubnames/pubtypes attributes are actually form · 39eebfad
      Eric Christopher authored
      SEC_OFFSET from the beginning of the section so go ahead and emit
      a label at the beginning of each one.
      
      llvm-svn: 191710
      39eebfad
  6. Sep 28, 2013
  7. Sep 24, 2013
  8. Sep 23, 2013
    • Eric Christopher's avatar
      Handle gnu pubtypes sections: · 261d2343
      Eric Christopher authored
      a) Make sure we are emitting the correct section in our section labels
      when we begin the module.
      b) Make sure we are emitting the correct pubtypes section in the
      presence of gnu pubtypes.
      c) For C++ struct, union, class, and enumeration types are default
      external.
      
      llvm-svn: 191225
      261d2343
    • Richard Mitton's avatar
      Fixed debug_aranges handling for common symbols. · 089ed89e
      Richard Mitton authored
      The size of common symbols is now tracked correctly, so they can be listed in the arange section without needing knowledge of other following symbols.
      
      .comm (and .lcomm) do not indicate to the system assembler any particular section to use, so we have to treat them as having no section.
      
      Test case update to account for this.
      
      llvm-svn: 191210
      089ed89e
  9. Sep 21, 2013
  10. Sep 20, 2013
  11. Sep 19, 2013
  12. Sep 13, 2013
  13. Sep 11, 2013
  14. Sep 10, 2013
    • Eric Christopher's avatar
      Hoist section call out of loop. · 13b99d2a
      Eric Christopher authored
      llvm-svn: 190440
      13b99d2a
    • Manman Ren's avatar
      Debug Info: create scope children DIEs when the scope DIE is not null. · 2312ed35
      Manman Ren authored
      We try to create the scope children DIEs after we create the scope DIE. But
      to avoid emitting empty lexical block DIE, we first check whether a scope
      DIE is going to be null, then create the scope children if it is not null.
      From the number of children, we decide whether to actually create the scope DIE.
      
      This patch also removes an early exit which checks for a special condition.
      It also removes deletion of un-used children DIEs that are generated
      because we used to generate children DIEs before the scope DIE.
      
      Deletion of un-used children DIEs may cause problem because we sometimes keep
      created DIEs in a member variable of a CU.
      
      llvm-svn: 190421
      2312ed35
    • Manman Ren's avatar
      Debug Info: define a DIRef template. · 34b3dcc3
      Manman Ren authored
      Specialize the constructors for DIRef<DIScope> and DIRef<DIType> to make sure
      the Value is indeed a scope ref and a type ref.
      
      Use DIScopeRef for DIScope::getContext and DIType::getContext and use DITypeRef
      for getContainingType and getClassType.
      
      DIScope::generateRef now returns a DIScopeRef instead of a "Value *" for
      readability and type safety.
      
      llvm-svn: 190418
      34b3dcc3
    • Manman Ren's avatar
      Debug Info: move DIScope::getContext back from DwarfDebug. · de897a36
      Manman Ren authored
      This partially reverts r190330. DIScope::getContext now returns DIScopeRef
      instead of DIScope. We construct a DIScopeRef from DIScope when we are
      dealing with subprogram, lexical block or name space.
      
      llvm-svn: 190362
      de897a36
  15. Sep 09, 2013
    • Eric Christopher's avatar
      Always add global names. We're adding them in the rest of the code · ba506db4
      Eric Christopher authored
      as well as types.
      
      No functional change as they're not emitted unless the option
      is true anyhow.
      
      llvm-svn: 190346
      ba506db4
    • Eric Christopher's avatar
      Rename for consistency. · 5f93bb92
      Eric Christopher authored
      llvm-svn: 190345
      5f93bb92
    • Manman Ren's avatar
      Debug Info: Use DIScopeRef for DIType::getContext. · 116868ea
      Manman Ren authored
          
      In DIBuilder, the context field of a TAG_member is updated to use the
      scope reference. Verifier is updated accordingly.
          
      DebugInfoFinder now needs to generate a type identifier map to have
      access to the actual scope. Same applies for BreakpointPrinter.
          
      processModule of DebugInfoFinder is called during initialization phase
      of the verifier to make sure the type identifier map is constructed early
      enough.
          
      We are now able to unique a simple class as demonstrated by the added
      testing case.
      
      llvm-svn: 190334
      116868ea
    • Manman Ren's avatar
      Debug Info: move DIScope::getContext to DwarfDebug. · 33796c5e
      Manman Ren authored
          
      DIScope::getContext is a wrapper function that calls the specific getContext
      method on each subclass. When we switch DIType::getContext to return DIScopeRef
      instead of DIScope, DIScope::getContext can no longer return a DIScope without
      a type identifier map.
          
      DIScope::getContext is only used by DwarfDebug, so we move it to DwarfDebug
      to have easy access to the type identifier map.
      
      llvm-svn: 190330
      33796c5e
    • Manman Ren's avatar
      Debug Info: Move isSubprogramContext from DebugInfo to DwarfDebug. · 3eb9dffc
      Manman Ren authored
      This helper function needs the type identifier map when we switch
      DIType::getContext to return DIScopeRef instead of DIScope.
      
      Since isSubprogramContext is used by DwarfDebug only, We move it to DwarfDebug
      to have easy access to the map.
      
      llvm-svn: 190325
      3eb9dffc
    • Manman Ren's avatar
      Debug Info: Rename DITypeRef to DIScopeRef. · 856191b0
      Manman Ren authored
      A reference to a scope is more general than a reference to a type since
      DIType is a subclass of DIScope.
      
      A reference to a type can be either an identifier for the type or
      the DIType itself, while a reference to a scope can be either an
      identifier for the type (when the scope is indeed a type) or the
      DIScope itself. A reference to a type and a reference to a scope
      will be resolved in the same way. The only difference is in the
      verifier when a field is a reference to a type (i.e. the containing
      type field of a DICompositeType) or a field is a reference to a scope
      (i.e. the context field of a DIType).
      
      This is to get ready for switching DIType::getContext to return
      DIScopeRef instead of DIScope.
      
      Tighten up isTypeRef and isScopeRef to make sure the identifier is not
      empty and the MDNode is DIType for TypeRef and DIScope for ScopeRef.
      
      llvm-svn: 190322
      856191b0
  16. Sep 05, 2013
    • Manman Ren's avatar
      Debug Info: Use identifier to reference DIType in base type field of · 60352032
      Manman Ren authored
      ptr_to_member.
      
      We introduce a new class DITypeRef that represents a reference to a DIType.
      It wraps around a Value*, which can be either an identifier in MDString
      or an actual MDNode. The class has a helper function "resolve" that
      finds the actual MDNode for a given DITypeRef.
      
      We specialize getFieldAs to return a field that is a reference to a
      DIType. To correctly access the base type field of ptr_to_member,
      getClassType now calls getFieldAs<DITypeRef> to return a DITypeRef.
      
      Also add a typedef for DITypeIdentifierMap and a helper
      generateDITypeIdentifierMap in DebugInfo.h. In DwarfDebug.cpp, we keep
      a DITypeIdentifierMap and call generateDITypeIdentifierMap to actually
      populate the map.
      
      Verifier is updated accordingly.
      
      llvm-svn: 190081
      60352032
Loading