From 39ac09770991ae0a9052fd0865159b0b17d22a3d Mon Sep 17 00:00:00 2001 From: Josh Conner Date: Fri, 1 Sep 2006 16:56:45 +0000 Subject: re PR middle-end/25505 (gcc uses way too much stack space for this code) 2006-09-01 Josh Conner PR c++/25505 gcc.dg/nrv3.c: New test. gcc.dg/nrv4.c: New test. gcc.dg/nrv5.c: New test. From-SVN: r116634 --- gcc/testsuite/gcc.dg/nrv5.c | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) create mode 100644 gcc/testsuite/gcc.dg/nrv5.c (limited to 'gcc/testsuite/gcc.dg/nrv5.c') diff --git a/gcc/testsuite/gcc.dg/nrv5.c b/gcc/testsuite/gcc.dg/nrv5.c new file mode 100644 index 0000000..ecca562 --- /dev/null +++ b/gcc/testsuite/gcc.dg/nrv5.c @@ -0,0 +1,28 @@ +/* Verify that NRV optimizations are prohibited when the LHS is + something that may be call-clobbered. */ +/* { dg-do compile } */ +/* { dg-options "-O -fdump-tree-optimized" } */ + +typedef struct { int x; void *y; } S; +typedef struct { int a; S b; } T; +S nrv_candidate (void); +void use_result (S); +void make_escape (S *); +void foo (void) +{ + S result; + T result_arr[10][5]; + + make_escape (&result); + make_escape (&(result_arr[3][4].b)); + + /* Neither call should be allowed to use NRV optimization. */ + result = nrv_candidate (); + result_arr[3][4].b = nrv_candidate (); + + use_result (result); + use_result (result_arr[3][4].b); +} + +/* { dg-final { scan-tree-dump-times "return slot optimization" 0 "optimized" } } */ +/* { dg-final { cleanup-tree-dump "optimized" } } */ -- cgit v1.1