mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-03-02 22:32:08 +00:00
This change unifies how LTOModule and the backend obtain linker flags for globals: via a new TargetLoweringObjectFile member function named emitLinkerFlagsForGlobal. A new function LTOModule::getLinkerOpts() returns the list of linker flags as a single concatenated string. This change affects the C libLTO API: the function lto_module_get_*deplibs now exposes an empty list, and lto_module_get_*linkeropts exposes a single element which combines the contents of all observed flags. libLTO should never have tried to parse the linker flags; it is the linker's job to do so. Because linkers will need to be able to parse flags in regular object files, it makes little sense for libLTO to have a redundant mechanism for doing so. The new API is compatible with the old one. It is valid for a user to specify multiple linker flags in a single pragma directive like this: #pragma comment(linker, "/defaultlib:foo /defaultlib:bar") The previous implementation would not have exposed either flag via lto_module_get_*deplibs (as the test in TargetLoweringObjectFileCOFF::getDepLibFromLinkerOpt was case sensitive) and would have exposed "/defaultlib:foo /defaultlib:bar" as a single flag via lto_module_get_*linkeropts. This may have been a bug in the implementation, but it does give us a chance to fix the interface. Differential Revision: http://reviews.llvm.org/D10548 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@241010 91177308-0d34-0410-b5e6-96231b3b80d8
197 lines
7.9 KiB
C++
197 lines
7.9 KiB
C++
//===-- llvm/Target/TargetLoweringObjectFile.h - Object Info ----*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file implements classes used to handle lowerings specific to common
|
|
// object file formats.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#ifndef LLVM_TARGET_TARGETLOWERINGOBJECTFILE_H
|
|
#define LLVM_TARGET_TARGETLOWERINGOBJECTFILE_H
|
|
|
|
#include "llvm/ADT/ArrayRef.h"
|
|
#include "llvm/IR/Module.h"
|
|
#include "llvm/MC/MCObjectFileInfo.h"
|
|
#include "llvm/MC/SectionKind.h"
|
|
|
|
namespace llvm {
|
|
class MachineModuleInfo;
|
|
class Mangler;
|
|
class MCContext;
|
|
class MCExpr;
|
|
class MCSection;
|
|
class MCSymbol;
|
|
class MCSymbolRefExpr;
|
|
class MCStreamer;
|
|
class MCValue;
|
|
class ConstantExpr;
|
|
class GlobalValue;
|
|
class TargetMachine;
|
|
|
|
class TargetLoweringObjectFile : public MCObjectFileInfo {
|
|
MCContext *Ctx;
|
|
|
|
TargetLoweringObjectFile(
|
|
const TargetLoweringObjectFile&) = delete;
|
|
void operator=(const TargetLoweringObjectFile&) = delete;
|
|
|
|
protected:
|
|
const DataLayout *DL;
|
|
bool SupportIndirectSymViaGOTPCRel;
|
|
bool SupportGOTPCRelWithOffset;
|
|
|
|
public:
|
|
MCContext &getContext() const { return *Ctx; }
|
|
|
|
TargetLoweringObjectFile() : MCObjectFileInfo(), Ctx(nullptr), DL(nullptr),
|
|
SupportIndirectSymViaGOTPCRel(false),
|
|
SupportGOTPCRelWithOffset(true) {}
|
|
|
|
virtual ~TargetLoweringObjectFile();
|
|
|
|
/// This method must be called before any actual lowering is done. This
|
|
/// specifies the current context for codegen, and gives the lowering
|
|
/// implementations a chance to set up their default sections.
|
|
virtual void Initialize(MCContext &ctx, const TargetMachine &TM);
|
|
|
|
virtual void emitPersonalityValue(MCStreamer &Streamer,
|
|
const TargetMachine &TM,
|
|
const MCSymbol *Sym) const;
|
|
|
|
/// Emit the module flags that the platform cares about.
|
|
virtual void emitModuleFlags(MCStreamer &Streamer,
|
|
ArrayRef<Module::ModuleFlagEntry> Flags,
|
|
Mangler &Mang, const TargetMachine &TM) const {}
|
|
|
|
/// Given a constant with the SectionKind, return a section that it should be
|
|
/// placed in.
|
|
virtual MCSection *getSectionForConstant(SectionKind Kind,
|
|
const Constant *C) const;
|
|
|
|
/// Classify the specified global variable into a set of target independent
|
|
/// categories embodied in SectionKind.
|
|
static SectionKind getKindForGlobal(const GlobalValue *GV,
|
|
const TargetMachine &TM);
|
|
|
|
/// This method computes the appropriate section to emit the specified global
|
|
/// variable or function definition. This should not be passed external (or
|
|
/// available externally) globals.
|
|
MCSection *SectionForGlobal(const GlobalValue *GV, SectionKind Kind,
|
|
Mangler &Mang, const TargetMachine &TM) const;
|
|
|
|
/// This method computes the appropriate section to emit the specified global
|
|
/// variable or function definition. This should not be passed external (or
|
|
/// available externally) globals.
|
|
MCSection *SectionForGlobal(const GlobalValue *GV, Mangler &Mang,
|
|
const TargetMachine &TM) const {
|
|
return SectionForGlobal(GV, getKindForGlobal(GV, TM), Mang, TM);
|
|
}
|
|
|
|
virtual void getNameWithPrefix(SmallVectorImpl<char> &OutName,
|
|
const GlobalValue *GV,
|
|
bool CannotUsePrivateLabel, Mangler &Mang,
|
|
const TargetMachine &TM) const;
|
|
|
|
virtual MCSection *getSectionForJumpTable(const Function &F, Mangler &Mang,
|
|
const TargetMachine &TM) const;
|
|
|
|
virtual bool shouldPutJumpTableInFunctionSection(bool UsesLabelDifference,
|
|
const Function &F) const;
|
|
|
|
/// Targets should implement this method to assign a section to globals with
|
|
/// an explicit section specfied. The implementation of this method can
|
|
/// assume that GV->hasSection() is true.
|
|
virtual MCSection *
|
|
getExplicitSectionGlobal(const GlobalValue *GV, SectionKind Kind,
|
|
Mangler &Mang, const TargetMachine &TM) const = 0;
|
|
|
|
/// Allow the target to completely override section assignment of a global.
|
|
virtual const MCSection *getSpecialCasedSectionGlobals(const GlobalValue *GV,
|
|
SectionKind Kind,
|
|
Mangler &Mang) const {
|
|
return nullptr;
|
|
}
|
|
|
|
/// Return an MCExpr to use for a reference to the specified global variable
|
|
/// from exception handling information.
|
|
virtual const MCExpr *
|
|
getTTypeGlobalReference(const GlobalValue *GV, unsigned Encoding,
|
|
Mangler &Mang, const TargetMachine &TM,
|
|
MachineModuleInfo *MMI, MCStreamer &Streamer) const;
|
|
|
|
/// Return the MCSymbol for a private symbol with global value name as its
|
|
/// base, with the specified suffix.
|
|
MCSymbol *getSymbolWithGlobalValueBase(const GlobalValue *GV,
|
|
StringRef Suffix, Mangler &Mang,
|
|
const TargetMachine &TM) const;
|
|
|
|
// The symbol that gets passed to .cfi_personality.
|
|
virtual MCSymbol *getCFIPersonalitySymbol(const GlobalValue *GV,
|
|
Mangler &Mang,
|
|
const TargetMachine &TM,
|
|
MachineModuleInfo *MMI) const;
|
|
|
|
const MCExpr *
|
|
getTTypeReference(const MCSymbolRefExpr *Sym, unsigned Encoding,
|
|
MCStreamer &Streamer) const;
|
|
|
|
virtual MCSection *getStaticCtorSection(unsigned Priority,
|
|
const MCSymbol *KeySym) const {
|
|
return StaticCtorSection;
|
|
}
|
|
|
|
virtual MCSection *getStaticDtorSection(unsigned Priority,
|
|
const MCSymbol *KeySym) const {
|
|
return StaticDtorSection;
|
|
}
|
|
|
|
/// \brief Create a symbol reference to describe the given TLS variable when
|
|
/// emitting the address in debug info.
|
|
virtual const MCExpr *getDebugThreadLocalSymbol(const MCSymbol *Sym) const;
|
|
|
|
virtual const MCExpr *
|
|
getExecutableRelativeSymbol(const ConstantExpr *CE, Mangler &Mang,
|
|
const TargetMachine &TM) const {
|
|
return nullptr;
|
|
}
|
|
|
|
/// \brief Target supports replacing a data "PC"-relative access to a symbol
|
|
/// through another symbol, by accessing the later via a GOT entry instead?
|
|
bool supportIndirectSymViaGOTPCRel() const {
|
|
return SupportIndirectSymViaGOTPCRel;
|
|
}
|
|
|
|
/// \brief Target GOT "PC"-relative relocation supports encoding an additional
|
|
/// binary expression with an offset?
|
|
bool supportGOTPCRelWithOffset() const {
|
|
return SupportGOTPCRelWithOffset;
|
|
}
|
|
|
|
/// \brief Get the target specific PC relative GOT entry relocation
|
|
virtual const MCExpr *getIndirectSymViaGOTPCRel(const MCSymbol *Sym,
|
|
const MCValue &MV,
|
|
int64_t Offset,
|
|
MachineModuleInfo *MMI,
|
|
MCStreamer &Streamer) const {
|
|
return nullptr;
|
|
}
|
|
|
|
virtual void emitLinkerFlagsForGlobal(raw_ostream &OS, const GlobalValue *GV,
|
|
const Mangler &Mang) const {}
|
|
|
|
protected:
|
|
virtual MCSection *SelectSectionForGlobal(const GlobalValue *GV,
|
|
SectionKind Kind, Mangler &Mang,
|
|
const TargetMachine &TM) const = 0;
|
|
};
|
|
|
|
} // end namespace llvm
|
|
|
|
#endif
|