From: Roger Sayle Date: Tue, 3 Jun 2003 17:13:06 +0000 (+0000) Subject: expr.c (emit_move_insn_1): Use emit_move_insn to move the parts of a complex number... X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=a79b3dc7c8d3e9c7cdd5bab9f8f5ae3841a95764;p=gcc.git expr.c (emit_move_insn_1): Use emit_move_insn to move the parts of a complex number rather than invoke... * expr.c (emit_move_insn_1): Use emit_move_insn to move the parts of a complex number rather than invoke mov_optab directly. From-SVN: r67389 --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 27132efc5b3..91e3bea8fd7 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,8 @@ +2003-06-03 Roger Sayle + + * expr.c (emit_move_insn_1): Use emit_move_insn to move the parts + of a complex number rather than invoke mov_optab directly. + 2003-06-03 Kazu Hirata * combine.c (simplify_set): Don't move a subreg in SET_SRC to diff --git a/gcc/expr.c b/gcc/expr.c index f340335515b..7adaca00565 100644 --- a/gcc/expr.c +++ b/gcc/expr.c @@ -3394,19 +3394,15 @@ emit_move_insn_1 (x, y) /* Note that the real part always precedes the imag part in memory regardless of machine's endianness. */ #ifdef STACK_GROWS_DOWNWARD - emit_insn (GEN_FCN (mov_optab->handlers[(int) submode].insn_code) - (gen_rtx_MEM (submode, XEXP (x, 0)), - gen_imagpart (submode, y))); - emit_insn (GEN_FCN (mov_optab->handlers[(int) submode].insn_code) - (gen_rtx_MEM (submode, XEXP (x, 0)), - gen_realpart (submode, y))); + emit_move_insn (gen_rtx_MEM (submode, XEXP (x, 0)), + gen_imagpart (submode, y)); + emit_move_insn (gen_rtx_MEM (submode, XEXP (x, 0)), + gen_realpart (submode, y)); #else - emit_insn (GEN_FCN (mov_optab->handlers[(int) submode].insn_code) - (gen_rtx_MEM (submode, XEXP (x, 0)), - gen_realpart (submode, y))); - emit_insn (GEN_FCN (mov_optab->handlers[(int) submode].insn_code) - (gen_rtx_MEM (submode, XEXP (x, 0)), - gen_imagpart (submode, y))); + emit_move_insn (gen_rtx_MEM (submode, XEXP (x, 0)), + gen_realpart (submode, y)); + emit_move_insn (gen_rtx_MEM (submode, XEXP (x, 0)), + gen_imagpart (submode, y)); #endif } else @@ -3481,10 +3477,8 @@ emit_move_insn_1 (x, y) || GET_CODE (imagpart_x) == SUBREG)) emit_insn (gen_rtx_CLOBBER (VOIDmode, x)); - emit_insn (GEN_FCN (mov_optab->handlers[(int) submode].insn_code) - (realpart_x, realpart_y)); - emit_insn (GEN_FCN (mov_optab->handlers[(int) submode].insn_code) - (imagpart_x, imagpart_y)); + emit_move_insn (realpart_x, realpart_y); + emit_move_insn (imagpart_x, imagpart_y); } return get_last_insn ();