aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.c-torture/execute/960416-1.c
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/testsuite/gcc.c-torture/execute/960416-1.c')
-rw-r--r--gcc/testsuite/gcc.c-torture/execute/960416-1.c63
1 files changed, 0 insertions, 63 deletions
diff --git a/gcc/testsuite/gcc.c-torture/execute/960416-1.c b/gcc/testsuite/gcc.c-torture/execute/960416-1.c
deleted file mode 100644
index f7cb056802c..00000000000
--- a/gcc/testsuite/gcc.c-torture/execute/960416-1.c
+++ /dev/null
@@ -1,63 +0,0 @@
-typedef unsigned long int st;
-typedef unsigned long long dt;
-typedef union
-{
- dt d;
- struct
- {
- st h, l;
- }
- s;
-} t_be;
-
-typedef union
-{
- dt d;
- struct
- {
- st l, h;
- }
- s;
-} t_le;
-
-#define df(f, t) \
-int \
-f (t afh, t bfh) \
-{ \
- t hh; \
- t hp, lp, dp, m; \
- st ad, bd; \
- int s; \
- s = 0; \
- ad = afh.s.h - afh.s.l; \
- bd = bfh.s.l - bfh.s.h; \
- if (bd > bfh.s.l) \
- { \
- bd = -bd; \
- s = ~s; \
- } \
- lp.d = (dt) afh.s.l * bfh.s.l; \
- hp.d = (dt) afh.s.h * bfh.s.h; \
- dp.d = (dt) ad *bd; \
- dp.d ^= s; \
- hh.d = hp.d + hp.s.h + lp.s.h + dp.s.h; \
- m.d = (dt) lp.s.h + hp.s.l + lp.s.l + dp.s.l; \
- return hh.s.l + m.s.l; \
-}
-
-df(f_le, t_le)
-df(f_be, t_be)
-
-main ()
-{
- t_be x;
- x.s.h = 0x10000000U;
- x.s.l = 0xe0000000U;
- if (x.d == 0x10000000e0000000ULL
- && f_be ((t_be) 0x100000000ULL, (t_be) 0x100000000ULL) != -1)
- abort ();
- if (x.d == 0xe000000010000000ULL
- && f_le ((t_le) 0x100000000ULL, (t_le) 0x100000000ULL) != -1)
- abort ();
- exit (0);
-}