rs6000: Don't add an immediate to r0 (PR80966)
authorSegher Boessenkool <segher@kernel.crashing.org>
Fri, 9 Jun 2017 03:46:08 +0000 (05:46 +0200)
committerSegher Boessenkool <segher@gcc.gnu.org>
Fri, 9 Jun 2017 03:46:08 +0000 (05:46 +0200)
commit120ef1d50ab7fe53a67fb2026374b2bdd67838bd
tree705e42d50783725696c7140aee6b70afcf3ba82c
parentff67045361eb84325e54c38c84cae2df9859bfd3
rs6000: Don't add an immediate to r0 (PR80966)

If there is a large stack frame the rs6000 -fstack-limit code would
calculate the new stack pointer value using two insns (an addis and
an addi), with r0 as temporary.  Such instructions do not exist.

This patch changes add<mode>3 to expand using a different strategy in
such cases; to FAIL if there is no way to do it (namely, if the source
is r0 and there is no way to get a temporary reg); and it changes
rs6000_emit_allocate_stack to assert gen_add3_insn did in fact emit
instructions.

PR target/80966
* config/rs6000/rs6000.c (rs6000_emit_allocate_stack): Assert that
gen_add3_insn did not fail.
* config/rs6000/rs6000.md (add<mode>3): If asked to add a constant to
r0, construct that number in a temporary reg and add that reg to r0.
If asked to put the result in r0 as well, fail.

gcc/testsuite/
* gcc.target/powerpc/stack-limit.c: New testcase.

From-SVN: r249046
gcc/ChangeLog
gcc/config/rs6000/rs6000.c
gcc/config/rs6000/rs6000.md
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/powerpc/stack-limit.c [new file with mode: 0644]