[llvm] [LV, VP]VP intrinsics support for the Loop Vectorizer (PR #76172)
    Florian Hahn via llvm-commits 
    llvm-commits at lists.llvm.org
       
    Wed Jan 31 08:21:34 PST 2024
    
    
  
================
@@ -9479,14 +9583,31 @@ void VPWidenMemoryInstructionRecipe::execute(VPTransformState &State) {
     }
   }
 
+  auto MaskValue = [&](unsigned Part) -> Value * {
+    if (isMaskRequired)
+      return BlockInMaskParts[Part];
+    return nullptr;
+  };
+
   // Handle Stores:
   if (SI) {
     State.setDebugLocFrom(SI->getDebugLoc());
 
     for (unsigned Part = 0; Part < State.UF; ++Part) {
       Instruction *NewSI = nullptr;
       Value *StoredVal = State.get(StoredValue, Part);
-      if (CreateGatherScatter) {
+      if (State.EVL) {
+        Value *EVLPart = State.get(State.EVL, Part);
----------------
fhahn wrote:
Would be good to assert here that `Part == 0`, same for loads
https://github.com/llvm/llvm-project/pull/76172
    
    
More information about the llvm-commits
mailing list