1 //===- MCSection.h - Machine Code Sections ----------------------*- C++ -*-===//
3 // The LLVM Compiler Infrastructure
5 // This file is distributed under the University of Illinois Open Source
6 // License. See LICENSE.TXT for details.
8 //===----------------------------------------------------------------------===//
10 // This file declares the MCSection class.
12 //===----------------------------------------------------------------------===//
14 #ifndef LLVM_MC_MCSECTION_H
15 #define LLVM_MC_MCSECTION_H
18 #include "llvm/ADT/StringRef.h"
19 #include "llvm/MC/SectionKind.h"
20 #include "llvm/Support/Casting.h"
27 /// MCSection - Instances of this class represent a uniqued identifier for a
28 /// section in the current translation unit. The MCContext class uniques and
40 MCSection(const MCSection&); // DO NOT IMPLEMENT
41 void operator=(const MCSection&); // DO NOT IMPLEMENT
43 MCSection(SectionVariant V, SectionKind K) : Variant(V), Kind(K) {}
44 SectionVariant Variant;
49 SectionKind getKind() const { return Kind; }
51 SectionVariant getVariant() const { return Variant; }
53 virtual void PrintSwitchToSection(const MCAsmInfo &MAI,
54 raw_ostream &OS) const = 0;
56 /// isBaseAddressKnownZero - Return true if we know that this section will
57 /// get a base address of zero. In cases where we know that this is true we
58 /// can emit section offsets as direct references to avoid a subtraction
59 /// from the base of the section, saving a relocation.
60 virtual bool isBaseAddressKnownZero() const {
64 static bool classof(const MCSection *) { return true; }
67 } // end namespace llvm