Commit f325c456 by Segher Boessenkool Committed by Segher Boessenkool

rs6000: Fix for -mwarn-cell-microcode (PR43763)

If using -mwarn-cell-microcode, rs6000_final_prescan_insn calls
get_insn_template to get the name of the machine instruction.  But,
get_insn_template calls the output template if that is code, and that
then can modify recog_data (it is normal to change the operands, for
example).

This patch saves and restores recog_data around the call to
get_insn_template to fix the problems this causes.


	PR target/43763
	* config/rs6000/rs6000.c (rs6000_final_prescan_insn): Save and
	restore recog_data (including the operand rtxes inside it) around
	the call to get_insn_template.

From-SVN: r245880
parent 945b6e16
2017-03-03 Segher Boesssenkool <segher@kernel.crashing.org>
PR target/43763
* config/rs6000/rs6000.c (rs6000_final_prescan_insn): Save and
restore recog_data (including the operand rtxes inside it) around
the call to get_insn_template.
2017-03-03 Martin Sebor <msebor@redhat.com>
PR tree-optimization/79699
......
......@@ -38848,7 +38848,12 @@ rs6000_final_prescan_insn (rtx_insn *insn, rtx *operand ATTRIBUTE_UNUSED,
if (insn_code_number < 0)
return;
/* get_insn_template can modify recog_data, so save and restore it. */
struct recog_data_d recog_data_save = recog_data;
for (int i = 0; i < recog_data.n_operands; i++)
recog_data.operand[i] = copy_rtx (recog_data.operand[i]);
temp = get_insn_template (insn_code_number, insn);
recog_data = recog_data_save;
if (get_attr_cell_micro (insn) == CELL_MICRO_ALWAYS)
warning_at (location, OPT_mwarn_cell_microcode,
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment