mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2025-01-02 00:51:56 +00:00
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'. llvm-svn: 120936
This commit is contained in:
parent
76601e7a99
commit
e30adfb732
@ -7207,6 +7207,9 @@ static bool isX86LogicalCmp(SDValue Op) {
|
||||
Opc == X86ISD::AND))
|
||||
return true;
|
||||
|
||||
if (Op.getResNo() == 2 && Opc == X86ISD::UMUL)
|
||||
return true;
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
|
@ -178,4 +178,26 @@ define i64 @test11a(i64 %x, i64 %y) nounwind readnone ssp noredzone {
|
||||
}
|
||||
|
||||
|
||||
declare noalias i8* @_Znam(i64) noredzone
|
||||
|
||||
define noalias i8* @test12(i64 %count) nounwind ssp noredzone {
|
||||
entry:
|
||||
%A = tail call { i64, i1 } @llvm.umul.with.overflow.i64(i64 %count, i64 4)
|
||||
%B = extractvalue { i64, i1 } %A, 1
|
||||
%C = extractvalue { i64, i1 } %A, 0
|
||||
%D = select i1 %B, i64 -1, i64 %C
|
||||
%call = tail call noalias i8* @_Znam(i64 %D) nounwind noredzone
|
||||
ret i8* %call
|
||||
; CHECK: test12:
|
||||
; CHECK: mulq
|
||||
; CHECK: movq $-1, %rdi
|
||||
; CHECK: cmovnoq %rax, %rdi
|
||||
; CHECK: jmp __Znam
|
||||
}
|
||||
|
||||
declare { i64, i1 } @llvm.umul.with.overflow.i64(i64, i64) nounwind readnone
|
||||
|
||||
|
||||
|
||||
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user