Fix wrong code in ldost-strlen-1.c
gcc/ChangeLog: PR tree-optimization/102720 * tree-ssa-structalias.c (compute_points_to_sets): Fix producing of call used and clobbered sets.
This commit is contained in:
parent
93d183a5ff
commit
99b287b8ef
@ -7541,18 +7541,19 @@ compute_points_to_sets (void)
|
||||
determine_global_memory_access (stmt, NULL,
|
||||
&reads_global_memory,
|
||||
&uses_global_memory);
|
||||
if (!uses_global_memory)
|
||||
;
|
||||
else if ((vi = lookup_call_use_vi (stmt)) != NULL)
|
||||
if ((vi = lookup_call_use_vi (stmt)) != NULL)
|
||||
{
|
||||
*pt = find_what_var_points_to (cfun->decl, vi);
|
||||
/* Escaped (and thus nonlocal) variables are always
|
||||
implicitly used by calls. */
|
||||
/* ??? ESCAPED can be empty even though NONLOCAL
|
||||
always escaped. */
|
||||
if (uses_global_memory)
|
||||
{
|
||||
pt->nonlocal = uses_global_memory;
|
||||
pt->escaped = uses_global_memory;
|
||||
}
|
||||
}
|
||||
else if (uses_global_memory)
|
||||
{
|
||||
/* If there is nothing special about this call then
|
||||
@ -7572,18 +7573,19 @@ compute_points_to_sets (void)
|
||||
determine_global_memory_access (stmt, &writes_global_memory,
|
||||
NULL, NULL);
|
||||
|
||||
if (!writes_global_memory)
|
||||
;
|
||||
else if ((vi = lookup_call_clobber_vi (stmt)) != NULL)
|
||||
if ((vi = lookup_call_clobber_vi (stmt)) != NULL)
|
||||
{
|
||||
*pt = find_what_var_points_to (cfun->decl, vi);
|
||||
/* Escaped (and thus nonlocal) variables are always
|
||||
implicitly clobbered by calls. */
|
||||
/* ??? ESCAPED can be empty even though NONLOCAL
|
||||
always escaped. */
|
||||
if (writes_global_memory)
|
||||
{
|
||||
pt->nonlocal = writes_global_memory;
|
||||
pt->escaped = writes_global_memory;
|
||||
}
|
||||
}
|
||||
else if (writes_global_memory)
|
||||
{
|
||||
/* If there is nothing special about this call then
|
||||
|
Loading…
Reference in New Issue
Block a user