From: Peter Bergner Date: Mon, 24 Feb 2020 00:22:57 +0000 (-0600) Subject: rs6000: Fix infinite loop building ghostscript and icu [PR93658] X-Git-Tag: releases/gcc-9.3.0~92 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=066184a282b622ac6880150eb4e42fe57881b606;p=thirdparty%2Fgcc.git rs6000: Fix infinite loop building ghostscript and icu [PR93658] Fix rs6000_legitimate_address_p(), which erroneously marks a valid Altivec address as being invalid, which causes LRA's process_address() to go into an infinite loop spilling the same address over and over again. Include Mike's earlier commits that fix bugs this patch exposes. Backport from master 2020-02-20 Peter Bergner PR target/93658 * config/rs6000/rs6000.c (rs6000_legitimate_address_p): Handle VSX vector modes. * gcc.target/powerpc/pr93658.c: New test. --- diff --git a/gcc/ChangeLog b/gcc/ChangeLog index ec6600af0886..8d8dbc0bdff5 100644 --- a/gcc/ChangeLog +++ b/gcc/ChangeLog @@ -1,3 +1,12 @@ +2020-02-23 Peter Bergner + + Backport from master + 2020-02-20 Peter Bergner + + PR target/93658 + * config/rs6000/rs6000.c (rs6000_legitimate_address_p): Handle VSX + vector modes. + 2020-02-23 Peter Bergner Backport from master diff --git a/gcc/config/rs6000/rs6000.c b/gcc/config/rs6000/rs6000.c index ce1bd3262d19..1d93570e7a59 100644 --- a/gcc/config/rs6000/rs6000.c +++ b/gcc/config/rs6000/rs6000.c @@ -9358,7 +9358,7 @@ rs6000_legitimate_address_p (machine_mode mode, rtx x, bool reg_ok_strict) bool quad_offset_p = mode_supports_dq_form (mode); /* If this is an unaligned stvx/ldvx type address, discard the outer AND. */ - if (VECTOR_MEM_ALTIVEC_P (mode) + if (VECTOR_MEM_ALTIVEC_OR_VSX_P (mode) && GET_CODE (x) == AND && CONST_INT_P (XEXP (x, 1)) && INTVAL (XEXP (x, 1)) == -16) diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index 9344d00e38a5..f02a94152300 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,11 @@ +2020-02-23 Peter Bergner + + Backport from master + 2020-02-20 Peter Bergner + + PR target/93658 + * gcc.target/powerpc/pr93658.c: New test. + 2020-02-20 H.J. Lu Backport from master diff --git a/gcc/testsuite/gcc.target/powerpc/pr93658.c b/gcc/testsuite/gcc.target/powerpc/pr93658.c new file mode 100644 index 000000000000..0170d34d2595 --- /dev/null +++ b/gcc/testsuite/gcc.target/powerpc/pr93658.c @@ -0,0 +1,20 @@ +/* { dg-do compile } */ +/* { dg-options "-O3 -fstack-protector-strong -mcpu=power8" } */ +/* { dg-require-effective-target powerpc_vsx_ok } */ + +/* PR93658: Failure compiling this test is an infinite loop in LRA's + process_address(), so set a short timeout limit. */ +/* { dg-timeout 5 } */ + +void bar(); +char b; +void +foo (void) +{ + char a; + int d = b; + char *e = &a; + while (d) + *e++ = --d; + bar (); +}