[llvm] [SLP] NFC. Use InstructionsState::valid if users just want to know whether VL has same opcode. (PR #120217)

Han-Kuan Chen via llvm-commits llvm-commits at lists.llvm.org
Thu Dec 26 10:44:08 PST 2024


================
@@ -8144,9 +8147,8 @@ void BoUpSLP::buildTree_rec(ArrayRef<Value *> VL, unsigned Depth,
   }
 
   // Don't handle scalable vectors
-  if (S.getOpcode() == Instruction::ExtractElement &&
-      isa<ScalableVectorType>(
-          cast<ExtractElementInst>(S.getMainOp())->getVectorOperandType())) {
+  if (auto *EE = dyn_cast_if_present<ExtractElementInst>(S.getMainOp());
----------------
HanKuanChen wrote:

Currently some code use isa some code use getOpcode. I think we should either

- use isa, dyn_cast, isa_and_present and dyn_cast_if_present for getMainOp
- use getOpcode and check whether the opcode is what we want

to make the code consistency.
However, isa (and others) can check `isa_and_present<InsertElementInst, ExtractValueInst, ExtractElementInst>` with less code. Use `getOpcode` will write a lot of code in this case.

https://github.com/llvm/llvm-project/pull/120217


More information about the llvm-commits mailing list