diff options
Diffstat (limited to 'lib/compiler/test')
| -rw-r--r-- | lib/compiler/test/beam_block_SUITE.erl | 26 | ||||
| -rw-r--r-- | lib/compiler/test/bs_match_SUITE.erl | 26 | 
2 files changed, 49 insertions, 3 deletions
| diff --git a/lib/compiler/test/beam_block_SUITE.erl b/lib/compiler/test/beam_block_SUITE.erl index 9fcb6e497d..55d5f2dbe8 100644 --- a/lib/compiler/test/beam_block_SUITE.erl +++ b/lib/compiler/test/beam_block_SUITE.erl @@ -22,7 +22,7 @@  -export([all/0,suite/0,groups/0,init_per_suite/1,end_per_suite/1,  	 init_per_group/2,end_per_group/2,  	 get_map_elements/1,otp_7345/1,move_opt_across_gc_bif/1, -	 erl_202/1]). +	 erl_202/1,repro/1]).  %% The only test for the following functions is that  %% the code compiles and is accepted by beam_validator. @@ -39,7 +39,8 @@ groups() ->        [get_map_elements,         otp_7345,         move_opt_across_gc_bif, -       erl_202 +       erl_202, +       repro        ]}].  init_per_suite(Config) -> @@ -158,6 +159,27 @@ erl_202({{_, _},X}, _) ->  erl_202({_, _}, #erl_202_r1{y=R2}) ->      {R2#erl_202_r2.x}. +%% See https://bugs.erlang.org/browse/ERL-266. +%% Instructions with failure labels are not safe to include +%% in a block. Including get_map_elements in a block would +%% lead to unsafe code. + +repro(_Config) -> +    [] = maps:to_list(repro([], #{}, #{})), +    [{tmp1,n}] = maps:to_list(repro([{tmp1,0}], #{}, #{})), +    [{tmp1,name}] = maps:to_list(repro([{tmp1,0}], #{}, #{0=>name})), +    ok. + +repro([], TempNames, _Slots) -> +    TempNames; +repro([{Temp, Slot}|Xs], TempNames, Slots0) -> +    {Name, Slots} = +	case Slots0 of +	    #{Slot := Name0} -> {Name0, Slots0}; +	    #{} ->              {n,     Slots0#{Slot => n}} +	end, +    repro(Xs, TempNames#{Temp => Name}, Slots). +  %%%  %%% The only test of the following code is that it compiles.  %%% diff --git a/lib/compiler/test/bs_match_SUITE.erl b/lib/compiler/test/bs_match_SUITE.erl index 224abf6c29..a9bee888d9 100644 --- a/lib/compiler/test/bs_match_SUITE.erl +++ b/lib/compiler/test/bs_match_SUITE.erl @@ -38,7 +38,8 @@  	 no_partition/1,calling_a_binary/1,binary_in_map/1,  	 match_string_opt/1,select_on_integer/1,  	 map_and_binary/1,unsafe_branch_caching/1, -	 bad_literals/1,good_literals/1,constant_propagation/1]). +	 bad_literals/1,good_literals/1,constant_propagation/1 +	]).  -export([coverage_id/1,coverage_external_ignore/2]). @@ -768,6 +769,11 @@ multiple_uses(Config) when is_list(Config) ->      {344,62879,345,<<245,159,1,89>>} = multiple_uses_1(<<1,88,245,159,1,89>>),      true = multiple_uses_2(<<0,0,197,18>>),      <<42,43>> = multiple_uses_3(<<0,0,42,43>>, fun id/1), + +    ok = first_after(<<>>, 42), +    <<1>> = first_after(<<1,2,3>>, 0), +    <<2>> = first_after(<<1,2,3>>, 1), +      ok.  multiple_uses_1(<<X:16,Tail/binary>>) -> @@ -789,6 +795,24 @@ multiple_uses_match(<<Y:16,Z:16>>) ->  multiple_uses_cmp(<<Y:16>>, <<Y:16>>) -> true;  multiple_uses_cmp(<<_:16>>, <<_:16>>) -> false. +first_after(Data, Offset) -> +    case byte_size(Data) > Offset of +	false -> +	    {First, Rest} = {ok, ok}, +	    ok; +	true -> +	    <<_:Offset/binary, Rest/binary>> = Data, +	    %% 'Rest' saved in y(0) before the call. +            {First, _} = match_first(Data, Rest), +            %% When beam_bsm sees the code, the following line +            %% which uses y(0) has been optimized away. +	    {First, Rest} = {First, Rest}, +	    First +    end. + +match_first(_, <<First:1/binary, Rest/binary>>) -> +    {First, Rest}. +  zero_label(Config) when is_list(Config) ->      <<"nosemouth">> = read_pols(<<"FACE","nose","mouth">>),      <<"CE">> = read_pols(<<"noFACE">>), | 
