[PATCH] D100574: [RISCV][WIP] Fix missing emergency slots for scalable stack offsets

Craig Topper via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Thu Apr 15 09:20:00 PDT 2021


craig.topper added inline comments.


================
Comment at: llvm/test/CodeGen/RISCV/rvv/emergency-slot.mir:92
+    renamable $x13 = nsw ADDI renamable $x16, -2
+    renamable $v0 = PseudoVRELOAD_M1 %stack.1 :: (load unknown-size from %stack.1, align 8)
+    renamable $v0 = PseudoVSLIDEDOWN_VX_M1 undef renamable $v0, killed renamable $v0, killed renamable $x13, $noreg, 8, implicit $vl, implicit $vtype
----------------
frasercrmck wrote:
> From what I can tell, we need to scavenge three registers to compute the stack offsets at this point. The scalable offsets certainly require two. After adding two extra slots, the code generated is:
> 
> ```
>     renamable $x13 = nsw ADDI renamable $x16, -2
>     $x5 = LUI 1
>     $x9 = ADDIW killed $x5, -1896
>     $x9 = ADD $x2, killed $x9
>     $x1 = PseudoReadVLENB
>     $x5 = ADDI $x0, 50
>     $x1 = MUL killed $x1, killed $x5
>     $x5 = LD $x2, 8 :: (load 8 from %stack.17)
>     $x9 = ADD killed $x9, killed $x1
>     $x1 = LD $x2, 16 :: (load 8 from %stack.16)
>     renamable $v0 = PseudoVRELOAD_M1 killed $x9 :: (load unknown-size from %stack.1, align 8)
> ```
> 
> I was wondering if I've missed something in my analysis. Perhaps @rogfer01, @StephenFan or @Hsiang-Kai know more?
> From what I can tell, we need to scavenge three registers to compute the stack offsets at this point. The scalable offsets certainly require two. After adding two extra slots, the code generated is:
> 
> ```
>     renamable $x13 = nsw ADDI renamable $x16, -2
>     $x5 = LUI 1
>     $x9 = ADDIW killed $x5, -1896
>     $x9 = ADD $x2, killed $x9
>     $x1 = PseudoReadVLENB
>     $x5 = ADDI $x0, 50
>     $x1 = MUL killed $x1, killed $x5
>     $x5 = LD $x2, 8 :: (load 8 from %stack.17)
>     $x9 = ADD killed $x9, killed $x1
>     $x1 = LD $x2, 16 :: (load 8 from %stack.16)
>     renamable $v0 = PseudoVRELOAD_M1 killed $x9 :: (load unknown-size from %stack.1, align 8)
> ```
> 
> I was wondering if I've missed something in my analysis. Perhaps @rogfer01, @StephenFan or @Hsiang-Kai know more?

I believe we found this same issue internally. @HsiangKai has patch in our downstream branch.


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D100574/new/

https://reviews.llvm.org/D100574



More information about the llvm-commits mailing list