diff options
Diffstat (limited to 'lib')
| -rw-r--r-- | lib/hipe/rtl/hipe_rtl_binary_construct.erl | 9 | ||||
| -rw-r--r-- | lib/hipe/test/bs_SUITE_data/bs_construct.erl | 16 | 
2 files changed, 22 insertions, 3 deletions
| diff --git a/lib/hipe/rtl/hipe_rtl_binary_construct.erl b/lib/hipe/rtl/hipe_rtl_binary_construct.erl index 40bd22aa8e..692bad7d96 100644 --- a/lib/hipe/rtl/hipe_rtl_binary_construct.erl +++ b/lib/hipe/rtl/hipe_rtl_binary_construct.erl @@ -2,7 +2,7 @@  %%  %% %CopyrightBegin%  %%  -%% Copyright Ericsson AB 2007-2009. All Rights Reserved. +%% Copyright Ericsson AB 2007-2015. All Rights Reserved.  %%   %% Licensed under the Apache License, Version 2.0 (the "License");  %% you may not use this file except in compliance with the License. @@ -1192,7 +1192,10 @@ copy_little_word(Base, Offset, NewOffset, Word) ->     hipe_rtl:mk_store(Base, TmpOffset, Word, byte),     hipe_rtl:mk_alu(NewOffset, Offset, 'add', hipe_rtl:mk_imm(32))]. -copy_offset_int_big(Base, Offset, NewOffset, Size, Tmp1) when is_integer(Size) -> +copy_offset_int_big(_Base, Offset, NewOffset, 0, _Tmp1) -> +  [hipe_rtl:mk_move(NewOffset, Offset)]; +copy_offset_int_big(Base, Offset, NewOffset, Size, Tmp1) +  when is_integer(Size), Size > 0 ->    Tmp2 = hipe_rtl:mk_new_reg(),    Tmp3 = hipe_rtl:mk_new_reg(),    Tmp4 = hipe_rtl:mk_new_reg(), @@ -1203,7 +1206,7 @@ copy_offset_int_big(Base, Offset, NewOffset, Size, Tmp1) when is_integer(Size) -    Tmp9 = hipe_rtl:mk_new_reg(),    OldByte = hipe_rtl:mk_new_reg(),    TmpOffset = hipe_rtl:mk_new_reg(), -  BranchLbl =  hipe_rtl:mk_new_label(), +  BranchLbl = hipe_rtl:mk_new_label(),    BodyLbl = hipe_rtl:mk_new_label(),    EndLbl = hipe_rtl:mk_new_label(),    NextLbl = hipe_rtl:mk_new_label(), diff --git a/lib/hipe/test/bs_SUITE_data/bs_construct.erl b/lib/hipe/test/bs_SUITE_data/bs_construct.erl index 9cc9ac848c..37a54c1981 100644 --- a/lib/hipe/test/bs_SUITE_data/bs_construct.erl +++ b/lib/hipe/test/bs_SUITE_data/bs_construct.erl @@ -13,6 +13,7 @@ test() ->    ok = bs5(),    16#10000008 = bit_size(large_bin(1, 2, 3, 4)),    ok = bad_ones(), +  ok = zero_width(),    ok.  %%-------------------------------------------------------------------- @@ -126,3 +127,18 @@ bad_ones() ->    Bin123 = <<1,2,3>>,    ?FAIL(<<Bin123/float>>),    ok. + +%%-------------------------------------------------------------------- +%% Taken from the emulator bs_construct_SUITE - seg faulted till 18.1 + +zero_width() -> +  Z = id(0), +  Small = id(42), +  Big = id(1 bsl 128),  % puts stuff on the heap +  <<>> = <<Small:Z>>, +  <<>> = <<Small:0>>, +  <<>> = <<Big:Z>>, +  <<>> = <<Big:0>>, +  ok. + +id(X) -> X. | 
