LLVM 20.0.0git
MCSectionXCOFF.h
Go to the documentation of this file.
1//===- MCSectionXCOFF.h - XCOFF Machine Code Sections -----------*- C++ -*-===//
2//
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
6//
7//===----------------------------------------------------------------------===//
8//
9// This file declares the MCSectionXCOFF class.
10//
11//===----------------------------------------------------------------------===//
12
13#ifndef LLVM_MC_MCSECTIONXCOFF_H
14#define LLVM_MC_MCSECTIONXCOFF_H
15
17#include "llvm/MC/MCSection.h"
19
20namespace llvm {
21
22// This class represents an XCOFF `Control Section`, more commonly referred to
23// as a csect. A csect represents the smallest possible unit of data/code which
24// will be relocated as a single block. A csect can either be:
25// 1) Initialized: The Type will be XTY_SD, and the symbols inside the csect
26// will have a label definition representing their offset within the csect.
27// 2) Uninitialized: The Type will be XTY_CM, it will contain a single symbol,
28// and may not contain label definitions.
29// 3) An external reference providing a symbol table entry for a symbol
30// contained in another XCOFF object file. External reference csects are not
31// implemented yet.
32class MCSectionXCOFF final : public MCSection {
33 friend class MCContext;
34
35 std::optional<XCOFF::CsectProperties> CsectProp;
36 MCSymbolXCOFF *const QualName;
37 StringRef SymbolTableName;
38 std::optional<XCOFF::DwarfSectionSubtypeFlags> DwarfSubtypeFlags;
39 bool MultiSymbolsAllowed;
40 SectionKind Kind;
41 static constexpr unsigned DefaultAlignVal = 4;
42 static constexpr unsigned DefaultTextAlignVal = 32;
43
44 // XTY_CM sections are virtual except for toc-data symbols.
47 MCSymbol *Begin, StringRef SymbolTableName,
48 bool MultiSymbolsAllowed)
50 /*IsVirtual=*/ST == XCOFF::XTY_CM && SMC != XCOFF::XMC_TD,
51 Begin),
52 CsectProp(XCOFF::CsectProperties(SMC, ST)), QualName(QualName),
53 SymbolTableName(SymbolTableName), DwarfSubtypeFlags(std::nullopt),
54 MultiSymbolsAllowed(MultiSymbolsAllowed), Kind(K) {
55 assert(
56 (ST == XCOFF::XTY_SD || ST == XCOFF::XTY_CM || ST == XCOFF::XTY_ER) &&
57 "Invalid or unhandled type for csect.");
58 assert(QualName != nullptr && "QualName is needed.");
59 if (SMC == XCOFF::XMC_UL)
60 assert((ST == XCOFF::XTY_CM || ST == XCOFF::XTY_ER) &&
61 "Invalid csect type for storage mapping class XCOFF::XMC_UL");
62
63 QualName->setRepresentedCsect(this);
65 if (ST != XCOFF::XTY_ER) {
66 // For a csect for program code, set the alignment to 32 bytes by default.
67 // For other csects, set the alignment to 4 bytes by default.
68 if (SMC == XCOFF::XMC_PR)
69 setAlignment(Align(DefaultTextAlignVal));
70 else
71 setAlignment(Align(DefaultAlignVal));
72 }
73 }
74
75 // DWARF sections are never virtual.
76 MCSectionXCOFF(StringRef Name, SectionKind K, MCSymbolXCOFF *QualName,
77 XCOFF::DwarfSectionSubtypeFlags DwarfSubtypeFlags,
78 MCSymbol *Begin, StringRef SymbolTableName,
79 bool MultiSymbolsAllowed)
80 : MCSection(SV_XCOFF, Name, K.isText(), /*IsVirtual=*/false, Begin),
81 QualName(QualName), SymbolTableName(SymbolTableName),
82 DwarfSubtypeFlags(DwarfSubtypeFlags),
83 MultiSymbolsAllowed(MultiSymbolsAllowed), Kind(K) {
84 assert(QualName != nullptr && "QualName is needed.");
85
86 // FIXME: use a more meaningful name for non csect sections.
87 QualName->setRepresentedCsect(this);
88
89 // Use default text alignment as the alignment for DWARF sections.
90 setAlignment(Align(DefaultTextAlignVal));
91 }
92
93 void printCsectDirective(raw_ostream &OS) const;
94
95public:
97
98 static bool classof(const MCSection *S) {
99 return S->getVariant() == SV_XCOFF;
100 }
101
103 assert(isCsect() && "Only csect section has mapping class property!");
104 return CsectProp->MappingClass;
105 }
107 return QualName->getStorageClass();
108 }
110 return QualName->getVisibilityType();
111 }
113 assert(isCsect() && "Only csect section has symbol type property!");
114 return CsectProp->Type;
115 }
116 MCSymbolXCOFF *getQualNameSymbol() const { return QualName; }
117
118 void printSwitchToSection(const MCAsmInfo &MAI, const Triple &T,
120 uint32_t Subsection) const override;
121 bool useCodeAlign() const override;
122 StringRef getSymbolTableName() const { return SymbolTableName; }
123 void setSymbolTableName(StringRef STN) { SymbolTableName = STN; }
124 bool isMultiSymbolsAllowed() const { return MultiSymbolsAllowed; }
125 bool isCsect() const { return CsectProp.has_value(); }
126 bool isDwarfSect() const { return DwarfSubtypeFlags.has_value(); }
127 std::optional<XCOFF::DwarfSectionSubtypeFlags> getDwarfSubtypeFlags() const {
128 return DwarfSubtypeFlags;
129 }
130 std::optional<XCOFF::CsectProperties> getCsectProp() const {
131 return CsectProp;
132 }
133 SectionKind getKind() const { return Kind; }
134};
135
136} // end namespace llvm
137
138#endif
uint64_t Align
assert(ImpDefSCC.getReg()==AMDGPU::SCC &&ImpDefSCC.isDef())
raw_pwrite_stream & OS
This class is intended to be used as a base class for asm properties and features specific to the tar...
Definition: MCAsmInfo.h:56
Context object for machine code objects.
Definition: MCContext.h:83
std::optional< XCOFF::CsectProperties > getCsectProp() const
bool isMultiSymbolsAllowed() const
StringRef getSymbolTableName() const
XCOFF::VisibilityType getVisibilityType() const
std::optional< XCOFF::DwarfSectionSubtypeFlags > getDwarfSubtypeFlags() const
void setSymbolTableName(StringRef STN)
XCOFF::StorageClass getStorageClass() const
SectionKind getKind() const
XCOFF::StorageMappingClass getMappingClass() const
MCSymbolXCOFF * getQualNameSymbol() const
static bool classof(const MCSection *S)
void printSwitchToSection(const MCAsmInfo &MAI, const Triple &T, raw_ostream &OS, uint32_t Subsection) const override
bool useCodeAlign() const override
Return true if a .align directive should use "optimized nops" to fill instead of 0s.
bool isDwarfSect() const
XCOFF::SymbolType getCSectType() const
Instances of this class represent a uniqued identifier for a section in the current translation unit.
Definition: MCSection.h:36
void setAlignment(Align Value)
Definition: MCSection.h:147
SectionVariant getVariant() const
Definition: MCSection.h:133
bool isText() const
Definition: MCSection.h:131
StringRef Name
Definition: MCSection.h:119
void setRepresentedCsect(MCSectionXCOFF *C)
void setStorageClass(XCOFF::StorageClass SC)
Definition: MCSymbolXCOFF.h:42
MCSymbol - Instances of this class represent a symbol name in the MC file, and MCSymbols are created ...
Definition: MCSymbol.h:41
SectionKind - This is a simple POD value that classifies the properties of a section.
Definition: SectionKind.h:22
StringRef - Represent a constant reference to a string, i.e.
Definition: StringRef.h:50
Triple - Helper class for working with autoconf configuration names.
Definition: Triple.h:44
This class implements an extremely fast bulk output stream that can only output to a stream.
Definition: raw_ostream.h:52
DwarfSectionSubtypeFlags
Values for defining the section subtype of sections of type STYP_DWARF as they would appear in the (s...
Definition: XCOFF.h:154
VisibilityType
Values for visibility as they would appear when encoded in the high 4 bits of the 16-bit unsigned n_t...
Definition: XCOFF.h:251
StorageClass
Definition: XCOFF.h:170
@ C_HIDEXT
Definition: XCOFF.h:206
StorageMappingClass
Storage Mapping Class definitions.
Definition: XCOFF.h:103
@ XMC_TD
Scalar data item in the TOC.
Definition: XCOFF.h:120
@ XMC_UL
Uninitialized thread-local variable.
Definition: XCOFF.h:127
@ XMC_PR
Program Code.
Definition: XCOFF.h:105
@ XTY_CM
Common csect definition. For uninitialized storage.
Definition: XCOFF.h:245
@ XTY_SD
Csect definition for initialized storage.
Definition: XCOFF.h:242
@ XTY_ER
External reference.
Definition: XCOFF.h:241
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:18
Implement std::hash so that hash_code can be used in STL containers.
Definition: BitVector.h:858