Page MenuHomeFreeBSD

crypt_r(3): fix reentrancy problems with DES
ClosedPublic

Authored by trasz on Jun 7 2021, 2:55 PM.
Tags
None
Referenced Files
Unknown Object (File)
Nov 13 2024, 6:19 AM
Unknown Object (File)
Oct 22 2024, 8:30 AM
Unknown Object (File)
Oct 16 2024, 12:17 AM
Unknown Object (File)
Oct 13 2024, 5:32 PM
Unknown Object (File)
Oct 5 2024, 10:59 AM
Unknown Object (File)
Oct 5 2024, 6:33 AM
Unknown Object (File)
Oct 5 2024, 6:01 AM
Unknown Object (File)
Oct 2 2024, 4:15 PM
Subscribers

Details

Summary

This code was originally written for non-reentrant crypt(3).
In 5f521d7ba72, a thread-safe crypt_r(3) was introduced. However,
it looks like the DES implementation is still not re-entrant;
routines like setup_salt() or des_setkey() still use global
variables.

Instead of something drastic, eg removing DES support altogether,
just mark those variables as thread-local.

Given that this only applies to DES, I think the impact is minimal.

Sponsored by: NetApp, Inc.
Sponsored by: Klara, Inc.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Not Applicable
Unit
Tests Not Applicable

Event Timeline

trasz requested review of this revision.Jun 7 2021, 2:55 PM
markj added inline comments.
secure/lib/libcrypt/crypt-des.c
77

It looks like this and some of the other tables below should be marked const. Can we do that as a part of this change?

83–84

Doesn't this need to be thread-local as well?

Add const, move 'static' first, and add __thread for stuff touched
by des_init().

trasz marked 2 inline comments as done.Jun 8 2021, 1:31 PM
trasz added inline comments.
secure/lib/libcrypt/crypt-des.c
77

Good idea, done.

83–84

These only seem to be written to by des_init(), so they should be equal for all threads, but... yeah, you're right.

I don't see any problems with the change, but note that this adds something like 30KB of data per thread. Probably not the end of the world but not ideal either.

This revision is now accepted and ready to land.Jun 8 2021, 1:59 PM

Yeah; I think it's acceptable, given it's a separate library and not libc.

(Tinderboxed.)

This revision was automatically updated to reflect the committed changes.