+2018-06-06 David Malcolm <dmalcolm@redhat.com>
+
+ * config/i386/i386-protos.h (ix86_expand_call): Strengthen return
+ type from "rtx" to "rtx_insn *".
+ * config/i386/i386.c (ix86_expand_split_stack_prologue): Likewise
+ for local "call_insn", removing cast.
+ (ix86_expand_call): Likewise, introducing a "call_insn" local.
+
2018-06-06 Eric Botcazou <ebotcazou@adacore.com>
PR tree-optimization/86066
extern void ix86_expand_sse_movcc (rtx, rtx, rtx, rtx);
extern void ix86_expand_sse_unpack (rtx, rtx, bool, bool);
extern bool ix86_expand_int_addcc (rtx[]);
-extern rtx ix86_expand_call (rtx, rtx, rtx, rtx, rtx, bool);
+extern rtx_insn *ix86_expand_call (rtx, rtx, rtx, rtx, rtx, bool);
extern void ix86_split_call_vzeroupper (rtx, rtx);
extern void x86_initialize_trampoline (rtx, rtx, rtx);
extern rtx ix86_zero_extend_to_Pmode (rtx);
HOST_WIDE_INT allocate;
unsigned HOST_WIDE_INT args_size;
rtx_code_label *label;
- rtx limit, current, allocate_rtx, call_insn, call_fusage;
+ rtx limit, current, allocate_rtx, call_fusage;
+ rtx_insn *call_insn;
rtx scratch_reg = NULL_RTX;
rtx_code_label *varargs_label = NULL;
rtx fn;
if (!TARGET_64BIT)
add_reg_note (call_insn, REG_ARGS_SIZE, GEN_INT (0));
/* Indicate that this function can't jump to non-local gotos. */
- make_reg_eh_region_note_nothrow_nononlocal (as_a <rtx_insn *> (call_insn));
+ make_reg_eh_region_note_nothrow_nononlocal (call_insn);
/* In order to make call/return prediction work right, we now need
to execute a return instruction. See
return tmp;
}
-rtx
+rtx_insn *
ix86_expand_call (rtx retval, rtx fnaddr, rtx callarg1,
rtx callarg2,
rtx pop, bool sibcall)
if (vec_len > 1)
call = gen_rtx_PARALLEL (VOIDmode, gen_rtvec_v (vec_len, vec));
- call = emit_call_insn (call);
+ rtx_insn *call_insn = emit_call_insn (call);
if (use)
- CALL_INSN_FUNCTION_USAGE (call) = use;
+ CALL_INSN_FUNCTION_USAGE (call_insn) = use;
- return call;
+ return call_insn;
}
/* Return true if the function being called was marked with attribute