rs6000: Wrap diff of immediates in const (PR83629)
authorSegher Boessenkool <segher@kernel.crashing.org>
Wed, 10 Jan 2018 15:13:07 +0000 (16:13 +0100)
committerSegher Boessenkool <segher@gcc.gnu.org>
Wed, 10 Jan 2018 15:13:07 +0000 (16:13 +0100)
commit8c6e19c1c24794163bc9114bb367c9d61b7f839c
tree5f267bfaade3241d4a715ef843334ee0deba267d
parentc9edeca8b88d20afa80143302be64e2e625e707a
rs6000: Wrap diff of immediates in const (PR83629)

In various of our 32-bit load_toc patterns we take the difference of
two immediates (labels) as a term to something bigger; but this isn't
canonical RTL, it needs to be wrapped in CONST.

PR target/83629
* config/rs6000/rs6000.md (load_toc_v4_PIC_2, load_toc_v4_PIC_3b,
load_toc_v4_PIC_3c): Wrap const term in CONST RTL.

testsuite/
PR target/83629
* gcc.target/powerpc/pr83629.c: New testcase.

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