diff options
Diffstat (limited to 'lib/compiler/src')
| -rw-r--r-- | lib/compiler/src/beam_clean.erl | 2 | ||||
| -rw-r--r-- | lib/compiler/src/v3_codegen.erl | 5 | 
2 files changed, 4 insertions, 3 deletions
| diff --git a/lib/compiler/src/beam_clean.erl b/lib/compiler/src/beam_clean.erl index 7ddf9fa2e2..955c128699 100644 --- a/lib/compiler/src/beam_clean.erl +++ b/lib/compiler/src/beam_clean.erl @@ -254,7 +254,7 @@ bs_restores([_|Is], Dict) ->  bs_restores([], Dict) -> Dict.  %% Pass 2. -bs_replace([{test,bs_start_match2,F,Live,[Src,Ctx],CtxR}|T], Dict, Acc) when is_atom(Ctx) -> +bs_replace([{test,bs_start_match2,F,Live,[Src,{context,Ctx}],CtxR}|T], Dict, Acc) ->      Slots = case gb_trees:lookup(Ctx, Dict) of  		{value,Slots0} -> Slots0;  		none -> 0 diff --git a/lib/compiler/src/v3_codegen.erl b/lib/compiler/src/v3_codegen.erl index a8f4926e55..8808c0a3b7 100644 --- a/lib/compiler/src/v3_codegen.erl +++ b/lib/compiler/src/v3_codegen.erl @@ -1162,7 +1162,7 @@ select_binary(#k_val_clause{val=#k_binary{segs=#k_var{name=V}},body=B,      {Bis0,Aft,St1} = match_cg(B, Vf, Int0, St0#cg{ctx=V}),      CtxReg = fetch_var(V, Int0),      Live = max_reg(Bef#sr.reg), -    Bis1 = [{test,bs_start_match2,{f,Tf},Live,[CtxReg,V],CtxReg}, +    Bis1 = [{test,bs_start_match2,{f,Tf},Live,[CtxReg,{context,V}],CtxReg},  	    {bs_save2,CtxReg,{V,V}}|Bis0],      Bis = finish_select_binary(Bis1),      {Bis,Aft,St1#cg{ctx=OldCtx}}; @@ -1174,7 +1174,8 @@ select_binary(#k_val_clause{val=#k_binary{segs=#k_var{name=Ivar}},body=B,      {Bis0,Aft,St1} = match_cg(B, Vf, Int0, St0#cg{ctx=Ivar}),      CtxReg = fetch_var(Ivar, Int0),      Live = max_reg(Bef#sr.reg), -    Bis1 = [{test,bs_start_match2,{f,Tf},Live,[fetch_var(V, Bef),Ivar],CtxReg}, +    Bis1 = [{test,bs_start_match2,{f,Tf},Live, +             [fetch_var(V, Bef),{context,Ivar}],CtxReg},  	    {bs_save2,CtxReg,{Ivar,Ivar}}|Bis0],      Bis = finish_select_binary(Bis1),      {Bis,Aft,St1#cg{ctx=OldCtx}}. | 
