From: Jan Beulich Date: Thu, 8 Jul 2004 05:58:35 +0000 (+0000) Subject: calls.c (emit_library_call_value_1): Use mode of function parameter rather than that... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=ff15c351eda434655cde7e6153b1a27db404a86d;p=gcc.git calls.c (emit_library_call_value_1): Use mode of function parameter rather than that of argument since constants... * calls.c (emit_library_call_value_1): Use mode of function parameter rather than that of argument since constants have none. From-SVN: r84267 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 7519fac6998..7e6ccaa7ab8 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,7 +1,10 @@ 2004-07-06 Jan Beulich - * config/i386/i386.c (ix86_gimplify_va_arg): Don't need temporary for - passing arguments the containers for which are registers. + * config/i386/i386.c (ix86_gimplify_va_arg): Don't need temporary for + passing arguments the containers for which are registers. + + * calls.c (emit_library_call_value_1): Use mode of function parameter + rather than that of argument since constants have none. 2004-07-08 Alexandre Oliva diff --git a/gcc/calls.c b/gcc/calls.c index 9f84199990e..3f427fbe7d5 100644 --- a/gcc/calls.c +++ b/gcc/calls.c @@ -3888,6 +3888,7 @@ emit_library_call_value_1 (int retval, rtx orgfun, rtx value, are to be pushed. */ for (count = 0; count < nargs; count++, argnum += inc) { + enum machine_mode mode = argvec[argnum].mode; rtx val = argvec[argnum].value; rtx reg = argvec[argnum].reg; int partial = argvec[argnum].partial; @@ -3895,7 +3896,7 @@ emit_library_call_value_1 (int retval, rtx orgfun, rtx value, /* Handle calls that pass values in multiple non-contiguous locations. The PA64 has examples of this for library calls. */ if (reg != 0 && GET_CODE (reg) == PARALLEL) - emit_group_load (reg, val, NULL_TREE, GET_MODE_SIZE (GET_MODE (val))); + emit_group_load (reg, val, NULL_TREE, GET_MODE_SIZE (mode)); else if (reg != 0 && partial == 0) emit_move_insn (reg, val);