Page MenuHomeFreeBSD

csu: Find the main pointer through the GOT
ClosedPublic

Authored by andrew on May 20 2024, 11:59 AM.
Tags
None
Referenced Files
Unknown Object (File)
Mon, Jun 22, 7:41 PM
Unknown Object (File)
Fri, Jun 5, 1:46 PM
Unknown Object (File)
May 22 2026, 5:04 AM
Unknown Object (File)
May 17 2026, 11:39 AM
Unknown Object (File)
May 17 2026, 11:39 AM
Unknown Object (File)
May 17 2026, 7:05 AM
Unknown Object (File)
May 16 2026, 9:48 PM
Unknown Object (File)
May 14 2026, 12:45 PM
Subscribers
None

Details

Summary

Use the Global Offset Table to find the location of main in crt1. With
lld the old code would point to main@plt, however ld.bfd fails to link
when main is in a shared library.

Fix this by using the GOT address to find main as it works with both
lld and bfd.

Sponsored by: Arm Ltd

Diff Detail

Repository
rG FreeBSD src repository
Lint
Lint Skipped
Unit
Tests Skipped
Build Status
Buildable 57773
Build 54661: arc lint + arc unit

Event Timeline

It surprises me that GNU ld doesn't want to create canonical PLTs, but avoiding them is reasonable; they are to functions what copy relocations are to data.

Putting main in a shared library sounds particularly cursed, but I guess it's not uncommon for testing frameworks. Presumably this is for libgtest_main.

This revision is now accepted and ready to land.May 20 2024, 5:32 PM

It was for something in the Google testing bits.

This revision was automatically updated to reflect the committed changes.