xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/full-lsr.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=x86 -mcpu=generic | FileCheck %s
2*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -march=x86 -mcpu=atom | FileCheck -check-prefix=ATOM %s
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Workerdefine void @foo(float* nocapture %A, float* nocapture %B, float* nocapture %C, i32 %N) nounwind {
5*9880d681SAndroid Build Coastguard Worker; ATOM: foo
6*9880d681SAndroid Build Coastguard Worker; ATOM: addl
7*9880d681SAndroid Build Coastguard Worker; ATOM: addl
8*9880d681SAndroid Build Coastguard Worker; ATOM: leal
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Worker; CHECK: foo
11*9880d681SAndroid Build Coastguard Worker; CHECK: addl
12*9880d681SAndroid Build Coastguard Worker; CHECK: addl
13*9880d681SAndroid Build Coastguard Worker; CHECK: addl
14*9880d681SAndroid Build Coastguard Worker
15*9880d681SAndroid Build Coastguard Workerentry:
16*9880d681SAndroid Build Coastguard Worker	%0 = icmp sgt i32 %N, 0		; <i1> [#uses=1]
17*9880d681SAndroid Build Coastguard Worker	br i1 %0, label %bb, label %return
18*9880d681SAndroid Build Coastguard Worker
19*9880d681SAndroid Build Coastguard Workerbb:		; preds = %bb, %entry
20*9880d681SAndroid Build Coastguard Worker	%i.03 = phi i32 [ 0, %entry ], [ %indvar.next, %bb ]		; <i32> [#uses=5]
21*9880d681SAndroid Build Coastguard Worker	%1 = getelementptr float, float* %A, i32 %i.03		; <float*> [#uses=1]
22*9880d681SAndroid Build Coastguard Worker	%2 = load float, float* %1, align 4		; <float> [#uses=1]
23*9880d681SAndroid Build Coastguard Worker	%3 = getelementptr float, float* %B, i32 %i.03		; <float*> [#uses=1]
24*9880d681SAndroid Build Coastguard Worker	%4 = load float, float* %3, align 4		; <float> [#uses=1]
25*9880d681SAndroid Build Coastguard Worker	%5 = fadd float %2, %4		; <float> [#uses=1]
26*9880d681SAndroid Build Coastguard Worker	%6 = getelementptr float, float* %C, i32 %i.03		; <float*> [#uses=1]
27*9880d681SAndroid Build Coastguard Worker	store float %5, float* %6, align 4
28*9880d681SAndroid Build Coastguard Worker	%7 = add i32 %i.03, 10		; <i32> [#uses=3]
29*9880d681SAndroid Build Coastguard Worker	%8 = getelementptr float, float* %A, i32 %7		; <float*> [#uses=1]
30*9880d681SAndroid Build Coastguard Worker	%9 = load float, float* %8, align 4		; <float> [#uses=1]
31*9880d681SAndroid Build Coastguard Worker	%10 = getelementptr float, float* %B, i32 %7		; <float*> [#uses=1]
32*9880d681SAndroid Build Coastguard Worker	%11 = load float, float* %10, align 4		; <float> [#uses=1]
33*9880d681SAndroid Build Coastguard Worker	%12 = fadd float %9, %11		; <float> [#uses=1]
34*9880d681SAndroid Build Coastguard Worker	%13 = getelementptr float, float* %C, i32 %7		; <float*> [#uses=1]
35*9880d681SAndroid Build Coastguard Worker	store float %12, float* %13, align 4
36*9880d681SAndroid Build Coastguard Worker	%indvar.next = add i32 %i.03, 1		; <i32> [#uses=2]
37*9880d681SAndroid Build Coastguard Worker	%exitcond = icmp eq i32 %indvar.next, %N		; <i1> [#uses=1]
38*9880d681SAndroid Build Coastguard Worker	br i1 %exitcond, label %return, label %bb
39*9880d681SAndroid Build Coastguard Worker
40*9880d681SAndroid Build Coastguard Workerreturn:		; preds = %bb, %entry
41*9880d681SAndroid Build Coastguard Worker	ret void
42*9880d681SAndroid Build Coastguard Worker}
43