diff options
| author | bors <bors@rust-lang.org> | 2025-07-22 18:39:58 +0000 |
|---|---|---|
| committer | bors <bors@rust-lang.org> | 2025-07-22 18:39:58 +0000 |
| commit | a7a1618e6c835f1f00940ad72203d05808209a0d (patch) | |
| tree | efca82e10564eec78574d5f91b339a786040552b /tests/codegen-llvm/inline-function-args-debug-info.rs | |
| parent | 2e5367566819ca7878baa9600ae7a93eb0e37bbf (diff) | |
| parent | 6bfa00816d7e4dcb0aee9fe547bc75dfe59dc613 (diff) | |
| download | rust-a7a1618e6c835f1f00940ad72203d05808209a0d.tar.gz rust-a7a1618e6c835f1f00940ad72203d05808209a0d.zip | |
Auto merge of #144249 - GuillaumeGomez:asm-tests, r=jieyouxu
Rename `tests/{assembly,codegen}` into `tests/{assembly,codegen}-llvm` and ignore these testsuites if configured backend doesn't match
Follow-up of https://github.com/rust-lang/rust/pull/144125.
This PR changes `compiletest` so that `asm` tests are only run if they match the current codegen backend. To better reflect it, I renamed the `tests/ui/asm` folder into `tests/ui/asm-llvm`. Like that, we can add new asm tests for other backends if we want without needing to add extra code to `compiletest`.
Next step will be to use the new code annotations added in rust-lang/rust#144125 to ignore ui tests failing in cg_gcc until it's fixed on our side.
cc `@antoyo` `@oli-obk`
r? `@Kobzol`
Diffstat (limited to 'tests/codegen-llvm/inline-function-args-debug-info.rs')
| -rw-r--r-- | tests/codegen-llvm/inline-function-args-debug-info.rs | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/tests/codegen-llvm/inline-function-args-debug-info.rs b/tests/codegen-llvm/inline-function-args-debug-info.rs new file mode 100644 index 00000000000..c31419cb914 --- /dev/null +++ b/tests/codegen-llvm/inline-function-args-debug-info.rs @@ -0,0 +1,23 @@ +// 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"] + +#[inline(never)] +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: 16 + // CHECK-NOT: !DILexicalBlock( + // CHECK: !DILocalVariable(name: "bbbb", arg: 2 + // CHECK-SAME: line: 16 + aaaa + bbbb +} |
