Details
- Reviewers
ruiu emaste • espindola
Diff Detail
- Repository
- rLLD LLVM Linker
- Build Status
Buildable 25404 Build 25403: arc lint + arc unit
Event Timeline
Now I think it is more clear than before that adding the size of the header in getPltVA is weird. Maybe that should be handled in getPltEntryOffset that's where we should compute an offset for an PLT entry. Also, please don't casually add an optional parameter to an existing function to "tweak" existing behavior in a subtle way. That kind of changes can quickly accumulate and make functions really hard to understand.
I mean we probably should set PltHeaderSize to 0 if IPLT because IPLT's header size is actually zero (unless it is a retpoline IPLT, in which case it should be set to an appropriate value.)
TargetInfo::getPltEntryOffset does not know which PLT section (normal PLT or IPLT) the caller is referring to.
TargetInfo::PltHeaderSize is a field of TargetInfo, not PltSection. I cannot set PltHeaderSize to 0 for IPLT because otherwise when both normal PLT and IPLT are used, the PltHeaderSize of the normal PLT would be incorrect (0).
- InputSection::writeTo calls PltSection::writeTo. This may happen twice, one for normal PLT and the other for IPLT
- PltSection::writeTo calls Target->writePltHeader and Target->writePlt. The two methods are overriden by Arch/*.cpp targets.
- X86_64<ELFT>::writePlt (and some other targets) calls Target->getPltEntryOffset.
The bit of information (whether it is PLT or IPLT) is lost when PltSection::writeTo calls into TargetInfo methods. I am confusing about a better place to place the PltHeaderSize information.
This is a rough sketch but I believe this is towards a right direction: https://gist.github.com/rui314/d919496a6db34483d673f9ebe34d6f89
Yeah, but the reason why this was just a sketch is because I believe TargetInfo::getPltEntryOffset no longer make much sense with this patch. Perhaps that should be removed.
Hm, the new code doesn't look great as it contains too many repetitions. Do you have any suggestion to make this code better?
Let me play with this code too.
There are pros and cons. It makes the code slightly longer. The duplication mostly happens in getPltEntryOffset(Index); call sites in X86_64 X86 SPARCV9
- uint64_t Off = getPltEntryOffset(Index); + uint64_t Off = PltHeaderSize + Index * PltEntrySize;
The advantage is that a casual reader does not need to read the definition of getPltEntryOffset to understand how the offsets are computed. I am biased but I find such duplication tolerable.
I see your point, and I agree with that. But the new code is also error-prone because you can make a mistake to not to add the header size, for example. So not sure which is better.