Thread-unsafe MD5 on big-endian systems with no OpenSSL

Started by Heikki Linnakangasover 1 year ago4 messageshackers
Jump to latest
#1Heikki Linnakangas
heikki.linnakangas@enterprisedb.com

While browsing through all our global variables for the multithreading
effort, I noticed that our MD5 implementation in src/common/md5.c uses a
static buffer on big-endian systems, which makes it not thread-safe.
That's a bug because that function is also used in libpq.

This was introduced in commit b67b57a966, which replaced the old MD5
fallback implementation with the one from pgcrypto. The thread-safety
didn't matter for pgcrypto, but for libpq it does.

This only affects big-endian systems that are compiled without OpenSSL.

--
Heikki Linnakangas
Neon (https://neon.tech)

Attachments:

0001-Make-fallback-MD5-implementation-thread-safe-on-big-.patchtext/x-patch; charset=UTF-8; name=0001-Make-fallback-MD5-implementation-thread-safe-on-big-.patchDownload+1-5
#2Robert Haas
robertmhaas@gmail.com
In reply to: Heikki Linnakangas (#1)
Re: Thread-unsafe MD5 on big-endian systems with no OpenSSL

On Tue, Aug 6, 2024 at 8:23 AM Heikki Linnakangas <hlinnaka@iki.fi> wrote:

While browsing through all our global variables for the multithreading
effort, I noticed that our MD5 implementation in src/common/md5.c uses a
static buffer on big-endian systems, which makes it not thread-safe.
That's a bug because that function is also used in libpq.

This was introduced in commit b67b57a966, which replaced the old MD5
fallback implementation with the one from pgcrypto. The thread-safety
didn't matter for pgcrypto, but for libpq it does.

This only affects big-endian systems that are compiled without OpenSSL.

LGTM.

--
Robert Haas
EDB: http://www.enterprisedb.com

#3Michael Paquier
michael@paquier.xyz
In reply to: Robert Haas (#2)
Re: Thread-unsafe MD5 on big-endian systems with no OpenSSL

On Aug 6, 2024, at 23:05, Robert Haas <robertmhaas@gmail.com> wrote:
On Tue, Aug 6, 2024 at 8:23 AM Heikki Linnakangas <hlinnaka@iki.fi> wrote:

This only affects big-endian systems that are compiled without OpenSSL.

LGTM.

Nice catch, looks fine to me as well.
--
Michael

#4Heikki Linnakangas
heikki.linnakangas@enterprisedb.com
In reply to: Michael Paquier (#3)
Re: Thread-unsafe MD5 on big-endian systems with no OpenSSL

On 06/08/2024 18:11, Michael Paquier wrote:

On Aug 6, 2024, at 23:05, Robert Haas <robertmhaas@gmail.com> wrote:
On Tue, Aug 6, 2024 at 8:23 AM Heikki Linnakangas <hlinnaka@iki.fi> wrote:

This only affects big-endian systems that are compiled without OpenSSL.

LGTM.

Nice catch, looks fine to me as well.

Committed, thanks

--
Heikki Linnakangas
Neon (https://neon.tech)