forked from OSchip/llvm-project
Debug info: Use record layout to find vbase offsets instead of vtables
This fixes an assertion when generating full debug info in the MS ABI for classes with virtual bases. Fixes PR20579. llvm-svn: 215137
This commit is contained in:
parent
e20470d399
commit
9f6e438022
|
@ -1195,9 +1195,7 @@ CollectCXXBases(const CXXRecordDecl *RD, llvm::DIFile Unit,
|
|||
if (BI.isVirtual()) {
|
||||
// virtual base offset offset is -ve. The code generator emits dwarf
|
||||
// expression where it expects +ve number.
|
||||
BaseOffset =
|
||||
0 - CGM.getItaniumVTableContext()
|
||||
.getVirtualBaseOffsetOffset(RD, Base).getQuantity();
|
||||
BaseOffset = 0 - RL.getVBaseClassOffset(Base).getQuantity();
|
||||
BFlags = llvm::DIDescriptor::FlagVirtual;
|
||||
} else
|
||||
BaseOffset = CGM.getContext().toBits(RL.getBaseClassOffset(Base));
|
||||
|
|
|
@ -1,4 +1,6 @@
|
|||
// RUN: %clang_cc1 -triple x86_64-none-linux-gnu -emit-llvm -g %s -o - | FileCheck %s
|
||||
// RUN: %clang_cc1 -triple i686-pc-windows-msvc -emit-llvm -g %s -o - | FileCheck %s --check-prefix=MSVC
|
||||
|
||||
template<typename T> struct Identity {
|
||||
typedef T Type;
|
||||
};
|
||||
|
@ -43,14 +45,18 @@ namespace VirtualDtor {
|
|||
}
|
||||
|
||||
namespace VirtualBase {
|
||||
struct A { };
|
||||
struct B : virtual A { };
|
||||
struct A { int a; };
|
||||
struct B : virtual A { int b; };
|
||||
|
||||
void f() {
|
||||
B b;
|
||||
}
|
||||
}
|
||||
|
||||
// MSVC: [[VBASE_B:![0-9]+]] = metadata !{i32 {{.*}}, metadata !"B", i32 {{[0-9]*}}, i64 96, i64 32, i32 0, i32 0, null, metadata [[ZZZ:![0-9]+]], i32 0, {{.*}}} ; [ DW_TAG_structure_type ] [B] [line 49, size 96, align 32, offset 0] [def] [from ]
|
||||
// MSVC: [[ZZZ]] = metadata !{metadata [[VBASE_A_IN_B:![0-9]+]],
|
||||
// MSVC: [[VBASE_A_IN_B]] = metadata !{i32 786460, null, metadata [[VBASE_B]], null, i32 0, i64 0, i64 0, i64 -8, i32 32, metadata !{{[0-9]*}}} ; [ DW_TAG_inheritance ] [line 0, size 0, align 0, offset 18446744073709551608] [from A]
|
||||
|
||||
namespace b5249287 {
|
||||
template <typename T> class A {
|
||||
struct B;
|
||||
|
|
Loading…
Reference in New Issue