xref: /aosp_15_r20/external/llvm/test/CodeGen/X86/2011-02-23-UnfoldBug.ll (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker; RUN: llc < %s -mtriple=x86_64-apple-darwin10
2*9880d681SAndroid Build Coastguard Worker; rdar://9045024
3*9880d681SAndroid Build Coastguard Worker; PR9305
4*9880d681SAndroid Build Coastguard Worker
5*9880d681SAndroid Build Coastguard Workerdefine void @calc_gb_rad_still_sse2_double() nounwind ssp {
6*9880d681SAndroid Build Coastguard Workerentry:
7*9880d681SAndroid Build Coastguard Worker  br label %for.cond.outer
8*9880d681SAndroid Build Coastguard Worker
9*9880d681SAndroid Build Coastguard Workerfor.cond.outer:                                   ; preds = %if.end71, %entry
10*9880d681SAndroid Build Coastguard Worker  %theta.0.ph = phi <2 x double> [ undef, %entry ], [ %theta.1, %if.end71 ]
11*9880d681SAndroid Build Coastguard Worker  %mul.i97 = fmul <2 x double> %theta.0.ph, undef
12*9880d681SAndroid Build Coastguard Worker  %mul.i96 = fmul <2 x double> %mul.i97, fmul (<2 x double> <double 2.000000e+00, double 2.000000e+00>, <2 x double> undef)
13*9880d681SAndroid Build Coastguard Worker  br i1 undef, label %for.body, label %for.end82
14*9880d681SAndroid Build Coastguard Worker
15*9880d681SAndroid Build Coastguard Workerfor.body:                                         ; preds = %for.cond.outer
16*9880d681SAndroid Build Coastguard Worker  br i1 undef, label %for.body33.lr.ph, label %for.end
17*9880d681SAndroid Build Coastguard Worker
18*9880d681SAndroid Build Coastguard Workerfor.body33.lr.ph:                                 ; preds = %for.body
19*9880d681SAndroid Build Coastguard Worker  %dccf.2 = select i1 undef, <2 x double> %mul.i96, <2 x double> undef
20*9880d681SAndroid Build Coastguard Worker  unreachable
21*9880d681SAndroid Build Coastguard Worker
22*9880d681SAndroid Build Coastguard Workerfor.end:                                          ; preds = %for.body
23*9880d681SAndroid Build Coastguard Worker  %vecins.i94 = insertelement <2 x double> undef, double 0.000000e+00, i32 0
24*9880d681SAndroid Build Coastguard Worker  %cmpsd.i = tail call <2 x double> @llvm.x86.sse2.cmp.sd(<2 x double> %vecins.i94, <2 x double> <double 0x3FE984B204153B34, double 0x3FE984B204153B34>, i8 2) nounwind
25*9880d681SAndroid Build Coastguard Worker  tail call void (...) @_mm_movemask_pd(<2 x double> %cmpsd.i) nounwind
26*9880d681SAndroid Build Coastguard Worker  br i1 undef, label %if.then67, label %if.end71
27*9880d681SAndroid Build Coastguard Worker
28*9880d681SAndroid Build Coastguard Workerif.then67:                                        ; preds = %for.end
29*9880d681SAndroid Build Coastguard Worker  %vecins.i91 = insertelement <2 x double> %vecins.i94, double undef, i32 0
30*9880d681SAndroid Build Coastguard Worker  br label %if.end71
31*9880d681SAndroid Build Coastguard Worker
32*9880d681SAndroid Build Coastguard Workerif.end71:                                         ; preds = %if.then67, %for.end
33*9880d681SAndroid Build Coastguard Worker  %theta.1 = phi <2 x double> [ %vecins.i91, %if.then67 ], [ %theta.0.ph, %for.end ]
34*9880d681SAndroid Build Coastguard Worker  br label %for.cond.outer
35*9880d681SAndroid Build Coastguard Worker
36*9880d681SAndroid Build Coastguard Workerfor.end82:                                        ; preds = %for.cond.outer
37*9880d681SAndroid Build Coastguard Worker  ret void
38*9880d681SAndroid Build Coastguard Worker}
39*9880d681SAndroid Build Coastguard Worker
40*9880d681SAndroid Build Coastguard Workerdeclare void @_mm_movemask_pd(...)
41*9880d681SAndroid Build Coastguard Worker
42*9880d681SAndroid Build Coastguard Workerdeclare <2 x double> @llvm.x86.sse2.cmp.sd(<2 x double>, <2 x double>, i8) nounwind readnone
43