HomeFreeBSD

[PowerPC] More relocation fixes

Description

[PowerPC] More relocation fixes

It turns out relocating the symbol table itself can cause issues, like fbt
crashing because it applies the offsets to the kernel twice.

This had been previously brought up in rS333447 when the stoffs hack was
added, but I had been unaware of this and reimplemented symtab relocation.

Instead of relocating the symbol table, keep track of the relocation base
in ddb, so the ddb symbols behave like the kernel linker-provided symbols.

This is intended to be NFC on platforms other than PowerPC, which do not
use fully relocatable kernels. (The relbase will always be 0)

  • Remove the rest of the stoffs hack.
  • Remove my half-baked displace_symbol_table() function.
  • Extend ddb initialization to cope with having a relocation offset on the kernel symbol table.
  • Fix my kernel-as-initrd hack to work with booke64 by using a temporary mapping to access the data.
  • Fix another instance of powerpc that is actually RELOCATABLE_KERNEL.
  • Change the behavior or X_db_symbol_values to apply the relocation base when updating valp, to match link_elf_symbol_values() behavior.

Reviewed by: jhibbits
Sponsored by: Tag1 Consulting, Inc.
Differential Revision: https://reviews.freebsd.org/D25223

Details

Provenance
bdragonAuthored on
Reviewer
jhibbits
Differential Revision
D25223: [PowerPC] More relocation fixes
Parents
rS362457: Fix up a comment added by r362455.
Branches
Unknown
Tags
Unknown