1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125
|
// RUN: %clang_cc1 -ffreestanding %s -triple=i386-unknown-unknown -target-feature +shstk -emit-llvm -o - -Wall -Werror | FileCheck %s --check-prefix=I386 --check-prefix=CHECK
// RUN: %clang_cc1 -ffreestanding %s -triple=x86_64-unknown-unknown -target-feature +shstk -emit-llvm -o - -Wall -Werror | FileCheck %s --check-prefix=X86_64 --check-prefix=CHECK
#include <immintrin.h>
void test_incsspd(int a) {
// CHECK-LABEL: @test_incsspd
// CHECK: call void @llvm.x86.incsspd(i32 %{{[0-9]+}})
_incsspd(a);
}
#ifdef __x86_64__
void test_incsspq(int a) {
// X86_64-LABEL: @test_incsspq
// X86_64: call void @llvm.x86.incsspq(i64 %{{[a-z0-9.]+}})
_incsspq(a);
}
void test_inc_ssp(unsigned int a) {
// X86_64-LABEL: @test_inc_ssp
// X86_64: call void @llvm.x86.incsspq(i64 %{{[a-z0-9.]+}})
_inc_ssp(a);
}
#else
void test_inc_ssp(unsigned int a) {
// I386-LABEL: @test_inc_ssp
// I386: call void @llvm.x86.incsspd(i32 %{{[0-9]+}})
_inc_ssp(a);
}
#endif
unsigned int test_rdsspd(unsigned int a) {
// CHECK-LABEL: @test_rdsspd
// CHECK: call i32 @llvm.x86.rdsspd(i32 %{{[a-z0-9.]+}})
return _rdsspd(a);
}
unsigned int test_rdsspd_i32(void) {
// CHECK-LABEL: @test_rdsspd_i32
// CHECK: call i32 @llvm.x86.rdsspd(i32 %{{[a-z0-9.]+}})
return _rdsspd_i32();
}
#ifdef __x86_64__
unsigned long long test_rdsspq(unsigned long long a) {
// X86_64-LABEL: @test_rdsspq
// X86_64: call i64 @llvm.x86.rdsspq(i64 %{{[a-z0-9.]+}})
return _rdsspq(a);
}
unsigned long long test_rdsspq_i64(void) {
// X86_64-LABEL: @test_rdsspq_i64
// X86_64: call i64 @llvm.x86.rdsspq(i64 %{{[a-z0-9.]+}})
return _rdsspq_i64();
}
unsigned long long test_get_ssp(void) {
// X86_64-LABEL: @test_get_ssp
// X86_64: call i64 @llvm.x86.rdsspq(i64 0)
return _get_ssp();
}
#else
unsigned int test_get_ssp(void) {
// I386-LABEL: @test_get_ssp
// I386: call i32 @llvm.x86.rdsspd(i32 0)
return _get_ssp();
}
#endif
void test_saveprevssp(void) {
// CHECK-LABEL: @test_saveprevssp
// CHECK: call void @llvm.x86.saveprevssp()
_saveprevssp();
}
void test_rstorssp(void * __p) {
// CHECK-LABEL: @test_rstorssp
// CHECK: call void @llvm.x86.rstorssp(ptr %{{[a-z0-9.]+}})
_rstorssp(__p);
}
void test_wrssd(unsigned int __a, void * __p) {
// CHECK-LABEL: @test_wrssd
// CHECK: call void @llvm.x86.wrssd(i32 %{{[a-z0-9.]+}}, ptr %{{[a-z0-9.]+}})
_wrssd(__a, __p);
}
#ifdef __x86_64__
void test_wrssq(unsigned long long __a, void * __p) {
// X86_64-LABEL: @test_wrssq
// X86_64: call void @llvm.x86.wrssq(i64 %{{[a-z0-9.]+}}, ptr %{{[a-z0-9.]+}})
_wrssq(__a, __p);
}
#endif
void test_wrussd(unsigned int __a, void * __p) {
// CHECK-LABEL: @test_wrussd
// CHECK: call void @llvm.x86.wrussd(i32 %{{[a-z0-9.]+}}, ptr %{{[a-z0-9.]+}})
_wrussd(__a, __p);
}
#ifdef __x86_64__
void test_wrussq(unsigned long long __a, void * __p) {
// X86_64-LABEL: @test_wrussq
// X86_64: call void @llvm.x86.wrussq(i64 %{{[a-z0-9.]+}}, ptr %{{[a-z0-9.]+}})
_wrussq(__a, __p);
}
#endif
void test_setssbsy(void) {
// CHECK-LABEL: @test_setssbsy
// CHECK: call void @llvm.x86.setssbsy()
_setssbsy();
}
void test_clrssbsy(void * __p) {
// CHECK-LABEL: @test_clrssbsy
// CHECK: call void @llvm.x86.clrssbsy(ptr %{{[a-z0-9.]+}})
_clrssbsy(__p);
}
|