diff options
| author | DianQK <dianqk@dianqk.net> | 2023-08-12 21:25:30 +0800 |
|---|---|---|
| committer | DianQK <dianqk@dianqk.net> | 2023-08-12 21:27:46 +0800 |
| commit | 6f5b4e358145066dfe76251e89eb40c531c4bb51 (patch) | |
| tree | 15446b66d5dbf156ee72a25e6f1011079d9318c0 /tests/codegen | |
| parent | f1b854818db00bec14accbc9d1c72e6ebefe64db (diff) | |
| download | rust-6f5b4e358145066dfe76251e89eb40c531c4bb51.tar.gz rust-6f5b4e358145066dfe76251e89eb40c531c4bb51.zip | |
Add test for method debuginfo declaration.
We've investigated one reason why debugging information often goes wrong at https://reviews.llvm.org/D152095. > LLVM can't handle IR where subprogram definitions are nested within DICompositeType when doing LTO builds, > because there's no good way to cross the CU boundary to insert a nested DISubprogram definition in one CU into a type defined in another CU.
Diffstat (limited to 'tests/codegen')
| -rw-r--r-- | tests/codegen/method-declaration.rs | 26 |
1 files changed, 26 insertions, 0 deletions
diff --git a/tests/codegen/method-declaration.rs b/tests/codegen/method-declaration.rs new file mode 100644 index 00000000000..4ae332b0107 --- /dev/null +++ b/tests/codegen/method-declaration.rs @@ -0,0 +1,26 @@ +// compile-flags: -g -Cno-prepopulate-passes + +// Verify that we added a declaration for a method. + +// CHECK: define{{.*}}@method{{.*}} !dbg ![[METHOD_DEF_DBG:[0-9]+]] +// CHECK: define{{.*}}@function{{.*}} !dbg ![[FUNC_DEF_DBG:[0-9]+]] + +#![crate_type = "lib"] + +// CHECK-DAG: ![[FOO_DBG:[0-9]+]] = !DICompositeType(tag: {{.*}} name: "Foo", {{.*}} identifier: +pub struct Foo; + +impl Foo { + // CHECK-DAG: ![[METHOD_DEF_DBG]] = distinct !DISubprogram(name: "method"{{.*}}, scope: ![[FOO_DBG]]{{.*}}DISPFlagDefinition{{.*}}, declaration: ![[METHOD_DECL_DBG:[0-9]+]] + // CHECK-DAG: ![[METHOD_DECL_DBG]] = !DISubprogram(name: "method"{{.*}}, scope: ![[FOO_DBG]] + #[no_mangle] + pub fn method() {} +} + +// CHECK: ![[FUNC_DEF_DBG]] = distinct !DISubprogram(name: "function" +// CHECK-NOT: declaration +// CHECK-SAME: DISPFlagDefinition +// CHECK-NOT: declaration +// CHECK-SAME: ) +#[no_mangle] +pub fn function() {} |
