summaryrefslogtreecommitdiffstats
path: root/llvm/utils/vim
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2010-08-28 17:59:08 +0000
committerChris Lattner <sabre@nondot.org>2010-08-28 17:59:08 +0000
commit94656b1c8c60994a8bcc6c9b03981a78f0bba3a7 (patch)
treee3bc5c3c8b9500f9af2d1cc290a4cc10d59e2003 /llvm/utils/vim
parentbcb6090ad0660f018a8365248d5467047f423e39 (diff)
downloadbcm5719-llvm-94656b1c8c60994a8bcc6c9b03981a78f0bba3a7.tar.gz
bcm5719-llvm-94656b1c8c60994a8bcc6c9b03981a78f0bba3a7.zip
fix the buildvector->insertp[sd] logic to not always create a redundant
insertp[sd] $0, which is a noop. Before: _f32: ## @f32 pshufd $1, %xmm1, %xmm2 pshufd $1, %xmm0, %xmm3 addss %xmm2, %xmm3 addss %xmm1, %xmm0 ## kill: XMM0<def> XMM0<kill> XMM0<def> insertps $0, %xmm0, %xmm0 insertps $16, %xmm3, %xmm0 ret after: _f32: ## @f32 movdqa %xmm0, %xmm2 addss %xmm1, %xmm2 pshufd $1, %xmm1, %xmm1 pshufd $1, %xmm0, %xmm3 addss %xmm1, %xmm3 movdqa %xmm2, %xmm0 insertps $16, %xmm3, %xmm0 ret The extra movs are due to a random (poor) scheduling decision. llvm-svn: 112379
Diffstat (limited to 'llvm/utils/vim')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud