46 lines
1.4 KiB
Rust
46 lines
1.4 KiB
Rust
//@ 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{{.*}}
|
|
}
|