mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-04-06 09:44:39 +00:00
Get the type of a shift from the shift, not from its shift
count operand. These should be the same but apparently are not always, and this is cleaner anyway. This improves the code in an existing test. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@122354 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
efc96dd38c
commit
5ecc340e34
@ -3178,7 +3178,7 @@ SDValue DAGCombiner::visitSRL(SDNode *N) {
|
||||
uint64_t c1 =
|
||||
cast<ConstantSDNode>(N0.getOperand(0)->getOperand(1))->getZExtValue();
|
||||
uint64_t c2 = N1C->getZExtValue();
|
||||
EVT InnerShiftVT = N0.getOperand(0)->getOperand(1).getValueType();
|
||||
EVT InnerShiftVT = N0.getOperand(0).getValueType();
|
||||
uint64_t InnerShiftSize = InnerShiftVT.getScalarType().getSizeInBits();
|
||||
// This is only valid if the OpSizeInBits + c1 = size of inner shift.
|
||||
if (c1 + OpSizeInBits == InnerShiftSize) {
|
||||
|
@ -29,9 +29,9 @@ entry:
|
||||
ret i8 %div
|
||||
|
||||
; CHECK: test3:
|
||||
; CHECK: imull $171, %eax, %eax
|
||||
; CHECK-NEXT: shrb %ah
|
||||
; CHECK-NEXT: movzbl %ah, %eax
|
||||
; CHECK: movzbl 8(%esp), %eax
|
||||
; CHECK-NEXT: imull $171, %eax, %eax
|
||||
; CHECK-NEXT: shrl $9, %eax
|
||||
; CHECK-NEXT: ret
|
||||
}
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user