summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gcc.target/powerpc/pr65787.c
blob: c819be9a70730809ed6ce7b0d29c003fa20b4b9c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
/* { dg-do compile { target { powerpc64le-*-* } } } */
/* { dg-skip-if "do not override -mcpu" { powerpc*-*-* } { "-mcpu=*" } { "-mcpu=power8" } } */
/* { dg-options "-mcpu=power8 -O3" } */
/* { dg-final { scan-assembler "xxsldwi \[0-9\]*,\[0-9\]*,\[0-9\]*,3" } } */
/* { dg-final { scan-assembler-not "xxpermdi" } } */

/* This test verifies that a vector extract operand properly has its
   lane changed by the swap optimization.  Element 2 of LE corresponds
   to element 1 of BE.  When doublewords are swapped, this becomes
   element 3 of BE, so we need to shift the vector left by 3 words
   to be able to extract the correct value from BE element zero.  */

typedef float  v4f32 __attribute__ ((__vector_size__ (16)));

void foo (float);
extern v4f32 x, y;

int main() {
  v4f32 z = x + y;
  foo (z[2]);
}