xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/machine-cse.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc -mtriple=x86_64-apple-macosx < %s | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker; rdar://7610418
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Worker%ptr = type { i8* }
5*9880d681SAndroid Build Coastguard Worker%struct.s1 = type { %ptr, %ptr }
6*9880d681SAndroid Build Coastguard Worker%struct.s2 = type { i32, i8*, i8*, [256 x %struct.s1*], [8 x i32], i64, i8*, i32, i64, i64, i32, %struct.s3*, %struct.s3*, [49 x i64] }
7*9880d681SAndroid Build Coastguard Worker%struct.s3 = type { %struct.s3*, %struct.s3*, i32, i32, i32 }
8*9880d681SAndroid Build Coastguard Worker
9*9880d681SAndroid Build Coastguard Workerdefine fastcc i8* @t(i32 %base) nounwind {
10*9880d681SAndroid Build Coastguard Workerentry:
11*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: t:
12*9880d681SAndroid Build Coastguard Worker; CHECK: leaq (%rax,%rax,4)
13*9880d681SAndroid Build Coastguard Worker  %0 = zext i32 %base to i64
14*9880d681SAndroid Build Coastguard Worker  %1 = getelementptr inbounds %struct.s2, %struct.s2* null, i64 %0
15*9880d681SAndroid Build Coastguard Worker  br i1 undef, label %bb1, label %bb2
16*9880d681SAndroid Build Coastguard Worker
17*9880d681SAndroid Build Coastguard Workerbb1:
18*9880d681SAndroid Build Coastguard Worker; CHECK: %bb1
19*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: shlq $9
20*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: leaq
21*9880d681SAndroid Build Coastguard Worker; CHECK: call
22*9880d681SAndroid Build Coastguard Worker  %2 = getelementptr inbounds %struct.s2, %struct.s2* null, i64 %0, i32 0
23*9880d681SAndroid Build Coastguard Worker  call void @bar(i32* %2) nounwind
24*9880d681SAndroid Build Coastguard Worker  unreachable
25*9880d681SAndroid Build Coastguard Worker
26*9880d681SAndroid Build Coastguard Workerbb2:
27*9880d681SAndroid Build Coastguard Worker; CHECK: %bb2
28*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: leaq
29*9880d681SAndroid Build Coastguard Worker; CHECK: callq
30*9880d681SAndroid Build Coastguard Worker  %3 = call fastcc i8* @foo(%struct.s2* %1) nounwind
31*9880d681SAndroid Build Coastguard Worker  unreachable
32*9880d681SAndroid Build Coastguard Worker
33*9880d681SAndroid Build Coastguard Workerbb3:
34*9880d681SAndroid Build Coastguard Worker  ret i8* undef
35*9880d681SAndroid Build Coastguard Worker}
36*9880d681SAndroid Build Coastguard Worker
37*9880d681SAndroid Build Coastguard Workerdeclare void @bar(i32*)
38*9880d681SAndroid Build Coastguard Worker
39*9880d681SAndroid Build Coastguard Workerdeclare fastcc i8* @foo(%struct.s2*) nounwind
40*9880d681SAndroid Build Coastguard Worker
41*9880d681SAndroid Build Coastguard Worker; rdar://8773371
42*9880d681SAndroid Build Coastguard Worker
43*9880d681SAndroid Build Coastguard Workerdeclare void @printf(...) nounwind
44*9880d681SAndroid Build Coastguard Worker
45*9880d681SAndroid Build Coastguard Workerdefine void @commute(i32 %test_case, i32 %scale) nounwind ssp {
46*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: commute:
47*9880d681SAndroid Build Coastguard Workerentry:
48*9880d681SAndroid Build Coastguard Worker  switch i32 %test_case, label %sw.bb307 [
49*9880d681SAndroid Build Coastguard Worker    i32 1, label %sw.bb
50*9880d681SAndroid Build Coastguard Worker    i32 2, label %sw.bb
51*9880d681SAndroid Build Coastguard Worker    i32 3, label %sw.bb
52*9880d681SAndroid Build Coastguard Worker  ]
53*9880d681SAndroid Build Coastguard Worker
54*9880d681SAndroid Build Coastguard Workersw.bb:                                            ; preds = %entry, %entry, %entry
55*9880d681SAndroid Build Coastguard Worker; CHECK: %sw.bb
56*9880d681SAndroid Build Coastguard Worker; CHECK: imull
57*9880d681SAndroid Build Coastguard Worker  %mul = mul nsw i32 %test_case, 3
58*9880d681SAndroid Build Coastguard Worker  %mul20 = mul nsw i32 %mul, %scale
59*9880d681SAndroid Build Coastguard Worker  br i1 undef, label %if.end34, label %sw.bb307
60*9880d681SAndroid Build Coastguard Worker
61*9880d681SAndroid Build Coastguard Workerif.end34:                                         ; preds = %sw.bb
62*9880d681SAndroid Build Coastguard Worker; CHECK: %if.end34
63*9880d681SAndroid Build Coastguard Worker; CHECK: leal
64*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: imull
65*9880d681SAndroid Build Coastguard Worker  tail call void (...) @printf(i32 %test_case, i32 %mul20) nounwind
66*9880d681SAndroid Build Coastguard Worker  %tmp = mul i32 %scale, %test_case
67*9880d681SAndroid Build Coastguard Worker  %tmp752 = mul i32 %tmp, 3
68*9880d681SAndroid Build Coastguard Worker  %tmp753 = zext i32 %tmp752 to i64
69*9880d681SAndroid Build Coastguard Worker  br label %bb.nph743.us
70*9880d681SAndroid Build Coastguard Worker
71*9880d681SAndroid Build Coastguard Workerfor.body53.us:                                    ; preds = %bb.nph743.us, %for.body53.us
72*9880d681SAndroid Build Coastguard Worker  %exitcond = icmp eq i64 undef, %tmp753
73*9880d681SAndroid Build Coastguard Worker  br i1 %exitcond, label %bb.nph743.us, label %for.body53.us
74*9880d681SAndroid Build Coastguard Worker
75*9880d681SAndroid Build Coastguard Workerbb.nph743.us:                                     ; preds = %for.body53.us, %if.end34
76*9880d681SAndroid Build Coastguard Worker  br label %for.body53.us
77*9880d681SAndroid Build Coastguard Worker
78*9880d681SAndroid Build Coastguard Workersw.bb307:                                         ; preds = %sw.bb, %entry
79*9880d681SAndroid Build Coastguard Worker  ret void
80*9880d681SAndroid Build Coastguard Worker}
81*9880d681SAndroid Build Coastguard Worker
82*9880d681SAndroid Build Coastguard Worker; CSE physical register defining instruction across MBB boundary.
83*9880d681SAndroid Build Coastguard Worker; rdar://10660865
84*9880d681SAndroid Build Coastguard Workerdefine i32 @cross_mbb_phys_cse(i32 %a, i32 %b) nounwind ssp {
85*9880d681SAndroid Build Coastguard Workerentry:
86*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: cross_mbb_phys_cse:
87*9880d681SAndroid Build Coastguard Worker; CHECK: cmpl
88*9880d681SAndroid Build Coastguard Worker; CHECK: ja
89*9880d681SAndroid Build Coastguard Worker  %cmp = icmp ugt i32 %a, %b
90*9880d681SAndroid Build Coastguard Worker  br i1 %cmp, label %return, label %if.end
91*9880d681SAndroid Build Coastguard Worker
92*9880d681SAndroid Build Coastguard Workerif.end:                                           ; preds = %entry
93*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: cmpl
94*9880d681SAndroid Build Coastguard Worker; CHECK: sbbl
95*9880d681SAndroid Build Coastguard Worker  %cmp1 = icmp ult i32 %a, %b
96*9880d681SAndroid Build Coastguard Worker  %. = sext i1 %cmp1 to i32
97*9880d681SAndroid Build Coastguard Worker  br label %return
98*9880d681SAndroid Build Coastguard Worker
99*9880d681SAndroid Build Coastguard Workerreturn:                                           ; preds = %if.end, %entry
100*9880d681SAndroid Build Coastguard Worker  %retval.0 = phi i32 [ 1, %entry ], [ %., %if.end ]
101*9880d681SAndroid Build Coastguard Worker  ret i32 %retval.0
102*9880d681SAndroid Build Coastguard Worker}
103*9880d681SAndroid Build Coastguard Worker
104*9880d681SAndroid Build Coastguard Worker; rdar://11393714
105*9880d681SAndroid Build Coastguard Workerdefine i8* @bsd_memchr(i8* %s, i32 %a, i32 %c, i64 %n) nounwind ssp {
106*9880d681SAndroid Build Coastguard Worker; CHECK: %entry
107*9880d681SAndroid Build Coastguard Worker; CHECK: xorl
108*9880d681SAndroid Build Coastguard Worker; CHECK: %preheader
109*9880d681SAndroid Build Coastguard Worker; CHECK: %do.body
110*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: xorl
111*9880d681SAndroid Build Coastguard Worker; CHECK: %do.cond
112*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: xorl
113*9880d681SAndroid Build Coastguard Worker; CHECK: %return
114*9880d681SAndroid Build Coastguard Workerentry:
115*9880d681SAndroid Build Coastguard Worker  %cmp = icmp eq i64 %n, 0
116*9880d681SAndroid Build Coastguard Worker  br i1 %cmp, label %return, label %preheader
117*9880d681SAndroid Build Coastguard Worker
118*9880d681SAndroid Build Coastguard Workerpreheader:
119*9880d681SAndroid Build Coastguard Worker  %conv2 = and i32 %c, 255
120*9880d681SAndroid Build Coastguard Worker  br label %do.body
121*9880d681SAndroid Build Coastguard Worker
122*9880d681SAndroid Build Coastguard Workerdo.body:
123*9880d681SAndroid Build Coastguard Worker  %n.addr.0 = phi i64 [ %dec, %do.cond ], [ %n, %preheader ]
124*9880d681SAndroid Build Coastguard Worker  %p.0 = phi i8* [ %incdec.ptr, %do.cond ], [ %s, %preheader ]
125*9880d681SAndroid Build Coastguard Worker  %cmp3 = icmp eq i32 %a, %conv2
126*9880d681SAndroid Build Coastguard Worker  br i1 %cmp3, label %return, label %do.cond
127*9880d681SAndroid Build Coastguard Worker
128*9880d681SAndroid Build Coastguard Workerdo.cond:
129*9880d681SAndroid Build Coastguard Worker  %incdec.ptr = getelementptr inbounds i8, i8* %p.0, i64 1
130*9880d681SAndroid Build Coastguard Worker  %dec = add i64 %n.addr.0, -1
131*9880d681SAndroid Build Coastguard Worker  %cmp6 = icmp eq i64 %dec, 0
132*9880d681SAndroid Build Coastguard Worker  br i1 %cmp6, label %return, label %do.body
133*9880d681SAndroid Build Coastguard Worker
134*9880d681SAndroid Build Coastguard Workerreturn:
135*9880d681SAndroid Build Coastguard Worker  %retval.0 = phi i8* [ null, %entry ], [ null, %do.cond ], [ %p.0, %do.body ]
136*9880d681SAndroid Build Coastguard Worker  ret i8* %retval.0
137*9880d681SAndroid Build Coastguard Worker}
138*9880d681SAndroid Build Coastguard Worker
139*9880d681SAndroid Build Coastguard Worker; PR13578
140*9880d681SAndroid Build Coastguard Worker@t2_global = external global i32
141*9880d681SAndroid Build Coastguard Worker
142*9880d681SAndroid Build Coastguard Workerdeclare i1 @t2_func()
143*9880d681SAndroid Build Coastguard Worker
144*9880d681SAndroid Build Coastguard Workerdefine i32 @t2() {
145*9880d681SAndroid Build Coastguard Worker  store i32 42, i32* @t2_global
146*9880d681SAndroid Build Coastguard Worker  %c = call i1 @t2_func()
147*9880d681SAndroid Build Coastguard Worker  br i1 %c, label %a, label %b
148*9880d681SAndroid Build Coastguard Worker
149*9880d681SAndroid Build Coastguard Workera:
150*9880d681SAndroid Build Coastguard Worker  %l = load i32, i32* @t2_global
151*9880d681SAndroid Build Coastguard Worker  ret i32 %l
152*9880d681SAndroid Build Coastguard Worker
153*9880d681SAndroid Build Coastguard Workerb:
154*9880d681SAndroid Build Coastguard Worker  ret i32 0
155*9880d681SAndroid Build Coastguard Worker
156*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: t2:
157*9880d681SAndroid Build Coastguard Worker; CHECK: t2_global@GOTPCREL(%rip)
158*9880d681SAndroid Build Coastguard Worker; CHECK-NOT: t2_global@GOTPCREL(%rip)
159*9880d681SAndroid Build Coastguard Worker}
160