blob: 2e77660c45c1d72773c517ab6cc2421752058173 [file] [log] [blame]
Chandler Carruth49589f02012-07-02 18:37:59 +00001; RUN: llc < %s -march=thumb -stats 2>&1 | \
Chandler Carruth4177e6f2012-07-02 12:47:22 +00002; RUN: grep "4 .*Number of machine instrs printed"
Evan Cheng9f76ed52009-06-24 06:36:07 +00003
4;; Integer absolute value, should produce something as good as:
5;; Thumb:
Bill Wendlingef2c86f2011-10-10 22:59:55 +00006;; movs r0, r0
7;; bpl
8;; rsb r0, r0, #0 (with opitmization, bpl + rsb is if-converted into rsbmi)
Evan Cheng9f76ed52009-06-24 06:36:07 +00009;; bx lr
10
11define i32 @test(i32 %a) {
12 %tmp1neg = sub i32 0, %a
13 %b = icmp sgt i32 %a, -1
14 %abs = select i1 %b, i32 %a, i32 %tmp1neg
15 ret i32 %abs
Bill Wendlingef2c86f2011-10-10 22:59:55 +000016; CHECK: movs r0, r0
17; CHECK: bpl
18; CHECK: rsb r0, r0, #0
19; CHECK: bx lr
Evan Cheng9f76ed52009-06-24 06:36:07 +000020}
21
Bill Wendlingef2c86f2011-10-10 22:59:55 +000022