about summary refs log tree commit diff
path: root/tests/codegen/inline-function-args-debug-info.rs
diff options
context:
space:
mode:
authorDavid Lattimore <dvdlttmr@gmail.com>2023-03-21 21:48:03 +1100
committerDavid Lattimore <dvdlttmr@gmail.com>2023-04-11 11:07:48 +1000
commita6292676eb412d8239b308cfd1660aa75623bf5b (patch)
treeed8daa1d079b24605de44a1cd3b2c4ea7b18236d /tests/codegen/inline-function-args-debug-info.rs
parent7cd6f55323c15c9e8eed6361777d04e33ba7c429 (diff)
downloadrust-a6292676eb412d8239b308cfd1660aa75623bf5b.tar.gz
rust-a6292676eb412d8239b308cfd1660aa75623bf5b.zip
Preserve argument indexes when inlining MIR
We store argument indexes on VarDebugInfo. Unlike the previous method of
relying on the variable index to know whether a variable is an argument,
this survives MIR inlining.

We also no longer check if var.source_info.scope is the outermost scope.
When a function gets inlined, the arguments to the inner function will
no longer be in the outermost scope. What we care about though is
whether they were in the outermost scope prior to inlining, which we
know by whether we assigned an argument index.
Diffstat (limited to 'tests/codegen/inline-function-args-debug-info.rs')
-rw-r--r--tests/codegen/inline-function-args-debug-info.rs20
1 files changed, 20 insertions, 0 deletions
diff --git a/tests/codegen/inline-function-args-debug-info.rs b/tests/codegen/inline-function-args-debug-info.rs
new file mode 100644
index 00000000000..e3d8caa49d4
--- /dev/null
+++ b/tests/codegen/inline-function-args-debug-info.rs
@@ -0,0 +1,20 @@
+// This test checks that debug information includes function argument indexes even if the function
+// gets inlined by MIR inlining. Without function argument indexes, `info args` in gdb won't show
+// arguments and their values for the current function.
+
+// compile-flags: -Zinline-mir=yes -Cdebuginfo=2 --edition=2021
+
+#![crate_type = "lib"]
+
+pub fn outer_function(x: usize, y: usize) -> usize {
+    inner_function(x, y) + 1
+}
+
+#[inline]
+fn inner_function(aaaa: usize, bbbb: usize) -> usize {
+    // CHECK: !DILocalVariable(name: "aaaa", arg: 1
+    // CHECK-SAME: line: 14
+    // CHECK: !DILocalVariable(name: "bbbb", arg: 2
+    // CHECK-SAME: line: 14
+    aaaa + bbbb
+}