diff options
Diffstat (limited to 'gcc-4.8/gcc/testsuite/gcc.target/i386/l_fma_4.h')
-rw-r--r-- | gcc-4.8/gcc/testsuite/gcc.target/i386/l_fma_4.h | 133 |
1 files changed, 133 insertions, 0 deletions
diff --git a/gcc-4.8/gcc/testsuite/gcc.target/i386/l_fma_4.h b/gcc-4.8/gcc/testsuite/gcc.target/i386/l_fma_4.h new file mode 100644 index 000000000..e33fe25ff --- /dev/null +++ b/gcc-4.8/gcc/testsuite/gcc.target/i386/l_fma_4.h @@ -0,0 +1,133 @@ + +#ifndef l_fma_4 +#define l_fma_4 + +void __attribute__((sseregparm)) +test_noneg_add_noneg_add (TYPE *a, TYPE *b, TYPE *c, TYPE *d, int n) +{ + int i; + for (i = 0; i < n; i++) + d[i] = ((a[i] * b[i]) + c[i]) * b[i] + c[i]; +} + +void __attribute__((sseregparm)) +test_noneg_add_noneg_sub (TYPE *a, TYPE *b, TYPE *c, TYPE *d, int n) +{ + int i; + for (i = 0; i < n; i++) + d[i] = ((a[i] * b[i]) + c[i]) * b[i] - c[i]; +} + +void __attribute__((sseregparm)) +test_noneg_add_neg_add (TYPE *a, TYPE *b, TYPE *c, TYPE *d, int n) +{ + int i; + for (i = 0; i < n; i++) + d[i] = -((a[i] * b[i]) + c[i]) * b[i] + c[i]; +} + +void __attribute__((sseregparm)) +test_noneg_add_neg_sub (TYPE *a, TYPE *b, TYPE *c, TYPE *d, int n) +{ + int i; + for (i = 0; i < n; i++) + d[i] = -((a[i] * b[i]) + c[i]) * b[i] - c[i]; +} + +void __attribute__((sseregparm)) +test_noneg_sub_noneg_add (TYPE *a, TYPE *b, TYPE *c, TYPE *d, int n) +{ + int i; + for (i = 0; i < n; i++) + d[i] = ((a[i] * b[i]) - c[i]) * b[i] + c[i]; +} + +void __attribute__((sseregparm)) +test_noneg_sub_noneg_sub (TYPE *a, TYPE *b, TYPE *c, TYPE *d, int n) +{ + int i; + for (i = 0; i < n; i++) + d[i] = ((a[i] * b[i]) - c[i]) * b[i] - c[i]; +} + +void __attribute__((sseregparm)) +test_noneg_sub_neg_add (TYPE *a, TYPE *b, TYPE *c, TYPE *d, int n) +{ + int i; + for (i = 0; i < n; i++) + d[i] = -((a[i] * b[i]) - c[i]) * b[i] + c[i]; +} + +void __attribute__((sseregparm)) +test_noneg_sub_neg_sub (TYPE *a, TYPE *b, TYPE *c, TYPE *d, int n) +{ + int i; + for (i = 0; i < n; i++) + d[i] = -((a[i] * b[i]) - c[i]) * b[i] - c[i]; +} + +void __attribute__((sseregparm)) +test_neg_add_noneg_add (TYPE *a, TYPE *b, TYPE *c, TYPE *d, int n) +{ + int i; + for (i = 0; i < n; i++) + d[i] = (-(a[i] * b[i]) + c[i]) * b[i] + c[i]; +} + +void __attribute__((sseregparm)) +test_neg_add_noneg_sub (TYPE *a, TYPE *b, TYPE *c, TYPE *d, int n) +{ + int i; + for (i = 0; i < n; i++) + d[i] = (-(a[i] * b[i]) + c[i]) * b[i] - c[i]; +} + +void __attribute__((sseregparm)) +test_neg_add_neg_add (TYPE *a, TYPE *b, TYPE *c, TYPE *d, int n) +{ + int i; + for (i = 0; i < n; i++) + d[i] = -(-(a[i] * b[i]) + c[i]) * b[i] + c[i]; +} + +void __attribute__((sseregparm)) +test_neg_add_neg_sub (TYPE *a, TYPE *b, TYPE *c, TYPE *d, int n) +{ + int i; + for (i = 0; i < n; i++) + d[i] = -(-(a[i] * b[i]) + c[i]) * b[i] - c[i]; +} + +void __attribute__((sseregparm)) +test_neg_sub_noneg_add (TYPE *a, TYPE *b, TYPE *c, TYPE *d, int n) +{ + int i; + for (i = 0; i < n; i++) + d[i] = (-(a[i] * b[i]) - c[i]) * b[i] + c[i]; +} + +void __attribute__((sseregparm)) +test_neg_sub_noneg_sub (TYPE *a, TYPE *b, TYPE *c, TYPE *d, int n) +{ + int i; + for (i = 0; i < n; i++) + d[i] = (-(a[i] * b[i]) - c[i]) * b[i] - c[i]; +} + +void __attribute__((sseregparm)) +test_neg_sub_neg_add (TYPE *a, TYPE *b, TYPE *c, TYPE *d, int n) +{ + int i; + for (i = 0; i < n; i++) + d[i] = -(-(a[i] * b[i]) - c[i]) * b[i] + c[i]; +} + +void __attribute__((sseregparm)) +test_neg_sub_neg_sub (TYPE *a, TYPE *b, TYPE *c, TYPE *d, int n) +{ + int i; + for (i = 0; i < n; i++) + d[i] = -(-(a[i] * b[i]) - c[i]) * b[i] - c[i]; +} + +#endif |