1 //===- MCSection.h - Machine Code Sections ----------------------*- C++ -*-===//
3 // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4 // See https://llvm.org/LICENSE.txt for license information.
5 // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
7 //===----------------------------------------------------------------------===//
9 // This file declares the MCSection class.
11 //===----------------------------------------------------------------------===//
13 #ifndef LLVM_MC_MCSECTION_H
14 #define LLVM_MC_MCSECTION_H
16 #include "llvm/ADT/SmallVector.h"
17 #include "llvm/ADT/ilist.h"
18 #include "llvm/MC/MCFragment.h"
19 #include "llvm/MC/SectionKind.h"
32 template <> struct ilist_alloc_traits
<MCFragment
> {
33 static void deleteNode(MCFragment
*V
);
36 /// Instances of this class represent a uniqued identifier for a section in the
37 /// current translation unit. The MCContext class uniques and creates these.
40 enum SectionVariant
{ SV_COFF
= 0, SV_ELF
, SV_MachO
, SV_Wasm
};
42 /// Express the state of bundle locked groups while emitting code.
43 enum BundleLockStateType
{
46 BundleLockedAlignToEnd
49 using FragmentListType
= iplist
<MCFragment
>;
51 using const_iterator
= FragmentListType::const_iterator
;
52 using iterator
= FragmentListType::iterator
;
54 using const_reverse_iterator
= FragmentListType::const_reverse_iterator
;
55 using reverse_iterator
= FragmentListType::reverse_iterator
;
59 MCSymbol
*End
= nullptr;
60 /// The alignment requirement of this section.
61 unsigned Alignment
= 1;
62 /// The section index in the assemblers section list.
64 /// The index of this section in the layout order.
67 /// Keeping track of bundle-locked state.
68 BundleLockStateType BundleLockState
= NotBundleLocked
;
70 /// Current nesting depth of bundle_lock directives.
71 unsigned BundleLockNestingDepth
= 0;
73 /// We've seen a bundle_lock directive but not its first instruction
75 bool BundleGroupBeforeFirstInst
: 1;
77 /// Whether this section has had instructions emitted into it.
78 bool HasInstructions
: 1;
80 /// Whether this section has had data emitted into it.
81 /// Right now this is only used by the ARM backend.
84 bool IsRegistered
: 1;
86 MCDummyFragment DummyFragment
;
88 FragmentListType Fragments
;
90 /// Mapping from subsection number to insertion point for subsection numbers
91 /// below that number.
92 SmallVector
<std::pair
<unsigned, MCFragment
*>, 1> SubsectionFragmentMap
;
95 SectionVariant Variant
;
98 MCSection(SectionVariant V
, SectionKind K
, MCSymbol
*Begin
);
102 MCSection(const MCSection
&) = delete;
103 MCSection
&operator=(const MCSection
&) = delete;
105 SectionKind
getKind() const { return Kind
; }
107 SectionVariant
getVariant() const { return Variant
; }
109 MCSymbol
*getBeginSymbol() { return Begin
; }
110 const MCSymbol
*getBeginSymbol() const {
111 return const_cast<MCSection
*>(this)->getBeginSymbol();
113 void setBeginSymbol(MCSymbol
*Sym
) {
117 MCSymbol
*getEndSymbol(MCContext
&Ctx
);
118 bool hasEnded() const;
120 unsigned getAlignment() const { return Alignment
; }
121 void setAlignment(unsigned Value
) { Alignment
= Value
; }
123 unsigned getOrdinal() const { return Ordinal
; }
124 void setOrdinal(unsigned Value
) { Ordinal
= Value
; }
126 unsigned getLayoutOrder() const { return LayoutOrder
; }
127 void setLayoutOrder(unsigned Value
) { LayoutOrder
= Value
; }
129 BundleLockStateType
getBundleLockState() const { return BundleLockState
; }
130 void setBundleLockState(BundleLockStateType NewState
);
131 bool isBundleLocked() const { return BundleLockState
!= NotBundleLocked
; }
133 bool isBundleGroupBeforeFirstInst() const {
134 return BundleGroupBeforeFirstInst
;
136 void setBundleGroupBeforeFirstInst(bool IsFirst
) {
137 BundleGroupBeforeFirstInst
= IsFirst
;
140 bool hasInstructions() const { return HasInstructions
; }
141 void setHasInstructions(bool Value
) { HasInstructions
= Value
; }
143 bool hasData() const { return HasData
; }
144 void setHasData(bool Value
) { HasData
= Value
; }
146 bool isRegistered() const { return IsRegistered
; }
147 void setIsRegistered(bool Value
) { IsRegistered
= Value
; }
149 MCSection::FragmentListType
&getFragmentList() { return Fragments
; }
150 const MCSection::FragmentListType
&getFragmentList() const {
151 return const_cast<MCSection
*>(this)->getFragmentList();
154 /// Support for MCFragment::getNextNode().
155 static FragmentListType
MCSection::*getSublistAccess(MCFragment
*) {
156 return &MCSection::Fragments
;
159 const MCDummyFragment
&getDummyFragment() const { return DummyFragment
; }
160 MCDummyFragment
&getDummyFragment() { return DummyFragment
; }
162 iterator
begin() { return Fragments
.begin(); }
163 const_iterator
begin() const { return Fragments
.begin(); }
165 iterator
end() { return Fragments
.end(); }
166 const_iterator
end() const { return Fragments
.end(); }
168 reverse_iterator
rbegin() { return Fragments
.rbegin(); }
169 const_reverse_iterator
rbegin() const { return Fragments
.rbegin(); }
171 reverse_iterator
rend() { return Fragments
.rend(); }
172 const_reverse_iterator
rend() const { return Fragments
.rend(); }
174 MCSection::iterator
getSubsectionInsertionPoint(unsigned Subsection
);
178 virtual void PrintSwitchToSection(const MCAsmInfo
&MAI
, const Triple
&T
,
180 const MCExpr
*Subsection
) const = 0;
182 /// Return true if a .align directive should use "optimized nops" to fill
184 virtual bool UseCodeAlign() const = 0;
186 /// Check whether this section is "virtual", that is has no actual object
188 virtual bool isVirtualSection() const = 0;
191 } // end namespace llvm
193 #endif // LLVM_MC_MCSECTION_H