Pierre Vittet <pier...@pvittet.com> writes:

> The bug appears when:
>       1) We use libiberty compiled with -O0
>       2) We first call md5_process_bytes with a less than 64 bits buffer (we
> call his size len1).
>       3) We make a new call of md5_process_bytes with a buffer which has a
> size len2 such as:
>       len2 > 127 + 65 (so test in line 228 of md5.C will be true)
>       128 -len1 != Mulint with Mulint %  __alignof__ (md5_uint32) != 0 (so
> condition on line 238 is true)
>       len2 - (128 - len1) = Mul64 and Mul64 such as Mul %64=0 (so the loop of
> line 239 is broken with len = 64, this leads to the bug as, line 249,
> (len & ~63) = 64 and we shift the buffer without processing the data).

The line numbers you mention do not correspond to any version of
libiberty/md5.c that I can see.  Can you list the exact line for each
line number you mention, so that your explanation is easier to follow?
Thanks.

Ian

Reply via email to