blob: 8f83f17377a5ef2e640793919e099e435c88cf01 [file] [log] [blame]
Hal Finkelbcc06082014-09-07 22:58:14 +00001// RUN: %clang_cc1 -triple x86_64-unknown-unknown -emit-llvm -o - %s | FileCheck %s
Hal Finkel3e49fda2014-07-16 22:44:54 +00002// RUN: %clang_cc1 -triple i386-mingw32 -fms-extensions -emit-llvm -o - %s | FileCheck %s
3
4// CHECK-LABEL: @test1
Hal Finkelbcc06082014-09-07 22:58:14 +00005int test1(int *a, int i) {
NAKAMURA Takumi4b04c112014-09-08 01:12:55 +00006// CHECK: store i32* %a, i32** [[A_ADDR:%.+]], align
David Blaikiea953f282015-02-27 21:19:58 +00007// CHECK: [[A:%.+]] = load i32*, i32** [[A_ADDR]]
NAKAMURA Takumi4b04c112014-09-08 01:12:55 +00008// CHECK: [[CMP:%.+]] = icmp ne i32* [[A]], null
9// CHECK: call void @llvm.assume(i1 [[CMP]])
Hal Finkelbcc06082014-09-07 22:58:14 +000010#ifdef _MSC_VER
11 __assume(a != 0)
12#else
13 __builtin_assume(a != 0);
14#endif
15
16// Nothing is generated for an assume with side effects...
David Blaikiea953f282015-02-27 21:19:58 +000017// CHECK-NOT: load i32*, i32** %i.addr
Hal Finkelbcc06082014-09-07 22:58:14 +000018// CHECK-NOT: call void @llvm.assume
19#ifdef _MSC_VER
20 __assume(++i != 0)
21#else
22 __builtin_assume(++i != 0);
23#endif
24
Hal Finkel3e49fda2014-07-16 22:44:54 +000025 return a[0];
26}
27