diff options
author | Jan Hubicka <jh@suse.cz> | 2020-11-15 15:10:22 +0100 |
---|---|---|
committer | Jan Hubicka <jh@suse.cz> | 2020-11-15 15:10:22 +0100 |
commit | 26285af40f98dfdb809b98b08386073c63b65db1 (patch) | |
tree | ac280fe6d1d81b16c828e96aa28b39d96bd40d31 | |
parent | faab61b585a8b4a42454f085dd6b7815992a98f5 (diff) | |
download | gcc-26285af40f98dfdb809b98b08386073c63b65db1.zip gcc-26285af40f98dfdb809b98b08386073c63b65db1.tar.gz gcc-26285af40f98dfdb809b98b08386073c63b65db1.tar.bz2 |
Mare return to clear EAF_UNUSED flag.
gcc/ChangeLog:
* ipa-modref.c (analyze_ssa_name_flags): Make return to clear
EAF_UNUSED flag.
gcc/testsuite/ChangeLog:
* gcc.c-torture/execute/pr97836.c: New test.
-rw-r--r-- | gcc/ipa-modref.c | 6 | ||||
-rw-r--r-- | gcc/testsuite/gcc.c-torture/execute/pr97836.c | 17 |
2 files changed, 21 insertions, 2 deletions
diff --git a/gcc/ipa-modref.c b/gcc/ipa-modref.c index 5273c20..4a43c50 100644 --- a/gcc/ipa-modref.c +++ b/gcc/ipa-modref.c @@ -1224,10 +1224,12 @@ analyze_ssa_name_flags (tree name, vec<unsigned char> &known_flags, int depth) print_gimple_stmt (dump_file, use_stmt, 0); } - /* Gimple return may load the return value. */ + /* Gimple return may load the return value. + Returning name counts as an use by tree-ssa-structalias.c */ if (greturn *ret = dyn_cast <greturn *> (use_stmt)) { - if (memory_access_to (gimple_return_retval (ret), name)) + if (memory_access_to (gimple_return_retval (ret), name) + || name == gimple_return_retval (ret)) flags &= ~EAF_UNUSED; } /* Account for LHS store, arg loads and flags from callee function. */ diff --git a/gcc/testsuite/gcc.c-torture/execute/pr97836.c b/gcc/testsuite/gcc.c-torture/execute/pr97836.c new file mode 100644 index 0000000..4585e1f --- /dev/null +++ b/gcc/testsuite/gcc.c-torture/execute/pr97836.c @@ -0,0 +1,17 @@ +int a; + +int b(int c) { return 0; } + +static int *d(int *e) { + if (a) { + a = a && b(*e); + } + return e; +} + +int main() { + int f; + if (d(&f) != &f) + __builtin_abort(); + return 0; +} |