6c348aca4e
https://github.com/llvm/llvm-project/pull/89799 changes llvm.dbg.value/declare intrinsics to be in a different, out-of-instruction-line representation. For example call void @llvm.dbg.declare(...) becomes #dbg_declare(...) Update tests accordingly to work with both the old and new way.
18 lines
851 B
Rust
18 lines
851 B
Rust
// Verify that `i32::cmp` FnDef type is declared with size 0 and align 1 in LLVM debuginfo.
|
|
//@ compile-flags: -O -g -Cno-prepopulate-passes
|
|
//@ ignore-msvc the types are mangled differently
|
|
|
|
use std::cmp::Ordering;
|
|
|
|
fn foo<F: FnOnce(&i32, &i32) -> Ordering>(v1: i32, v2: i32, compare: F) -> Ordering {
|
|
compare(&v1, &v2)
|
|
}
|
|
|
|
pub fn main() {
|
|
foo(0, 1, i32::cmp);
|
|
}
|
|
|
|
// CHECK: %compare.dbg.spill = alloca [0 x i8], align 1
|
|
// CHECK: dbg{{.}}declare({{(metadata )?}}ptr %compare.dbg.spill, {{(metadata )?}}![[VAR:.*]], {{(metadata )?}}!DIExpression()
|
|
// CHECK: ![[TYPE:.*]] = !DIDerivedType(tag: DW_TAG_pointer_type, name: "fn(&i32, &i32) -> core::cmp::Ordering", baseType: !{{.*}}, align: 1, dwarfAddressSpace: {{.*}})
|
|
// CHECK: ![[VAR]] = !DILocalVariable(name: "compare", scope: !{{.*}}, file: !{{.*}}, line: {{.*}}, type: ![[TYPE]], align: 1)
|