ARM test cases contributed by Apple.
[oota-llvm.git] / test / CodeGen / ARM / pack.ll
1 ; RUN: llvm-upgrade < %s | llvm-as | llc -march=arm &&
2 ; RUN: llvm-upgrade < %s | llvm-as | llc -march=arm -mattr=+v6 | grep pkhbt | wc -l | grep 5 &&
3 ; RUN: llvm-upgrade < %s | llvm-as | llc -march=arm -mattr=+v6 | grep pkhtb | wc -l | grep 4
4 implementation   ; Functions:
5
6 int %test1(int %X, int %Y) {
7         %tmp1 = and int %X, 65535               ; <int> [#uses=1]
8         %tmp4 = shl int %Y, ubyte 16            ; <int> [#uses=1]
9         %tmp5 = or int %tmp4, %tmp1             ; <int> [#uses=1]
10         ret int %tmp5
11 }
12
13 int %test1a(int %X, int %Y) {
14         %tmp19 = and int %X, 65535              ; <int> [#uses=1]
15         %tmp37 = shl int %Y, ubyte 16           ; <int> [#uses=1]
16         %tmp5 = or int %tmp37, %tmp19           ; <int> [#uses=1]
17         ret int %tmp5
18 }
19
20 int %test2(int %X, int %Y) {
21         %tmp1 = and int %X, 65535               ; <int> [#uses=1]
22         %tmp3 = shl int %Y, ubyte 12            ; <int> [#uses=1]
23         %tmp4 = and int %tmp3, -65536           ; <int> [#uses=1]
24         %tmp57 = or int %tmp4, %tmp1            ; <int> [#uses=1]
25         ret int %tmp57
26 }
27
28 int %test3(int %X, int %Y) {
29         %tmp19 = and int %X, 65535              ; <int> [#uses=1]
30         %tmp37 = shl int %Y, ubyte 18           ; <int> [#uses=1]
31         %tmp5 = or int %tmp37, %tmp19           ; <int> [#uses=1]
32         ret int %tmp5
33 }
34
35 int %test4(int %X, int %Y) {
36         %tmp1 = and int %X, 65535               ; <int> [#uses=1]
37         %tmp3 = and int %Y, -65536              ; <int> [#uses=1]
38         %tmp46 = or int %tmp3, %tmp1            ; <int> [#uses=1]
39         ret int %tmp46
40 }
41
42 int %test5(int %X, int %Y) {
43         %tmp17 = and int %X, -65536             ; <int> [#uses=1]
44         %tmp2 = cast int %Y to uint             ; <uint> [#uses=1]
45         %tmp4 = shr uint %tmp2, ubyte 16                ; <uint> [#uses=1]
46         %tmp4 = cast uint %tmp4 to int          ; <int> [#uses=1]
47         %tmp5 = or int %tmp4, %tmp17            ; <int> [#uses=1]
48         ret int %tmp5
49 }
50
51 int %test5a(int %X, int %Y) {
52         %tmp110 = and int %X, -65536            ; <int> [#uses=1]
53         %Y = cast int %Y to uint                ; <uint> [#uses=1]
54         %tmp37 = shr uint %Y, ubyte 16          ; <uint> [#uses=1]
55         %tmp39 = cast uint %tmp37 to int                ; <int> [#uses=1]
56         %tmp5 = or int %tmp39, %tmp110          ; <int> [#uses=1]
57         ret int %tmp5
58 }
59
60 int %test6(int %X, int %Y) {
61         %tmp1 = and int %X, -65536              ; <int> [#uses=1]
62         %Y = cast int %Y to uint                ; <uint> [#uses=1]
63         %tmp37 = shr uint %Y, ubyte 12          ; <uint> [#uses=1]
64         %tmp38 = cast uint %tmp37 to int                ; <int> [#uses=1]
65         %tmp4 = and int %tmp38, 65535           ; <int> [#uses=1]
66         %tmp59 = or int %tmp4, %tmp1            ; <int> [#uses=1]
67         ret int %tmp59
68 }
69
70 int %test7(int %X, int %Y) {
71         %tmp1 = and int %X, -65536              ; <int> [#uses=1]
72         %tmp3 = shr int %Y, ubyte 18            ; <int> [#uses=1]
73         %tmp4 = and int %tmp3, 65535            ; <int> [#uses=1]
74         %tmp57 = or int %tmp4, %tmp1            ; <int> [#uses=1]
75         ret int %tmp57
76 }
77