Page MenuHomeFreeBSD

link_elf_obj: Process init_array and fini_array
ClosedPublic

Authored by markj on Mar 3 2021, 9:05 PM.
Tags
None
Referenced Files
Unknown Object (File)
Sun, Apr 20, 11:04 AM
Unknown Object (File)
Mar 29 2025, 9:41 PM
Unknown Object (File)
Mar 29 2025, 9:33 PM
Unknown Object (File)
Mar 29 2025, 9:10 PM
Unknown Object (File)
Mar 21 2025, 12:47 AM
Unknown Object (File)
Mar 17 2025, 11:10 PM
Unknown Object (File)
Feb 28 2025, 11:35 PM
Unknown Object (File)
Feb 24 2025, 9:04 AM
Subscribers

Details

Summary

Reuse the existing logic for .ctors/.dtors.

This is required for KASAN.

Diff Detail

Repository
rS FreeBSD src repository - subversion
Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 37550
Build 34439: arc lint + arc unit

Event Timeline

markj requested review of this revision.Mar 3 2021, 9:05 PM
markj added inline comments.
sys/kern/link_elf_obj.c
536

I am not sure why .dtors is not handled. I don't have a use for it but can implement it if it seems worthwhile.

In principle it could be that an object contains both .ctors and SHT_INIT_ARRAY sections. I suggest to warn, at least.

BTW, we rely on ld -r correctly merge all sections with the same name+attributes, but for many reasons this might not occur. So I think a warning is due if ctors_addr is non-NULL.

Print a warning if ctors_addr is already non-zero.

This revision is now accepted and ready to land.Mar 3 2021, 10:36 PM