Page MenuHomeFreeBSD

rtld: implement _dl_iterate_phdr_locked
ClosedPublic

Authored by kevans on Nov 13 2024, 10:24 PM.
Tags
None
Referenced Files
Unknown Object (File)
Dec 5 2024, 4:48 AM
Unknown Object (File)
Nov 22 2024, 4:43 AM
Unknown Object (File)
Nov 22 2024, 4:15 AM
Unknown Object (File)
Nov 22 2024, 3:57 AM
Unknown Object (File)
Nov 21 2024, 8:05 AM
Unknown Object (File)
Nov 21 2024, 3:08 AM
Unknown Object (File)
Nov 18 2024, 10:50 PM
Unknown Object (File)
Nov 18 2024, 10:48 PM
Subscribers

Details

Summary

Some sanitizers need to be able to use dl_iterate_phdr() after stopping
the rest of the process, but it's very hard to do so reliably as a
non-participant in the main logic of the program.

Introduce _dl_iterate_phdr_locked to bypass the locking that's normally
required for dl_iterate_phdr() and slap some scary warning on it. It
will remain undocumented and probably shouldn't be used for anything
else.

Diff Detail

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

Event Timeline

Now after a fresh look, I suggest to change the new function to be read-only. What I mean, is to remove hold/unhold_object and marker linkage. I believe this is 'better' in the sense that it would induce the UB memory accesses on the caller, but other threads would not see unlocked updates.

Re-implement r/o

Revert the previous implementation and just write a new short and sweet
implementation that iterates over the globallist and invokes the callback.

libexec/rtld-elf/rtld.c
4225

You still want to do rtld_fill_dl_phdr_info(&obj_rtld, &phdr_info); and then execute callback on rtld data.

kevans marked an inline comment as done.

Don't skip the rtld object itself, and use consistent sizeof() while here.

libexec/rtld-elf/rtld.c
4225

D'oh! Thanks

kib added inline comments.
libexec/rtld-elf/rtld.c
4216

I think the initialization is not needed.

This revision is now accepted and ready to land.Nov 14 2024, 12:41 AM
This revision was automatically updated to reflect the committed changes.