add a high-priority SSE issue from sgefa

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@25787 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
Chris Lattner 2006-01-29 09:14:47 +00:00
parent b638cd89db
commit 6a28456e18

View File

@ -213,4 +213,38 @@ commutative, it is not matched with the load on both sides. The dag combiner
should be made smart enough to cannonicalize the load into the RHS of a compare
when it can invert the result of the compare for free.
//===---------------------------------------------------------------------===//
The code generated for 'abs' is truly aweful:
float %foo(float %tmp.38) {
%tmp.39 = setgt float %tmp.38, 0.000000e+00
%tmp.45 = sub float -0.000000e+00, %tmp.38
%mem_tmp.0.0 = select bool %tmp.39, float %tmp.38, float %tmp.45
ret float %mem_tmp.0.0
}
_foo:
subl $4, %esp
movss LCPI1_0, %xmm0
movss 8(%esp), %xmm1
subss %xmm1, %xmm0
xorps %xmm2, %xmm2
ucomiss %xmm2, %xmm1
setp %al
seta %cl
orb %cl, %al
testb %al, %al
jne LBB_foo_2 #
LBB_foo_1: #
movss %xmm0, %xmm1
LBB_foo_2: #
movss %xmm1, (%esp)
flds (%esp)
addl $4, %esp
ret
This should be a high-priority to fix. With the fp-stack, this is a single
instruction. With SSE it could be far better than this. Why is the sequence
above using 'setp'? It shouldn't care about nan's.