diff --git a/gcc/ChangeLog b/gcc/ChangeLog index 5540fb6d4a8..2c8c9a58b74 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,9 @@ +2015-02-28 Jan Hubicka + + PR ipa/65236 + * cgraphunit.c (cgraph_node::expand_thunk): Enable return slot + opt. + 2015-02-28 Xingxing Pan * config/aarch64/aarch64.md: (mov_aarch64): Change type diff --git a/gcc/cgraphunit.c b/gcc/cgraphunit.c index 9f6878a19e3..e640907550d 100644 --- a/gcc/cgraphunit.c +++ b/gcc/cgraphunit.c @@ -1680,6 +1680,14 @@ cgraph_node::expand_thunk (bool output_asm_thunks, bool force_gimple_thunk) callees->call_stmt = call; gimple_call_set_from_thunk (call, true); gimple_call_set_with_bounds (call, instrumentation_clone); + + /* Return slot optimization is always possible and in fact requred to + return values with DECL_BY_REFERENCE. */ + if (aggregate_value_p (resdecl, TREE_TYPE (thunk_fndecl)) + && (!is_gimple_reg_type (TREE_TYPE (resdecl)) + || DECL_BY_REFERENCE (resdecl))) + gimple_call_set_return_slot_opt (call, true); + if (restmp && !alias_is_noreturn) { gimple_call_set_lhs (call, restmp); diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 27b6a4ac218..bf0978e957f 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2015-02-28 Jan Hubicka + + PR ipa/65236 + * g++.dg/ipa/ipa-icf-6.C: New testcase. + 2015-02-27 Pat Haugen * gcc.dg/vect/pr59354.c: Move vector producing code to separate function. diff --git a/gcc/testsuite/g++.dg/ipa/ipa-icf-6.C b/gcc/testsuite/g++.dg/ipa/ipa-icf-6.C new file mode 100644 index 00000000000..933ab5dcf08 --- /dev/null +++ b/gcc/testsuite/g++.dg/ipa/ipa-icf-6.C @@ -0,0 +1,37 @@ +/* { dg-do run } */ +/* { dg-options "-O3 -fdump-ipa-icf" } */ + +struct A { + A() {ptr=&b;} + A(const A &a) {ptr = &b;} + void test() { if (ptr != &b) __builtin_abort ();} + int b; + int *ptr; +}; + +A test1(A a) +{ + a.test(); + return a; +} +A test2(A a) +{ + a.test(); + return a; +} +__attribute__ ((noinline)) +static void +test_me (A (*t)(A)) +{ + struct A a, b=t(a); + b.test (); +} +int +main() +{ + test_me (test1); + test_me (test2); + return 0; +} +/* { dg-final { scan-ipa-dump-times "Unified; Wrapper has been created" 1 "icf" } } */ +/* { dg-final { cleanup-ipa-dump "icf" } } */