2022-08-14 21:06:01 -05:00
|
|
|
// Floating-point clamp is designed to be implementable as max+min,
|
|
|
|
// so check to make sure that's what it's actually emitting.
|
|
|
|
|
|
|
|
// assembly-output: emit-asm
|
|
|
|
// compile-flags: --crate-type=lib -O -C llvm-args=-x86-asm-syntax=intel
|
|
|
|
// only-x86_64
|
|
|
|
|
|
|
|
// CHECK-LABEL: clamp_demo:
|
|
|
|
#[no_mangle]
|
|
|
|
pub fn clamp_demo(a: f32, x: f32, y: f32) -> f32 {
|
|
|
|
// CHECK: maxss
|
|
|
|
// CHECK: minss
|
|
|
|
a.clamp(x, y)
|
|
|
|
}
|
|
|
|
|
|
|
|
// CHECK-LABEL: clamp12_demo:
|
|
|
|
#[no_mangle]
|
|
|
|
pub fn clamp12_demo(a: f32) -> f32 {
|
2022-08-16 20:39:22 -05:00
|
|
|
// CHECK: movss xmm1
|
2022-08-14 21:06:01 -05:00
|
|
|
// CHECK-NEXT: maxss xmm1, xmm0
|
|
|
|
// CHECK-NEXT: movss xmm0
|
|
|
|
// CHECK-NEXT: minss xmm0, xmm1
|
|
|
|
// CHECK-NEXT: ret
|
|
|
|
a.clamp(1.0, 2.0)
|
|
|
|
}
|