| // Verify that algebraic intrinsics generate the correct LLVM calls |
| |
| // Ensure operations get inlined |
| //@ compile-flags: -Copt-level=1 |
| |
| #![crate_type = "lib"] |
| #![feature(f16)] |
| #![feature(f128)] |
| #![feature(float_algebraic)] |
| |
| // CHECK-LABEL: @f16_algebraic_add |
| #[no_mangle] |
| pub fn f16_algebraic_add(a: f16, b: f16) -> f16 { |
| // CHECK: fadd reassoc nsz arcp contract half %{{.+}}, %{{.+}} |
| a.algebraic_add(b) |
| } |
| |
| // CHECK-LABEL: @f16_algebraic_sub |
| #[no_mangle] |
| pub fn f16_algebraic_sub(a: f16, b: f16) -> f16 { |
| // CHECK: fsub reassoc nsz arcp contract half %{{.+}}, %{{.+}} |
| a.algebraic_sub(b) |
| } |
| |
| // CHECK-LABEL: @f16_algebraic_mul |
| #[no_mangle] |
| pub fn f16_algebraic_mul(a: f16, b: f16) -> f16 { |
| // CHECK: fmul reassoc nsz arcp contract half %{{.+}}, %{{.+}} |
| a.algebraic_mul(b) |
| } |
| |
| // CHECK-LABEL: @f16_algebraic_div |
| #[no_mangle] |
| pub fn f16_algebraic_div(a: f16, b: f16) -> f16 { |
| // CHECK: fdiv reassoc nsz arcp contract half %{{.+}}, %{{.+}} |
| a.algebraic_div(b) |
| } |
| |
| // CHECK-LABEL: @f16_algebraic_rem |
| #[no_mangle] |
| pub fn f16_algebraic_rem(a: f16, b: f16) -> f16 { |
| // CHECK: frem reassoc nsz arcp contract half %{{.+}}, %{{.+}} |
| a.algebraic_rem(b) |
| } |
| |
| // CHECK-LABEL: @f32_algebraic_add |
| #[no_mangle] |
| pub fn f32_algebraic_add(a: f32, b: f32) -> f32 { |
| // CHECK: fadd reassoc nsz arcp contract float %{{.+}}, %{{.+}} |
| a.algebraic_add(b) |
| } |
| |
| // CHECK-LABEL: @f32_algebraic_sub |
| #[no_mangle] |
| pub fn f32_algebraic_sub(a: f32, b: f32) -> f32 { |
| // CHECK: fsub reassoc nsz arcp contract float %{{.+}}, %{{.+}} |
| a.algebraic_sub(b) |
| } |
| |
| // CHECK-LABEL: @f32_algebraic_mul |
| #[no_mangle] |
| pub fn f32_algebraic_mul(a: f32, b: f32) -> f32 { |
| // CHECK: fmul reassoc nsz arcp contract float %{{.+}}, %{{.+}} |
| a.algebraic_mul(b) |
| } |
| |
| // CHECK-LABEL: @f32_algebraic_div |
| #[no_mangle] |
| pub fn f32_algebraic_div(a: f32, b: f32) -> f32 { |
| // CHECK: fdiv reassoc nsz arcp contract float %{{.+}}, %{{.+}} |
| a.algebraic_div(b) |
| } |
| |
| // CHECK-LABEL: @f32_algebraic_rem |
| #[no_mangle] |
| pub fn f32_algebraic_rem(a: f32, b: f32) -> f32 { |
| // CHECK: frem reassoc nsz arcp contract float %{{.+}}, %{{.+}} |
| a.algebraic_rem(b) |
| } |
| |
| // CHECK-LABEL: @f64_algebraic_add |
| #[no_mangle] |
| pub fn f64_algebraic_add(a: f64, b: f64) -> f64 { |
| // CHECK: fadd reassoc nsz arcp contract double %{{.+}}, %{{.+}} |
| a.algebraic_add(b) |
| } |
| |
| // CHECK-LABEL: @f64_algebraic_sub |
| #[no_mangle] |
| pub fn f64_algebraic_sub(a: f64, b: f64) -> f64 { |
| // CHECK: fsub reassoc nsz arcp contract double %{{.+}}, %{{.+}} |
| a.algebraic_sub(b) |
| } |
| |
| // CHECK-LABEL: @f64_algebraic_mul |
| #[no_mangle] |
| pub fn f64_algebraic_mul(a: f64, b: f64) -> f64 { |
| // CHECK: fmul reassoc nsz arcp contract double %{{.+}}, %{{.+}} |
| a.algebraic_mul(b) |
| } |
| |
| // CHECK-LABEL: @f64_algebraic_div |
| #[no_mangle] |
| pub fn f64_algebraic_div(a: f64, b: f64) -> f64 { |
| // CHECK: fdiv reassoc nsz arcp contract double %{{.+}}, %{{.+}} |
| a.algebraic_div(b) |
| } |
| |
| // CHECK-LABEL: @f64_algebraic_rem |
| #[no_mangle] |
| pub fn f64_algebraic_rem(a: f64, b: f64) -> f64 { |
| // CHECK: frem reassoc nsz arcp contract double %{{.+}}, %{{.+}} |
| a.algebraic_rem(b) |
| } |
| |
| // CHECK-LABEL: @f128_algebraic_add |
| #[no_mangle] |
| pub fn f128_algebraic_add(a: f128, b: f128) -> f128 { |
| // CHECK: fadd reassoc nsz arcp contract fp128 %{{.+}}, %{{.+}} |
| a.algebraic_add(b) |
| } |
| |
| // CHECK-LABEL: @f128_algebraic_sub |
| #[no_mangle] |
| pub fn f128_algebraic_sub(a: f128, b: f128) -> f128 { |
| // CHECK: fsub reassoc nsz arcp contract fp128 %{{.+}}, %{{.+}} |
| a.algebraic_sub(b) |
| } |
| |
| // CHECK-LABEL: @f128_algebraic_mul |
| #[no_mangle] |
| pub fn f128_algebraic_mul(a: f128, b: f128) -> f128 { |
| // CHECK: fmul reassoc nsz arcp contract fp128 %{{.+}}, %{{.+}} |
| a.algebraic_mul(b) |
| } |
| |
| // CHECK-LABEL: @f128_algebraic_div |
| #[no_mangle] |
| pub fn f128_algebraic_div(a: f128, b: f128) -> f128 { |
| // CHECK: fdiv reassoc nsz arcp contract fp128 %{{.+}}, %{{.+}} |
| a.algebraic_div(b) |
| } |
| |
| // CHECK-LABEL: @f128_algebraic_rem |
| #[no_mangle] |
| pub fn f128_algebraic_rem(a: f128, b: f128) -> f128 { |
| // CHECK: frem reassoc nsz arcp contract fp128 %{{.+}}, %{{.+}} |
| a.algebraic_rem(b) |
| } |