diff options
author | rms <rms@138bc75d-0d04-0410-961f-82ee72b054a4> | 1993-03-31 21:01:23 +0000 |
---|---|---|
committer | rms <rms@138bc75d-0d04-0410-961f-82ee72b054a4> | 1993-03-31 21:01:23 +0000 |
commit | 43a8db1a869bf796f109d8b17fd0da475d1a810f (patch) | |
tree | 322b82df11c2f263ff12ee127ede55f4672a5c09 /gcc/config/m68k/crds.h | |
parent | 7b6f34561e8facda4b85d944e55b339700f97812 (diff) | |
download | gcc-43a8db1a869bf796f109d8b17fd0da475d1a810f.tar.gz |
(ASM_OUTPUT_DOUBLE, PRINT_OPERAND):
Use new REAL_VALUE... macros.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@3967 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/config/m68k/crds.h')
-rw-r--r-- | gcc/config/m68k/crds.h | 29 |
1 files changed, 16 insertions, 13 deletions
diff --git a/gcc/config/m68k/crds.h b/gcc/config/m68k/crds.h index 33c3ec5f3ce..f20b34ec888 100644 --- a/gcc/config/m68k/crds.h +++ b/gcc/config/m68k/crds.h @@ -4,7 +4,7 @@ Written by Gary E. Miller bug reports to Gary_Edmunds_Miller@cup.portal.com - Copyright (C) 1987 Free Software Foundation, Inc. + Copyright (C) 1987, 1993 Free Software Foundation, Inc. This file is part of GNU CC. @@ -168,9 +168,9 @@ bss_section () \ #undef ASM_OUTPUT_DOUBLE #define ASM_OUTPUT_DOUBLE(FILE,VALUE) \ -do { union { double f; long l[2];} tem; \ - tem.f = (VALUE); \ - fprintf (FILE, "\t.long 0x%x, 0x%x\n", tem.l[0], tem.l[1]); \ +do { long l[2]; \ + REAL_VALUE_TO_TARGET_DOUBLE (VALUE, l); \ + fprintf (FILE, "\t.long 0x%x, 0x%x\n", l[0], l[1]); \ } while (0) /*unos has no .skip :-( */ @@ -300,18 +300,21 @@ do { union { double f; long l[2];} tem; \ && (i = standard_sun_fpa_constant_p (X))) \ fprintf (FILE, "%%%d", i & 0x1ff); \ else if (GET_CODE (X) == CONST_DOUBLE && GET_MODE (X) == SFmode) \ - { union { double d; int i[2]; } u; \ - union { float f; int i; } u1; \ - u.i[0] = CONST_DOUBLE_LOW (X); u.i[1] = CONST_DOUBLE_HIGH (X); \ - u1.f = u.d; \ + { REAL_VALUE_TYPE r; long l; \ + REAL_VALUE_FROM_CONST_DOUBLE (r, X); \ if (CODE == 'f') \ - ASM_OUTPUT_FLOAT_OPERAND (FILE, u1.f); \ + ASM_OUTPUT_FLOAT_OPERAND (CODE, FILE, r); \ else \ - fprintf (FILE, "$0x%x", u1.i); } \ + { REAL_VALUE_TO_TARGET_SINGLE (r, l); \ + fprintf (FILE, "$0x%x", l); } } \ + else if (GET_CODE (X) == CONST_DOUBLE && GET_MODE (X) == XFmode) \ + { REAL_VALUE_TYPE r; \ + REAL_VALUE_FROM_CONST_DOUBLE (r, X); \ + ASM_OUTPUT_LONG_DOUBLE_OPERAND (FILE, r); } \ else if (GET_CODE (X) == CONST_DOUBLE && GET_MODE (X) != DImode) \ - { union { double d; int i[2]; } u; \ - u.i[0] = CONST_DOUBLE_LOW (X); u.i[1] = CONST_DOUBLE_HIGH (X); \ - ASM_OUTPUT_DOUBLE_OPERAND (FILE, u.d); } \ + { REAL_VALUE_TYPE r; \ + REAL_VALUE_FROM_CONST_DOUBLE (r, X); \ + ASM_OUTPUT_DOUBLE_OPERAND (FILE, r); } \ else { putc ('$', FILE); output_addr_const (FILE, X); }} /* Note that this contains a kludge that knows that the only reason |