diff options
| author | Greg Clayton <gclayton@apple.com> | 2016-03-30 20:14:35 +0000 | 
|---|---|---|
| committer | Greg Clayton <gclayton@apple.com> | 2016-03-30 20:14:35 +0000 | 
| commit | 2f869fe9d27c3364ba778701c84c4ad964770a1b (patch) | |
| tree | f4bd768ae884307160544a0887fb23bdc487b324 /lldb/source/Plugins/SymbolFile/DWARF/DWARFASTParserGo.cpp | |
| parent | a3cbf2a738042819bb2d7d4fae048e633d2588d2 (diff) | |
| download | bcm5719-llvm-2f869fe9d27c3364ba778701c84c4ad964770a1b.tar.gz bcm5719-llvm-2f869fe9d27c3364ba778701c84c4ad964770a1b.zip | |
When support for DWO files was added, there were two ways to pass lldb::user_id_t out to the rest of LLDB:
1 - DWARF in .o files with debug map in executable: we would place the compile unit index in the upper 32 bits of the 64 bit value and the lower 32 bits would be the DIE offset
2 - DWO: we would place the compile unit offset in the upper 32 bits of the 64 bit value and the lower 32 bits would be the DIE offset
There was a mixing and matching of this and it wasn't done consistently.
Major changes include:
The DIERef constructor that takes a lldb::user_id_t now requires a SymbolFileDWARF:
DIERef(lldb::user_id_t uid, SymbolFileDWARF *dwarf)
It is needed so that it can be decoded correctly. If it is DWARF in .o files with debug map in executable, then we get the right compile unit from the SymbolFileDWARFDebugMap, otherwise, we use the compile unit offset and DIE offset for DWO or normal DWARF.
The function:
lldb::user_id_t DIERef::GetUID() const;
Now becomes
lldb::user_id_t DIERef::GetUID(SymbolFileDWARF *dwarf) const;
Again, we need the DWARF file to encode it correctly.
This removes the need for "lldb::user_id_t SymbolFileDWARF::MakeUserID() const" and for bool SymbolFileDWARF::UserIDMatches (lldb::user_id_t uid) const". There were also many places were doing things inneficiently like:
1 - encode a dw_offset_t into a lldb::user_id_t
2 - call the public SymbolFile interface to resolve types using the lldb::user_id_t
3 - This would then decode the lldb::user_id_t into a DIERef, and then try to find that type.
There are many places that are now doing this more efficiently by storing DW_AT_type form values as DWARFFormValue objects and then making a DIERef from them and directly calling the underlying function to resolve the lldb_private::Type, lldb_private::CompilerType, lldb_private::CompilerDecl, lldb_private::CompilerDeclContext.
If there are any regressions in DWARF with DWO, we will need to fix any issues that arise since the original patch wasn't functional for the much more widely used DWARF in .o files with debug map.
<rdar://problem/25200976>
llvm-svn: 264909
Diffstat (limited to 'lldb/source/Plugins/SymbolFile/DWARF/DWARFASTParserGo.cpp')
| -rw-r--r-- | lldb/source/Plugins/SymbolFile/DWARF/DWARFASTParserGo.cpp | 40 | 
1 files changed, 21 insertions, 19 deletions
| diff --git a/lldb/source/Plugins/SymbolFile/DWARF/DWARFASTParserGo.cpp b/lldb/source/Plugins/SymbolFile/DWARF/DWARFASTParserGo.cpp index 12f14eeed83..346e2d63b90 100644 --- a/lldb/source/Plugins/SymbolFile/DWARF/DWARFASTParserGo.cpp +++ b/lldb/source/Plugins/SymbolFile/DWARF/DWARFASTParserGo.cpp @@ -144,7 +144,7 @@ DWARFASTParserGo::ParseTypeFromDWARF(const lldb_private::SymbolContext &sc, cons                          }                      } -                    DEBUG_PRINTF("0x%8.8" PRIx64 ": %s (\"%s\") type => 0x%8.8lx\n", dwarf->MakeUserID(die.GetOffset()), +                    DEBUG_PRINTF("0x%8.8" PRIx64 ": %s (\"%s\") type => 0x%8.8lx\n", die.GetID(),                                   DW_TAG_value_to_name(tag), type_name_cstr, encoding_uid);                      switch (tag) @@ -183,7 +183,7 @@ DWARFASTParserGo::ParseTypeFromDWARF(const lldb_private::SymbolContext &sc, cons                              break;                      } -                    type_sp.reset(new Type(dwarf->MakeUserID(die.GetOffset()), dwarf, type_name_const_str, byte_size, +                    type_sp.reset(new Type(die.GetID(), dwarf, type_name_const_str, byte_size,                                             NULL, encoding_uid, encoding_data_type, &decl, compiler_type, resolve_state));                      dwarf->m_die_to_type[die.GetDIE()] = type_sp.get(); @@ -254,7 +254,7 @@ DWARFASTParserGo::ParseTypeFromDWARF(const lldb_private::SymbolContext &sc, cons                          }                      } -                    DEBUG_PRINTF("0x%8.8" PRIx64 ": %s (\"%s\")\n", dwarf->MakeUserID(die.GetOffset()), +                    DEBUG_PRINTF("0x%8.8" PRIx64 ": %s (\"%s\")\n", die.GetID(),                                   DW_TAG_value_to_name(tag), type_name_cstr);                      bool compiler_type_was_created = false; @@ -265,7 +265,7 @@ DWARFASTParserGo::ParseTypeFromDWARF(const lldb_private::SymbolContext &sc, cons                          compiler_type = m_ast.CreateStructType(go_kind, type_name_const_str, byte_size);                      } -                    type_sp.reset(new Type(dwarf->MakeUserID(die.GetOffset()), dwarf, type_name_const_str, byte_size, +                    type_sp.reset(new Type(die.GetID(), dwarf, type_name_const_str, byte_size,                                             NULL, LLDB_INVALID_UID, Type::eEncodingIsUID, &decl, compiler_type,                                             Type::eResolveStateForward)); @@ -347,7 +347,7 @@ DWARFASTParserGo::ParseTypeFromDWARF(const lldb_private::SymbolContext &sc, cons                          }                      } -                    DEBUG_PRINTF("0x%8.8" PRIx64 ": %s (\"%s\")\n", dwarf->MakeUserID(die.GetOffset()), +                    DEBUG_PRINTF("0x%8.8" PRIx64 ": %s (\"%s\")\n", die.GetID(),                                   DW_TAG_value_to_name(tag), type_name_cstr);                      std::vector<CompilerType> function_param_types; @@ -363,7 +363,7 @@ DWARFASTParserGo::ParseTypeFromDWARF(const lldb_private::SymbolContext &sc, cons                      compiler_type = m_ast.CreateFunctionType(type_name_const_str, function_param_types.data(),                                                            function_param_types.size(), is_variadic); -                    type_sp.reset(new Type(dwarf->MakeUserID(die.GetOffset()), dwarf, type_name_const_str, 0, NULL, +                    type_sp.reset(new Type(die.GetID(), dwarf, type_name_const_str, 0, NULL,                                             LLDB_INVALID_UID, Type::eEncodingIsUID, &decl, compiler_type,                                             Type::eResolveStateFull));                      assert(type_sp.get()); @@ -410,7 +410,7 @@ DWARFASTParserGo::ParseTypeFromDWARF(const lldb_private::SymbolContext &sc, cons                              }                          } -                        DEBUG_PRINTF("0x%8.8" PRIx64 ": %s (\"%s\")\n", dwarf->MakeUserID(die.GetOffset()), +                        DEBUG_PRINTF("0x%8.8" PRIx64 ": %s (\"%s\")\n", die.GetID(),                                       DW_TAG_value_to_name(tag), type_name_cstr);                          Type *element_type = dwarf->ResolveTypeUID(type_die_offset); @@ -433,7 +433,7 @@ DWARFASTParserGo::ParseTypeFromDWARF(const lldb_private::SymbolContext &sc, cons                              {                                  compiler_type = m_ast.CreateArrayType(type_name_const_str, array_element_type, 0);                              } -                            type_sp.reset(new Type(dwarf->MakeUserID(die.GetOffset()), dwarf, type_name_const_str, +                            type_sp.reset(new Type(die.GetID(), dwarf, type_name_const_str,                                                     byte_stride, NULL, type_die_offset, Type::eEncodingIsUID, &decl,                                                     compiler_type, Type::eResolveStateFull));                              type_sp->SetEncodingType(element_type); @@ -463,7 +463,7 @@ DWARFASTParserGo::ParseTypeFromDWARF(const lldb_private::SymbolContext &sc, cons                  else if (sc.function != NULL && sc_parent_die)                  {                      symbol_context_scope = -                        sc.function->GetBlock(true).FindBlockByID(dwarf->MakeUserID(sc_parent_die.GetOffset())); +                        sc.function->GetBlock(true).FindBlockByID(sc_parent_die.GetID());                      if (symbol_context_scope == NULL)                          symbol_context_scope = sc.function;                  } @@ -510,7 +510,7 @@ DWARFASTParserGo::ParseChildParameters(const SymbolContext &sc,                  if (num_attributes > 0)                  {                      Declaration decl; -                    dw_offset_t param_type_die_offset = DW_INVALID_OFFSET; +                    DWARFFormValue param_type_die_offset;                      uint32_t i;                      for (i = 0; i < num_attributes; ++i) @@ -525,7 +525,7 @@ DWARFASTParserGo::ParseChildParameters(const SymbolContext &sc,                                      // = form_value.AsCString();                                      break;                                  case DW_AT_type: -                                    param_type_die_offset = form_value.Reference(); +                                    param_type_die_offset = form_value;                                      break;                                  case DW_AT_location:                                  //                          if (form_value.BlockData()) @@ -547,7 +547,7 @@ DWARFASTParserGo::ParseChildParameters(const SymbolContext &sc,                          }                      } -                    Type *type = parent_die.ResolveTypeUID(param_type_die_offset); +                    Type *type = parent_die.ResolveTypeUID(DIERef(param_type_die_offset));                      if (type)                      {                          function_param_types.push_back(type->GetForwardCompilerType()); @@ -628,7 +628,7 @@ DWARFASTParserGo::CompleteTypeFromDWARF(const DWARFDIE &die, lldb_private::Type      Log *log = nullptr; // (LogChannelDWARF::GetLogIfAny(DWARF_LOG_DEBUG_INFO|DWARF_LOG_TYPE_COMPLETION));      if (log)          dwarf->GetObjectFile()->GetModule()->LogMessageVerboseBacktrace( -            log, "0x%8.8" PRIx64 ": %s '%s' resolving forward declaration...", dwarf->MakeUserID(die.GetOffset()), +            log, "0x%8.8" PRIx64 ": %s '%s' resolving forward declaration...", die.GetID(),              DW_TAG_value_to_name(tag), type->GetName().AsCString());      assert(compiler_type);      DWARFAttributes attributes; @@ -683,7 +683,7 @@ DWARFASTParserGo::ParseChildMembers(const SymbolContext &sc, const DWARFDIE &par                      Declaration decl;                      const char *name = NULL; -                    lldb::user_id_t encoding_uid = LLDB_INVALID_UID; +                    DWARFFormValue encoding_uid;                      uint32_t member_byte_offset = UINT32_MAX;                      uint32_t i;                      for (i = 0; i < num_attributes; ++i) @@ -698,7 +698,7 @@ DWARFASTParserGo::ParseChildMembers(const SymbolContext &sc, const DWARFDIE &par                                      name = form_value.AsCString();                                      break;                                  case DW_AT_type: -                                    encoding_uid = form_value.Reference(); +                                    encoding_uid = form_value;                                      break;                                  case DW_AT_data_member_location:                                      if (form_value.BlockData()) @@ -735,7 +735,7 @@ DWARFASTParserGo::ParseChildMembers(const SymbolContext &sc, const DWARFDIE &par                          }                      } -                    Type *member_type = die.ResolveTypeUID(encoding_uid); +                    Type *member_type = die.ResolveTypeUID(DIERef(encoding_uid));                      if (member_type)                      {                          CompilerType member_go_type = member_type->GetFullCompilerType(); @@ -808,10 +808,12 @@ DWARFASTParserGo::ParseFunctionFromDWARF(const SymbolContext &sc, const DWARFDIE              if (dwarf->FixupAddress(func_range.GetBaseAddress()))              { -                const user_id_t func_user_id = dwarf->MakeUserID(die.GetOffset()); +                const user_id_t func_user_id = die.GetID();                  func_sp.reset(new Function(sc.comp_unit, -                                           dwarf->MakeUserID(func_user_id), // UserID is the DIE offset -                                           dwarf->MakeUserID(func_user_id), func_name, func_type, +                                           func_user_id, // UserID is the DIE offset +                                           func_user_id, +                                           func_name, +                                           func_type,                                             func_range)); // first address range                  if (func_sp.get() != NULL) | 

