Bob Wilson | 13e80bd | 2009-10-27 05:50:28 +0000 | [diff] [blame] | 1 | ; RUN: llc < %s -march=arm | FileCheck %s |
Chris Lattner | baf2199 | 2007-04-03 00:13:16 +0000 | [diff] [blame] | 2 | |
Dan Gohman | 572645c | 2010-02-12 10:34:29 +0000 | [diff] [blame] | 3 | ; This loop is rewritten with an indvar which counts down, which |
| 4 | ; frees up a register from holding the trip count. |
| 5 | |
Dan Gohman | 0462327 | 2009-05-18 15:16:49 +0000 | [diff] [blame] | 6 | define void @test(i32* %P, i32 %A, i32 %i) nounwind { |
Chris Lattner | baf2199 | 2007-04-03 00:13:16 +0000 | [diff] [blame] | 7 | entry: |
Johnny Chen | 9e08876 | 2010-03-17 17:52:21 +0000 | [diff] [blame^] | 8 | ; CHECK: str r1, [{{r.*}}, {{r.*}}, lsl #2] |
Dan Gohman | 572645c | 2010-02-12 10:34:29 +0000 | [diff] [blame] | 9 | icmp eq i32 %i, 0 ; <i1>:0 [#uses=1] |
| 10 | br i1 %0, label %return, label %bb |
| 11 | |
| 12 | bb: ; preds = %bb, %entry |
| 13 | %indvar = phi i32 [ 0, %entry ], [ %indvar.next, %bb ] ; <i32> [#uses=2] |
| 14 | %i_addr.09.0 = sub i32 %i, %indvar ; <i32> [#uses=1] |
| 15 | %tmp2 = getelementptr i32* %P, i32 %i_addr.09.0 ; <i32*> [#uses=1] |
| 16 | store i32 %A, i32* %tmp2 |
| 17 | %indvar.next = add i32 %indvar, 1 ; <i32> [#uses=2] |
| 18 | icmp eq i32 %indvar.next, %i ; <i1>:1 [#uses=1] |
| 19 | br i1 %1, label %return, label %bb |
| 20 | |
| 21 | return: ; preds = %bb, %entry |
| 22 | ret void |
| 23 | } |
| 24 | |
| 25 | ; This loop has a non-address use of the count-up indvar, so |
| 26 | ; it'll remain. Now the original store uses a negative-stride address. |
| 27 | |
| 28 | define void @test_with_forced_iv(i32* %P, i32 %A, i32 %i) nounwind { |
| 29 | entry: |
Bob Wilson | 13e80bd | 2009-10-27 05:50:28 +0000 | [diff] [blame] | 30 | ; CHECK: str r1, [{{r.*}}, -{{r.*}}, lsl #2] |
Chris Lattner | baf2199 | 2007-04-03 00:13:16 +0000 | [diff] [blame] | 31 | icmp eq i32 %i, 0 ; <i1>:0 [#uses=1] |
| 32 | br i1 %0, label %return, label %bb |
| 33 | |
| 34 | bb: ; preds = %bb, %entry |
| 35 | %indvar = phi i32 [ 0, %entry ], [ %indvar.next, %bb ] ; <i32> [#uses=2] |
| 36 | %i_addr.09.0 = sub i32 %i, %indvar ; <i32> [#uses=1] |
| 37 | %tmp2 = getelementptr i32* %P, i32 %i_addr.09.0 ; <i32*> [#uses=1] |
| 38 | store i32 %A, i32* %tmp2 |
Dan Gohman | 572645c | 2010-02-12 10:34:29 +0000 | [diff] [blame] | 39 | store i32 %indvar, i32* null |
Chris Lattner | baf2199 | 2007-04-03 00:13:16 +0000 | [diff] [blame] | 40 | %indvar.next = add i32 %indvar, 1 ; <i32> [#uses=2] |
| 41 | icmp eq i32 %indvar.next, %i ; <i1>:1 [#uses=1] |
| 42 | br i1 %1, label %return, label %bb |
| 43 | |
| 44 | return: ; preds = %bb, %entry |
| 45 | ret void |
| 46 | } |
| 47 | |