On Tue, 12 Jan 2016, Tom de Vries wrote: > On 12/01/16 12:22, Richard Biener wrote: > > Doesnt' the same issue apply to > > > > > >unsigned int *p; > > > > > > > >static void __attribute__((noinline, noclone)) > > > >foo (void) > > > >{ > > > > unsigned int z; > > > > > > > > for (z = 0; z < N; ++z) > > > > ++(*p); > > > >} > > thus when we have a MEM_REF[p_1]? SCEV will not analyze > > its evolution to a POLYNOMIAL_CHREC and thus access_fns will > > be NULL again. > > > > I didn't manage to trigger this scenario, though I could probably make it > happen by modifying ftree-loop-im to work in one case (the load of the value > of p) but not the other (the *p load and store). > > > I think avoiding a NULL access_fns is ok but it should be done > > unconditionally, not only for the DECL_P case. > > Ok, I'll retest and commit this patch.
Please add a comment as well. > Thanks, > - Tom > -- Richard Biener <rguent...@suse.de> SUSE LINUX GmbH, GF: Felix Imendoerffer, Jane Smithard, Graham Norton, HRB 21284 (AG Nuernberg)