On Fri, Jun 27, 2025 at 10:34:15AM -0700, Josh Poimboeuf wrote:
> On Fri, Jun 27, 2025 at 12:53:28PM +0200, Peter Zijlstra wrote:
> > On Thu, Jun 26, 2025 at 04:55:29PM -0700, Josh Poimboeuf wrote:
> > > An upcoming patch will add the SHF_MERGE flag to x86 __jump_table and
> > > __bug_table so their entry sizes can be defined in inline asm.
> > > 
> > > However, those sections have SHF_WRITE, which the Clang linker (lld)
> > > explicitly forbids combining with SHF_MERGE.
> > > 
> > > Those sections are modified at runtime and must remain writable.  While
> > > SHF_WRITE is ignored by vmlinux, it's still needed for modules.
> > > 
> > > To work around the linker interference, remove SHF_WRITE during
> > > compilation and restore it after linking the module.
> > 
> > This is vile... but I'm not sure I have a better solution.
> > 
> > Eventually we should get the toolchains fixed, but we can't very well
> > mandate clang-21+ to build x86 just yet.
> 
> Yeah, I really hate this too.  I really tried to find something better,
> including mucking with the linker script, but this was unfortunately the
> only thing that worked.
> 
> Though, looking at it again, I realize we can localize the pain to Clang
> (and the makefile) by leaving the code untouched and instead strip
> SHF_WRITE before the link and re-add it afterwards.  Then we can tie
> this horrible hack to specific Clang versions when it gets fixed.

Oh yeah, that might be nicer indeed!

Reply via email to