On Thu, May 3, 2012 at 3:30 PM, Matt Davis <mattdav...@gmail.com> wrote:
> I have been fighting with a simple problem for the past few nights.  In my
> GIMPLE pass I create a variable, an ssa name for that variable, and then 
> assign
> it to the LHS of a call I build:
>
>  call = gimple_build_call(fndecl, 0);
>  decl = create_tmp_var(TREE_TYPE(TREE_TYPE(test_decode_fndecl)), "FOO");
>  ssa  = make_ssa_name(decl, call);
>  gimple_set_lhs(call, ssa);
>  gsi_insert_before(&gsi, call, GSI_SAME_STMT);
>
> I verify the GIMPLE and it looks proper:
>
>  char * FOO.2;
>  /* some gimple code */
>  FOO.2_8 = fn();
>  strcat(&mylocal, FOO.2_8);

Probably for the use stmt you did not call update_stmt.  You can check
in the debugger by debug_immediate_uses () which likely prints no use
for FOO.2_8

>
> However, when I build with -Os the GIMPLE looks like:
>  char * FOO.2;
>  /* some gimple code */
>  fn();
>  strcat(&mylocal, FOO.2_8);
>
> And the compiler segfaults in "ptr_deref_may_alias_decl_p" for 'ptr' FOO.2_8 
> and
> 'decl' mylocal arguments.  The segfault occurs because TREE_TYPE(ptr) is NULL
> and calling POINTER_TYPE_P(TREE_TYPE(ptr)) dereferences a NULL.

That's what happens when an SSA name is released.

> After more debugging, it is eliminate_unnecessary_stmts() which tries to 
> remove
> the 'FOO.2_8 = fn();' statement.  In that routine, the LHS is considered 
> "dead"
> and because of that the routine sets the LHS to NULL.

It's dead if it has no uses.

> So, I guess my question is, how can I force this stmt to hang around?  I 
> looked
> at eliminate_unnecessary_stmts, and do not see any specific flags I can set to
> the stmt to make 'em hang around, and I do not know what to do to make LHS
> appear not "dead."  Even if I set 'ssa' TREE_USED and 'decl' as 
> DECL_PRESERVE_P.

Well, that's not how SSA uses/defs work.

> Thanks for any information!
>
> -Matt

Reply via email to