diff --git a/lldb/source/Expression/DWARFExpression.cpp b/lldb/source/Expression/DWARFExpression.cpp --- a/lldb/source/Expression/DWARFExpression.cpp +++ b/lldb/source/Expression/DWARFExpression.cpp @@ -2374,9 +2374,11 @@ return false; } } else { - // Retrieve the type DIE that the value is being converted to. + // Retrieve the type DIE that the value is being converted to. This + // offset is compile unit relative so we need to fix it up. + const uint64_t abs_die_offset = die_offset + dwarf_cu->GetOffset(); // FIXME: the constness has annoying ripple effects. - DWARFDIE die = const_cast(dwarf_cu)->GetDIE(die_offset); + DWARFDIE die = const_cast(dwarf_cu)->GetDIE(abs_die_offset); if (!die) { if (error_ptr) error_ptr->SetErrorString("Cannot resolve DW_OP_convert type DIE"); diff --git a/lldb/unittests/Expression/DWARFExpressionTest.cpp b/lldb/unittests/Expression/DWARFExpressionTest.cpp --- a/lldb/unittests/Expression/DWARFExpressionTest.cpp +++ b/lldb/unittests/Expression/DWARFExpressionTest.cpp @@ -61,6 +61,9 @@ class DWARFExpressionTester : public YAMLModuleTester { public: + DWARFExpressionTester(llvm::StringRef yaml_data, size_t cu_index) : + YAMLModuleTester(yaml_data, cu_index) {} + using YAMLModuleTester::YAMLModuleTester; llvm::Expected Eval(llvm::ArrayRef expr) { return ::Evaluate(expr, m_module_sp, m_dwarf_unit); @@ -179,6 +182,17 @@ debug_info: - Version: 4 AddrSize: 8 + AbbrevTableID: 0 + AbbrOffset: 0x0 + Entries: + - AbbrCode: 0x00000001 + Values: + - Value: 0x000000000000000C + - AbbrCode: 0x00000000 + - Version: 4 + AddrSize: 8 + AbbrevTableID: 0 + AbbrOffset: 0x0 Entries: - AbbrCode: 0x00000001 Values: @@ -214,14 +228,16 @@ - Value: 0x000000000000000b # DW_ATE_numeric_string - Value: 0x0000000000000001 - AbbrCode: 0x00000000 + )"; + // Compile unit relative offsets to each DW_TAG_base_type uint8_t offs_uint32_t = 0x0000000e; uint8_t offs_uint64_t = 0x00000011; uint8_t offs_sint64_t = 0x00000014; uint8_t offs_uchar = 0x00000017; uint8_t offs_schar = 0x0000001a; - DWARFExpressionTester t(yamldata); + DWARFExpressionTester t(yamldata, /*cu_index=*/1); ASSERT_TRUE((bool)t.GetDwarfUnit()); // Constant is given as little-endian. diff --git a/lldb/unittests/TestingSupport/Symbol/YAMLModuleTester.h b/lldb/unittests/TestingSupport/Symbol/YAMLModuleTester.h --- a/lldb/unittests/TestingSupport/Symbol/YAMLModuleTester.h +++ b/lldb/unittests/TestingSupport/Symbol/YAMLModuleTester.h @@ -33,7 +33,7 @@ public: /// Parse the debug info sections from the YAML description. - YAMLModuleTester(llvm::StringRef yaml_data); + YAMLModuleTester(llvm::StringRef yaml_data, size_t cu_index = 0); DWARFUnit *GetDwarfUnit() const { return m_dwarf_unit; } lldb::ModuleSP GetModule() const { return m_module_sp; } }; diff --git a/lldb/unittests/TestingSupport/Symbol/YAMLModuleTester.cpp b/lldb/unittests/TestingSupport/Symbol/YAMLModuleTester.cpp --- a/lldb/unittests/TestingSupport/Symbol/YAMLModuleTester.cpp +++ b/lldb/unittests/TestingSupport/Symbol/YAMLModuleTester.cpp @@ -14,7 +14,7 @@ using namespace lldb_private; -YAMLModuleTester::YAMLModuleTester(llvm::StringRef yaml_data) { +YAMLModuleTester::YAMLModuleTester(llvm::StringRef yaml_data, size_t cu_index) { llvm::Expected File = TestFile::fromYaml(yaml_data); EXPECT_THAT_EXPECTED(File, llvm::Succeeded()); m_file = std::move(*File); @@ -22,5 +22,5 @@ m_module_sp = std::make_shared(m_file->moduleSpec()); auto &symfile = *llvm::cast(m_module_sp->GetSymbolFile()); - m_dwarf_unit = symfile.DebugInfo().GetUnitAtIndex(0); + m_dwarf_unit = symfile.DebugInfo().GetUnitAtIndex(cu_index); }