blob: 4d9eda062f9e5cf13233c114b42d9ffa9e32b576 [file] [log] [blame]
Jim Grosbach92bf81d2011-07-12 16:06:01 +00001; RUN: llc < %s -mtriple=thumbv7-apple-darwin -mattr=+thumb2 | FileCheck %s
Jim Grosbach25e6d482011-07-08 21:50:04 +00002; If-conversion defeats the purpose of this test, which is to check conditional
Jim Grosbach92bf81d2011-07-12 16:06:01 +00003; branch generation, so use memory barrier instruction to make sure it doesn't
4; happen and we get actual branches.
Evan Cheng31b99dd2009-08-14 18:31:44 +00005
Dan Gohman30fc5bb2010-05-03 14:35:47 +00006define i32 @f1(i32 %a, i32 %b, i32* %v) {
Evan Cheng31b99dd2009-08-14 18:31:44 +00007entry:
8; CHECK: f1:
Benjamin Kramer823bdbc2009-10-31 19:22:24 +00009; CHECK: bne LBB
Evan Cheng31b99dd2009-08-14 18:31:44 +000010 %tmp = icmp eq i32 %a, %b ; <i1> [#uses=1]
11 br i1 %tmp, label %cond_true, label %return
12
13cond_true: ; preds = %entry
Jim Grosbach92bf81d2011-07-12 16:06:01 +000014 call void @llvm.memory.barrier(i1 true, i1 true, i1 true, i1 true, i1 false)
Evan Cheng31b99dd2009-08-14 18:31:44 +000015 store i32 0, i32* %v
Dan Gohman30fc5bb2010-05-03 14:35:47 +000016 ret i32 0
Evan Cheng31b99dd2009-08-14 18:31:44 +000017
18return: ; preds = %entry
Jim Grosbach92bf81d2011-07-12 16:06:01 +000019 call void @llvm.memory.barrier(i1 true, i1 true, i1 true, i1 true, i1 false)
Dan Gohman30fc5bb2010-05-03 14:35:47 +000020 ret i32 1
Evan Cheng31b99dd2009-08-14 18:31:44 +000021}
22
Dan Gohman30fc5bb2010-05-03 14:35:47 +000023define i32 @f2(i32 %a, i32 %b, i32* %v) {
Evan Cheng31b99dd2009-08-14 18:31:44 +000024entry:
25; CHECK: f2:
Benjamin Kramer823bdbc2009-10-31 19:22:24 +000026; CHECK: bge LBB
Evan Cheng31b99dd2009-08-14 18:31:44 +000027 %tmp = icmp slt i32 %a, %b ; <i1> [#uses=1]
28 br i1 %tmp, label %cond_true, label %return
29
30cond_true: ; preds = %entry
Jim Grosbach92bf81d2011-07-12 16:06:01 +000031 call void @llvm.memory.barrier(i1 true, i1 true, i1 true, i1 true, i1 false)
Evan Cheng31b99dd2009-08-14 18:31:44 +000032 store i32 0, i32* %v
Dan Gohman30fc5bb2010-05-03 14:35:47 +000033 ret i32 0
Evan Cheng31b99dd2009-08-14 18:31:44 +000034
35return: ; preds = %entry
Jim Grosbach92bf81d2011-07-12 16:06:01 +000036 call void @llvm.memory.barrier(i1 true, i1 true, i1 true, i1 true, i1 false)
Dan Gohman30fc5bb2010-05-03 14:35:47 +000037 ret i32 1
Evan Cheng31b99dd2009-08-14 18:31:44 +000038}
39
Dan Gohman30fc5bb2010-05-03 14:35:47 +000040define i32 @f3(i32 %a, i32 %b, i32* %v) {
Evan Cheng31b99dd2009-08-14 18:31:44 +000041entry:
42; CHECK: f3:
Benjamin Kramer823bdbc2009-10-31 19:22:24 +000043; CHECK: bhs LBB
Evan Cheng31b99dd2009-08-14 18:31:44 +000044 %tmp = icmp ult i32 %a, %b ; <i1> [#uses=1]
45 br i1 %tmp, label %cond_true, label %return
46
47cond_true: ; preds = %entry
Jim Grosbach92bf81d2011-07-12 16:06:01 +000048 call void @llvm.memory.barrier(i1 true, i1 true, i1 true, i1 true, i1 false)
Evan Cheng31b99dd2009-08-14 18:31:44 +000049 store i32 0, i32* %v
Dan Gohman30fc5bb2010-05-03 14:35:47 +000050 ret i32 0
Evan Cheng31b99dd2009-08-14 18:31:44 +000051
52return: ; preds = %entry
Jim Grosbach92bf81d2011-07-12 16:06:01 +000053 call void @llvm.memory.barrier(i1 true, i1 true, i1 true, i1 true, i1 false)
Dan Gohman30fc5bb2010-05-03 14:35:47 +000054 ret i32 1
Evan Cheng31b99dd2009-08-14 18:31:44 +000055}
56
Dan Gohman30fc5bb2010-05-03 14:35:47 +000057define i32 @f4(i32 %a, i32 %b, i32* %v) {
Evan Cheng31b99dd2009-08-14 18:31:44 +000058entry:
59; CHECK: f4:
Benjamin Kramer823bdbc2009-10-31 19:22:24 +000060; CHECK: blo LBB
Evan Cheng31b99dd2009-08-14 18:31:44 +000061 %tmp = icmp ult i32 %a, %b ; <i1> [#uses=1]
62 br i1 %tmp, label %return, label %cond_true
63
64cond_true: ; preds = %entry
Jim Grosbach92bf81d2011-07-12 16:06:01 +000065 call void @llvm.memory.barrier(i1 true, i1 true, i1 true, i1 true, i1 false)
Evan Cheng31b99dd2009-08-14 18:31:44 +000066 store i32 0, i32* %v
Dan Gohman30fc5bb2010-05-03 14:35:47 +000067 ret i32 0
Evan Cheng31b99dd2009-08-14 18:31:44 +000068
69return: ; preds = %entry
Jim Grosbach92bf81d2011-07-12 16:06:01 +000070 call void @llvm.memory.barrier(i1 true, i1 true, i1 true, i1 true, i1 false)
Dan Gohman30fc5bb2010-05-03 14:35:47 +000071 ret i32 1
Evan Cheng31b99dd2009-08-14 18:31:44 +000072}
Jim Grosbach92bf81d2011-07-12 16:06:01 +000073
74declare void @llvm.memory.barrier(i1, i1, i1, i1, i1) nounwind