Page MenuHomeFreeBSD

lib/libcrypt: unbundle hash functions
ClosedPublic

Authored by fuz on Oct 11 2024, 3:50 PM.
Tags
None
Referenced Files
Unknown Object (File)
Fri, Dec 27, 12:31 PM
Unknown Object (File)
Nov 25 2024, 2:42 PM
Unknown Object (File)
Nov 15 2024, 6:40 AM
Unknown Object (File)
Nov 14 2024, 2:27 PM
Unknown Object (File)
Nov 13 2024, 11:00 AM
Unknown Object (File)
Nov 12 2024, 12:26 PM
Unknown Object (File)
Nov 10 2024, 3:49 AM
Unknown Object (File)
Nov 8 2024, 4:58 AM
Subscribers

Details

Summary

libcrypt bundles the various hash functions it needs,
duplicating code that is also found in libmd.
Unbundle the hash functions and apply the same hack used
for libncursesw so static consumers link -lmd in addition
to -lcrypt.

Test Plan

builds fine, passes test suite.

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 59942
Build 56827: arc lint + arc unit

Event Timeline

fuz requested review of this revision.Oct 11 2024, 3:50 PM

Add missing SUBDIR_DEPENDS for libcrypt, which now depends on libmd.

Doesn't seem to be doing the trick completely though?

Uploaded the wrong patch, should be fine now.

Correctly register the build dependency of libcrypt on libmd.
Thanks to @bapt for how to do this. Not sure why there are
apparently three or more places in which library dependencies
are registered.

Add a dependency to the realinstall target of libcrypt.
Apparently that is needed for the ldscript shim to be installed.

LGTM, assuming it didn't break something linking against libcrypt... the double underscore aliasing stuff seems a little suspicious.

In D47062#1073317, @fuz wrote:

Correctly register the build dependency of libcrypt on libmd.
Thanks to @bapt for how to do this. Not sure why there are
apparently three or more places in which library dependencies
are registered.

SUBDIR_DEPEND are used for tree walks, but can't be used in the earlier phases of buildworld as we have to more surgically construct the world objdir to avoid using/linking against things from the host system accidentally. It'd be nice if we could generate at least some of the Makefile.inc1 glue from lib/Makefile, but we simply don't today.

lib/libcrypt/Makefile
32 ↗(On Diff #144815)

Oh dear

This revision is now accepted and ready to land.Oct 23 2024, 2:09 PM
This revision was automatically updated to reflect the committed changes.