summaryrefslogtreecommitdiff
path: root/compiler/GHC/CmmToAsm
diff options
context:
space:
mode:
authorBen Gamari <ben@smart-cactus.org>2021-01-07 22:53:55 -0500
committerMarge Bot <ben+marge-bot@smart-cactus.org>2021-03-17 19:07:47 -0400
commit42049339cd7adfc5b7220ad49cca21efedf6a2ca (patch)
tree1573acba31ff30ee2e983f508f94965c67fa3d20 /compiler/GHC/CmmToAsm
parent4fbc855849967402474763cb8afba92716c48e41 (diff)
downloadhaskell-42049339cd7adfc5b7220ad49cca21efedf6a2ca.tar.gz
CmmToAsm.Reg.Linear: Make linearRA body a join point
Avoid top-level recursion.
Diffstat (limited to 'compiler/GHC/CmmToAsm')
-rw-r--r--compiler/GHC/CmmToAsm/Reg/Linear.hs36
1 files changed, 17 insertions, 19 deletions
diff --git a/compiler/GHC/CmmToAsm/Reg/Linear.hs b/compiler/GHC/CmmToAsm/Reg/Linear.hs
index 586c1fbaf3..fc35db1874 100644
--- a/compiler/GHC/CmmToAsm/Reg/Linear.hs
+++ b/compiler/GHC/CmmToAsm/Reg/Linear.hs
@@ -348,7 +348,7 @@ processBlock block_live (BasicBlock id instrs)
initBlock id block_live
(instrs', fixups)
- <- linearRA block_live [] [] id instrs
+ <- linearRA block_live id instrs
-- pprTraceM "blockResult" $ ppr (instrs', fixups)
return $ BasicBlock id instrs' : fixups
@@ -385,30 +385,28 @@ initBlock id block_live
-- | Do allocation for a sequence of instructions.
linearRA
- :: OutputableRegConstraint freeRegs instr
+ :: forall freeRegs instr. (OutputableRegConstraint freeRegs instr)
=> BlockMap RegSet -- ^ map of what vregs are live on entry to each block.
- -> [instr] -- ^ accumulator for instructions already processed.
- -> [NatBasicBlock instr] -- ^ accumulator for blocks of fixup code.
-> BlockId -- ^ id of the current block, for debugging.
-> [LiveInstr instr] -- ^ liveness annotated instructions in this block.
-
-> RegM freeRegs
( [instr] -- instructions after register allocation
, [NatBasicBlock instr]) -- fresh blocks of fixup code.
-
-
-linearRA _ accInstr accFixup _ []
- = return
- ( reverse accInstr -- instrs need to be returned in the correct order.
- , accFixup) -- it doesn't matter what order the fixup blocks are returned in.
-
-
-linearRA block_live accInstr accFixups id (instr:instrs)
- = do
- (accInstr', new_fixups) <- raInsn block_live accInstr id instr
-
- linearRA block_live accInstr' (new_fixups ++ accFixups) id instrs
-
+linearRA block_live block_id = go [] []
+ where
+ go :: [instr] -- ^ accumulator for instructions already processed.
+ -> [NatBasicBlock instr] -- ^ accumulator for blocks of fixup code.
+ -> [LiveInstr instr] -- ^ liveness annotated instructions in this block.
+ -> RegM freeRegs
+ ( [instr] -- instructions after register allocation
+ , [NatBasicBlock instr] ) -- fresh blocks of fixup code.
+ go !accInstr !accFixups [] = do
+ return ( reverse accInstr -- instrs need to be returned in the correct order.
+ , accFixups ) -- it doesn't matter what order the fixup blocks are returned in.
+
+ go accInstr accFixups (instr:instrs) = do
+ (accInstr', new_fixups) <- raInsn block_live accInstr block_id instr
+ go accInstr' (new_fixups ++ accFixups) instrs
-- | Do allocation for a single instruction.
raInsn