1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71
|
/* Verify SPE vector permute builtins. */
/* { dg-do run { target { powerpc*-*-* && powerpc_spe } } } */
/* Remove `-ansi' from options so that <spe.h> compiles. */
/* { dg-options "" } */
#include <spe.h>
#include <stdlib.h>
#define vector __attribute__ ((vector_size (8)))
#define WORDS_BIG_ENDIAN (__BYTE_ORDER__ == __ORDER_BIG_ENDIAN__)
int
main (void)
{
vector int a = { 0x11111111, 0x22222222 };
vector int b = { 0x33333333, 0x44444444 };
vector int c;
/* c[hi] = a[hi], c[lo] = b[hi] */
c = __ev_mergehi (a, b);
if (c[0] != (WORDS_BIG_ENDIAN ? 0x11111111 : 0x44444444))
abort ();
if (c[1] != (WORDS_BIG_ENDIAN ? 0x33333333 : 0x22222222))
abort ();
/* c[hi] = a[lo], c[lo] = b[lo] */
c = __ev_mergelo (a, b);
if (c[0] != (WORDS_BIG_ENDIAN ? 0x22222222 : 0x33333333))
abort ();
if (c[1] != (WORDS_BIG_ENDIAN ? 0x44444444 : 0x11111111))
abort ();
/* c[hi] = a[lo], c[lo] = b[hi] */
c = __ev_mergelohi (a, b);
if (c[0] != (WORDS_BIG_ENDIAN ? 0x22222222 : 0x44444444))
abort ();
if (c[1] != (WORDS_BIG_ENDIAN ? 0x33333333 : 0x11111111))
abort ();
/* c[hi] = a[hi], c[lo] = b[lo] */
c = __ev_mergehilo (a, b);
if (c[0] != (WORDS_BIG_ENDIAN ? 0x11111111 : 0x33333333))
abort ();
if (c[1] != (WORDS_BIG_ENDIAN ? 0x44444444 : 0x22222222))
abort ();
/* c[hi] = a[hi], c[lo] = b[hi] */
c = __builtin_spe_evmergehi (a, b);
if (c[0] != (WORDS_BIG_ENDIAN ? 0x11111111 : 0x44444444))
abort ();
if (c[1] != (WORDS_BIG_ENDIAN ? 0x33333333 : 0x22222222))
abort ();
/* c[hi] = a[lo], c[lo] = b[lo] */
c = __builtin_spe_evmergelo (a, b);
if (c[0] != (WORDS_BIG_ENDIAN ? 0x22222222 : 0x33333333))
abort ();
if (c[1] != (WORDS_BIG_ENDIAN ? 0x44444444 : 0x11111111))
abort ();
/* c[hi] = a[lo], c[lo] = b[hi] */
c = __builtin_spe_evmergelohi (a, b);
if (c[0] != (WORDS_BIG_ENDIAN ? 0x22222222 : 0x44444444))
abort ();
if (c[1] != (WORDS_BIG_ENDIAN ? 0x33333333 : 0x11111111))
abort ();
/* c[hi] = a[hi], c[lo] = b[lo] */
c = __builtin_spe_evmergehilo (a, b);
if (c[0] != (WORDS_BIG_ENDIAN ? 0x11111111 : 0x33333333))
abort ();
if (c[1] != (WORDS_BIG_ENDIAN ? 0x44444444 : 0x22222222))
abort ();
return 0;
}
|