2010-08-06 01:39:44 +08:00
|
|
|
// RUN: %clang_cc1 -triple x86_64-apple-darwin10 -ftrapv %s -emit-llvm -o - | FileCheck %s
|
|
|
|
|
2009-04-02 09:14:26 +08:00
|
|
|
unsigned int ui, uj, uk;
|
|
|
|
int i, j, k;
|
|
|
|
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define void @test0()
|
2010-08-06 01:39:44 +08:00
|
|
|
void test0() {
|
|
|
|
// -ftrapv doesn't affect unsigned arithmetic.
|
2015-02-28 05:19:58 +08:00
|
|
|
// CHECK: [[T1:%.*]] = load i32, i32* @uj
|
|
|
|
// CHECK-NEXT: [[T2:%.*]] = load i32, i32* @uk
|
2010-08-06 01:39:44 +08:00
|
|
|
// CHECK-NEXT: [[T3:%.*]] = add i32 [[T1]], [[T2]]
|
|
|
|
// CHECK-NEXT: store i32 [[T3]], i32* @ui
|
2009-04-02 09:14:26 +08:00
|
|
|
ui = uj + uk;
|
2010-08-06 01:39:44 +08:00
|
|
|
|
2015-02-28 05:19:58 +08:00
|
|
|
// CHECK: [[T1:%.*]] = load i32, i32* @j
|
|
|
|
// CHECK-NEXT: [[T2:%.*]] = load i32, i32* @k
|
2011-07-10 01:41:47 +08:00
|
|
|
// CHECK-NEXT: [[T3:%.*]] = call { i32, i1 } @llvm.sadd.with.overflow.i32(i32 [[T1]], i32 [[T2]])
|
|
|
|
// CHECK-NEXT: [[T4:%.*]] = extractvalue { i32, i1 } [[T3]], 0
|
|
|
|
// CHECK-NEXT: [[T5:%.*]] = extractvalue { i32, i1 } [[T3]], 1
|
2012-09-08 10:08:36 +08:00
|
|
|
// CHECK-NEXT: [[T6:%.*]] = xor i1 [[T5]], true
|
|
|
|
// CHECK-NEXT: br i1 [[T6]]
|
2020-10-21 17:11:25 +08:00
|
|
|
// CHECK: call void @llvm.ubsantrap(i8 0)
|
2009-04-02 09:14:26 +08:00
|
|
|
i = j + k;
|
|
|
|
}
|
2010-08-06 01:39:44 +08:00
|
|
|
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define void @test1()
|
2010-08-06 01:39:44 +08:00
|
|
|
void test1() {
|
|
|
|
extern void opaque(int);
|
|
|
|
opaque(i++);
|
|
|
|
|
2015-02-28 05:19:58 +08:00
|
|
|
// CHECK: [[T1:%.*]] = load i32, i32* @i
|
2011-07-10 01:41:47 +08:00
|
|
|
// CHECK-NEXT: [[T2:%.*]] = call { i32, i1 } @llvm.sadd.with.overflow.i32(i32 [[T1]], i32 1)
|
|
|
|
// CHECK-NEXT: [[T3:%.*]] = extractvalue { i32, i1 } [[T2]], 0
|
|
|
|
// CHECK-NEXT: [[T4:%.*]] = extractvalue { i32, i1 } [[T2]], 1
|
2012-09-08 10:08:36 +08:00
|
|
|
// CHECK-NEXT: [[T5:%.*]] = xor i1 [[T4]], true
|
|
|
|
// CHECK-NEXT: br i1 [[T5]]
|
2020-10-21 17:11:25 +08:00
|
|
|
// CHECK: call void @llvm.ubsantrap(i8 0)
|
2010-08-06 01:39:44 +08:00
|
|
|
}
|
|
|
|
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define void @test2()
|
2010-08-06 01:39:44 +08:00
|
|
|
void test2() {
|
|
|
|
extern void opaque(int);
|
|
|
|
opaque(++i);
|
|
|
|
|
2015-02-28 05:19:58 +08:00
|
|
|
// CHECK: [[T1:%.*]] = load i32, i32* @i
|
2011-07-10 01:41:47 +08:00
|
|
|
// CHECK-NEXT: [[T2:%.*]] = call { i32, i1 } @llvm.sadd.with.overflow.i32(i32 [[T1]], i32 1)
|
|
|
|
// CHECK-NEXT: [[T3:%.*]] = extractvalue { i32, i1 } [[T2]], 0
|
|
|
|
// CHECK-NEXT: [[T4:%.*]] = extractvalue { i32, i1 } [[T2]], 1
|
2012-09-08 10:08:36 +08:00
|
|
|
// CHECK-NEXT: [[T5:%.*]] = xor i1 [[T4]], true
|
|
|
|
// CHECK-NEXT: br i1 [[T5]]
|
2020-10-21 17:11:25 +08:00
|
|
|
// CHECK: call void @llvm.ubsantrap(i8 0)
|
2010-08-06 01:39:44 +08:00
|
|
|
}
|
2012-11-02 06:13:39 +08:00
|
|
|
|
2013-08-15 14:47:53 +08:00
|
|
|
// CHECK-LABEL: define void @test3(
|
2012-11-02 06:13:39 +08:00
|
|
|
void test3(int a, int b, float c, float d) {
|
|
|
|
// CHECK-NOT: @llvm.trap
|
|
|
|
(void)(a / b);
|
|
|
|
(void)(a % b);
|
|
|
|
(void)(c / d);
|
|
|
|
// CHECK: }
|
|
|
|
}
|