1
; RUN: llc < %s -march=thumb -mattr=+thumb2 | FileCheck %s
5
define i1 @f1(i32 %a) {
7
%tmp1 = icmp ne i32 %tmp, 0
11
; CHECK: tst.w r0, #187
14
define i1 @f2(i32 %a) {
15
%tmp = and i32 %a, 187
16
%tmp1 = icmp eq i32 0, %tmp
20
; CHECK: tst.w r0, #187
22
; 0x00aa00aa = 11141290
23
define i1 @f3(i32 %a) {
24
%tmp = and i32 %a, 11141290
25
%tmp1 = icmp eq i32 %tmp, 0
29
; CHECK: tst.w r0, #11141290
31
; 0x00aa00aa = 11141290
32
define i1 @f4(i32 %a) {
33
%tmp = and i32 %a, 11141290
34
%tmp1 = icmp ne i32 0, %tmp
38
; CHECK: tst.w r0, #11141290
40
; 0xcc00cc00 = 3422604288
41
define i1 @f5(i32 %a) {
42
%tmp = and i32 %a, 3422604288
43
%tmp1 = icmp ne i32 %tmp, 0
47
; CHECK: tst.w r0, #-872363008
49
; 0xcc00cc00 = 3422604288
50
define i1 @f6(i32 %a) {
51
%tmp = and i32 %a, 3422604288
52
%tmp1 = icmp eq i32 0, %tmp
56
; CHECK: tst.w r0, #-872363008
58
; 0xdddddddd = 3722304989
59
define i1 @f7(i32 %a) {
60
%tmp = and i32 %a, 3722304989
61
%tmp1 = icmp eq i32 %tmp, 0
65
; CHECK: tst.w r0, #-572662307
67
; 0xdddddddd = 3722304989
68
define i1 @f8(i32 %a) {
69
%tmp = and i32 %a, 3722304989
70
%tmp1 = icmp ne i32 0, %tmp
74
; CHECK: tst.w r0, #-572662307
76
; 0x00110000 = 1114112
77
define i1 @f9(i32 %a) {
78
%tmp = and i32 %a, 1114112
79
%tmp1 = icmp ne i32 %tmp, 0
83
; CHECK: tst.w r0, #1114112
85
; 0x00110000 = 1114112
86
define i1 @f10(i32 %a) {
87
%tmp = and i32 %a, 1114112
88
%tmp1 = icmp eq i32 0, %tmp
92
; CHECK: tst.w r0, #1114112