Page MenuHomeFreeBSD

powerpc: add R_PPC_ADDR32 handler for kldxref
ClosedPublic

Authored by alfredo on Jan 4 2022, 8:42 PM.
Referenced Files
Unknown Object (File)
Mon, Apr 6, 11:47 AM
Unknown Object (File)
Sun, Apr 5, 11:48 AM
Unknown Object (File)
Sat, Apr 4, 4:15 PM
Unknown Object (File)
Sat, Apr 4, 5:56 AM
Unknown Object (File)
Fri, Mar 27, 6:09 AM
Unknown Object (File)
Thu, Mar 26, 1:27 PM
Unknown Object (File)
Wed, Mar 25, 6:44 PM
Unknown Object (File)
Mon, Mar 23, 1:14 AM
Subscribers

Details

Summary

Implements R_PPC_ADDR32 handler for kldxref, addressing "kldxref: unhandled relocation type 1" when running "kldxref /boot/kernel" on powerpc 32 bits.
Apparently this relocation appeared after in-tree LLVM compiler upgrade between versions LLVM11 and 13.

In this change added a "where32" variable with type Elf32_Addr when destination is word32 on both 32 or 64 bits and guarded PPC64-only relocation with an ifdef. Comments are welcome.

Diff Detail

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

Event Timeline

Looks good.

usr.sbin/kldxref/ef_powerpc.c
67

No change is really needed here, but maybe just cast 'where' to (Elf32_Addr *)?

This revision is now accepted and ready to land.Jan 6 2022, 6:53 PM
alfredo added inline comments.
usr.sbin/kldxref/ef_powerpc.c
67

yes but the cast need to be later since at this point we don't know what data size is going to be used.
Then I preferred to create a new variable here and use it where appropriate, following the pattern used on other architectures.

This revision was automatically updated to reflect the committed changes.