mirror of
https://github.com/RPCS3/llvm.git
synced 2025-01-26 20:57:15 +00:00
a272803ec5
makes a mess of the lit output when they ultimately fail. The 2012-10-02-DAGCycle test is really frustrating because the *only* explanation for what it is testing is a rdar link. I would really rather that rdar links (which are not public or part of the open source project) were not committed to the source code. Regardless, the actual problem *must* be described as the rdar link is completely opaque. The fact that this test didn't check for any particular output further exacerbates the inability of any other developer to debug failures. The mem-promote-integers test has nice comments and *seems* to be a great test for our lowering... except that we don't actually check that any of the generated code is correct or matches some pattern. We just avoid crashing. It would be great to go back and populate this test with the actual expectations. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@214605 91177308-0d34-0410-b5e6-96231b3b80d8
53 lines
2.3 KiB
LLVM
53 lines
2.3 KiB
LLVM
; RUN: llc -mtriple=i386-apple-macosx -relocation-model=pic < %s > /dev/null
|
|
; RUN: llc -mtriple=x86_64-apple-macosx -relocation-model=pic < %s > /dev/null
|
|
|
|
; rdar://12393897
|
|
|
|
%TRp = type { i32, %TRH*, i32, i32 }
|
|
%TRH = type { i8*, i8*, i8*, i8*, {}* }
|
|
|
|
define i32 @t(%TRp* inreg %rp) nounwind optsize ssp {
|
|
entry:
|
|
%handler = getelementptr inbounds %TRp* %rp, i32 0, i32 1
|
|
%0 = load %TRH** %handler, align 4
|
|
%sync = getelementptr inbounds %TRH* %0, i32 0, i32 4
|
|
%sync12 = load {}** %sync, align 4
|
|
%1 = bitcast {}* %sync12 to i32 (%TRp*)*
|
|
%call = tail call i32 %1(%TRp* inreg %rp) nounwind optsize
|
|
ret i32 %call
|
|
}
|
|
|
|
%btConeShape = type { %btConvexInternalShape, float, float, float, [3 x i32] }
|
|
%btConvexInternalShape = type { %btConvexShape, %btVector, %btVector, float, float }
|
|
%btConvexShape = type { %btCollisionShape }
|
|
%btCollisionShape = type { i32 (...)**, i32, i8* }
|
|
%btVector = type { [4 x float] }
|
|
|
|
define { <2 x float>, <2 x float> } @t2(%btConeShape* %this) unnamed_addr uwtable ssp align 2 {
|
|
entry:
|
|
%0 = getelementptr inbounds %btConeShape* %this, i64 0, i32 0
|
|
br i1 undef, label %if.then, label %if.end17
|
|
|
|
if.then: ; preds = %entry
|
|
%vecnorm.sroa.2.8.copyload = load float* undef, align 4
|
|
%cmp4 = fcmp olt float undef, 0x3D10000000000000
|
|
%vecnorm.sroa.2.8.copyload36 = select i1 %cmp4, float -1.000000e+00, float %vecnorm.sroa.2.8.copyload
|
|
%call.i.i.i = tail call float @sqrtf(float 0.000000e+00) nounwind readnone
|
|
%div.i.i = fdiv float 1.000000e+00, %call.i.i.i
|
|
%mul7.i.i.i = fmul float %div.i.i, %vecnorm.sroa.2.8.copyload36
|
|
%1 = load float (%btConvexInternalShape*)** undef, align 8
|
|
%call12 = tail call float %1(%btConvexInternalShape* %0)
|
|
%mul7.i.i = fmul float %call12, %mul7.i.i.i
|
|
%retval.sroa.0.4.insert = insertelement <2 x float> zeroinitializer, float undef, i32 1
|
|
%add13.i = fadd float undef, %mul7.i.i
|
|
%retval.sroa.1.8.insert = insertelement <2 x float> undef, float %add13.i, i32 0
|
|
br label %if.end17
|
|
|
|
if.end17: ; preds = %if.then, %entry
|
|
%retval.sroa.1.8.load3338 = phi <2 x float> [ %retval.sroa.1.8.insert, %if.then ], [ undef, %entry ]
|
|
%retval.sroa.0.0.load3137 = phi <2 x float> [ %retval.sroa.0.4.insert, %if.then ], [ undef, %entry ]
|
|
ret { <2 x float>, <2 x float> } undef
|
|
}
|
|
|
|
declare float @sqrtf(float) nounwind readnone
|