Index: lib/Headers/altivec.h =================================================================== --- lib/Headers/altivec.h +++ lib/Headers/altivec.h @@ -15034,6 +15034,108 @@ #endif #endif +/*-- vec_reve------------------------------------------------------------*/ + +static inline __ATTRS_o_ai vector bool char +vec_reve(vector bool char __a) { + vector bool char __vec = __builtin_shufflevector(__a, __a, + 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0); + return __vec; +} + +static inline __ATTRS_o_ai vector signed char +vec_reve(vector signed char __a) { + vector signed char __vec = __builtin_shufflevector(__a, __a, + 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0); + return __vec; +} + +static inline __ATTRS_o_ai vector unsigned char +vec_reve(vector unsigned char __a) { + vector unsigned char __vec = __builtin_shufflevector(__a, __a, + 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0); + return __vec; +} + +static inline __ATTRS_o_ai vector bool int +vec_reve(vector bool int __a) { + vector bool int __vec = __builtin_shufflevector(__a, __a, + 3, 2, 1, 0); + return __vec; +} + +static inline __ATTRS_o_ai vector signed int +vec_reve(vector signed int __a) { + vector signed int __vec = __builtin_shufflevector(__a, __a, + 3, 2, 1, 0); + return __vec; +} + +static inline __ATTRS_o_ai vector unsigned int +vec_reve(vector unsigned int __a) { + vector unsigned int __vec = __builtin_shufflevector(__a, __a, + 3, 2, 1, 0); + return __vec; +} + +static inline __ATTRS_o_ai vector bool short +vec_reve(vector bool short __a) { + vector bool short __vec = __builtin_shufflevector(__a, __a, + 7, 6, 5, 4, 3, 2, 1, 0); + return __vec; +} + +static inline __ATTRS_o_ai vector signed short +vec_reve(vector signed short __a) { + vector signed short __vec = __builtin_shufflevector(__a, __a, + 7, 6, 5, 4, 3, 2, 1, 0); + return __vec; +} + +static inline __ATTRS_o_ai vector unsigned short +vec_reve(vector unsigned short __a) { + vector unsigned short __vec = __builtin_shufflevector(__a, __a, + 7, 6, 5, 4, 3, 2, 1, 0); + return __vec; +} + +static inline __ATTRS_o_ai vector float +vec_reve(vector float __a) { + vector float __vec = __builtin_shufflevector(__a, __a, + 3, 2, 1, 0); + return __vec; +} + +#ifdef __VSX__ +static inline __ATTRS_o_ai vector bool long long +vec_reve(vector bool long long __a) { + vector bool long long __vec = __builtin_shufflevector(__a, __a, + 1, 0); + return __vec; +} + +static inline __ATTRS_o_ai vector signed long long +vec_reve(vector signed long long __a) { + vector signed long long __vec = __builtin_shufflevector(__a, __a, + 1, 0); + return __vec; +} + +static inline __ATTRS_o_ai vector unsigned long long +vec_reve(vector unsigned long long __a) { + vector unsigned long long __vec = __builtin_shufflevector(__a, __a, + 1, 0); + return __vec; +} +static inline __ATTRS_o_ai vector double +vec_reve(vector double __a) { + vector double __vec = __builtin_shufflevector(__a, __a, + 1, 0); + return __vec; +} +#endif + + #undef __ATTRS_o_ai #endif /* __ALTIVEC_H */ Index: test/CodeGen/builtins-ppc-altivec.c =================================================================== --- test/CodeGen/builtins-ppc-altivec.c +++ test/CodeGen/builtins-ppc-altivec.c @@ -24,6 +24,13 @@ vector unsigned int vui = { 1, 2, 3, 4 }; vector float vf = { -1.5, 2.5, -3.5, 4.5 }; +#ifdef __VSX__ +vector bool long long vbll = {3, 5}; +vector signed long long vll = {1, -2}; +vector unsigned long long vull = {4,7}; +vector double vd = {-2.5, 6.5}; +#endif + vector bool char res_vbc; vector signed char res_vsc; vector unsigned char res_vuc; @@ -36,6 +43,13 @@ vector unsigned int res_vui; vector float res_vf; +#ifdef __VSX__ +vector bool long long res_vbll; +vector signed long long res_vll; +vector unsigned long long res_vull; +vector double res_vd; +#endif + // CHECK-NOALTIVEC: error: unknown type name 'vector' signed char param_sc; @@ -8996,3 +9010,64 @@ // CHECK: @llvm.ppc.altivec.vcmpgefp.p(i32 2 // CHECK-LE: @llvm.ppc.altivec.vcmpgefp.p(i32 2 } + +// check-label: define void @test8 +void test8() { + res_vbc = vec_reve(vbc); + // CHECK: %shuffle.{{.+}} = shufflevector <16 x i8> %{{[0-9]+}}, <16 x i8> %{{[0-9]+}}, <16 x i32> + // CHECK-LE: %shuffle.{{.+}} = shufflevector <16 x i8> %{{[0-9]+}}, <16 x i8> %{{[0-9]+}}, <16 x i32> + + res_vsc = vec_reve(vsc); + // CHECK: %shuffle.{{.+}} = shufflevector <16 x i8> %{{[0-9]+}}, <16 x i8> %{{[0-9]+}}, <16 x i32> + // CHECK-LE: %shuffle.{{.+}} = shufflevector <16 x i8> %{{[0-9]+}}, <16 x i8> %{{[0-9]+}}, <16 x i32> + + res_vuc = vec_reve(vuc); + // CHECK: %shuffle.{{.+}} = shufflevector <16 x i8> %{{[0-9]+}}, <16 x i8> %{{[0-9]+}}, <16 x i32> + // CHECK-LE: %shuffle.{{.+}} = shufflevector <16 x i8> %{{[0-9]+}}, <16 x i8> %{{[0-9]+}}, <16 x i32> + + res_vbi = vec_reve(vbi); + // CHECK: %shuffle.{{.+}} = shufflevector <4 x i32> %{{[0-9]+}}, <4 x i32> %{{[0-9]+}}, <4 x i32> + // CHECK-LE: %shuffle.{{.+}} = shufflevector <4 x i32> %{{[0-9]+}}, <4 x i32> %{{[0-9]+}}, <4 x i32> + + res_vi = vec_reve(vi); + // CHECK: %shuffle.{{.+}} = shufflevector <4 x i32> %{{[0-9]+}}, <4 x i32> %{{[0-9]+}}, <4 x i32> + // CHECK-LE: %shuffle.{{.+}} = shufflevector <4 x i32> %{{[0-9]+}}, <4 x i32> %{{[0-9]+}}, <4 x i32> + + res_vui = vec_reve(vui); + // CHECK: %shuffle.{{.+}} = shufflevector <4 x i32> %{{[0-9]+}}, <4 x i32> %{{[0-9]+}}, <4 x i32> + // CHECK-LE: %shuffle.{{.+}} = shufflevector <4 x i32> %{{[0-9]+}}, <4 x i32> %{{[0-9]+}}, <4 x i32> + + res_vbs = vec_reve(vbs); + // CHECK %shuffle.{{.+}} = shufflevector <8 x i16> %{{[0-9]+}}, <8 x i16> %{{[0-9]+}}, <8 x i32> + // CHECK-LE %shuffle.{{.+}} = shufflevector <8 x i16> %{{[0-9]+}}, <8 x i16> %{{[0-9]+}}, <8 x i32> + + res_vbs = vec_reve(vs); + // CHECK %shuffle.{{.+}} = shufflevector <8 x i16> %{{[0-9]+}}, <8 x i16> %{{[0-9]+}}, <8 x i32> + // CHECK-LE %shuffle.{{.+}} = shufflevector <8 x i16> %{{[0-9]+}}, <8 x i16> %{{[0-9]+}}, <8 x i32> + + res_vbs = vec_reve(vus); + // CHECK %shuffle.{{.+}} = shufflevector <8 x i16> %{{[0-9]+}}, <8 x i16> %{{[0-9]+}}, <8 x i32> + // CHECK-LE %shuffle.{{.+}} = shufflevector <8 x i16> %{{[0-9]+}}, <8 x i16> %{{[0-9]+}}, <8 x i32> + + res_vf = vec_reve(vf); + // CHECK %shuffle.{{.+}} = shufflevector <4 x float> %{{[0-9]+}}, <4 x float> %{{[0-9]+}}, <4 x i32> + // CHECK-LE %shuffle.{{.+}} = shufflevector <4 x float> %{{[0-9]+}}, <4 x float> %{{[0-9]+}}, <4 x i32> + + #ifdef __VSX__ + res_vbll = vec_reve(vbll); + // CHECK %shuffle.{{.+}} = shufflevector <2 x i64> %{{[0-9]+}}, <2 x i64> %{{[0-9]+}}, <2 x i32> + // CHECK-LE %shuffle.{{.+}} = shufflevector <2 x i64> %{{[0-9]+}}, <2 x i64> %{{[0-9]+}}, <2 x i32> + + res_vll = vec_reve(vll); + // CHECK %shuffle.{{.+}} = shufflevector <2 x i64> %{{[0-9]+}}, <2 x i64> %{{[0-9]+}}, <2 x i32> + // CHECK-LE %shuffle.{{.+}} = shufflevector <2 x i64> %{{[0-9]+}}, <2 x i64> %{{[0-9]+}}, <2 x i32> + + res_vull = vec_reve(vull); + // CHECK %shuffle.{{.+}} = shufflevector <2 x i64> %{{[0-9]+}}, <2 x i64> %{{[0-9]+}}, <2 x i32> + // CHECK-LE %shuffle.{{.+}} = shufflevector <2 x i64> %{{[0-9]+}}, <2 x i64> %{{[0-9]+}}, <2 x i32> + + res_vd = vec_reve(vd); + // CHECK %shuffle.{{.+}} = shufflevector <2 x double> %{{[0-9]+}}, <2 x double> %{{[0-9]+}}, <2 x i32> + // CHECK-LE %shuffle.{{.+}} = shufflevector <2 x double> %{{[0-9]+}}, <2 x double> %{{[0-9]+}}, <2 x i32> + #endif +}