| // RUN: %clang_cc1 -triple x86_64-apple-darwin9 -target-cpu corei7-avx -emit-llvm %s -o - | FileCheck %s | 
 | // RUN: %clang_cc1 -triple x86_64-apple-darwin9 -target-cpu corei7-avx -emit-llvm -x c++ %s -o - | FileCheck %s | 
 |  | 
 | typedef double vector8double __attribute__((__vector_size__(64))); | 
 | typedef float  vector8float  __attribute__((__vector_size__(32))); | 
 | typedef long   vector8long   __attribute__((__vector_size__(64))); | 
 | typedef short  vector8short  __attribute__((__vector_size__(16))); | 
 | typedef unsigned long   vector8ulong   __attribute__((__vector_size__(64))); | 
 | typedef unsigned short  vector8ushort  __attribute__((__vector_size__(16))); | 
 |  | 
 | #ifdef __cplusplus | 
 | extern "C" { | 
 | #endif | 
 |  | 
 | vector8float flt_trunc(vector8double x) { | 
 |   return __builtin_convertvector(x, vector8float); | 
 |   // CHECK-LABEL: @flt_trunc | 
 |   // CHECK: fptrunc <8 x double> %{{[^ ]}} to <8 x float> | 
 | } | 
 |  | 
 | vector8double flt_ext(vector8float x) { | 
 |   return __builtin_convertvector(x, vector8double); | 
 |   // CHECK-LABEL: @flt_ext | 
 |   // CHECK: fpext <8 x float> %{{[^ ]}} to <8 x double> | 
 | } | 
 |  | 
 | vector8long flt_tosi(vector8float x) { | 
 |   return __builtin_convertvector(x, vector8long); | 
 |   // CHECK-LABEL: @flt_tosi | 
 |   // CHECK: fptosi <8 x float> %{{[^ ]}} to <8 x i64> | 
 | } | 
 |  | 
 | vector8ulong flt_toui(vector8float x) { | 
 |   return __builtin_convertvector(x, vector8ulong); | 
 |   // CHECK-LABEL: @flt_toui | 
 |   // CHECK: fptoui <8 x float> %{{[^ ]}} to <8 x i64> | 
 | } | 
 |  | 
 | vector8ulong fltd_toui(vector8double x) { | 
 |   return __builtin_convertvector(x, vector8ulong); | 
 |   // CHECK-LABEL: @fltd_toui | 
 |   // CHECK: fptoui <8 x double> %{{[^ ]}} to <8 x i64> | 
 | } | 
 |  | 
 | vector8ulong int_zext(vector8ushort x) { | 
 |   return __builtin_convertvector(x, vector8ulong); | 
 |   // CHECK-LABEL: @int_zext | 
 |   // CHECK: zext <8 x i16> %{{[^ ]}} to <8 x i64> | 
 | } | 
 |  | 
 | vector8long int_sext(vector8short x) { | 
 |   return __builtin_convertvector(x, vector8long); | 
 |   // CHECK-LABEL: @int_sext | 
 |   // CHECK: sext <8 x i16> %{{[^ ]}} to <8 x i64> | 
 | } | 
 |  | 
 | vector8float int_tofp(vector8short x) { | 
 |   return __builtin_convertvector(x, vector8float); | 
 |   // CHECK-LABEL: @int_tofp | 
 |   // CHECK: sitofp <8 x i16> %{{[^ ]}} to <8 x float> | 
 | } | 
 |  | 
 | vector8float uint_tofp(vector8ushort x) { | 
 |   return __builtin_convertvector(x, vector8float); | 
 |   // CHECK-LABEL: @uint_tofp | 
 |   // CHECK: uitofp <8 x i16> %{{[^ ]}} to <8 x float> | 
 | } | 
 |  | 
 | #ifdef __cplusplus | 
 | } | 
 | #endif | 
 |  | 
 |  | 
 | #ifdef __cplusplus | 
 | template<typename T> | 
 | T int_toT(vector8long x) { | 
 |   return __builtin_convertvector(x, T); | 
 | } | 
 |  | 
 | extern "C" { | 
 |   vector8double int_toT_fp(vector8long x) { | 
 |     // CHECK-LABEL: @int_toT_fp | 
 |     // CHECK: sitofp <8 x i64> %{{[^ ]}} to <8 x double> | 
 |     return int_toT<vector8double>(x); | 
 |   } | 
 | } | 
 | #else | 
 | vector8double int_toT_fp(vector8long x) { | 
 |   return __builtin_convertvector(x, vector8double); | 
 | } | 
 | #endif | 
 |  |