Jim Grosbach | 5f5b411 | 2010-05-05 20:47:15 +0000 | [diff] [blame] | 1 | ; RUN: llc < %s -march=arm | FileCheck %s -check-prefix=CHECK-ARM |
2 | ; RUN: llc < %s -march=arm -mcpu=cortex-m3 \ | ||||
3 | ; RUN: | FileCheck %s -check-prefix=CHECK-ARMV7M | ||||
Dan Gohman | f17a25c | 2007-07-18 16:29:46 +0000 | [diff] [blame] | 4 | |
Tanya Lattner | 246a137 | 2008-02-17 20:02:20 +0000 | [diff] [blame] | 5 | define i32 @f1(i32 %a, i32 %b) { |
Dan Gohman | f17a25c | 2007-07-18 16:29:46 +0000 | [diff] [blame] | 6 | entry: |
Jim Grosbach | 5f5b411 | 2010-05-05 20:47:15 +0000 | [diff] [blame] | 7 | ; CHECK-ARM: f1 |
8 | ; CHECK-ARM: __divsi3 | ||||
9 | ; CHECK-ARMV7M: f1 | ||||
10 | ; CHECK-ARMV7M: sdiv | ||||
Tanya Lattner | 246a137 | 2008-02-17 20:02:20 +0000 | [diff] [blame] | 11 | %tmp1 = sdiv i32 %a, %b ; <i32> [#uses=1] |
12 | ret i32 %tmp1 | ||||
Dan Gohman | f17a25c | 2007-07-18 16:29:46 +0000 | [diff] [blame] | 13 | } |
14 | |||||
Tanya Lattner | 246a137 | 2008-02-17 20:02:20 +0000 | [diff] [blame] | 15 | define i32 @f2(i32 %a, i32 %b) { |
Dan Gohman | f17a25c | 2007-07-18 16:29:46 +0000 | [diff] [blame] | 16 | entry: |
Jim Grosbach | 5f5b411 | 2010-05-05 20:47:15 +0000 | [diff] [blame] | 17 | ; CHECK-ARM: f2 |
18 | ; CHECK-ARM: __udivsi3 | ||||
Jim Grosbach | b17947e | 2010-05-05 21:07:46 +0000 | [diff] [blame] | 19 | ; CHECK-ARMV7M: f2 |
Jim Grosbach | 5f5b411 | 2010-05-05 20:47:15 +0000 | [diff] [blame] | 20 | ; CHECK-ARMV7M: udiv |
Tanya Lattner | 246a137 | 2008-02-17 20:02:20 +0000 | [diff] [blame] | 21 | %tmp1 = udiv i32 %a, %b ; <i32> [#uses=1] |
22 | ret i32 %tmp1 | ||||
Dan Gohman | f17a25c | 2007-07-18 16:29:46 +0000 | [diff] [blame] | 23 | } |
24 | |||||
Tanya Lattner | 246a137 | 2008-02-17 20:02:20 +0000 | [diff] [blame] | 25 | define i32 @f3(i32 %a, i32 %b) { |
Dan Gohman | f17a25c | 2007-07-18 16:29:46 +0000 | [diff] [blame] | 26 | entry: |
Jim Grosbach | 5f5b411 | 2010-05-05 20:47:15 +0000 | [diff] [blame] | 27 | ; CHECK-ARM: f3 |
28 | ; CHECK-ARM: __modsi3 | ||||
Jim Grosbach | b17947e | 2010-05-05 21:07:46 +0000 | [diff] [blame] | 29 | ; CHECK-ARMV7M: f3 |
Jim Grosbach | 5f5b411 | 2010-05-05 20:47:15 +0000 | [diff] [blame] | 30 | ; CHECK-ARMV7M: sdiv |
Tanya Lattner | 246a137 | 2008-02-17 20:02:20 +0000 | [diff] [blame] | 31 | %tmp1 = srem i32 %a, %b ; <i32> [#uses=1] |
32 | ret i32 %tmp1 | ||||
Dan Gohman | f17a25c | 2007-07-18 16:29:46 +0000 | [diff] [blame] | 33 | } |
34 | |||||
Tanya Lattner | 246a137 | 2008-02-17 20:02:20 +0000 | [diff] [blame] | 35 | define i32 @f4(i32 %a, i32 %b) { |
Dan Gohman | f17a25c | 2007-07-18 16:29:46 +0000 | [diff] [blame] | 36 | entry: |
Jim Grosbach | 5f5b411 | 2010-05-05 20:47:15 +0000 | [diff] [blame] | 37 | ; CHECK-ARM: f4 |
38 | ; CHECK-ARM: __umodsi3 | ||||
Jim Grosbach | b17947e | 2010-05-05 21:07:46 +0000 | [diff] [blame] | 39 | ; CHECK-ARMV7M: f4 |
Jim Grosbach | 5f5b411 | 2010-05-05 20:47:15 +0000 | [diff] [blame] | 40 | ; CHECK-ARMV7M: udiv |
Tanya Lattner | 246a137 | 2008-02-17 20:02:20 +0000 | [diff] [blame] | 41 | %tmp1 = urem i32 %a, %b ; <i32> [#uses=1] |
42 | ret i32 %tmp1 | ||||
Dan Gohman | f17a25c | 2007-07-18 16:29:46 +0000 | [diff] [blame] | 43 | } |
Tanya Lattner | 246a137 | 2008-02-17 20:02:20 +0000 | [diff] [blame] | 44 |