summaryrefslogtreecommitdiffstats
path: root/clang/test/CodeGenCXX/builtins-arm-exclusive.cpp
diff options
context:
space:
mode:
authorAkira Hatanaka <ahatanaka@apple.com>2016-12-01 19:25:14 +0000
committerAkira Hatanaka <ahatanaka@apple.com>2016-12-01 19:25:14 +0000
commit6c299ca6e769be0ffa075ceb2310113748449ee8 (patch)
treef958b9bee09101b2159525c7755c15784b967d85 /clang/test/CodeGenCXX/builtins-arm-exclusive.cpp
parent0134152cb4613b61f6af262ab4d8c92a5a70dd0d (diff)
downloadbcm5719-llvm-6c299ca6e769be0ffa075ceb2310113748449ee8.tar.gz
bcm5719-llvm-6c299ca6e769be0ffa075ceb2310113748449ee8.zip
[CodeGen][ARM] Make sure the value and type used to create a bitcast
have the same size. This fixes an asset that is triggered when an address of a boolean variable is passed to __builtin_arm_ldrex or __builtin_arm_strex. rdar://problem/29269006 llvm-svn: 288404
Diffstat (limited to 'clang/test/CodeGenCXX/builtins-arm-exclusive.cpp')
-rw-r--r--clang/test/CodeGenCXX/builtins-arm-exclusive.cpp24
1 files changed, 24 insertions, 0 deletions
diff --git a/clang/test/CodeGenCXX/builtins-arm-exclusive.cpp b/clang/test/CodeGenCXX/builtins-arm-exclusive.cpp
new file mode 100644
index 00000000000..06f7a023ade
--- /dev/null
+++ b/clang/test/CodeGenCXX/builtins-arm-exclusive.cpp
@@ -0,0 +1,24 @@
+// RUN: %clang_cc1 -Wall -Werror -triple thumbv8-linux-gnueabi -fno-signed-char -emit-llvm -o - %s | FileCheck %s
+// RUN: %clang_cc1 -Wall -Werror -triple arm64-apple-ios7.0 -emit-llvm -o - %s | FileCheck %s --check-prefix=CHECK-ARM64
+
+bool b;
+
+// CHECK-LABEL: @_Z10test_ldrexv()
+// CHECK: call i32 @llvm.arm.ldrex.p0i8(i8* @b)
+
+// CHECK-ARM64-LABEL: @_Z10test_ldrexv()
+// CHECK-ARM64: call i64 @llvm.aarch64.ldxr.p0i8(i8* @b)
+
+void test_ldrex() {
+ b = __builtin_arm_ldrex(&b);
+}
+
+// CHECK-LABEL: @_Z10tset_strexv()
+// CHECK: %{{.*}} = call i32 @llvm.arm.strex.p0i8(i32 1, i8* @b)
+
+// CHECK-ARM64-LABEL: @_Z10tset_strexv()
+// CHECK-ARM64: %{{.*}} = call i32 @llvm.aarch64.stxr.p0i8(i64 1, i8* @b)
+
+void tset_strex() {
+ __builtin_arm_strex(true, &b);
+}
OpenPOWER on IntegriCloud