Silence -Wunused-variable in release builds.
[llvm/stm8.git] / test / CodeGen / MBlaze / shift.ll
blob99f0519c020c04ffa5785a9eb0173649e907daeb
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.
5 ; RUN: llc < %s -march=mblaze | FileCheck -check-prefix=FUN %s
6 ; RUN: llc < %s -march=mblaze -mattr=+barrel | FileCheck -check-prefix=SHT %s
8 define i8 @test_i8(i8 %a, i8 %b) {
9     ; FUN:        test_i8:
10     ; SHT:        test_i8:
12     %tmp.1 = shl i8 %a, %b
13     ; FUN:        andi
14     ; FUN:        add
15     ; FUN:        bnei
16     ; SHT-NOT:    bnei
18     ret i8 %tmp.1
19     ; FUN:        rtsd
20     ; SHT:        rtsd
21     ; FUN-NOT:    bsll
22     ; SHT-NEXT:   bsll
25 define i8 @testc_i8(i8 %a, i8 %b) {
26     ; FUN:        testc_i8:
27     ; SHT:        testc_i8:
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
37     ret i8 %tmp.1
38     ; FUN:        rtsd
39     ; SHT:        rtsd
40     ; FUN-NOT:    bsll
41     ; SHT-NEXT:   bslli
44 define i16 @test_i16(i16 %a, i16 %b) {
45     ; FUN:        test_i16:
46     ; SHT:        test_i16:
48     %tmp.1 = shl i16 %a, %b
49     ; FUN:        andi
50     ; FUN:        add
51     ; FUN:        bnei
52     ; SHT-NOT:    bnei
54     ret i16 %tmp.1
55     ; FUN:        rtsd
56     ; SHT:        rtsd
57     ; FUN-NOT:    bsll
58     ; SHT-NEXT:   bsll
61 define i16 @testc_i16(i16 %a, i16 %b) {
62     ; FUN:        testc_i16:
63     ; SHT:        testc_i16:
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
73     ret i16 %tmp.1
74     ; FUN:        rtsd
75     ; SHT:        rtsd
76     ; FUN-NOT:    bsll
77     ; SHT-NEXT:   bslli
80 define i32 @test_i32(i32 %a, i32 %b) {
81     ; FUN:        test_i32:
82     ; SHT:        test_i32:
84     %tmp.1 = shl i32 %a, %b
85     ; FUN:        andi
86     ; FUN:        add
87     ; FUN:        bnei
88     ; SHT-NOT:    andi
89     ; SHT-NOT:    bnei
91     ret i32 %tmp.1
92     ; FUN:        rtsd
93     ; SHT:        rtsd
94     ; FUN-NOT:    bsll
95     ; SHT-NEXT:   bsll
98 define i32 @testc_i32(i32 %a, i32 %b) {
99     ; FUN:        testc_i32:
100     ; SHT:        testc_i32:
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
110     ret i32 %tmp.1
111     ; FUN:        rtsd
112     ; SHT:        rtsd
113     ; FUN-NOT:    bsll
114     ; SHT-NEXT:   bslli