re PR target/60203 (Support long double/_Decimal128 direct move on power8)
commitb9809dc4cf74a31f6b7a059c48b0995518e6e782
authorMichael Meissner <meissner@linux.vnet.ibm.com>
Wed, 19 Feb 2014 02:14:17 +0000 (19 02:14 +0000)
committerMichael Meissner <meissner@gcc.gnu.org>
Wed, 19 Feb 2014 02:14:17 +0000 (19 02:14 +0000)
tree58fca839fbf8f8be51078d382be8b1a2755ae116
parent4785ca2660e8b37ca1e37e2da6534ed72b5b4714
re PR target/60203 (Support long double/_Decimal128 direct move on power8)

2014-02-18  Michael Meissner  <meissner@linux.vnet.ibm.com>

PR target/60203
* config/rs6000/rs6000.md (mov<mode>_64bit, TF/TDmode moves):
Split 64-bit moves into 2 patterns.  Do not allow the use of
direct move for TDmode in little endian, since the decimal value
has little endian bytes within a word, but the 64-bit pieces are
ordered in a big endian fashion, and normal subreg's of TDmode are
not allowed.
(mov<mode>_64bit_dm): Likewise.
(movtd_64bit_nodm): Likewise.

From-SVN: r207868
gcc/ChangeLog
gcc/config/rs6000/rs6000.md