ARM test cases contributed by Apple.
[oota-llvm.git] / test / CodeGen / ARM / uxtb.ll
1 ; RUN: llvm-upgrade < %s | llvm-as | llc -march=arm &&
2 ; RUN: llvm-upgrade < %s | llvm-as | llc -march=arm -mattr=+v6 | grep uxt | wc -l | grep 10
3
4 uint %test1(uint %x) {
5         %tmp1 = and uint %x, 16711935           ; <uint> [#uses=1]
6         ret uint %tmp1
7 }
8
9 uint %test2(uint %x) {
10         %tmp1 = shr uint %x, ubyte 8            ; <uint> [#uses=1]
11         %tmp2 = and uint %tmp1, 16711935                ; <uint> [#uses=1]
12         ret uint %tmp2
13 }
14
15 uint %test3(uint %x) {
16         %tmp1 = shr uint %x, ubyte 8            ; <uint> [#uses=1]
17         %tmp2 = and uint %tmp1, 16711935                ; <uint> [#uses=1]
18         ret uint %tmp2
19 }
20
21 uint %test4(uint %x) {
22         %tmp1 = shr uint %x, ubyte 8            ; <uint> [#uses=1]
23         %tmp6 = and uint %tmp1, 16711935                ; <uint> [#uses=1]
24         ret uint %tmp6
25 }
26
27 uint %test5(uint %x) {
28         %tmp1 = shr uint %x, ubyte 8            ; <uint> [#uses=1]
29         %tmp2 = and uint %tmp1, 16711935                ; <uint> [#uses=1]
30         ret uint %tmp2
31 }
32
33 uint %test6(uint %x) {
34         %tmp1 = shr uint %x, ubyte 16           ; <uint> [#uses=1]
35         %tmp2 = and uint %tmp1, 255             ; <uint> [#uses=1]
36         %tmp4 = shl uint %x, ubyte 16           ; <uint> [#uses=1]
37         %tmp5 = and uint %tmp4, 16711680                ; <uint> [#uses=1]
38         %tmp6 = or uint %tmp2, %tmp5            ; <uint> [#uses=1]
39         ret uint %tmp6
40 }
41
42 uint %test7(uint %x) {
43         %tmp1 = shr uint %x, ubyte 16           ; <uint> [#uses=1]
44         %tmp2 = and uint %tmp1, 255             ; <uint> [#uses=1]
45         %tmp4 = shl uint %x, ubyte 16           ; <uint> [#uses=1]
46         %tmp5 = and uint %tmp4, 16711680                ; <uint> [#uses=1]
47         %tmp6 = or uint %tmp2, %tmp5            ; <uint> [#uses=1]
48         ret uint %tmp6
49 }
50
51 uint %test8(uint %x) {
52         %tmp1 = shl uint %x, ubyte 8            ; <uint> [#uses=1]
53         %tmp2 = and uint %tmp1, 16711680                ; <uint> [#uses=1]
54         %tmp5 = shr uint %x, ubyte 24           ; <uint> [#uses=1]
55         %tmp6 = or uint %tmp2, %tmp5            ; <uint> [#uses=1]
56         ret uint %tmp6
57 }
58
59 uint %test9(uint %x) {
60         %tmp1 = shr uint %x, ubyte 24           ; <uint> [#uses=1]
61         %tmp4 = shl uint %x, ubyte 8            ; <uint> [#uses=1]
62         %tmp5 = and uint %tmp4, 16711680                ; <uint> [#uses=1]
63         %tmp6 = or uint %tmp5, %tmp1            ; <uint> [#uses=1]
64         ret uint %tmp6
65 }
66
67 uint %test10(uint %p0) {
68         %tmp1 = shr uint %p0, ubyte 7           ; <uint> [#uses=1]
69         %tmp2 = and uint %tmp1, 16253176                ; <uint> [#uses=2]
70         %tmp4 = shr uint %tmp2, ubyte 5         ; <uint> [#uses=1]
71         %tmp5 = and uint %tmp4, 458759          ; <uint> [#uses=1]
72         %tmp7 = or uint %tmp5, %tmp2            ; <uint> [#uses=1]
73         ret uint %tmp7
74 }
75