blob: 777894dbbe86fa4b5347d97d314fb706b2d558e0 (
plain)
| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
 | // 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;
}
 |