@@ -90,8 +90,8 @@ class X86TargetInfo final : public TargetInfo {
90
90
int32_t Index, unsigned RelOff) const override ;
91
91
bool needsCopyRel (uint32_t Type, const SymbolBody &S) const override ;
92
92
bool needsDynRelative (unsigned Type) const override ;
93
- bool needsGot (uint32_t Type, const SymbolBody &S) const override ;
94
- bool needsPlt (uint32_t Type, const SymbolBody &S) const override ;
93
+ bool needsGot (uint32_t Type, SymbolBody &S) const override ;
94
+ bool needsPlt (uint32_t Type, SymbolBody &S) const override ;
95
95
void relocateOne (uint8_t *Loc, uint8_t *BufEnd, uint32_t Type, uint64_t P,
96
96
uint64_t SA, uint64_t ZA = 0 ,
97
97
uint8_t *PairedLoc = nullptr ) const override ;
@@ -121,8 +121,8 @@ class X86_64TargetInfo final : public TargetInfo {
121
121
void writePlt (uint8_t *Buf, uint64_t GotEntryAddr, uint64_t PltEntryAddr,
122
122
int32_t Index, unsigned RelOff) const override ;
123
123
bool needsCopyRel (uint32_t Type, const SymbolBody &S) const override ;
124
- bool needsGot (uint32_t Type, const SymbolBody &S) const override ;
125
- bool needsPlt (uint32_t Type, const SymbolBody &S) const override ;
124
+ bool needsGot (uint32_t Type, SymbolBody &S) const override ;
125
+ bool needsPlt (uint32_t Type, SymbolBody &S) const override ;
126
126
void relocateOne (uint8_t *Loc, uint8_t *BufEnd, uint32_t Type, uint64_t P,
127
127
uint64_t SA, uint64_t ZA = 0 ,
128
128
uint8_t *PairedLoc = nullptr ) const override ;
@@ -157,8 +157,8 @@ class PPC64TargetInfo final : public TargetInfo {
157
157
PPC64TargetInfo ();
158
158
void writePlt (uint8_t *Buf, uint64_t GotEntryAddr, uint64_t PltEntryAddr,
159
159
int32_t Index, unsigned RelOff) const override ;
160
- bool needsGot (uint32_t Type, const SymbolBody &S) const override ;
161
- bool needsPlt (uint32_t Type, const SymbolBody &S) const override ;
160
+ bool needsGot (uint32_t Type, SymbolBody &S) const override ;
161
+ bool needsPlt (uint32_t Type, SymbolBody &S) const override ;
162
162
void relocateOne (uint8_t *Loc, uint8_t *BufEnd, uint32_t Type, uint64_t P,
163
163
uint64_t SA, uint64_t ZA = 0 ,
164
164
uint8_t *PairedLoc = nullptr ) const override ;
@@ -176,8 +176,8 @@ class AArch64TargetInfo final : public TargetInfo {
176
176
unsigned getTlsGotRel (unsigned Type = -1 ) const override ;
177
177
bool isTlsDynRel (unsigned Type, const SymbolBody &S) const override ;
178
178
bool needsCopyRel (uint32_t Type, const SymbolBody &S) const override ;
179
- bool needsGot (uint32_t Type, const SymbolBody &S) const override ;
180
- bool needsPlt (uint32_t Type, const SymbolBody &S) const override ;
179
+ bool needsGot (uint32_t Type, SymbolBody &S) const override ;
180
+ bool needsPlt (uint32_t Type, SymbolBody &S) const override ;
181
181
void relocateOne (uint8_t *Loc, uint8_t *BufEnd, uint32_t Type, uint64_t P,
182
182
uint64_t SA, uint64_t ZA = 0 ,
183
183
uint8_t *PairedLoc = nullptr ) const override ;
@@ -197,8 +197,8 @@ template <class ELFT> class MipsTargetInfo final : public TargetInfo {
197
197
unsigned getDynRel (unsigned Type) const override ;
198
198
void writeGotHeader (uint8_t *Buf) const override ;
199
199
bool needsCopyRel (uint32_t Type, const SymbolBody &S) const override ;
200
- bool needsGot (uint32_t Type, const SymbolBody &S) const override ;
201
- bool needsPlt (uint32_t Type, const SymbolBody &S) const override ;
200
+ bool needsGot (uint32_t Type, SymbolBody &S) const override ;
201
+ bool needsPlt (uint32_t Type, SymbolBody &S) const override ;
202
202
void relocateOne (uint8_t *Loc, uint8_t *BufEnd, uint32_t Type, uint64_t P,
203
203
uint64_t SA, uint64_t ZA = 0 ,
204
204
uint8_t *PairedLoc = nullptr ) const override ;
@@ -263,13 +263,9 @@ bool TargetInfo::isHintRel(uint32_t Type) const { return false; }
263
263
bool TargetInfo::isRelRelative (uint32_t Type) const { return true ; }
264
264
bool TargetInfo::isSizeRel (uint32_t Type) const { return false ; }
265
265
266
- bool TargetInfo::needsGot (uint32_t Type, const SymbolBody &S) const {
267
- return false ;
268
- }
266
+ bool TargetInfo::needsGot (uint32_t Type, SymbolBody &S) const { return false ; }
269
267
270
- bool TargetInfo::needsPlt (uint32_t Type, const SymbolBody &S) const {
271
- return false ;
272
- }
268
+ bool TargetInfo::needsPlt (uint32_t Type, SymbolBody &S) const { return false ; }
273
269
274
270
unsigned TargetInfo::relaxTls (uint8_t *Loc, uint8_t *BufEnd, uint32_t Type,
275
271
uint64_t P, uint64_t SA,
@@ -376,15 +372,15 @@ bool X86TargetInfo::needsCopyRel(uint32_t Type, const SymbolBody &S) const {
376
372
return false ;
377
373
}
378
374
379
- bool X86TargetInfo::needsGot (uint32_t Type, const SymbolBody &S) const {
375
+ bool X86TargetInfo::needsGot (uint32_t Type, SymbolBody &S) const {
380
376
if (S.isTls () && Type == R_386_TLS_GD)
381
377
return Target->canRelaxTls (Type, &S) && canBePreempted (&S, true );
382
378
if (Type == R_386_TLS_GOTIE || Type == R_386_TLS_IE)
383
379
return !canRelaxTls (Type, &S);
384
380
return Type == R_386_GOT32 || needsPlt (Type, S);
385
381
}
386
382
387
- bool X86TargetInfo::needsPlt (uint32_t Type, const SymbolBody &S) const {
383
+ bool X86TargetInfo::needsPlt (uint32_t Type, SymbolBody &S) const {
388
384
return isGnuIFunc<ELF32LE>(S) ||
389
385
(Type == R_386_PLT32 && canBePreempted (&S, true )) ||
390
386
(Type == R_386_PC32 && S.isShared ());
@@ -646,7 +642,7 @@ bool X86_64TargetInfo::needsCopyRel(uint32_t Type, const SymbolBody &S) const {
646
642
return false ;
647
643
}
648
644
649
- bool X86_64TargetInfo::needsGot (uint32_t Type, const SymbolBody &S) const {
645
+ bool X86_64TargetInfo::needsGot (uint32_t Type, SymbolBody &S) const {
650
646
if (Type == R_X86_64_TLSGD)
651
647
return Target->canRelaxTls (Type, &S) && canBePreempted (&S, true );
652
648
if (Type == R_X86_64_GOTTPOFF)
@@ -658,7 +654,7 @@ bool X86_64TargetInfo::isTlsDynRel(unsigned Type, const SymbolBody &S) const {
658
654
return Type == R_X86_64_GOTTPOFF || Type == R_X86_64_TLSGD;
659
655
}
660
656
661
- bool X86_64TargetInfo::needsPlt (uint32_t Type, const SymbolBody &S) const {
657
+ bool X86_64TargetInfo::needsPlt (uint32_t Type, SymbolBody &S) const {
662
658
if (needsCopyRel (Type, S))
663
659
return false ;
664
660
if (isGnuIFunc<ELF64LE>(S))
@@ -684,17 +680,19 @@ bool X86_64TargetInfo::needsPlt(uint32_t Type, const SymbolBody &S) const {
684
680
// For the static linking part, we just return true and everything else
685
681
// will use the the PLT entry as the address.
686
682
//
687
- // The remaining (unimplemented) problem is making sure pointer equality
688
- // still works. We need the help of the dynamic linker for that. We
689
- // let it know that we have a direct reference to a so symbol by creating
690
- // an undefined symbol with a non zero st_value. Seeing that, the
691
- // dynamic linker resolves the symbol to the value of the symbol we created.
692
- // This is true even for got entries, so pointer equality is maintained.
693
- // To avoid an infinite loop, the only entry that points to the
694
- // real function is a dedicated got entry used by the plt. That is
695
- // identified by special relocation types (R_X86_64_JUMP_SLOT,
683
+ // The remaining problem is making sure pointer equality still works. We
684
+ // need the help of the dynamic linker for that. We let it know that we have
685
+ // a direct reference to a so symbol by creating an undefined symbol with a
686
+ // non zero st_value. Seeing that, the dynamic linker resolves the symbol to
687
+ // the value of the symbol we created. This is true even for got entries, so
688
+ // pointer equality is maintained. To avoid an infinite loop, the only entry
689
+ // that points to the real function is a dedicated got entry used by the
690
+ // plt. That is identified by special relocation types (R_X86_64_JUMP_SLOT,
696
691
// R_386_JMP_SLOT, etc).
697
- return S.isShared ();
692
+ if (!S.isShared ())
693
+ return false ;
694
+ S.NeedsCopyOrPltAddr = true ;
695
+ return true ;
698
696
case R_X86_64_PLT32:
699
697
return canBePreempted (&S, true );
700
698
}
@@ -989,7 +987,7 @@ void PPC64TargetInfo::writePlt(uint8_t *Buf, uint64_t GotEntryAddr,
989
987
write32be (Buf + 28 , 0x4e800420 ); // bctr
990
988
}
991
989
992
- bool PPC64TargetInfo::needsGot (uint32_t Type, const SymbolBody &S) const {
990
+ bool PPC64TargetInfo::needsGot (uint32_t Type, SymbolBody &S) const {
993
991
if (needsPlt (Type, S))
994
992
return true ;
995
993
@@ -1005,7 +1003,7 @@ bool PPC64TargetInfo::needsGot(uint32_t Type, const SymbolBody &S) const {
1005
1003
}
1006
1004
}
1007
1005
1008
- bool PPC64TargetInfo::needsPlt (uint32_t Type, const SymbolBody &S) const {
1006
+ bool PPC64TargetInfo::needsPlt (uint32_t Type, SymbolBody &S) const {
1009
1007
// These are function calls that need to be redirected through a PLT stub.
1010
1008
return Type == R_PPC64_REL24 && canBePreempted (&S, false );
1011
1009
}
@@ -1240,7 +1238,7 @@ bool AArch64TargetInfo::needsCopyRel(uint32_t Type, const SymbolBody &S) const {
1240
1238
}
1241
1239
}
1242
1240
1243
- bool AArch64TargetInfo::needsGot (uint32_t Type, const SymbolBody &S) const {
1241
+ bool AArch64TargetInfo::needsGot (uint32_t Type, SymbolBody &S) const {
1244
1242
switch (Type) {
1245
1243
case R_AARCH64_TLSIE_LD64_GOTTPREL_LO12_NC:
1246
1244
case R_AARCH64_TLSIE_ADR_GOTTPREL_PAGE21:
@@ -1252,7 +1250,7 @@ bool AArch64TargetInfo::needsGot(uint32_t Type, const SymbolBody &S) const {
1252
1250
}
1253
1251
}
1254
1252
1255
- bool AArch64TargetInfo::needsPlt (uint32_t Type, const SymbolBody &S) const {
1253
+ bool AArch64TargetInfo::needsPlt (uint32_t Type, SymbolBody &S) const {
1256
1254
if (isGnuIFunc<ELF64LE>(S))
1257
1255
return true ;
1258
1256
switch (Type) {
@@ -1439,12 +1437,12 @@ bool MipsTargetInfo<ELFT>::needsCopyRel(uint32_t Type,
1439
1437
}
1440
1438
1441
1439
template <class ELFT >
1442
- bool MipsTargetInfo<ELFT>::needsGot(uint32_t Type, const SymbolBody &S) const {
1440
+ bool MipsTargetInfo<ELFT>::needsGot(uint32_t Type, SymbolBody &S) const {
1443
1441
return Type == R_MIPS_GOT16 || Type == R_MIPS_CALL16;
1444
1442
}
1445
1443
1446
1444
template <class ELFT >
1447
- bool MipsTargetInfo<ELFT>::needsPlt(uint32_t Type, const SymbolBody &S) const {
1445
+ bool MipsTargetInfo<ELFT>::needsPlt(uint32_t Type, SymbolBody &S) const {
1448
1446
return false ;
1449
1447
}
1450
1448
0 commit comments