Compiler segfaults in some cases when using -mwarn-cell-microcode.
Created attachment 20390 [details] snippet that triggers the segfault Segfaults when compiled with -O3 -mcpu=cell -mwarn-cell-microcode.
Confirmed. The problem is from: /* Vector constant 0 is handled as a splitter of V2SI, and in the pattern of V1DI, V4HI, and V2SF. FIXME: We should probably return # and add post reload splitters for these, but this way is so easy ;-). */
Still happens.
Author: segher Date: Fri Mar 3 17:00:50 2017 New Revision: 245880 URL: https://gcc.gnu.org/viewcvs?rev=245880&root=gcc&view=rev Log: 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. Modified: trunk/gcc/ChangeLog trunk/gcc/config/rs6000/rs6000.c
-mwarn-cell-microcode was removed in r248695 (it's in GCC 7). No backports planned.