Skip to content

Commit

Permalink
[𝘀𝗽𝗿] initial version
Browse files Browse the repository at this point in the history
Created using spr 1.3.4
  • Loading branch information
ilovepi committed Oct 7, 2024
1 parent 2918e77 commit de9501c
Show file tree
Hide file tree
Showing 19 changed files with 122 additions and 81 deletions.
12 changes: 7 additions & 5 deletions lld/ELF/Arch/AArch64.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1208,10 +1208,12 @@ void elf::createTaggedSymbols(Ctx &ctx) {
}
}

void elf::setAArch64TargetInfo(Ctx &ctx) {
TargetInfo *elf::getAArch64TargetInfo(Ctx &ctx) {
if ((ctx.arg.andFeatures & GNU_PROPERTY_AARCH64_FEATURE_1_BTI) ||
ctx.arg.zPacPlt)
ctx.target.reset(new AArch64BtiPac(ctx));
else
ctx.target.reset(new AArch64(ctx));
ctx.arg.zPacPlt) {
static AArch64BtiPac t(ctx);
return &t;
}
static AArch64 t(ctx);
return &t;
}
5 changes: 4 additions & 1 deletion lld/ELF/Arch/AMDGPU.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -219,4 +219,7 @@ int64_t AMDGPU::getImplicitAddend(const uint8_t *buf, RelType type) const {
}
}

void elf::setAMDGPUTargetInfo(Ctx &ctx) { ctx.target.reset(new AMDGPU(ctx)); }
TargetInfo *elf::getAMDGPUTargetInfo(Ctx &ctx) {
static AMDGPU target(ctx);
return ⌖
}
5 changes: 4 additions & 1 deletion lld/ELF/Arch/ARM.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1533,7 +1533,10 @@ template <typename ELFT> void elf::writeARMCmseImportLib(Ctx &ctx) {
"': " + toString(std::move(e)));
}

void elf::setARMTargetInfo(Ctx &ctx) { ctx.target.reset(new ARM(ctx)); }
TargetInfo *elf::getARMTargetInfo(Ctx &ctx) {
static ARM target(ctx);
return &target;
}

template void elf::writeARMCmseImportLib<ELF32LE>(Ctx &);
template void elf::writeARMCmseImportLib<ELF32BE>(Ctx &);
Expand Down
5 changes: 4 additions & 1 deletion lld/ELF/Arch/AVR.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -267,7 +267,10 @@ void AVR::relocate(uint8_t *loc, const Relocation &rel, uint64_t val) const {
}
}

void elf::setAVRTargetInfo(Ctx &ctx) { ctx.target.reset(new AVR(ctx)); }
TargetInfo *elf::getAVRTargetInfo(Ctx &ctx) {
static AVR target(ctx);
return &target;
}

static uint32_t getEFlags(InputFile *file) {
return cast<ObjFile<ELF32LE>>(file)->getObj().getHeader().e_flags;
Expand Down
5 changes: 4 additions & 1 deletion lld/ELF/Arch/Hexagon.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -404,4 +404,7 @@ int64_t Hexagon::getImplicitAddend(const uint8_t *buf, RelType type) const {
}
}

void elf::setHexagonTargetInfo(Ctx &ctx) { ctx.target.reset(new Hexagon(ctx)); }
TargetInfo *elf::getHexagonTargetInfo(Ctx &ctx) {
static Hexagon target(ctx);
return &target;
}
5 changes: 3 additions & 2 deletions lld/ELF/Arch/LoongArch.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -893,6 +893,7 @@ void LoongArch::finalizeRelax(int passes) const {
}
}

void elf::setLoongArchTargetInfo(Ctx &ctx) {
ctx.target.reset(new LoongArch(ctx));
TargetInfo *elf::getLoongArchTargetInfo(Ctx &ctx) {
static LoongArch target(ctx);
return &target;
}
5 changes: 4 additions & 1 deletion lld/ELF/Arch/MSP430.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -88,4 +88,7 @@ void MSP430::relocate(uint8_t *loc, const Relocation &rel, uint64_t val) const {
}
}

void elf::setMSP430TargetInfo(Ctx &ctx) { ctx.target.reset(new MSP430(ctx)); }
TargetInfo *elf::getMSP430TargetInfo(Ctx &ctx) {
static MSP430 target(ctx);
return &target;
}
18 changes: 9 additions & 9 deletions lld/ELF/Arch/Mips.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -779,23 +779,23 @@ template <class ELFT> bool elf::isMipsPIC(const Defined *sym) {
return cast<ObjFile<ELFT>>(file)->getObj().getHeader().e_flags & EF_MIPS_PIC;
}

void elf::setMipsTargetInfo(Ctx &ctx) {
TargetInfo *elf::getMipsTargetInfo(Ctx &ctx) {
switch (ctx.arg.ekind) {
case ELF32LEKind: {
ctx.target.reset(new MIPS<ELF32LE>(ctx));
return;
static MIPS<ELF32LE> t(ctx);
return &t;
}
case ELF32BEKind: {
ctx.target.reset(new MIPS<ELF32BE>(ctx));
return;
static MIPS<ELF32BE> t(ctx);
return &t;
}
case ELF64LEKind: {
ctx.target.reset(new MIPS<ELF64LE>(ctx));
return;
static MIPS<ELF64LE> t(ctx);
return &t;
}
case ELF64BEKind: {
ctx.target.reset(new MIPS<ELF64BE>(ctx));
return;
static MIPS<ELF64BE> t(ctx);
return &t;
}
default:
llvm_unreachable("unsupported target");
Expand Down
5 changes: 4 additions & 1 deletion lld/ELF/Arch/PPC.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -523,4 +523,7 @@ void PPC::relocateAlloc(InputSectionBase &sec, uint8_t *buf) const {
}
}

void elf::setPPCTargetInfo(Ctx &ctx) { ctx.target.reset(new PPC(ctx)); }
TargetInfo *elf::getPPCTargetInfo(Ctx &ctx) {
static PPC target(ctx);
return &target;
}
5 changes: 4 additions & 1 deletion lld/ELF/Arch/PPC64.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1747,4 +1747,7 @@ bool PPC64::adjustPrologueForCrossSplitStack(uint8_t *loc, uint8_t *end,
return true;
}

void elf::setPPC64TargetInfo(Ctx &ctx) { ctx.target.reset(new PPC64(ctx)); }
TargetInfo *elf::getPPC64TargetInfo(Ctx &ctx) {
static PPC64 target(ctx);
return &target;
}
5 changes: 4 additions & 1 deletion lld/ELF/Arch/RISCV.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1329,4 +1329,7 @@ void elf::mergeRISCVAttributesSections(Ctx &ctx) {
mergeAttributesSection(ctx, sections));
}

void elf::setRISCVTargetInfo(Ctx &ctx) { ctx.target.reset(new RISCV(ctx)); }
TargetInfo *elf::getRISCVTargetInfo(Ctx &ctx) {
static RISCV target(ctx);
return &target;
}
5 changes: 4 additions & 1 deletion lld/ELF/Arch/SPARCV9.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -193,4 +193,7 @@ void SPARCV9::writePlt(uint8_t *buf, const Symbol & /*sym*/,
relocateNoSym(buf + 4, R_SPARC_WDISP19, -(off + 4 - pltEntrySize));
}

void elf::setSPARCV9TargetInfo(Ctx &ctx) { ctx.target.reset(new SPARCV9(ctx)); }
TargetInfo *elf::getSPARCV9TargetInfo(Ctx &ctx) {
static SPARCV9 target(ctx);
return &target;
}
5 changes: 4 additions & 1 deletion lld/ELF/Arch/SystemZ.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -600,4 +600,7 @@ void SystemZ::relocate(uint8_t *loc, const Relocation &rel,
}
}

void elf::setSystemZTargetInfo(Ctx &ctx) { ctx.target.reset(new SystemZ(ctx)); }
TargetInfo *elf::getSystemZTargetInfo(Ctx &ctx) {
static SystemZ t(ctx);
return &t;
}
24 changes: 14 additions & 10 deletions lld/ELF/Arch/X86.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -706,17 +706,21 @@ void RetpolineNoPic::writePlt(uint8_t *buf, const Symbol &sym,
write32le(buf + 22, -off - 26);
}

void elf::setX86TargetInfo(Ctx &ctx) {
TargetInfo *elf::getX86TargetInfo(Ctx &ctx) {
if (ctx.arg.zRetpolineplt) {
if (ctx.arg.isPic)
ctx.target.reset(new RetpolinePic(ctx));
else
ctx.target.reset(new RetpolineNoPic(ctx));
return;
if (ctx.arg.isPic) {
static RetpolinePic t(ctx);
return &t;
}
static RetpolineNoPic t(ctx);
return &t;
}

if (ctx.arg.andFeatures & GNU_PROPERTY_X86_FEATURE_1_IBT) {
static IntelIBT t(ctx);
return &t;
}

if (ctx.arg.andFeatures & GNU_PROPERTY_X86_FEATURE_1_IBT)
ctx.target.reset(new IntelIBT(ctx));
else
ctx.target.reset(new X86(ctx));
static X86 t(ctx);
return &t;
}
24 changes: 14 additions & 10 deletions lld/ELF/Arch/X86_64.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -1237,17 +1237,21 @@ void RetpolineZNow::writePlt(uint8_t *buf, const Symbol &sym,
write32le(buf + 8, ctx.in.plt->getVA() - pltEntryAddr - 12);
}

void elf::setX86_64TargetInfo(Ctx &ctx) {
TargetInfo *elf::getX86_64TargetInfo(Ctx &ctx) {
if (ctx.arg.zRetpolineplt) {
if (ctx.arg.zNow)
ctx.target.reset(new RetpolineZNow(ctx));
else
ctx.target.reset(new Retpoline(ctx));
return;
if (ctx.arg.zNow) {
static RetpolineZNow t(ctx);
return &t;
}
static Retpoline t(ctx);
return &t;
}

if (ctx.arg.andFeatures & GNU_PROPERTY_X86_FEATURE_1_IBT)
ctx.target.reset(new IntelIBT(ctx));
else
ctx.target.reset(new X86_64(ctx));
if (ctx.arg.andFeatures & GNU_PROPERTY_X86_FEATURE_1_IBT) {
static IntelIBT t(ctx);
return &t;
}

static X86_64 t(ctx);
return &t;
}
2 changes: 1 addition & 1 deletion lld/ELF/Config.h
Original file line number Diff line number Diff line change
Expand Up @@ -545,7 +545,7 @@ struct Ctx {
Config arg;
LinkerDriver driver;
LinkerScript *script;
std::unique_ptr<TargetInfo> target;
TargetInfo *target;

// These variables are initialized by Writer and should not be used before
// Writer is initialized.
Expand Down
4 changes: 2 additions & 2 deletions lld/ELF/Driver.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -99,7 +99,7 @@ void Ctx::reset() {
driver.~LinkerDriver();
new (&driver) LinkerDriver(*this);
script = nullptr;
target.reset();
target = nullptr;

bufferStart = nullptr;
mainPart = nullptr;
Expand Down Expand Up @@ -3126,7 +3126,7 @@ template <class ELFT> void LinkerDriver::link(opt::InputArgList &args) {
// The Target instance handles target-specific stuff, such as applying
// relocations or writing a PLT section. It also contains target-dependent
// values such as a default image base address.
setTarget(ctx);
ctx.target = getTarget(ctx);

ctx.arg.eflags = ctx.target->calcEFlags();
// maxPageSize (sometimes called abi page size) is the maximum page size that
Expand Down
32 changes: 16 additions & 16 deletions lld/ELF/Target.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -45,39 +45,39 @@ std::string lld::toString(RelType type) {
return std::string(s);
}

void elf::setTarget(Ctx &ctx) {
TargetInfo *elf::getTarget(Ctx &ctx) {
switch (ctx.arg.emachine) {
case EM_386:
case EM_IAMCU:
return setX86TargetInfo(ctx);
return getX86TargetInfo(ctx);
case EM_AARCH64:
return setAArch64TargetInfo(ctx);
return getAArch64TargetInfo(ctx);
case EM_AMDGPU:
return setAMDGPUTargetInfo(ctx);
return getAMDGPUTargetInfo(ctx);
case EM_ARM:
return setARMTargetInfo(ctx);
return getARMTargetInfo(ctx);
case EM_AVR:
return setAVRTargetInfo(ctx);
return getAVRTargetInfo(ctx);
case EM_HEXAGON:
return setHexagonTargetInfo(ctx);
return getHexagonTargetInfo(ctx);
case EM_LOONGARCH:
return setLoongArchTargetInfo(ctx);
return getLoongArchTargetInfo(ctx);
case EM_MIPS:
return setMipsTargetInfo(ctx);
return getMipsTargetInfo(ctx);
case EM_MSP430:
return setMSP430TargetInfo(ctx);
return getMSP430TargetInfo(ctx);
case EM_PPC:
return setPPCTargetInfo(ctx);
return getPPCTargetInfo(ctx);
case EM_PPC64:
return setPPC64TargetInfo(ctx);
return getPPC64TargetInfo(ctx);
case EM_RISCV:
return setRISCVTargetInfo(ctx);
return getRISCVTargetInfo(ctx);
case EM_SPARCV9:
return setSPARCV9TargetInfo(ctx);
return getSPARCV9TargetInfo(ctx);
case EM_S390:
return setSystemZTargetInfo(ctx);
return getSystemZTargetInfo(ctx);
case EM_X86_64:
return setX86_64TargetInfo(ctx);
return getX86_64TargetInfo(ctx);
default:
fatal("unsupported e_machine value: " + Twine(ctx.arg.emachine));
}
Expand Down
32 changes: 16 additions & 16 deletions lld/ELF/Target.h
Original file line number Diff line number Diff line change
Expand Up @@ -179,21 +179,21 @@ class TargetInfo {
uint64_t defaultImageBase = 0x10000;
};

void setAArch64TargetInfo(Ctx &);
void setAMDGPUTargetInfo(Ctx &);
void setARMTargetInfo(Ctx &);
void setAVRTargetInfo(Ctx &);
void setHexagonTargetInfo(Ctx &);
void setLoongArchTargetInfo(Ctx &);
void setMSP430TargetInfo(Ctx &);
void setMipsTargetInfo(Ctx &);
void setPPC64TargetInfo(Ctx &);
void setPPCTargetInfo(Ctx &);
void setRISCVTargetInfo(Ctx &);
void setSPARCV9TargetInfo(Ctx &);
void setSystemZTargetInfo(Ctx &);
void setX86TargetInfo(Ctx &);
void setX86_64TargetInfo(Ctx &);
TargetInfo *getAArch64TargetInfo(Ctx &);
TargetInfo *getAMDGPUTargetInfo(Ctx &);
TargetInfo *getARMTargetInfo(Ctx &);
TargetInfo *getAVRTargetInfo(Ctx &);
TargetInfo *getHexagonTargetInfo(Ctx &);
TargetInfo *getLoongArchTargetInfo(Ctx &);
TargetInfo *getMSP430TargetInfo(Ctx &);
TargetInfo *getMipsTargetInfo(Ctx &);
TargetInfo *getPPC64TargetInfo(Ctx &);
TargetInfo *getPPCTargetInfo(Ctx &);
TargetInfo *getRISCVTargetInfo(Ctx &);
TargetInfo *getSPARCV9TargetInfo(Ctx &);
TargetInfo *getSystemZTargetInfo(Ctx &);
TargetInfo *getX86TargetInfo(Ctx &);
TargetInfo *getX86_64TargetInfo(Ctx &);

struct ErrorPlace {
InputSectionBase *isec;
Expand Down Expand Up @@ -251,7 +251,7 @@ void convertArmInstructionstoBE8(InputSection *sec, uint8_t *buf);
void createTaggedSymbols(Ctx &);
void initSymbolAnchors(Ctx &);

void setTarget(Ctx &);
TargetInfo *getTarget(Ctx &);

template <class ELFT> bool isMipsPIC(const Defined *sym);

Expand Down

0 comments on commit de9501c

Please sign in to comment.