[PowerPC 2/4] Little-endian adjustments for VSX insert/extract operations
authorBill Schmidt <wschmidt@linux.vnet.ibm.com>
Tue, 9 Dec 2014 16:43:32 +0000 (16:43 +0000)
committerBill Schmidt <wschmidt@linux.vnet.ibm.com>
Tue, 9 Dec 2014 16:43:32 +0000 (16:43 +0000)
commit03b9f9f2b636a5c074db619d2a811c8776dec07f
tree7332b1a8f316120908a4544789285aa0afc7dab1
parentc50f9f15f5979c2f47aa97e80af22472fa2b2a57
[PowerPC 2/4] Little-endian adjustments for VSX insert/extract operations

For little endian, we need to make some straightforward adjustments in
the code expansions for scalar_to_vector and vector_extract of v2f64.
First, scalar_to_vector must place the scalar into vector element
zero.  However, our implementation of SUBREG_TO_REG will place it into
big-element vector element zero (high-order bits), and for little
endian we need it in the low-order bits.  The LE implementation splats
the high-order doubleword into the low-order doubleword.

Second, the meaning of (vector_extract x, 0) and (vector_extract x, 1)
must be reversed for similar reasons.

A new test is added that tests code generation for insertelement and
extractelement for both element 0 and element 1.  It is disabled in
this patch but enabled in patch 4/4, for reasons stated in the test.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@223788 91177308-0d34-0410-b5e6-96231b3b80d8
lib/Target/PowerPC/PPCInstrVSX.td