diff options
author | Cyril SIX <cyril.six@kalray.eu> | 2019-09-03 10:52:23 +0200 |
---|---|---|
committer | Cyril SIX <cyril.six@kalray.eu> | 2019-09-03 10:52:23 +0200 |
commit | 0cb5a0b65b4fbeb5bc1c14f75951798f20500177 (patch) | |
tree | 767381d2490c86dcee95da2631ac5c94e14de8f5 /test/monniaux/builtins/fma.c | |
parent | 1fbd5d18a9f4398d7ecb9b9ab148a96f575fd1e0 (diff) | |
parent | 2f7f68f69b6408e4de6210c827b108eff011af51 (diff) | |
download | compcert-kvx-0cb5a0b65b4fbeb5bc1c14f75951798f20500177.tar.gz compcert-kvx-0cb5a0b65b4fbeb5bc1c14f75951798f20500177.zip |
Merge remote-tracking branch 'origin/mppa-work-upstream-merge' into mppa-work
Conflicts:
configure
mppa_k1c/Archi.v
mppa_k1c/Asmexpand.ml
Diffstat (limited to 'test/monniaux/builtins/fma.c')
-rw-r--r-- | test/monniaux/builtins/fma.c | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/test/monniaux/builtins/fma.c b/test/monniaux/builtins/fma.c new file mode 100644 index 00000000..4083e781 --- /dev/null +++ b/test/monniaux/builtins/fma.c @@ -0,0 +1,14 @@ +#define COMPCERT_NO_FP_MACROS +#include <math.h> +#include <stdio.h> +#include <stdlib.h> + +int main(int argc, char **argv) { + if (argc < 4) return 1; + double x = strtod(argv[1], NULL); + double y = strtod(argv[2], NULL); + double z = strtod(argv[3], NULL); + printf("%g %g %g\n", __builtin_fma(x, y, z), fma(x, y, z), x*y + z); + printf("%g %g %g\n", __builtin_fma(-x, y, z), fma(-x, y, z), (-x)*y + z); + return 0; +} |