aboutsummaryrefslogtreecommitdiffstats
path: root/lib/compiler/src/beam_reorder.erl
diff options
context:
space:
mode:
authorBjörn Gustavsson <[email protected]>2015-10-08 10:15:20 +0200
committerBjörn Gustavsson <[email protected]>2015-10-08 10:15:20 +0200
commit02e98b776ed9b37086997ee8703c773536ab6102 (patch)
tree99a8c494dcc17137c664aeb55d0704fde4921061 /lib/compiler/src/beam_reorder.erl
parentaed173c7fe32647d51d2eaeab6c639c8bd3978ee (diff)
parent76bb9f0e9a0b36ea7c9720c2bf90f6b52a4eabf8 (diff)
downloadotp-02e98b776ed9b37086997ee8703c773536ab6102.tar.gz
otp-02e98b776ed9b37086997ee8703c773536ab6102.tar.bz2
otp-02e98b776ed9b37086997ee8703c773536ab6102.zip
Merge branch 'bjorn/compiler/fix-crash'
* bjorn/compiler/fix-crash: beam_reorder: Eliminate compiler crash
Diffstat (limited to 'lib/compiler/src/beam_reorder.erl')
-rw-r--r--lib/compiler/src/beam_reorder.erl21
1 files changed, 13 insertions, 8 deletions
diff --git a/lib/compiler/src/beam_reorder.erl b/lib/compiler/src/beam_reorder.erl
index 70adca6b04..41586a7bf2 100644
--- a/lib/compiler/src/beam_reorder.erl
+++ b/lib/compiler/src/beam_reorder.erl
@@ -110,14 +110,19 @@ reorder_1([{test,_,{f,L},Ss}=I|Is0], D0,
end
end
end;
-reorder_1([{allocate_zero,N,Live}|Is], D,
- [{get_tuple_element,_,_,{x,X}}=G|Acc])
- when X+1 =:= Live ->
- %% Move allocation instruction upwards past get_tuple_element
- %% instructions to give more opportunities for moving
- %% get_tuple_element instructions.
- I = {allocate_zero,N,X},
- reorder_1([I,G|Is], D, Acc);
+reorder_1([{allocate_zero,N,Live}=I0|Is], D,
+ [{get_tuple_element,{x,Tup},_,{x,Dst}}=G|Acc]=Acc0) ->
+ case Tup < Dst andalso Dst+1 =:= Live of
+ true ->
+ %% Move allocation instruction upwards past
+ %% get_tuple_element instructions to create more
+ %% opportunities for moving get_tuple_element
+ %% instructions.
+ I = {allocate_zero,N,Dst},
+ reorder_1([I,G|Is], D, Acc);
+ false ->
+ reorder_1(Is, D, [I0|Acc0])
+ end;
reorder_1([I|Is], D, Acc) ->
reorder_1(Is, D, [I|Acc]);
reorder_1([], _, Acc) -> reverse(Acc).