| Safe Haskell | None |
|---|---|
| Language | Haskell2010 |
RegAlloc.Graph.Spill
Description
When there aren't enough registers to hold all the vregs we have to spill some of those vregs to slots on the stack. This module is used modify the code to use those slots.
Synopsis
- regSpill :: Instruction instr => Platform -> [LiveCmmDecl statics instr] -> UniqSet Int -> UniqSet VirtualReg -> UniqSM ([LiveCmmDecl statics instr], UniqSet Int, SpillStats)
- data SpillStats = SpillStats {
- spillStoreLoad :: UniqFM (Reg, Int, Int)
- accSpillSL :: (Reg, Int, Int) -> (Reg, Int, Int) -> (Reg, Int, Int)
Documentation
Spill all these virtual regs to stack slots.
TODO: See if we can split some of the live ranges instead of just globally spilling the virtual reg. This might make the spill cleaner's job easier.
TODO: On CISCy x86 and x86_64 we don't necessarily have to add a mov instruction when making spills. If an instr is using a spilled virtual we may be able to address the spill slot directly.
data SpillStats Source #
Spiller statistics. Tells us what registers were spilled.
Instances
Instance details
Defined in RegAlloc.Graph.Spill