// 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; | |
} |