[erlang-questions] Problem with pattern matching in large binaries

Kostis Sagonas kostis@REDACTED
Tue May 6 16:59:01 CEST 2008


Sverker Eriksson wrote:
> 
> Per Gustafsson wrote:
>> I took a look at this and it seems that in the BYTE_OFFSET macro on line 
>>   153 in erl_bits.h there is a cast to unsigned that really should be to 
>> Uint that probably causes this problem, but I do not have a good machine 
>> for testing this change. (Our amd64 does not have enough memory to build 
>> a 1 Gb binary)
> 
> I will take a look at this with my Intel Quad, 64bit, 4 Gb.
> 
> If Per is right, a fix will be released to R12B-3.

I have not seen Per's mail on the mailing list (just the above reply), 
but I can confirm that by modifying the macro on line 153 as Per 
suggested, some things work as expected regarding big binary 
construction on a 64 bit machine.  For example, without the fix, I get:

1> B = <<1:(2 bsl 32)>>.
<<>>

which is clearly bogus, while with the fix:

1> B = <<1:(2 bsl 32)>>.
<<0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,
   0,...>>

which seems much more likely to be the correct result.  Indeed:

2> byte_size(B).
1073741824
3> 2 bsl 32.
8589934592


For those eager to try it: the fix is trivial and can be applied by 
interested parties by hand, instead of waiting till the official release 
of R12B-3.


Kostis




More information about the erlang-questions mailing list