/* { dg-do run { target { powerpc*-*-* && vmx_hw } } } */ /* { dg-do compile { target { powerpc*-*-* && { ! vmx_hw } } } } */ /* { dg-options "-maltivec" } */ /* { dg-require-effective-target powerpc_altivec } */ /* Program to test PowerPC AltiVec instructions. */ #include #include extern void abort (void); #define CHECK_IF(E) if(!(E)) abort() vector char sca = {0,4,8,1,5,9,2,6,10,3,7,11,15,12,14,13}; vector char scb = {6,4,8,3,1,9,2,6,10,3,7,11,15,12,14,13}; vector char sc_expected = {3,4,8,2,3,9,2,6,10,3,7,11,15,12,14,13}; vector char scz; vector unsigned char uca = {0,4,8,1,5,9,2,6,10,3,7,11,15,12,14,13}; vector unsigned char ucb = {6,4,8,3,1,9,2,6,10,3,7,11,15,12,14,13}; vector unsigned char uc_expected = {3,4,8,2,3,9,2,6,10,3,7,11,15,12,14,13}; vector unsigned char ucz; vector short int ssia = {9, 16, 25, 36}; vector short int ssib = {-8, -27, -64, -125}; vector short int ssiz; vector short unsigned int ssua = {9, 16, 25, 36}; vector short unsigned int ssub = {8, 27, 64, 125}; vector short unsigned int ssuz; vector unsigned int uia = {22, 13, 24, 39}; vector unsigned int uib = {8, 7, 4, 15}; vector unsigned int ui_expected = {15, 10, 14, 27}; vector unsigned int uiz; vector int a1 = (vector int){ 100, 200, 300, 400 }; vector int a2 = (vector int){ 500, 600, 700, 800 }; vector int addi = (vector int){ 600, 800, 1000, 1200 }; vector int avgi = (vector int){ 300, 400, 500, 600 }; vector float f1 = (vector float){ 1.0, 2.0, 3.0, 4.0 }; vector float f2 = (vector float){ 5.0, 6.0, 7.0, 8.0 }; vector float f3; vector float addf1 = (vector float){ 6.0, 8.0, 10.0, 12.0 }; vector float addf2 = (vector float){ 6.1, 8.1, 10.1, 12.1 }; vector float addf3 = (vector float){ 6.0, 8.0, 9.9, 12.1 }; vector int k; vector float f, g, h; int i; int main () { k = vec_add (a1, a2); CHECK_IF (vec_all_eq (addi, k)); CHECK_IF (vec_all_ge (addi, k)); CHECK_IF (vec_all_le (addi, k)); CHECK_IF (vec_any_eq (addi, k)); CHECK_IF (vec_any_ge (addi, k)); CHECK_IF (vec_any_le (addi, k)); CHECK_IF (!vec_any_ne (addi, k)); CHECK_IF (!vec_any_lt (addi, k)); CHECK_IF (!vec_any_gt (addi, k)); CHECK_IF (!vec_any_ne (addi, k)); CHECK_IF (!vec_any_lt (addi, k)); CHECK_IF (!vec_any_gt (addi, k)); ssiz = vec_avg (ssia, ssib); ssuz = vec_avg (ssua, ssub); k = vec_avg (a1, a2); scz = vec_avg (sca, scb); for (i=0; i< 16; i++) if (scz[i] != sc_expected[i]) abort (); ucz = vec_avg (uca, ucb); for (i=0; i<16; i++) if (ucz[i] != uc_expected[i]) abort (); uiz = vec_avg (uia, uib); for (i=0; i< 4; i++) if (uiz[i] != ui_expected[i]) abort (); CHECK_IF (vec_all_eq (k, avgi)); h = vec_add (f1, f2); CHECK_IF (vec_all_eq (h, addf1)); CHECK_IF (vec_all_ge (h, addf1)); CHECK_IF (vec_all_le (h, addf1)); CHECK_IF (vec_any_eq (h, addf1)); CHECK_IF (vec_any_ge (h, addf1)); CHECK_IF (vec_any_le (h, addf1)); CHECK_IF (!vec_any_ne (h, addf1)); CHECK_IF (!vec_any_lt (h, addf1)); CHECK_IF (!vec_any_gt (h, addf1)); CHECK_IF (!vec_any_ne (h, addf1)); CHECK_IF (!vec_any_lt (h, addf1)); CHECK_IF (!vec_any_gt (h, addf1)); CHECK_IF (vec_all_gt (addf2, addf1)); CHECK_IF (vec_any_gt (addf2, addf1)); CHECK_IF (vec_all_ge (addf2, addf1)); CHECK_IF (vec_any_ge (addf2, addf1)); CHECK_IF (vec_all_ne (addf2, addf1)); CHECK_IF (vec_any_ne (addf2, addf1)); CHECK_IF (!vec_all_lt (addf2, addf1)); CHECK_IF (!vec_any_lt (addf2, addf1)); CHECK_IF (!vec_all_le (addf2, addf1)); CHECK_IF (!vec_any_le (addf2, addf1)); CHECK_IF (!vec_all_eq (addf2, addf1)); CHECK_IF (!vec_any_eq (addf2, addf1)); CHECK_IF (vec_any_eq (addf3, addf1)); CHECK_IF (vec_any_ne (addf3, addf1)); CHECK_IF (vec_any_lt (addf3, addf1)); CHECK_IF (vec_any_le (addf3, addf1)); CHECK_IF (vec_any_gt (addf3, addf1)); CHECK_IF (vec_any_ge (addf3, addf1)); CHECK_IF (!vec_all_eq (addf3, addf1)); CHECK_IF (!vec_all_ne (addf3, addf1)); CHECK_IF (!vec_all_lt (addf3, addf1)); CHECK_IF (!vec_all_le (addf3, addf1)); CHECK_IF (!vec_all_gt (addf3, addf1)); CHECK_IF (!vec_all_ge (addf3, addf1)); CHECK_IF (vec_all_numeric (addf3)); CHECK_IF (vec_all_in (addf1, addf2)); CHECK_IF (vec_step (vector bool char) == 16); CHECK_IF (vec_step (addf3) == 4); return 0; }