X-Git-Url: http://demsky.eecs.uci.edu/git/?a=blobdiff_plain;f=include%2Fllvm%2FMC%2FMCSection.h;h=21fdb6bd39b8ba9bb55f0143c17b9f5be3dce02f;hb=f43e3fdb4ffddff6f71b5597c813c43e1e206564;hp=5eb8559c90a75d3d41c8796bf5df63abb1b3b390;hpb=4a7bc1e5aafbb543a9a535bce54fc62d18723b35;p=oota-llvm.git diff --git a/include/llvm/MC/MCSection.h b/include/llvm/MC/MCSection.h index 5eb8559c90a..21fdb6bd39b 100644 --- a/include/llvm/MC/MCSection.h +++ b/include/llvm/MC/MCSection.h @@ -14,38 +14,58 @@ #ifndef LLVM_MC_MCSECTION_H #define LLVM_MC_MCSECTION_H -#include -#include "llvm/ADT/StringRef.h" - -// FIXME: HORRIBLE HACK: major layering violation to get an enum. -#include "llvm/Target/TargetLoweringObjectFile.h" +#include "llvm/MC/SectionKind.h" +#include "llvm/Support/Compiler.h" namespace llvm { - class MCContext; - + class MCAsmInfo; + class raw_ostream; + /// MCSection - Instances of this class represent a uniqued identifier for a /// section in the current translation unit. The MCContext class uniques and /// creates these. class MCSection { - std::string Name; - MCSection(const MCSection&); // DO NOT IMPLEMENT - void operator=(const MCSection&); // DO NOT IMPLEMENT + public: + enum SectionVariant { + SV_COFF = 0, + SV_ELF, + SV_MachO + }; + + private: + MCSection(const MCSection&) LLVM_DELETED_FUNCTION; + void operator=(const MCSection&) LLVM_DELETED_FUNCTION; protected: - MCSection(const StringRef &Name, SectionKind K, MCContext &Ctx); + MCSection(SectionVariant V, SectionKind K) : Variant(V), Kind(K) {} + SectionVariant Variant; SectionKind Kind; public: virtual ~MCSection(); - static MCSection *Create(const StringRef &Name, SectionKind K, - MCContext &Ctx); - - const std::string &getName() const { return Name; } SectionKind getKind() const { return Kind; } + + SectionVariant getVariant() const { return Variant; } + + virtual void PrintSwitchToSection(const MCAsmInfo &MAI, + raw_ostream &OS) const = 0; + + /// isBaseAddressKnownZero - Return true if we know that this section will + /// get a base address of zero. In cases where we know that this is true we + /// can emit section offsets as direct references to avoid a subtraction + /// from the base of the section, saving a relocation. + virtual bool isBaseAddressKnownZero() const { + return false; + } + + // UseCodeAlign - Return true if a .align directive should use + // "optimized nops" to fill instead of 0s. + virtual bool UseCodeAlign() const = 0; + + /// isVirtualSection - Check whether this section is "virtual", that is + /// has no actual object file contents. + virtual bool isVirtualSection() const = 0; }; - - typedef MCSection MCSectionELF; - } // end namespace llvm #endif