Teach X86ISelLowering that the second result of X86ISD::UMUL is a flags
authorChris Lattner <sabre@nondot.org>
Sun, 5 Dec 2010 07:49:54 +0000 (07:49 +0000)
committerChris Lattner <sabre@nondot.org>
Sun, 5 Dec 2010 07:49:54 +0000 (07:49 +0000)
commit9637d5b22ec655d9b2f6cdb5fb23b0ce0ec9c8a5
treed6a13f219ef8586ab4e90dc307244aeedf94f3e4
parentb20e0b1fddfd9099e12b84a71fbc8ccff5a12b10
Teach X86ISelLowering that the second result of X86ISD::UMUL is a flags
result.  This allows us to compile:

void *test12(long count) {
      return new int[count];
}

into:

test12:
movl $4, %ecx
movq %rdi, %rax
mulq %rcx
movq $-1, %rdi
cmovnoq %rax, %rdi
jmp __Znam                  ## TAILCALL

instead of:

test12:
movl $4, %ecx
movq %rdi, %rax
mulq %rcx
seto %cl
testb %cl, %cl
movq $-1, %rdi
cmoveq %rax, %rdi
jmp __Znam

Of course it would be even better if the regalloc inverted the cmov to 'cmovoq',
which would eliminate the need for the 'movq %rdi, %rax'.

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@120936 91177308-0d34-0410-b5e6-96231b3b80d8
lib/Target/X86/X86ISelLowering.cpp
test/CodeGen/X86/select.ll