Page MenuHomeFreeBSD

[PowerPC64] Fix broken kernel modules due to LLD 9+ TOC optimization
ClosedPublic

Authored by alfredo on Nov 11 2019, 6:00 PM.
Tags
None
Referenced Files
Unknown Object (File)
Tue, Jan 7, 2:07 PM
Unknown Object (File)
Tue, Jan 7, 2:07 PM
Unknown Object (File)
Tue, Jan 7, 2:07 PM
Unknown Object (File)
Tue, Jan 7, 2:07 PM
Unknown Object (File)
Tue, Jan 7, 10:45 AM
Unknown Object (File)
Dec 12 2024, 1:18 AM
Unknown Object (File)
Dec 4 2024, 2:45 PM
Unknown Object (File)
Dec 3 2024, 3:47 PM
Subscribers

Details

Summary

LLD9 introduced a TOC optimization that isn't compatible with kernel dynamic linker causing panic when loading kernel modules (pf, linuxkpi and so)

This patch disables TOC optimization when building kernel modules

Test Plan

Tested kldload on powerpc64 (QEMU)

Diff Detail

Lint
Lint Passed
Unit
No Test Coverage
Build Status
Buildable 27452
Build 25690: arc lint + arc unit

Event Timeline

removed compiler check to address gcc+lld possible use case

sys/conf/kmod.mk
172

Can't this just be:

LDFLAGS.lld+= --no-toc-optimize

?

alfredo added inline comments.
sys/conf/kmod.mk
172

I tried it in the past and it didn't work. Anyway I just double checked it and this mechanism still not working, unfortunately.

In fact, there's only one place using it (and probably isn't working too)

# grep -R "LDFLAGS.lld" /usr/src/*
stand/i386/Makefile.inc:LDFLAGS.lld+=	-Wl,--no-rosegment

Thanks for testing the alternative.

This revision is now accepted and ready to land.Nov 14 2019, 2:49 PM