diff options
Diffstat (limited to 'clang/test/CodeGen/builtins-ppc-htm.c')
-rw-r--r-- | clang/test/CodeGen/builtins-ppc-htm.c | 62 |
1 files changed, 62 insertions, 0 deletions
diff --git a/clang/test/CodeGen/builtins-ppc-htm.c b/clang/test/CodeGen/builtins-ppc-htm.c new file mode 100644 index 00000000000..87baa77af81 --- /dev/null +++ b/clang/test/CodeGen/builtins-ppc-htm.c @@ -0,0 +1,62 @@ +// REQUIRES: powerpc-registered-target +// RUN: %clang_cc1 -faltivec -target-feature +htm -triple powerpc64-unknown-unknown -emit-llvm %s -o - | FileCheck %s + +void test1(long int *r, int code, long int *a, long int *b) { +// CHECK-LABEL: define void @test1 + + r[0] = __builtin_tbegin (0); +// CHECK: @llvm.ppc.tbegin + r[1] = __builtin_tbegin (1); +// CHECK: @llvm.ppc.tbegin + r[2] = __builtin_tend (0); +// CHECK: @llvm.ppc.tend + r[3] = __builtin_tendall (); +// CHECK: @llvm.ppc.tendall + + r[4] = __builtin_tabort (code); +// CHECK: @llvm.ppc.tabort + r[5] = __builtin_tabort (0x1); +// CHECK: @llvm.ppc.tabort + r[6] = __builtin_tabortdc (0xf, a[0], b[0]); +// CHECK: @llvm.ppc.tabortdc + r[7] = __builtin_tabortdci (0xf, a[1], 0x1); +// CHECK: @llvm.ppc.tabortdc + r[8] = __builtin_tabortwc (0xf, a[2], b[2]); +// CHECK: @llvm.ppc.tabortwc + r[9] = __builtin_tabortwci (0xf, a[3], 0x1); +// CHECK: @llvm.ppc.tabortwc + + r[10] = __builtin_tcheck (); +// CHECK: @llvm.ppc.tcheck + r[11] = __builtin_trechkpt (); +// CHECK: @llvm.ppc.trechkpt + r[12] = __builtin_treclaim (0); +// CHECK: @llvm.ppc.treclaim + r[13] = __builtin_tresume (); +// CHECK: @llvm.ppc.tresume + r[14] = __builtin_tsuspend (); +// CHECK: @llvm.ppc.tsuspend + r[15] = __builtin_tsr (0); +// CHECK: @llvm.ppc.tsr + + r[16] = __builtin_ttest (); +// CHECK: @llvm.ppc.ttest + + r[17] = __builtin_get_texasr (); +// CHECK: @llvm.ppc.get.texasr + r[18] = __builtin_get_texasru (); +// CHECK: @llvm.ppc.get.texasru + r[19] = __builtin_get_tfhar (); +// CHECK: @llvm.ppc.get.tfhar + r[20] = __builtin_get_tfiar (); +// CHECK: @llvm.ppc.get.tfiar + + __builtin_set_texasr (a[21]); +// CHECK: @llvm.ppc.set.texasr + __builtin_set_texasru (a[22]); +// CHECK: @llvm.ppc.set.texasru + __builtin_set_tfhar (a[23]); +// CHECK: @llvm.ppc.set.tfhar + __builtin_set_tfiar (a[24]); +// CHECK: @llvm.ppc.set.tfiar +} |