summaryrefslogtreecommitdiff
path: root/gcc/config/spu
diff options
context:
space:
mode:
authoruweigand <uweigand@138bc75d-0d04-0410-961f-82ee72b054a4>2010-12-16 18:12:23 +0000
committeruweigand <uweigand@138bc75d-0d04-0410-961f-82ee72b054a4>2010-12-16 18:12:23 +0000
commit01d1f82e58c1b1578736d8a818a0e9b534c846e7 (patch)
tree5a3401d20cbba543eb6dcc4b9302c304ae9353af /gcc/config/spu
parentc8b13e49c9b3c747c0c61f75d8e76107b0dddabe (diff)
downloadgcc-01d1f82e58c1b1578736d8a818a0e9b534c846e7.tar.gz
* config/spu/t-spu-elf (LIB2_SIDITI_CONV_FUNC): Define.
* config/spu/spu.h (MIN_UNITS_PER_WORD): Do not define. (LIBGCC2_UNITS_PER_WORD): Define if not already defined. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@167950 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/config/spu')
-rw-r--r--gcc/config/spu/spu.h13
-rw-r--r--gcc/config/spu/t-spu-elf4
2 files changed, 14 insertions, 3 deletions
diff --git a/gcc/config/spu/spu.h b/gcc/config/spu/spu.h
index 234ff49f114..d56a52b5504 100644
--- a/gcc/config/spu/spu.h
+++ b/gcc/config/spu/spu.h
@@ -65,9 +65,16 @@ extern GTY(()) int spu_tune;
#define UNITS_PER_WORD (BITS_PER_WORD/BITS_PER_UNIT)
-/* We never actually change UNITS_PER_WORD, but defining this causes
- libgcc to use some different sizes of types when compiling. */
-#define MIN_UNITS_PER_WORD 4
+/* When building libgcc, we need to assume 4 words per units even
+ though UNITS_PER_WORD is 16, because the SPU has basically a 32-bit
+ instruction set although register size is 128 bits. In particular,
+ this causes libgcc to contain __divdi3 instead of __divti3 etc.
+ However, we allow this default to be re-defined on the command
+ line, so that we can use the LIB2_SIDITI_CONV_FUNCS mechanism
+ to get (in addition) TImode versions of some routines. */
+#ifndef LIBGCC2_UNITS_PER_WORD
+#define LIBGCC2_UNITS_PER_WORD 4
+#endif
#define POINTER_SIZE 32
diff --git a/gcc/config/spu/t-spu-elf b/gcc/config/spu/t-spu-elf
index 3bb54e428dd..341a5aadee3 100644
--- a/gcc/config/spu/t-spu-elf
+++ b/gcc/config/spu/t-spu-elf
@@ -61,6 +61,10 @@ fp-bit.c: $(srcdir)/config/fp-bit.c $(srcdir)/config/spu/t-spu-elf
echo '#define FLOAT' > fp-bit.c
cat $(srcdir)/config/fp-bit.c >> fp-bit.c
+# Build TImode conversion routines to support Fortran 128-bit
+# integer data types.
+LIB2_SIDITI_CONV_FUNCS=yes
+
# Don't let CTOR_LIST end up in sdata section.
CRTSTUFF_T_CFLAGS =