diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 7a64192a6d7..18eaa23380d 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2010-12-16 Ulrich Weigand + + * 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. + 2010-12-16 Jakub Jelinek PR debug/46893 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 =