| // SPDX-License-Identifier: GPL-2.0+ |
| |
| #include <linux/errno.h> |
| |
| #include "test_fpu.h" |
| |
| int test_fpu(void) |
| { |
| /* |
| * This sequence of operations tests that rounding mode is |
| * to nearest and that denormal numbers are supported. |
| * Volatile variables are used to avoid compiler optimizing |
| * the calculations away. |
| */ |
| volatile double a, b, c, d, e, f, g; |
| |
| a = 4.0; |
| b = 1e-15; |
| c = 1e-310; |
| |
| /* Sets precision flag */ |
| d = a + b; |
| |
| /* Result depends on rounding mode */ |
| e = a + b / 2; |
| |
| /* Denormal and very large values */ |
| f = b / c; |
| |
| /* Depends on denormal support */ |
| g = a + c * f; |
| |
| if (d > a && e > a && g > a) |
| return 0; |
| else |
| return -EINVAL; |
| } |