ae4ae1685c
Fix tests/codegen/riscv-abi/call-llvm-intrinsics.rs Fix tests/codegen/riscv-abi/riscv64-lp64d-abi.rs Fix tests/codegen/riscv-abi/riscv64-lp64f-lp64d-abi.rs On riscv64gc ignore tests/ui/debuginfo/debuginfo-emit-llvm-ir-and-split-debuginfo.rs Make tests/codegen/riscv-abi/riscv64-lp64d-abi.rs no_core Make tests/codegen/riscv-abi/riscv64-lp64f-lp64d-abi.rs no_core Set -O for tests/codegen/riscv-abi/riscv64-lp64d-abi.rs Set -O for tests/codegen/riscv-abi/riscv64-lp64f-lp64d-abi.rs
30 lines
567 B
Rust
30 lines
567 B
Rust
//@ compile-flags: -C no-prepopulate-passes
|
|
|
|
//@ only-riscv64
|
|
|
|
#![feature(link_llvm_intrinsics)]
|
|
#![crate_type = "lib"]
|
|
|
|
struct A;
|
|
|
|
impl Drop for A {
|
|
fn drop(&mut self) {
|
|
println!("A");
|
|
}
|
|
}
|
|
|
|
extern "C" {
|
|
#[link_name = "llvm.sqrt.f32"]
|
|
fn sqrt(x: f32) -> f32;
|
|
}
|
|
|
|
pub fn do_call() {
|
|
let _a = A;
|
|
|
|
unsafe {
|
|
// Ensure that we `call` LLVM intrinsics instead of trying to `invoke` them
|
|
// CHECK: store float 4.000000e+00, ptr %{{.}}, align 4
|
|
// CHECK: call float @llvm.sqrt.f32(float %{{.}}
|
|
sqrt(4.0);
|
|
}
|
|
}
|