------- Comment #2 from ebotcazou at gcc dot gnu dot org  2007-09-20 20:45 
-------
> A reghunt revealed that this was caused by the following patch:
> 
> 2007-03-02  Eric Botcazou  <[EMAIL PROTECTED]>
> 
>         * config/alpha/alpha.c (alpha_gp_save_rtx): Insert the insns at the
>         entry by means of emit_insn_at_entry.

Right.  Interestingly enough, this is purely a checking failure, i.e. the IL
is correct at the end of the pass.  What happens is that in

  if (USING_SJLJ_EXCEPTIONS)
    sjlj_build_landing_pads ();
  else
    dw2_build_landing_pads ();

  cfun->eh->built_landing_pads = 1;

  /* We've totally changed the CFG.  Start over.  */
  find_exception_handler_labels ();
  break_superblocks ();
  if (USING_SJLJ_EXCEPTIONS)
    commit_edge_insertions ();

dw2_build_landing_pads will trigger a CFG verification, which of course is
not the right thing to do given the comment in the code.

The solution is the original patch I posted:
  http://gcc.gnu.org/ml/gcc-patches/2006-11/msg01448.html
which was OKed by RTH:
  http://gcc.gnu.org/ml/gcc-patches/2007-02/msg01162.html
so I'm going to apply it.


-- 


http://gcc.gnu.org/bugzilla/show_bug.cgi?id=32325

Reply via email to