/* Verify SPE vector permute builtins. */ /* { dg-do run { target { powerpc*-*-* && powerpc_spe } } } */ /* Remove `-ansi' from options so that compiles. */ /* { dg-options "" } */ #include #include #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; }