aboutsummaryrefslogblamecommitdiffstats
path: root/lib/hipe/test/basic_SUITE_data/basic_issues_hipe.erl
blob: fc87abb54e6d55d748a935a930d6401e2bce2fa5 (plain) (tree)
1
2
3
4
5
6
7
8
9
10









                                                                       


                                                                      

         

                              
                       
                        

                                 
                         







                                                                      
                                                                      




                                                                      































                                                                      






















































































                                                                      









                                                                      
                                    



                                                                                  

                           




                                                         
%%% -*- erlang-indent-level: 2 -*-
%%%-------------------------------------------------------------------
%%% Author: Kostis Sagonas
%%%
%%% Contains code examples that exhibited crashes in the HiPE compiler.
%%%-------------------------------------------------------------------
-module(basic_issues_hipe).

-export([test/0]).

%% functions that need to be exported so that they are retained and/or
%% not specialized away by the compiler.
-export([auth/4, wxSizer_replace/2, parent_class/1]).

test() ->
  ok = test_dominance_trees(),
  ok = test_merged_const(),
  ok = test_var_pair(),
  ok = test_bif_fails(),
  ok = test_find_catches(),
  ok = test_heap_allocate_trim(),
  ok = wxSizer_replace(),
  ok.

%%--------------------------------------------------------------------
%% This is taken from a file sent to us by Martin Bjorklund @ Nortel
%% on 14th November 2004. The problem was in the SSA unconvert pass.
%%
%% No tests here; we simply check that the HiPE compiler does not go
%% into an infinite loop when compiling strange functions like this.
%%--------------------------------------------------------------------

auth(_, A, B, C) ->
  auth(A, B, C, []).

%%--------------------------------------------------------------------
%% Exposed a crash in the generation of dominance trees used in SSA.
%%--------------------------------------------------------------------

-record(state, {f}).

test_dominance_trees() ->
  {ok, true} = doit(true, #state{f = true}),
  ok.

doit(Foo, S) ->
  Fee = case Foo of
	  Bar when Bar == S#state.f; Bar == [] -> true;
	  _ -> false
	end,
  {ok, Fee}.

%%--------------------------------------------------------------------
%% Checks that the merging of constants in the constant table uses the
%% appropriate comparison function for this.
%%--------------------------------------------------------------------

test_merged_const() ->
  Const1 = {'', 1.0000},
  Const2 = {'', 1},
  match(Const1, Const2).

match(A, A) ->
  error;
match(_A, _B) ->
  ok.

%%--------------------------------------------------------------------
%% Checks that the HiPE compiler does not get confused by constant
%% data structures similar to the internal compiler data structures.
%%--------------------------------------------------------------------

test_var_pair() ->
  ok = var_pair([gazonk]).

var_pair([_|_]) ->
  var_pair({var, some_atom});
var_pair(_) ->
  ok.

%%--------------------------------------------------------------------
%% This module was causing the HiPE compiler to crash in January 2007.
%% The culprit was an "optimization" of the BEAM compiler: postponing
%% the save of x variables when BIFs cannot fail.  This was fixed on
%% February 1st, by making the HiPE compiler use the same functions
%% as the BEAM compiler for deciding whether a BIF fails.
%%--------------------------------------------------------------------

test_bif_fails() ->
  [42] = bif_fails_in_catch([42]),
  true = bif_fails_in_try([42]),
  ok.

bif_fails_in_catch(X) ->
  case catch get(gazonk) of
    _ -> X
  end.

bif_fails_in_try(X) ->
  try
    true = X =/= []
  catch
    _ -> nil(X)
  end.

nil(_) -> [].

%%--------------------------------------------------------------------
%% Test that resulted in a native code compiler crash in the code of
%% hipe_icode_exceptions:find_catches/1 when compiling find_catches/2.
%%--------------------------------------------------------------------

test_find_catches() ->
  42 = find_catches(a, false),
  ok.

find_catches(X, Y) ->
  case X of
    a when Y =:= true ->
      catch id(X),
      X;
    b when Y =:= true ->
      catch id(X),
      X;
    a ->
      catch id(X),
      42;
    b ->
      catch id(X),
      42
  end.

id(X) -> X.

%%--------------------------------------------------------------------
%% Date: Dec 28, 2007
%%
%% This is a test adapted from the file sent to the Erlang mailing
%% list by Eranga Udesh. The file did not compile because of problems
%% with the heap_allocate instruction and stack trimming.
%%--------------------------------------------------------------------

test_heap_allocate_trim() ->
  {abandon, 42} = get_next_retry(a, 42),
  ok.

get_next_retry(Error, Count) ->
  case catch pair(retry_scheme, {Error, Count}) of
    _ ->
      case pair(Error, Count) of
        _ -> {abandon, Count}
      end
  end.

pair(A, B) -> {A, B}.

%%--------------------------------------------------------------------
%% Date: June 11, 2018
%%
%% Stripped down test case (from `wxSizer') that crashed the lazy code
%% motion pass of the HiPE compiler in a pre-release of Erlang/OTP 21.
%% A similar crash existed in `ssl_correction'.
%%--------------------------------------------------------------------

wxSizer_replace() ->
  wxSizer_replace(?MODULE, ?MODULE).

-define(CLASS(Type, Class), ((Type) =:= Class) orelse (Type):parent_class(Class)).

wxSizer_replace(OldwinT, NewwinT) -> % this function was the culprit
  ?CLASS(OldwinT, ?MODULE),
  ?CLASS(NewwinT, ?MODULE),
  ok.

parent_class(wxWindow) -> true;
parent_class(wxEvtHandler) -> true;
parent_class(_Class) -> erlang:error({badtype, ?MODULE}).