> -----Original Message----- > From: Jakub Jelinek [mailto:ja...@redhat.com] > Sent: Monday, October 22, 2012 3:16 PM > To: Bin Cheng > Cc: gcc-patches@gcc.gnu.org > Subject: Re: [PATCH GCC]Fix test case failure reported in PR54989 > > On Mon, Oct 22, 2012 at 11:00:08AM +0800, Bin Cheng wrote: > > The test case "gcc/testsuite/gcc.dg/hoist-register-pressure.c" is > > failed on x86_64-apple-darwin because it uses more registers than > > x86_64-linux. This can be fixed by simplifying the case using fewer > registers. > > > > Tested on x86_64-apple-darwin/x86_64-linux, is it OK? > > I'd say it is better to do the scan-rtl-dump only on nonpic targets, that way > it won't be done on darwin or for testing with --target_board=unix/-fpic where > it would fail too. You can add the test with smaller register pressure as a > new test (hoist-register-pressure2.c). >
Hi Jakub, Thanks for the suggestion. Updated patch as attached. Now it can work with -fPIC/-fno-PIC options. Tested on x86_64-apple-darwin/x86-linux, is it OK. Thanks gcc/testsuite/ChangeLog 2012-10-22 Bin Cheng <bin.ch...@arm.com> * gcc.dg/hoist-register-pressure-1.c: Rename from hoist-register-pressure.c. Add nonpic condition. * gcc.dg/hoist-register-pressure-2.c: New test.
Index: gcc/testsuite/gcc.dg/hoist-register-pressure-1.c =================================================================== --- gcc/testsuite/gcc.dg/hoist-register-pressure-1.c (revision 0) +++ gcc/testsuite/gcc.dg/hoist-register-pressure-1.c (revision 0) @@ -0,0 +1,31 @@ +/* { dg-options "-Os -fdump-rtl-hoist" } */ +/* { dg-final { scan-rtl-dump "PRE/HOIST: end of bb .* copying expression" "hoist" { target { nonpic } } } } */ + +#define BUF 100 +int a[BUF]; + +void com (int); +void bar (int); + +int foo (int x, int y, int z) +{ + /* "x+y" won't be hoisted if "-fira-hoist-pressure" is disabled, + because its rtx_cost is too small. */ + if (z) + { + a[1] = a[0] + a[2]; + a[2] = a[1] + a[3]; + a[3] = a[2] + a[4]; + a[4] = a[3] + a[5]; + a[5] = a[4] + a[6]; + a[6] = a[5] + a[7]; + a[7] = a[6] + a[8]; + com (x+y); + } + else + { + bar (x+y); + } + + return 0; +} Index: gcc/testsuite/gcc.dg/hoist-register-pressure-2.c =================================================================== --- gcc/testsuite/gcc.dg/hoist-register-pressure-2.c (revision 0) +++ gcc/testsuite/gcc.dg/hoist-register-pressure-2.c (revision 0) @@ -0,0 +1,32 @@ +/* { dg-options "-Os -fdump-rtl-hoist" } */ +/* { dg-final { scan-rtl-dump "PRE/HOIST: end of bb .* copying expression" "hoist" } } */ + +#define BUF 100 +int a[BUF]; + +void com (int); +void bar (int); + +int foo (int x, int y, int z) +{ + /* "x+y" won't be hoisted if "-fira-hoist-pressure" is disabled, + because its rtx_cost is too small. */ + if (z) + { + a[1] = a[0]; + a[2] = a[1]; + a[3] = a[3]; + a[4] = a[5]; + a[5] = a[7]; + a[6] = a[11]; + a[7] = a[13]; + a[8] = a[17]; + com (x+y); + } + else + { + bar (x+y); + } + + return 0; +} Index: gcc/testsuite/gcc.dg/hoist-register-pressure.c =================================================================== --- gcc/testsuite/gcc.dg/hoist-register-pressure.c (revision 192629) +++ gcc/testsuite/gcc.dg/hoist-register-pressure.c (working copy) @@ -1,31 +0,0 @@ -/* { dg-options "-Os -fdump-rtl-hoist" } */ -/* { dg-final { scan-rtl-dump "PRE/HOIST: end of bb .* copying expression" "hoist" } } */ - -#define BUF 100 -int a[BUF]; - -void com (int); -void bar (int); - -int foo (int x, int y, int z) -{ - /* "x+y" won't be hoisted if "-fira-hoist-pressure" is disabled, - because its rtx_cost is too small. */ - if (z) - { - a[1] = a[0] + a[2]; - a[2] = a[1] + a[3]; - a[3] = a[2] + a[4]; - a[4] = a[3] + a[5]; - a[5] = a[4] + a[6]; - a[6] = a[5] + a[7]; - a[7] = a[6] + a[8]; - com (x+y); - } - else - { - bar (x+y); - } - - return 0; -}