diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 43d54a1855c..b600f6df9f4 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,10 @@ +2004-02-04 Eric Botcazou + + * config/sparc/sparc.c (function_arg_pass_by_reference): Return 1 + for all modes whose size is greater than 8 bytes if ARCH32. + (sparc_va_arg): Handle all modes whose size is greater than 8 bytes + by reference if ARCH32. + 2004-02-04 Aldy Hernandez * cgraphunit.c (cgraph_postorder): Fix typo in comment. diff --git a/gcc/config/sparc/sparc.c b/gcc/config/sparc/sparc.c index 855fe1d6747..c58046277c5 100644 --- a/gcc/config/sparc/sparc.c +++ b/gcc/config/sparc/sparc.c @@ -5672,10 +5672,8 @@ function_arg_pass_by_reference (const struct sparc_args *cum ATTRIBUTE_UNUSED, if (TARGET_ARCH32) { return ((type && AGGREGATE_TYPE_P (type)) - || mode == TFmode || mode == SCmode - || mode == DCmode - || mode == TCmode); + || GET_MODE_SIZE (mode) > 8); } else { @@ -5886,10 +5884,8 @@ sparc_va_arg (tree valist, tree type) else { if (AGGREGATE_TYPE_P (type) - || TYPE_MODE (type) == TFmode || TYPE_MODE (type) == SCmode - || TYPE_MODE (type) == DCmode - || TYPE_MODE (type) == TCmode) + || GET_MODE_SIZE (TYPE_MODE (type)) > 8) { indirect = 1; size = rsize = UNITS_PER_WORD;