1 /* { dg-do compile { target ia32 } } */ 2 /* { dg-options "-mno-sse -mno-mmx -miamcu" } */ 3 4 /* AVX512F and AVX512BW modes. */ 5 typedef unsigned char V64QImode __attribute__((vector_size(64))); 6 typedef unsigned short V32HImode __attribute__((vector_size(64))); 7 typedef unsigned int V16SImode __attribute__((vector_size(64))); 8 typedef unsigned long long V8DImode __attribute__((vector_size(64))); 9 typedef float V16SFmode __attribute__((vector_size(64))); 10 typedef double V8DFmode __attribute__((vector_size(64))); 11 12 /* AVX and AVX2 modes. */ 13 typedef unsigned char V32QImode __attribute__((vector_size(32))); 14 typedef unsigned short V16HImode __attribute__((vector_size(32))); 15 typedef unsigned int V8SImode __attribute__((vector_size(32))); 16 typedef unsigned long long V4DImode __attribute__((vector_size(32))); 17 typedef float V8SFmode __attribute__((vector_size(32))); 18 typedef double V4DFmode __attribute__((vector_size(32))); 19 20 /* SSE1 and SSE2 modes. */ 21 typedef unsigned char V16QImode __attribute__((vector_size(16))); 22 typedef unsigned short V8HImode __attribute__((vector_size(16))); 23 typedef unsigned int V4SImode __attribute__((vector_size(16))); 24 typedef unsigned long long V2DImode __attribute__((vector_size(16))); 25 typedef float V4SFmode __attribute__((vector_size(16))); 26 typedef double V2DFmode __attribute__((vector_size(16))); 27 28 /* MMX and 3DNOW modes. */ 29 typedef unsigned char V8QImode __attribute__((vector_size(8))); 30 typedef unsigned short V4HImode __attribute__((vector_size(8))); 31 typedef unsigned int V2SImode __attribute__((vector_size(8))); 32 typedef float V2SFmode __attribute__((vector_size(8))); 33 34 /* Test argument loading and unloading of each. */ 35 #define TEST(TYPE) \ 36 extern TYPE data_##TYPE; \ 37 void p_##TYPE (TYPE x) { data_##TYPE = x; } \ 38 TYPE r_##TYPE (TYPE x) { return x; } \ 39 void s_##TYPE (void) { p_##TYPE (data_##TYPE); } 40 41 TEST(V64QImode) 42 TEST(V32HImode) 43 TEST(V16SImode) 44 TEST(V8DImode) 45 TEST(V16SFmode) 46 TEST(V8DFmode) 47 48 TEST(V32QImode) 49 TEST(V16HImode) 50 TEST(V8SImode) 51 TEST(V4DImode) 52 TEST(V8SFmode) 53 TEST(V4DFmode) 54 55 TEST(V16QImode) 56 TEST(V8HImode) 57 TEST(V4SImode) 58 TEST(V2DImode) 59 TEST(V4SFmode) 60 TEST(V2DFmode) 61 62 TEST(V8QImode) 63 TEST(V4HImode) 64 TEST(V2SImode) 65 TEST(V2SFmode) 66