From f49e7cbb33e6e27b0ce5eb35244d7241c800a7c1 Mon Sep 17 00:00:00 2001 From: camthesaxman Date: Thu, 26 Oct 2017 00:28:13 -0500 Subject: finally fix 64-bit --- gcc/Makefile | 2 +- gcc/thumb.md | 8 ++++++-- 2 files changed, 7 insertions(+), 3 deletions(-) (limited to 'gcc') diff --git a/gcc/Makefile b/gcc/Makefile index 1e2c4ad..c30991a 100644 --- a/gcc/Makefile +++ b/gcc/Makefile @@ -24,7 +24,7 @@ VPATH = $(srcdir) CC = gcc -BASE_CFLAGS = -g -std=gnu11 -m32 +BASE_CFLAGS = -g -std=gnu11 INCLUDES = -I. -I$(srcdir) diff --git a/gcc/thumb.md b/gcc/thumb.md index 8cebc50..f78624f 100755 --- a/gcc/thumb.md +++ b/gcc/thumb.md @@ -1085,8 +1085,10 @@ { case MODE_FLOAT: { + int i; union real_extract u; - memcpy((char *)&u, (char *)&CONST_DOUBLE_LOW(operands[0]), sizeof u); + for (i = 0; i < sizeof (REAL_VALUE_TYPE) / sizeof (HOST_WIDE_INT); i++) + u.i[i] = XWINT(operands[0], 2 + i); assemble_real (u.d, GET_MODE (operands[0])); break; } @@ -1107,8 +1109,10 @@ { case MODE_FLOAT: { + int i; union real_extract u; - memcpy((char *)&u, (char *)&CONST_DOUBLE_LOW(operands[0]), sizeof u); + for (i = 0; i < sizeof (REAL_VALUE_TYPE) / sizeof (HOST_WIDE_INT); i++) + u.i[i] = XWINT(operands[0], 2 + i); assemble_real (u.d, GET_MODE (operands[0])); break; } -- cgit v1.2.3