Skip to content

Conversation

@nielsdos
Copy link
Member

There's two problems:

  • Some loops used unsigned int instead of size_t.
  • The 2*N-bit addition that is emulated using 2 N bit numbers has a bug: it first truncated the number to 32/64 bit and only then shifted. This resulted in the wrong length info stored inside the resulting hash.

…trings >= 4GiB

There's two problems:
- Some loops used `unsigned int` instead of `size_t`.
- The 2*N-bit addition that is emulated using 2 N bit numbers has a bug:
  it first truncated the number to 32/64 bit and only then shifted. This
  resulted in the wrong length info stored inside the resulting hash.
@staabm
Copy link
Contributor

staabm commented Dec 12, 2023

would be great to have the repro from #12936 in this PR?

Comment on lines +283 to +292
unsigned int index, partLen;
size_t i;

/* Compute number of bytes mod 128 */
index = (unsigned int) ((context->count[0] >> 3) & 0x7F);
/* Update number of bits */
if ((context->count[0] += ((uint32_t) inputLen << 3)) < ((uint32_t) inputLen << 3)) {
context->count[1]++;
}
context->count[1] += ((uint32_t) inputLen >> 29);
context->count[1] += (uint32_t) (inputLen >> 29);
Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Does it make sense for master to change those to use uint_least64_t ? As those should always be defined even on 32 bit where there is not a fixed width 64 bit number.

Copy link
Member Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

For the counts right? Perhaps, although we have to be careful with endianness and the handling of the counts in the finalize step.

Copy link
Member

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Yes, but I didn't think about endianness

@nielsdos
Copy link
Member Author

would be great to have the repro from #12936 in this PR?

I asked Ilija about it and we concluded that it will be bad for CI stability.

@nielsdos nielsdos closed this in 2b8c008 Dec 12, 2023
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Projects

None yet

Development

Successfully merging this pull request may close these issues.

hash() function hangs endlessly if using sha512 on strings >= 4GiB

3 participants