]> git.lizzy.rs Git - rust.git/commitdiff
smoketest f32 fast-math intrinsics
authorRalf Jung <post@ralfj.de>
Sat, 11 Apr 2020 09:03:41 +0000 (11:03 +0200)
committerRalf Jung <post@ralfj.de>
Sat, 11 Apr 2020 09:37:26 +0000 (11:37 +0200)
tests/run-pass/float_fast_math.rs

index ba7e6ac3ec06345f1286c6fe8f920af0b61aec30..8e5a88ff336a215afd422ebb9833759c507f72a3 100644 (file)
@@ -3,7 +3,19 @@
 use std::intrinsics::{fadd_fast, fsub_fast, fmul_fast, fdiv_fast, frem_fast};
 
 #[inline(never)]
-pub fn test_operations(a: f64, b: f64) {
+pub fn test_operations_f64(a: f64, b: f64) {
+    // make sure they all map to the correct operation
+    unsafe {
+        assert_eq!(fadd_fast(a, b), a + b);
+        assert_eq!(fsub_fast(a, b), a - b);
+        assert_eq!(fmul_fast(a, b), a * b);
+        assert_eq!(fdiv_fast(a, b), a / b);
+        assert_eq!(frem_fast(a, b), a % b);
+    }
+}
+
+#[inline(never)]
+pub fn test_operations_f32(a: f32, b: f32) {
     // make sure they all map to the correct operation
     unsafe {
         assert_eq!(fadd_fast(a, b), a + b);
@@ -15,6 +27,8 @@ pub fn test_operations(a: f64, b: f64) {
 }
 
 fn main() {
-    test_operations(1., 2.);
-    test_operations(10., 5.);
+    test_operations_f64(1., 2.);
+    test_operations_f64(10., 5.);
+    test_operations_f32(11., 2.);
+    test_operations_f32(10., 15.);
 }