diff options
| author | liushuyu <liushuyu011@gmail.com> | 2024-09-03 13:42:10 -0600 |
|---|---|---|
| committer | liushuyu <liushuyu011@gmail.com> | 2024-09-04 08:10:53 -0600 |
| commit | 6e4c5c10b9b8740cecd62464c616cc82a01bc962 (patch) | |
| tree | f04590a4181f4eac883c7e119a4153ed32519228 | |
| parent | e98e88bfdf810d74540fcc0a464608683a7eacc7 (diff) | |
| download | rust-6e4c5c10b9b8740cecd62464c616cc82a01bc962.tar.gz rust-6e4c5c10b9b8740cecd62464c616cc82a01bc962.zip | |
tests: add an assembly scanning test for s390x backchain switch
| -rw-r--r-- | tests/assembly/s390x-backchain-toggle.rs | 46 |
1 files changed, 46 insertions, 0 deletions
diff --git a/tests/assembly/s390x-backchain-toggle.rs b/tests/assembly/s390x-backchain-toggle.rs new file mode 100644 index 00000000000..8b6d0cf2123 --- /dev/null +++ b/tests/assembly/s390x-backchain-toggle.rs @@ -0,0 +1,46 @@ +//@ revisions: enable-backchain disable-backchain +//@ assembly-output: emit-asm +//@ compile-flags: -O --crate-type=lib --target=s390x-unknown-linux-gnu +//@ needs-llvm-components: systemz +//@[enable-backchain] compile-flags: -Ctarget-feature=+backchain +//@[disable-backchain] compile-flags: -Ctarget-feature=-backchain +#![feature(no_core, lang_items)] +#![no_std] +#![no_core] + +#[lang = "sized"] +trait Sized {} + +extern "C" { + fn extern_func(); +} + +// CHECK-LABEL: test_backchain +#[no_mangle] +extern "C" fn test_backchain() -> i32 { + // Here we try to match if backchain register is saved to the parameter area (stored in r15/sp) + // And also if a new parameter area (160 bytes) is allocated for the upcoming function call + // enable-backchain: lgr [[REG1:.*]], %r15 + // enable-backchain-NEXT: aghi %r15, -160 + // enable-backchain: stg [[REG1]], 0(%r15) + // disable-backchain: aghi %r15, -160 + // disable-backchain-NOT: stg %r{{.*}}, 0(%r15) + unsafe { + extern_func(); + } + // enable-backchain-NEXT: brasl %r{{.*}}, extern_func@PLT + // disable-backchain: brasl %r{{.*}}, extern_func@PLT + + // Make sure that the expected return value is written into %r2 (return register): + // enable-backchain-NEXT: lghi %r2, 1 + // disable-backchain: lghi %r2, 0 + #[cfg(target_feature = "backchain")] + { + 1 + } + #[cfg(not(target_feature = "backchain"))] + { + 0 + } + // CHECK: br %r{{.*}} +} |
