mirror of
https://github.com/RPCS3/llvm.git
synced 2024-12-14 07:31:53 +00:00
[DAGCombiner] Don't combine aext(setcc) if the setcc is already using the target's preferred result type.
With AVX512 vXi1 types are legal so we shouldn't be extending them. This change is similar to existing code in the zext(setcc) combine. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@319120 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
b7bbf042a3
commit
a8862041d4
@ -7945,13 +7945,16 @@ SDValue DAGCombiner::visitANY_EXTEND(SDNode *N) {
|
||||
// aext(setcc) -> aext(vsetcc)
|
||||
// Only do this before legalize for now.
|
||||
if (VT.isVector() && !LegalOperations) {
|
||||
EVT N0VT = N0.getOperand(0).getValueType();
|
||||
// We know that the # elements of the results is the same as the
|
||||
// # elements of the compare (and the # elements of the compare result
|
||||
// for that matter). Check to see that they are the same size. If so,
|
||||
// we know that the element size of the sext'd result matches the
|
||||
// element size of the compare operands.
|
||||
if (VT.getSizeInBits() == N0VT.getSizeInBits())
|
||||
EVT N00VT = N0.getOperand(0).getValueType();
|
||||
if (getSetCCResultType(N00VT) == N0.getValueType())
|
||||
return SDValue();
|
||||
|
||||
// We know that the # elements of the results is the same as the
|
||||
// # elements of the compare (and the # elements of the compare result
|
||||
// for that matter). Check to see that they are the same size. If so,
|
||||
// we know that the element size of the sext'd result matches the
|
||||
// element size of the compare operands.
|
||||
if (VT.getSizeInBits() == N00VT.getSizeInBits())
|
||||
return DAG.getSetCC(SDLoc(N), VT, N0.getOperand(0),
|
||||
N0.getOperand(1),
|
||||
cast<CondCodeSDNode>(N0.getOperand(2))->get());
|
||||
@ -7959,7 +7962,7 @@ SDValue DAGCombiner::visitANY_EXTEND(SDNode *N) {
|
||||
// elements we can use a matching integer vector type and then
|
||||
// truncate/any extend
|
||||
else {
|
||||
EVT MatchingVectorType = N0VT.changeVectorElementTypeToInteger();
|
||||
EVT MatchingVectorType = N00VT.changeVectorElementTypeToInteger();
|
||||
SDValue VsetCC =
|
||||
DAG.getSetCC(SDLoc(N), MatchingVectorType, N0.getOperand(0),
|
||||
N0.getOperand(1),
|
||||
|
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user