On Fri, May 20, 2011 at 4:06 PM, Ryan Mansfield <rmansfi...@qnx.com> wrote:
> There is a crash in vect_is_slp_reduction where use_stmt doesn't get
> initialized in the FOR_EACH_IMM_USE_FAST loop.
>
> 1718          FOR_EACH_IMM_USE_FAST (use_p, imm_iter, lhs)
> (gdb) call debug_tree(lhs)
>  <ssa_name 0x7ffff6e3a5a0
>    type <integer_type 0x7ffff7f8c7e0 int32_t sizes-gimplified public SI
>        size <integer_cst 0x7ffff7ec47e0 constant 32>
>        unit size <integer_cst 0x7ffff7ec4580 constant 4>
>        align 32 symtab 0 alias set -1 canonical type 0x7ffff7ecb498
> precision 32 min <integer_cst 0x7ffff7ec4780 -2147483648> max <integer_cst
> 0x7ffff7ec47a0 2147483647> context <translation_unit_decl 0x7ffff7f98508
> D.1314>
>        pointer_to_this <pointer_type 0x7ffff7f9f930>>
>    var <var_decl 0x7ffff6e1ce60 g_29_lsm.18>def_stmt g_29_lsm.18_137 = PHI
> <g_29_lsm.18_87(15), D.2113_96(18)>
>
>    version 137>
> (gdb) n
> 1742          if (found)
> (gdb)
> 1746          if (gimple_code (use_stmt) == GIMPLE_PHI)
> (gdb)
>
> Program received signal SIGSEGV, Segmentation fault.
> 0x0000000000980f22 in gimple_code (g=0x0) at ../../gcc/gimple.h:1098
> 1098      return g->gsbase.code;
>
> Is the following sufficient?

No, we shouldn't arrive with a NULL use_stmt here.

Richard.

> Index: tree-vect-loop.c
> ===================================================================
> --- tree-vect-loop.c    (revision 173945)
> +++ tree-vect-loop.c    (working copy)
> @@ -1743,7 +1743,7 @@
>         break;
>
>       /* This is a loop exit phi, and we haven't reached the reduction phi.
>  */
> -      if (gimple_code (use_stmt) == GIMPLE_PHI)
> +      if (!use_stmt || gimple_code (use_stmt) == GIMPLE_PHI)
>         return false;
>
>       if (!is_gimple_assign (use_stmt)
>
> Regards,
>
> Ryan Mansfield
>

Reply via email to