blob: feb49d02c06776711548a82aa8bd33be5ef98dd8 [file] [log] [blame]
Reid Spencer1c0c94d2007-04-15 19:11:47 +00001; RUN: llvm-upgrade < %s | llvm-as | llc -march=arm -mattr=+v6 | \
Dan Gohman28beeea2007-08-15 13:36:28 +00002; RUN: grep pkhbt | count 5
Reid Spencer1c0c94d2007-04-15 19:11:47 +00003; RUN: llvm-upgrade < %s | llvm-as | llc -march=arm -mattr=+v6 | \
Dan Gohman28beeea2007-08-15 13:36:28 +00004; RUN: grep pkhtb | count 4
Reid Spencer1c0c94d2007-04-15 19:11:47 +00005; END.
6
Evan Cheng02b985c2007-01-19 09:20:23 +00007implementation ; Functions:
8
9int %test1(int %X, int %Y) {
10 %tmp1 = and int %X, 65535 ; <int> [#uses=1]
11 %tmp4 = shl int %Y, ubyte 16 ; <int> [#uses=1]
12 %tmp5 = or int %tmp4, %tmp1 ; <int> [#uses=1]
13 ret int %tmp5
14}
15
16int %test1a(int %X, int %Y) {
17 %tmp19 = and int %X, 65535 ; <int> [#uses=1]
18 %tmp37 = shl int %Y, ubyte 16 ; <int> [#uses=1]
19 %tmp5 = or int %tmp37, %tmp19 ; <int> [#uses=1]
20 ret int %tmp5
21}
22
23int %test2(int %X, int %Y) {
24 %tmp1 = and int %X, 65535 ; <int> [#uses=1]
25 %tmp3 = shl int %Y, ubyte 12 ; <int> [#uses=1]
26 %tmp4 = and int %tmp3, -65536 ; <int> [#uses=1]
27 %tmp57 = or int %tmp4, %tmp1 ; <int> [#uses=1]
28 ret int %tmp57
29}
30
31int %test3(int %X, int %Y) {
32 %tmp19 = and int %X, 65535 ; <int> [#uses=1]
33 %tmp37 = shl int %Y, ubyte 18 ; <int> [#uses=1]
34 %tmp5 = or int %tmp37, %tmp19 ; <int> [#uses=1]
35 ret int %tmp5
36}
37
38int %test4(int %X, int %Y) {
39 %tmp1 = and int %X, 65535 ; <int> [#uses=1]
40 %tmp3 = and int %Y, -65536 ; <int> [#uses=1]
41 %tmp46 = or int %tmp3, %tmp1 ; <int> [#uses=1]
42 ret int %tmp46
43}
44
45int %test5(int %X, int %Y) {
46 %tmp17 = and int %X, -65536 ; <int> [#uses=1]
47 %tmp2 = cast int %Y to uint ; <uint> [#uses=1]
48 %tmp4 = shr uint %tmp2, ubyte 16 ; <uint> [#uses=1]
49 %tmp4 = cast uint %tmp4 to int ; <int> [#uses=1]
50 %tmp5 = or int %tmp4, %tmp17 ; <int> [#uses=1]
51 ret int %tmp5
52}
53
54int %test5a(int %X, int %Y) {
55 %tmp110 = and int %X, -65536 ; <int> [#uses=1]
56 %Y = cast int %Y to uint ; <uint> [#uses=1]
57 %tmp37 = shr uint %Y, ubyte 16 ; <uint> [#uses=1]
58 %tmp39 = cast uint %tmp37 to int ; <int> [#uses=1]
59 %tmp5 = or int %tmp39, %tmp110 ; <int> [#uses=1]
60 ret int %tmp5
61}
62
63int %test6(int %X, int %Y) {
64 %tmp1 = and int %X, -65536 ; <int> [#uses=1]
65 %Y = cast int %Y to uint ; <uint> [#uses=1]
66 %tmp37 = shr uint %Y, ubyte 12 ; <uint> [#uses=1]
67 %tmp38 = cast uint %tmp37 to int ; <int> [#uses=1]
68 %tmp4 = and int %tmp38, 65535 ; <int> [#uses=1]
69 %tmp59 = or int %tmp4, %tmp1 ; <int> [#uses=1]
70 ret int %tmp59
71}
72
73int %test7(int %X, int %Y) {
74 %tmp1 = and int %X, -65536 ; <int> [#uses=1]
75 %tmp3 = shr int %Y, ubyte 18 ; <int> [#uses=1]
76 %tmp4 = and int %tmp3, 65535 ; <int> [#uses=1]
77 %tmp57 = or int %tmp4, %tmp1 ; <int> [#uses=1]
78 ret int %tmp57
79}
80