diff options
author | Chris Lattner <sabre@nondot.org> | 2010-06-26 20:27:24 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2010-06-26 20:27:24 +0000 |
commit | 217e056e409f51bc64a82334e72bed0f14a51270 (patch) | |
tree | 425800e065fb935cc5b19ef38d67f82bd058fe8c /clang/test | |
parent | 3bbc52ce3e3d5a4e28147085266819c17bb7ad99 (diff) | |
download | bcm5719-llvm-217e056e409f51bc64a82334e72bed0f14a51270.tar.gz bcm5719-llvm-217e056e409f51bc64a82334e72bed0f14a51270.zip |
implement rdar://7432000 - signed negate should codegen as NSW.
While I'm in there, adjust pointer to member adjustments as well.
llvm-svn: 106955
Diffstat (limited to 'clang/test')
-rw-r--r-- | clang/test/CodeGen/builtins-ppc-altivec.c | 6 | ||||
-rw-r--r-- | clang/test/CodeGen/exprs.c | 15 | ||||
-rw-r--r-- | clang/test/CodeGenCXX/pointers-to-data-members.cpp | 4 |
3 files changed, 19 insertions, 6 deletions
diff --git a/clang/test/CodeGen/builtins-ppc-altivec.c b/clang/test/CodeGen/builtins-ppc-altivec.c index b40cf5bed60..1ffb05905af 100644 --- a/clang/test/CodeGen/builtins-ppc-altivec.c +++ b/clang/test/CodeGen/builtins-ppc-altivec.c @@ -43,13 +43,13 @@ int main () int res_i; /* vec_abs */ - vsc = vec_abs(vsc); // CHECK: sub <16 x i8> zeroinitializer + vsc = vec_abs(vsc); // CHECK: sub nsw <16 x i8> zeroinitializer // CHECK: @llvm.ppc.altivec.vmaxsb - vs = vec_abs(vs); // CHECK: sub <8 x i16> zeroinitializer + vs = vec_abs(vs); // CHECK: sub nsw <8 x i16> zeroinitializer // CHECK: @llvm.ppc.altivec.vmaxsh - vi = vec_abs(vi); // CHECK: sub <4 x i32> zeroinitializer + vi = vec_abs(vi); // CHECK: sub nsw <4 x i32> zeroinitializer // CHECK: @llvm.ppc.altivec.vmaxsw vf = vec_abs(vf); // CHECK: and <4 x i32> diff --git a/clang/test/CodeGen/exprs.c b/clang/test/CodeGen/exprs.c index d82cbf48d30..a90ae58dc3f 100644 --- a/clang/test/CodeGen/exprs.c +++ b/clang/test/CodeGen/exprs.c @@ -1,4 +1,4 @@ -// RUN: %clang_cc1 %s -emit-llvm -o - +// RUN: %clang_cc1 %s -emit-llvm -o - | FileCheck %s // PR1895 // sizeof function @@ -119,3 +119,16 @@ void f9(struct S *x) { void f10() { __builtin_sin(0); } + +// Tests for signed integer overflow stuff. +// rdar://7432000 +void f11() { + // CHECK: define void @f11 + extern volatile int f11G, a, b; + // CHECK: add nsw i32 + f11G = a + b; + // CHECK: sub nsw i32 + f11G = a - b; + // CHECK: sub nsw i32 0, + f11G = -a; +} diff --git a/clang/test/CodeGenCXX/pointers-to-data-members.cpp b/clang/test/CodeGenCXX/pointers-to-data-members.cpp index e527c72d495..70308c6abc5 100644 --- a/clang/test/CodeGenCXX/pointers-to-data-members.cpp +++ b/clang/test/CodeGenCXX/pointers-to-data-members.cpp @@ -68,11 +68,11 @@ void f() { // CHECK: store i64 -1, i64* @_ZN5Casts2paE pa = 0; - // CHECK: [[ADJ:%[a-zA-Z0-9\.]+]] = add i64 {{.*}}, 4 + // CHECK: [[ADJ:%[a-zA-Z0-9\.]+]] = add nsw i64 {{.*}}, 4 // CHECK: store i64 [[ADJ]], i64* @_ZN5Casts2pcE pc = pa; - // CHECK: [[ADJ:%[a-zA-Z0-9\.]+]] = sub i64 {{.*}}, 4 + // CHECK: [[ADJ:%[a-zA-Z0-9\.]+]] = sub nsw i64 {{.*}}, 4 // CHECK: store i64 [[ADJ]], i64* @_ZN5Casts2paE pa = static_cast<int A::*>(pc); } |