forked from OSchip/llvm-project
[SLP] use reduction kind's opcode to create new instructions; NFC
Similar to 5a1d31a28
-
This should be no-functional-change because the reduction kind
opcodes are 1-for-1 mappings to the instructions we are matching
as reductions. But we want to remove the need for the
`OperationData` opcode field because that does not work when
we start matching intrinsics (eg, maxnum) as reduction candidates.
This commit is contained in:
parent
5d24089a70
commit
4c022b5a41
|
@ -6457,6 +6457,7 @@ class HorizontalReduction {
|
||||||
Value *createOp(IRBuilder<> &Builder, Value *LHS, Value *RHS,
|
Value *createOp(IRBuilder<> &Builder, Value *LHS, Value *RHS,
|
||||||
const Twine &Name) const {
|
const Twine &Name) const {
|
||||||
assert(isVectorizable() && "Unhandled reduction operation.");
|
assert(isVectorizable() && "Unhandled reduction operation.");
|
||||||
|
unsigned RdxOpcode = RecurrenceDescriptor::getOpcode(Kind);
|
||||||
switch (Kind) {
|
switch (Kind) {
|
||||||
case RecurKind::Add:
|
case RecurKind::Add:
|
||||||
case RecurKind::Mul:
|
case RecurKind::Mul:
|
||||||
|
@ -6465,26 +6466,22 @@ class HorizontalReduction {
|
||||||
case RecurKind::Xor:
|
case RecurKind::Xor:
|
||||||
case RecurKind::FAdd:
|
case RecurKind::FAdd:
|
||||||
case RecurKind::FMul:
|
case RecurKind::FMul:
|
||||||
return Builder.CreateBinOp((Instruction::BinaryOps)Opcode, LHS, RHS,
|
return Builder.CreateBinOp((Instruction::BinaryOps)RdxOpcode, LHS, RHS,
|
||||||
Name);
|
Name);
|
||||||
|
|
||||||
case RecurKind::SMax: {
|
case RecurKind::SMax: {
|
||||||
assert(Opcode == Instruction::ICmp && "Expected integer types.");
|
|
||||||
Value *Cmp = Builder.CreateICmpSGT(LHS, RHS, Name);
|
Value *Cmp = Builder.CreateICmpSGT(LHS, RHS, Name);
|
||||||
return Builder.CreateSelect(Cmp, LHS, RHS, Name);
|
return Builder.CreateSelect(Cmp, LHS, RHS, Name);
|
||||||
}
|
}
|
||||||
case RecurKind::SMin: {
|
case RecurKind::SMin: {
|
||||||
assert(Opcode == Instruction::ICmp && "Expected integer types.");
|
|
||||||
Value *Cmp = Builder.CreateICmpSLT(LHS, RHS, Name);
|
Value *Cmp = Builder.CreateICmpSLT(LHS, RHS, Name);
|
||||||
return Builder.CreateSelect(Cmp, LHS, RHS, Name);
|
return Builder.CreateSelect(Cmp, LHS, RHS, Name);
|
||||||
}
|
}
|
||||||
case RecurKind::UMax: {
|
case RecurKind::UMax: {
|
||||||
assert(Opcode == Instruction::ICmp && "Expected integer types.");
|
|
||||||
Value *Cmp = Builder.CreateICmpUGT(LHS, RHS, Name);
|
Value *Cmp = Builder.CreateICmpUGT(LHS, RHS, Name);
|
||||||
return Builder.CreateSelect(Cmp, LHS, RHS, Name);
|
return Builder.CreateSelect(Cmp, LHS, RHS, Name);
|
||||||
}
|
}
|
||||||
case RecurKind::UMin: {
|
case RecurKind::UMin: {
|
||||||
assert(Opcode == Instruction::ICmp && "Expected integer types.");
|
|
||||||
Value *Cmp = Builder.CreateICmpULT(LHS, RHS, Name);
|
Value *Cmp = Builder.CreateICmpULT(LHS, RHS, Name);
|
||||||
return Builder.CreateSelect(Cmp, LHS, RHS, Name);
|
return Builder.CreateSelect(Cmp, LHS, RHS, Name);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue