diff options
| author | Akira Hatanaka <ahatanaka@apple.com> | 2016-12-01 19:25:14 +0000 |
|---|---|---|
| committer | Akira Hatanaka <ahatanaka@apple.com> | 2016-12-01 19:25:14 +0000 |
| commit | 6c299ca6e769be0ffa075ceb2310113748449ee8 (patch) | |
| tree | f958b9bee09101b2159525c7755c15784b967d85 /clang/test/CodeGenCXX/builtins-arm-exclusive.cpp | |
| parent | 0134152cb4613b61f6af262ab4d8c92a5a70dd0d (diff) | |
| download | bcm5719-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.cpp | 24 |
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); +} |

