xref: /rk3399_rockchip-uboot/post/lib_powerpc/fpu/20001122-1.c (revision 326ea986ac150acdc7656d57fca647db80b50158)
1a47a12beSStefan Roese /*
2a47a12beSStefan Roese  * Copyright (C) 2007
3a47a12beSStefan Roese  * Wolfgang Denk, DENX Software Engineering, wd@denx.de.
4a47a12beSStefan Roese  *
5*1a459660SWolfgang Denk  * SPDX-License-Identifier:	GPL-2.0+
6a47a12beSStefan Roese  */
7a47a12beSStefan Roese /*
8a47a12beSStefan Roese  * This file is originally a part of the GCC testsuite.
9a47a12beSStefan Roese  */
10a47a12beSStefan Roese 
11a47a12beSStefan Roese #include <common.h>
12a47a12beSStefan Roese 
13a47a12beSStefan Roese #include <post.h>
14a47a12beSStefan Roese 
15a47a12beSStefan Roese GNU_FPOST_ATTR
16a47a12beSStefan Roese 
17e009cdebSKumar Gala #if CONFIG_POST & CONFIG_SYS_POST_FPU
18e009cdebSKumar Gala 
fpu_post_test_math1(void)19a47a12beSStefan Roese int fpu_post_test_math1 (void)
20a47a12beSStefan Roese {
21944416e0SStefan Roese 	volatile double a;
22a47a12beSStefan Roese 	double c, d;
23a47a12beSStefan Roese 	volatile double b;
24a47a12beSStefan Roese 
25a47a12beSStefan Roese 	d = 1.0;
26a47a12beSStefan Roese 
27a47a12beSStefan Roese 	do
28a47a12beSStefan Roese 	{
29a47a12beSStefan Roese 		c = d;
30a47a12beSStefan Roese 		d = c * 0.5;
31a47a12beSStefan Roese 		b = 1 + d;
32a47a12beSStefan Roese 	} while (b != 1.0);
33a47a12beSStefan Roese 
34a47a12beSStefan Roese 	a = 1.0 + c;
35a47a12beSStefan Roese 
36a47a12beSStefan Roese 	if (a == 1.0) {
37a47a12beSStefan Roese 		post_log ("Error in FPU math1 test\n");
38a47a12beSStefan Roese 		return -1;
39a47a12beSStefan Roese 	}
40a47a12beSStefan Roese 
41a47a12beSStefan Roese 	return 0;
42a47a12beSStefan Roese }
43a47a12beSStefan Roese 
44a47a12beSStefan Roese #endif /* CONFIG_POST & CONFIG_SYS_POST_FPU */
45