forked from OSchip/llvm-project
[SystemZ] Bugfix in storeLoadCanUseBlockBinary().
Check that the MemoryVT of LoadA matches that of LoadB. This fixes https://bugs.llvm.org/show_bug.cgi?id=46239. Review: Ulrich Weigand Differential Revision: https://reviews.llvm.org/D81671
This commit is contained in:
parent
8580af3f7d
commit
d3f7448e3c
|
@ -1456,7 +1456,8 @@ bool SystemZDAGToDAGISel::storeLoadCanUseBlockBinary(SDNode *N,
|
||||||
auto *StoreA = cast<StoreSDNode>(N);
|
auto *StoreA = cast<StoreSDNode>(N);
|
||||||
auto *LoadA = cast<LoadSDNode>(StoreA->getValue().getOperand(1 - I));
|
auto *LoadA = cast<LoadSDNode>(StoreA->getValue().getOperand(1 - I));
|
||||||
auto *LoadB = cast<LoadSDNode>(StoreA->getValue().getOperand(I));
|
auto *LoadB = cast<LoadSDNode>(StoreA->getValue().getOperand(I));
|
||||||
return !LoadA->isVolatile() && canUseBlockOperation(StoreA, LoadB);
|
return !LoadA->isVolatile() && LoadA->getMemoryVT() == LoadB->getMemoryVT() &&
|
||||||
|
canUseBlockOperation(StoreA, LoadB);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SystemZDAGToDAGISel::Select(SDNode *Node) {
|
void SystemZDAGToDAGISel::Select(SDNode *Node) {
|
||||||
|
|
|
@ -371,6 +371,21 @@ define void @f26(i64 *%ptr1, i64 *%ptr2) {
|
||||||
ret void
|
ret void
|
||||||
}
|
}
|
||||||
|
|
||||||
|
; Test a case where one of the loads are optimized by the DAGCombiner to a
|
||||||
|
; zero-extending load of half the original size.
|
||||||
|
define void @f27(i16* noalias %ptr1, i16* noalias %ptr2) {
|
||||||
|
; CHECK-LABEL: f27:
|
||||||
|
; CHECK-NOT: nc
|
||||||
|
; CHECK: br %r14
|
||||||
|
entry:
|
||||||
|
%0 = load i16, i16 *%ptr1, align 2
|
||||||
|
%1 = lshr i16 %0, 8
|
||||||
|
%2 = load i16, i16 *%ptr2, align 2
|
||||||
|
%and7 = and i16 %1, %2
|
||||||
|
store i16 %and7, i16 *%ptr1, align 2
|
||||||
|
ret void
|
||||||
|
}
|
||||||
|
|
||||||
!0 = !{ !"root" }
|
!0 = !{ !"root" }
|
||||||
!1 = !{ !"set1", !0 }
|
!1 = !{ !"set1", !0 }
|
||||||
!2 = !{ !"set2", !0 }
|
!2 = !{ !"set2", !0 }
|
||||||
|
|
Loading…
Reference in New Issue