xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/2009-03-12-CPAlignBug.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=i386-apple-darwin -mattr=+sse2 | not grep ".space"
2*9880d681SAndroid Build Coastguard Worker; rdar://6668548
3*9880d681SAndroid Build Coastguard Worker
4*9880d681SAndroid Build Coastguard Workerdeclare double @llvm.sqrt.f64(double) nounwind readonly
5*9880d681SAndroid Build Coastguard Worker
6*9880d681SAndroid Build Coastguard Workerdeclare double @fabs(double)
7*9880d681SAndroid Build Coastguard Worker
8*9880d681SAndroid Build Coastguard Workerdeclare double @llvm.pow.f64(double, double) nounwind readonly
9*9880d681SAndroid Build Coastguard Worker
10*9880d681SAndroid Build Coastguard Workerdefine void @SolveCubic_bb1(i32* %solutions, double* %x, x86_fp80 %.reload, x86_fp80 %.reload5, x86_fp80 %.reload6, double %.reload8) nounwind {
11*9880d681SAndroid Build Coastguard WorkernewFuncRoot:
12*9880d681SAndroid Build Coastguard Worker	br label %bb1
13*9880d681SAndroid Build Coastguard Worker
14*9880d681SAndroid Build Coastguard Workerbb1.ret.exitStub:		; preds = %bb1
15*9880d681SAndroid Build Coastguard Worker	ret void
16*9880d681SAndroid Build Coastguard Worker
17*9880d681SAndroid Build Coastguard Workerbb1:		; preds = %newFuncRoot
18*9880d681SAndroid Build Coastguard Worker	store i32 1, i32* %solutions, align 4
19*9880d681SAndroid Build Coastguard Worker	%0 = tail call double @llvm.sqrt.f64(double %.reload8)		; <double> [#uses=1]
20*9880d681SAndroid Build Coastguard Worker	%1 = fptrunc x86_fp80 %.reload6 to double		; <double> [#uses=1]
21*9880d681SAndroid Build Coastguard Worker	%2 = tail call double @fabs(double %1) nounwind readnone		; <double> [#uses=1]
22*9880d681SAndroid Build Coastguard Worker	%3 = fadd double %0, %2		; <double> [#uses=1]
23*9880d681SAndroid Build Coastguard Worker	%4 = tail call double @llvm.pow.f64(double %3, double 0x3FD5555555555555)		; <double> [#uses=1]
24*9880d681SAndroid Build Coastguard Worker	%5 = fpext double %4 to x86_fp80		; <x86_fp80> [#uses=2]
25*9880d681SAndroid Build Coastguard Worker	%6 = fdiv x86_fp80 %.reload5, %5		; <x86_fp80> [#uses=1]
26*9880d681SAndroid Build Coastguard Worker	%7 = fadd x86_fp80 %5, %6		; <x86_fp80> [#uses=1]
27*9880d681SAndroid Build Coastguard Worker	%8 = fptrunc x86_fp80 %7 to double		; <double> [#uses=1]
28*9880d681SAndroid Build Coastguard Worker	%9 = fcmp olt x86_fp80 %.reload6, 0xK00000000000000000000		; <i1> [#uses=1]
29*9880d681SAndroid Build Coastguard Worker	%iftmp.6.0 = select i1 %9, double 1.000000e+00, double -1.000000e+00		; <double> [#uses=1]
30*9880d681SAndroid Build Coastguard Worker	%10 = fmul double %8, %iftmp.6.0		; <double> [#uses=1]
31*9880d681SAndroid Build Coastguard Worker	%11 = fpext double %10 to x86_fp80		; <x86_fp80> [#uses=1]
32*9880d681SAndroid Build Coastguard Worker	%12 = fdiv x86_fp80 %.reload, 0xKC000C000000000000000		; <x86_fp80> [#uses=1]
33*9880d681SAndroid Build Coastguard Worker	%13 = fadd x86_fp80 %11, %12		; <x86_fp80> [#uses=1]
34*9880d681SAndroid Build Coastguard Worker	%14 = fptrunc x86_fp80 %13 to double		; <double> [#uses=1]
35*9880d681SAndroid Build Coastguard Worker	store double %14, double* %x, align 1
36*9880d681SAndroid Build Coastguard Worker	br label %bb1.ret.exitStub
37*9880d681SAndroid Build Coastguard Worker}
38