diff options
author | rguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-05-31 11:01:32 +0000 |
---|---|---|
committer | rguenth <rguenth@138bc75d-0d04-0410-961f-82ee72b054a4> | 2010-05-31 11:01:32 +0000 |
commit | 9a7b938d92bed9f068038d1409e9b0a5e94ffc57 (patch) | |
tree | 711d4b253a8788575f9ceb2e718e1baf693159a1 /gcc/tree-ssa-structalias.c | |
parent | a2c73aa9cefa9232faa47c108c61750558c74182 (diff) | |
download | gcc-9a7b938d92bed9f068038d1409e9b0a5e94ffc57.tar.gz |
2010-05-31 Richard Guenther <rguenther@suse.de>
* tree-ssa-structalias.c (find_func_aliases): Handle
BUILT_IN_RETURN.
git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@160067 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'gcc/tree-ssa-structalias.c')
-rw-r--r-- | gcc/tree-ssa-structalias.c | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/gcc/tree-ssa-structalias.c b/gcc/tree-ssa-structalias.c index a851ef2e2e9..d70b36c3498 100644 --- a/gcc/tree-ssa-structalias.c +++ b/gcc/tree-ssa-structalias.c @@ -4241,6 +4241,26 @@ find_func_aliases (gimple origt) /* va_end doesn't have any effect that matters. */ case BUILT_IN_VA_END: return; + /* Alternate return. Simply give up for now. */ + case BUILT_IN_RETURN: + { + fi = NULL; + if (!in_ipa_mode + || !(fi = get_vi_for_tree (cfun->decl))) + make_constraint_from (get_varinfo (escaped_id), anything_id); + else if (in_ipa_mode + && fi != NULL) + { + struct constraint_expr lhs, rhs; + lhs = get_function_part_constraint (fi, fi_result); + rhs.var = anything_id; + rhs.offset = 0; + rhs.type = SCALAR; + get_constraint_for (gimple_return_retval (t), &rhsc); + process_constraint (new_constraint (lhs, rhs)); + } + return; + } /* printf-style functions may have hooks to set pointers to point to somewhere into the generated string. Leave them for a later excercise... */ |