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.
- regSpill :: Instruction instr => [LiveCmmTop statics instr] -> UniqSet Int -> UniqSet VirtualReg -> UniqSM ([LiveCmmTop statics instr], UniqSet Int, SpillStats)
- data SpillStats = SpillStats {
- spillStoreLoad :: UniqFM (Reg, Int, Int)
- accSpillSL :: (Num t2, Num t3) => (t1, t2, t3) -> (t, t2, t3) -> (t1, t2, t3)
Documentation
:: Instruction instr | |
=> [LiveCmmTop statics instr] | the code |
-> UniqSet Int | available stack slots |
-> UniqSet VirtualReg | the regs to spill |
-> UniqSM ([LiveCmmTop statics instr], UniqSet Int, SpillStats) |
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 nessesarally 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.
accSpillSL :: (Num t2, Num t3) => (t1, t2, t3) -> (t, t2, t3) -> (t1, t2, t3)Source