2014-05-24 06:12:01 +08:00
|
|
|
// RUN: %clang_cc1 %s -ffreestanding -triple x86_64-apple-macosx10.9.0 -emit-llvm -o - | FileCheck %s
|
2015-05-14 08:45:20 +08:00
|
|
|
//
|
|
|
|
// RUN: rm -rf %t
|
|
|
|
// RUN: %clang_cc1 %s -ffreestanding -triple x86_64-apple-macosx10.9.0 -emit-llvm -o - \
|
2015-06-16 08:19:29 +08:00
|
|
|
// RUN: -fmodules -fimplicit-module-maps -fmodules-cache-path=%t -isystem %S/Inputs/include \
|
2015-05-14 08:45:20 +08:00
|
|
|
// RUN: | FileCheck %s
|
2015-07-08 09:00:30 +08:00
|
|
|
// REQUIRES: x86-registered-target
|
2014-05-24 06:12:01 +08:00
|
|
|
#include <xmmintrin.h>
|
|
|
|
|
2016-06-19 04:01:07 +08:00
|
|
|
// CHECK: @c = common global i8 0, align 16
|
|
|
|
_MM_ALIGN16 char c;
|
|
|
|
|
2014-05-24 06:12:01 +08:00
|
|
|
// Make sure the last step of _mm_cvtps_pi16 converts <4 x i32> to <4 x i16> by
|
|
|
|
// checking that clang emits PACKSSDW instead of PACKSSWB.
|
|
|
|
|
|
|
|
// CHECK: define i64 @test_mm_cvtps_pi16
|
|
|
|
// CHECK: call x86_mmx @llvm.x86.mmx.packssdw
|
|
|
|
|
|
|
|
__m64 test_mm_cvtps_pi16(__m128 a) {
|
|
|
|
return _mm_cvtps_pi16(a);
|
|
|
|
}
|
2015-05-14 08:45:20 +08:00
|
|
|
|
|
|
|
// Make sure that including <xmmintrin.h> also makes <emmintrin.h>'s content available.
|
|
|
|
// This is an ugly hack for GCC compatibility.
|
2019-09-17 11:56:28 +08:00
|
|
|
__m128d test_xmmintrin_provides_emmintrin(__m128d __a, __m128d __b) {
|
2015-05-14 08:45:20 +08:00
|
|
|
return _mm_add_sd(__a, __b);
|
|
|
|
}
|
|
|
|
|
2016-03-23 04:57:51 +08:00
|
|
|
#if __STDC_HOSTED__
|
|
|
|
// Make sure stdlib.h symbols are accessible.
|
|
|
|
void *p = NULL;
|
|
|
|
#endif
|