Skip to content

Commit

Permalink
adjust live variables
Browse files Browse the repository at this point in the history
  • Loading branch information
lukaszcz authored and paulcadman committed Feb 20, 2024
1 parent a0072ab commit f4e6a65
Show file tree
Hide file tree
Showing 2 changed files with 20 additions and 3 deletions.
5 changes: 4 additions & 1 deletion src/Juvix/Compiler/Reg/Data/IndexMap.hs
Original file line number Diff line number Diff line change
Expand Up @@ -33,8 +33,11 @@ assign IndexMap {..} k =
}
)

lookup' :: (Hashable k) => IndexMap k -> k -> Maybe Index
lookup' IndexMap {..} k = HashMap.lookup k _indexMapTable

lookup :: (Hashable k) => IndexMap k -> k -> Index
lookup IndexMap {..} k = fromJust $ HashMap.lookup k _indexMapTable
lookup mp = fromJust . lookup' mp

combine :: forall k. (Hashable k) => IndexMap k -> IndexMap k -> IndexMap k
combine mp1 mp2 =
Expand Down
18 changes: 16 additions & 2 deletions src/Juvix/Compiler/Reg/Transformation/SSA.hs
Original file line number Diff line number Diff line change
Expand Up @@ -22,13 +22,20 @@ computeFunctionSSA =
where
go :: Instruction -> IndexMap VarRef -> (IndexMap VarRef, Instruction)
go instr mp = case getResultVar instr' of
Just vref -> (mp', setResultVar instr' (mkVarRef VarGroupLocal idx))
Just vref -> (mp', updateLiveVars mp' (setResultVar instr' (mkVarRef VarGroupLocal idx)))
where
(idx, mp') = IndexMap.assign mp vref
Nothing -> (mp, instr')
Nothing -> (mp, updateLiveVars mp instr')
where
instr' = overValueRefs (adjustVarRef mp) instr

updateLiveVars :: IndexMap VarRef -> Instruction -> Instruction
updateLiveVars mp = \case
Prealloc x -> Prealloc $ over instrPreallocLiveVars (mapMaybe (adjustVarRef' mp)) x
Call x -> Call $ over instrCallLiveVars (mapMaybe (adjustVarRef' mp)) x
CallClosures x -> CallClosures $ over instrCallClosuresLiveVars (mapMaybe (adjustVarRef' mp)) x
instr -> instr

-- For branches, when necessary we insert assignments unifying the renamed
-- output variables into a single output variable for both branches.
combine :: Instruction -> NonEmpty (IndexMap VarRef) -> (IndexMap VarRef, Instruction)
Expand Down Expand Up @@ -103,6 +110,13 @@ computeFunctionSSA =
VarGroupArgs -> vref
VarGroupLocal -> mkVarRef VarGroupLocal (IndexMap.lookup mpv vref)

adjustVarRef' :: IndexMap VarRef -> VarRef -> Maybe VarRef
adjustVarRef' mpv vref = case IndexMap.lookup' mpv vref of
Just idx -> Just $ mkVarRef VarGroupLocal idx
Nothing -> case vref ^. varRefGroup of
VarGroupArgs -> Just vref
VarGroupLocal -> Nothing

assignInBranch :: Code -> Index -> Index -> Code
assignInBranch is idx idx' =
is
Expand Down

0 comments on commit f4e6a65

Please sign in to comment.