1; Ensure that shifts are lowered to loops when the barrel shifter unit is
2; not available in the hardware and that loops are not used when the
3; barrel shifter unit is available in the hardware.
4;
5; RUN: llc < %s -march=mblaze | FileCheck -check-prefix=FUN %s
6; RUN: llc < %s -march=mblaze -mattr=+barrel | FileCheck -check-prefix=SHT %s
7
8define i8 @test_i8(i8 %a, i8 %b) {
9    ; FUN:        test_i8:
10    ; SHT:        test_i8:
11
12    %tmp.1 = shl i8 %a, %b
13    ; FUN:        andi
14    ; FUN:        add
15    ; FUN:        bnei
16    ; SHT-NOT:    bnei
17
18    ret i8 %tmp.1
19    ; FUN:        rtsd
20    ; SHT:        rtsd
21    ; FUN-NOT:    bsll
22    ; SHT-NEXT:   bsll
23}
24
25define i8 @testc_i8(i8 %a, i8 %b) {
26    ; FUN:        testc_i8:
27    ; SHT:        testc_i8:
28
29    %tmp.1 = shl i8 %a, 5
30    ; FUN:        andi
31    ; FUN:        add
32    ; FUN:        bnei
33    ; SHT-NOT:    andi
34    ; SHT-NOT:    add
35    ; SHT-NOT:    bnei
36
37    ret i8 %tmp.1
38    ; FUN:        rtsd
39    ; SHT:        rtsd
40    ; FUN-NOT:    bsll
41    ; SHT-NEXT:   bslli
42}
43
44define i16 @test_i16(i16 %a, i16 %b) {
45    ; FUN:        test_i16:
46    ; SHT:        test_i16:
47
48    %tmp.1 = shl i16 %a, %b
49    ; FUN:        andi
50    ; FUN:        add
51    ; FUN:        bnei
52    ; SHT-NOT:    bnei
53
54    ret i16 %tmp.1
55    ; FUN:        rtsd
56    ; SHT:        rtsd
57    ; FUN-NOT:    bsll
58    ; SHT-NEXT:   bsll
59}
60
61define i16 @testc_i16(i16 %a, i16 %b) {
62    ; FUN:        testc_i16:
63    ; SHT:        testc_i16:
64
65    %tmp.1 = shl i16 %a, 5
66    ; FUN:        andi
67    ; FUN:        add
68    ; FUN:        bnei
69    ; SHT-NOT:    andi
70    ; SHT-NOT:    add
71    ; SHT-NOT:    bnei
72
73    ret i16 %tmp.1
74    ; FUN:        rtsd
75    ; SHT:        rtsd
76    ; FUN-NOT:    bsll
77    ; SHT-NEXT:   bslli
78}
79
80define i32 @test_i32(i32 %a, i32 %b) {
81    ; FUN:        test_i32:
82    ; SHT:        test_i32:
83
84    %tmp.1 = shl i32 %a, %b
85    ; FUN:        andi
86    ; FUN:        add
87    ; FUN:        bnei
88    ; SHT-NOT:    andi
89    ; SHT-NOT:    bnei
90
91    ret i32 %tmp.1
92    ; FUN:        rtsd
93    ; SHT:        rtsd
94    ; FUN-NOT:    bsll
95    ; SHT-NEXT:   bsll
96}
97
98define i32 @testc_i32(i32 %a, i32 %b) {
99    ; FUN:        testc_i32:
100    ; SHT:        testc_i32:
101
102    %tmp.1 = shl i32 %a, 5
103    ; FUN:        andi
104    ; FUN:        add
105    ; FUN:        bnei
106    ; SHT-NOT:    andi
107    ; SHT-NOT:    add
108    ; SHT-NOT:    bnei
109
110    ret i32 %tmp.1
111    ; FUN:        rtsd
112    ; SHT:        rtsd
113    ; FUN-NOT:    bsll
114    ; SHT-NEXT:   bslli
115}
116