
Check that getDebugInfo() is not null, as in the first revision, before calling getDebugInfo()->addHeapAllocSiteMetadata(). Else would cause a crash with a new expression in a default arg. --- Clang marks calls to operator new as heap allocation sites, but the operator declared at global scope returns a void pointer. There is no explicit cast in the code, so the compiler has to write down the allocated type itself. Also generalize a cast to use CallBase, so that we mark heap alloc sites when exceptions are enabled. Differential Revision: https://reviews.llvm.org/D80966
27 lines
1.0 KiB
C
27 lines
1.0 KiB
C
// RUN: %clang_cc1 -triple x86_64-windows-msvc -debug-info-kind=limited -gcodeview -fdeclspec -S -emit-llvm %s -o - | FileCheck %s
|
|
|
|
struct Foo;
|
|
struct Bar;
|
|
|
|
__declspec(allocator) void *alloc_void();
|
|
__declspec(allocator) struct Foo *alloc_foo();
|
|
|
|
void call_alloc() {
|
|
struct Foo *p = alloc_void();
|
|
struct Foo *w = alloc_foo();
|
|
struct Foo *q = (struct Foo*)alloc_void();
|
|
struct Foo *r = (struct Foo*)(struct Bar*)alloc_void();
|
|
}
|
|
|
|
// CHECK-LABEL: define {{.*}}void @call_alloc
|
|
// CHECK: call i8* {{.*}}@alloc_void{{.*}} !heapallocsite [[DBG1:!.*]]
|
|
// CHECK: call %struct.Foo* {{.*}}@alloc_foo{{.*}} !heapallocsite [[DBG2:!.*]]
|
|
// CHECK: call i8* {{.*}}@alloc_void{{.*}} !heapallocsite [[DBG2]]
|
|
// CHECK: call i8* {{.*}}@alloc_void{{.*}} !heapallocsite [[DBG3:!.*]]
|
|
|
|
// CHECK: [[DBG1]] = !{}
|
|
// CHECK: [[DBG2]] = !DICompositeType(tag: DW_TAG_structure_type,
|
|
// CHECK-SAME: name: "Foo"
|
|
// CHECK: [[DBG3]] = !DICompositeType(tag: DW_TAG_structure_type,
|
|
// CHECK-SAME: name: "Bar"
|