about summary refs log tree commit diff
path: root/tests/codegen/inline-function-args-debug-info.rs
diff options
context:
space:
mode:
authorRalf Jung <post@ralfj.de>2023-04-14 14:28:19 +0200
committerRalf Jung <post@ralfj.de>2023-04-14 14:28:19 +0200
commit06707ab30f06d189636cb219cc689f19eda9a2bb (patch)
tree5017bdd02725ad3658357cb34f05dbdb257c6fe1 /tests/codegen/inline-function-args-debug-info.rs
parent2386cd7b22174f277d5bd9ad802bcffc3b902ab6 (diff)
parente3de409aaa592a36548a9f453688c3e877b5caa1 (diff)
downloadrust-06707ab30f06d189636cb219cc689f19eda9a2bb.tar.gz
rust-06707ab30f06d189636cb219cc689f19eda9a2bb.zip
Merge from rustc
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
+}