LLVM  15.0.0git
MCXCOFFStreamer.cpp
Go to the documentation of this file.
1 //===- lib/MC/MCXCOFFStreamer.cpp - XCOFF Object Output -------------------===//
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 assembles .s files and emits XCOFF .o object files.
10 //
11 //===----------------------------------------------------------------------===//
12 
15 #include "llvm/MC/MCAsmBackend.h"
16 #include "llvm/MC/MCAssembler.h"
17 #include "llvm/MC/MCCodeEmitter.h"
18 #include "llvm/MC/MCDirectives.h"
19 #include "llvm/MC/MCObjectWriter.h"
20 #include "llvm/MC/MCSectionXCOFF.h"
21 #include "llvm/MC/MCSymbolXCOFF.h"
22 #include "llvm/MC/TargetRegistry.h"
23 #include "llvm/Support/Casting.h"
24 
25 using namespace llvm;
26 
28  std::unique_ptr<MCAsmBackend> MAB,
29  std::unique_ptr<MCObjectWriter> OW,
30  std::unique_ptr<MCCodeEmitter> Emitter)
31  : MCObjectStreamer(Context, std::move(MAB), std::move(OW),
32  std::move(Emitter)) {}
33 
36  auto *Symbol = cast<MCSymbolXCOFF>(Sym);
38 
39  switch (Attribute) {
40  case MCSA_Global:
41  case MCSA_Extern:
42  Symbol->setStorageClass(XCOFF::C_EXT);
43  Symbol->setExternal(true);
44  break;
45  case MCSA_LGlobal:
46  Symbol->setStorageClass(XCOFF::C_HIDEXT);
47  Symbol->setExternal(true);
48  break;
49  case llvm::MCSA_Weak:
50  Symbol->setStorageClass(XCOFF::C_WEAKEXT);
51  Symbol->setExternal(true);
52  break;
53  case llvm::MCSA_Hidden:
54  Symbol->setVisibilityType(XCOFF::SYM_V_HIDDEN);
55  break;
57  Symbol->setVisibilityType(XCOFF::SYM_V_PROTECTED);
58  break;
60  Symbol->setVisibilityType(XCOFF::SYM_V_EXPORTED);
61  break;
62  default:
63  report_fatal_error("Not implemented yet.");
64  }
65  return true;
66 }
67 
69  MCSymbol *Symbol, MCSymbolAttr Linkage, MCSymbolAttr Visibility) {
70 
71  emitSymbolAttribute(Symbol, Linkage);
72 
73  // When the caller passes `MCSA_Invalid` for the visibility, do not emit one.
74  if (Visibility == MCSA_Invalid)
75  return;
76 
77  emitSymbolAttribute(Symbol, Visibility);
78 }
79 
81  unsigned ByteAlignment) {
83  Symbol->setExternal(cast<MCSymbolXCOFF>(Symbol)->getStorageClass() !=
85  Symbol->setCommon(Size, ByteAlignment);
86 
87  // Default csect align is 4, but common symbols have explicit alignment values
88  // and we should honor it.
89  cast<MCSymbolXCOFF>(Symbol)->getRepresentedCsect()->setAlignment(
91 
92  // Emit the alignment and storage for the variable to the section.
94  emitZeros(Size);
95 }
96 
98  uint64_t Size, unsigned ByteAlignment,
99  SMLoc Loc) {
100  report_fatal_error("Zero fill not implemented for XCOFF.");
101 }
102 
104  const MCSubtargetInfo &STI) {
105  MCAssembler &Assembler = getAssembler();
107  SmallString<256> Code;
108  raw_svector_ostream VecOS(Code);
109  Assembler.getEmitter().encodeInstruction(Inst, VecOS, Fixups, STI);
110 
111  // Add the fixups and data.
113  const size_t ContentsSize = DF->getContents().size();
114  auto &DataFragmentFixups = DF->getFixups();
115  for (auto &Fixup : Fixups) {
116  Fixup.setOffset(Fixup.getOffset() + ContentsSize);
117  DataFragmentFixups.push_back(Fixup);
118  }
119 
120  DF->setHasInstructions(STI);
121  DF->getContents().append(Code.begin(), Code.end());
122 }
123 
125  std::unique_ptr<MCAsmBackend> &&MAB,
126  std::unique_ptr<MCObjectWriter> &&OW,
127  std::unique_ptr<MCCodeEmitter> &&CE,
128  bool RelaxAll) {
130  std::move(OW), std::move(CE));
131  if (RelaxAll)
132  S->getAssembler().setRelaxAll(true);
133  return S;
134 }
135 
137  uint64_t Size,
138  MCSymbol *CsectSym,
139  unsigned ByteAlignment) {
140  emitCommonSymbol(CsectSym, Size, ByteAlignment);
141 }
llvm
This is an optimization pass for GlobalISel generic memory operations.
Definition: AddressRanges.h:17
llvm::MCXCOFFStreamer::emitXCOFFSymbolLinkageWithVisibility
void emitXCOFFSymbolLinkageWithVisibility(MCSymbol *Symbol, MCSymbolAttr Linkage, MCSymbolAttr Visibility) override
Emit a symbol's linkage and visibility with a linkage directive for XCOFF.
Definition: MCXCOFFStreamer.cpp:68
llvm::MCSymbol
MCSymbol - Instances of this class represent a symbol name in the MC file, and MCSymbols are created ...
Definition: MCSymbol.h:41
llvm::MCAssembler::registerSymbol
void registerSymbol(const MCSymbol &Symbol, bool *Created=nullptr)
Definition: MCAssembler.cpp:467
llvm::MCObjectStreamer::emitValueToAlignment
void emitValueToAlignment(unsigned ByteAlignment, int64_t Value=0, unsigned ValueSize=1, unsigned MaxBytesToEmit=0) override
Emit some number of copies of Value until the byte alignment ByteAlignment is reached.
Definition: MCObjectStreamer.cpp:644
llvm::MCContext
Context object for machine code objects.
Definition: MCContext.h:74
llvm::Attribute
Definition: Attributes.h:52
MCCodeEmitter.h
MCDirectives.h
llvm::MCSA_Invalid
@ MCSA_Invalid
Not a valid directive.
Definition: MCDirectives.h:19
llvm::SmallVector
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
Definition: SmallVector.h:1185
llvm::MCXCOFFStreamer::emitCommonSymbol
void emitCommonSymbol(MCSymbol *Symbol, uint64_t Size, unsigned ByteAlignment) override
Emit a common symbol.
Definition: MCXCOFFStreamer.cpp:80
llvm::MCXCOFFStreamer::emitSymbolAttribute
bool emitSymbolAttribute(MCSymbol *Symbol, MCSymbolAttr Attribute) override
Add the given Attribute to Symbol.
Definition: MCXCOFFStreamer.cpp:34
MCAssembler.h
llvm::MCInst
Instances of this class represent a single low-level machine instruction.
Definition: MCInst.h:184
llvm::XCOFF::SYM_V_PROTECTED
@ SYM_V_PROTECTED
Definition: XCOFF.h:239
llvm::MCSymbolAttr
MCSymbolAttr
Definition: MCDirectives.h:18
Context
LLVMContext & Context
Definition: NVVMIntrRange.cpp:66
XCOFF.h
llvm::MCXCOFFStreamer::emitZerofill
void emitZerofill(MCSection *Section, MCSymbol *Symbol=nullptr, uint64_t Size=0, unsigned ByteAlignment=0, SMLoc Loc=SMLoc()) override
Emit the zerofill section and an optional symbol.
Definition: MCXCOFFStreamer.cpp:97
llvm::MCStreamer
Streaming machine code generation interface.
Definition: MCStreamer.h:201
MCAsmBackend.h
llvm::SMLoc
Represents a location in source code.
Definition: SMLoc.h:23
llvm::MCSA_Extern
@ MCSA_Extern
.extern (XCOFF)
Definition: MCDirectives.h:32
llvm::MCSA_Protected
@ MCSA_Protected
.protected (ELF)
Definition: MCDirectives.h:43
llvm::MCSA_LGlobal
@ MCSA_LGlobal
.lglobl (XCOFF)
Definition: MCDirectives.h:31
llvm::MCObjectStreamer
Streaming object file generation interface.
Definition: MCObjectStreamer.h:42
llvm::AArch64::Fixups
Fixups
Definition: AArch64FixupKinds.h:17
llvm::report_fatal_error
void report_fatal_error(Error Err, bool gen_crash_diag=true)
Report a serious error, calling any installed error handler.
Definition: Error.cpp:143
llvm::MCSA_Hidden
@ MCSA_Hidden
.hidden (ELF)
Definition: MCDirectives.h:33
Align
uint64_t Align
Definition: ELFObjHandler.cpp:81
MCSectionXCOFF.h
DF
static RegisterPass< DebugifyFunctionPass > DF("debugify-function", "Attach debug info to a function")
llvm::SmallString< 256 >
llvm::MCSA_Exported
@ MCSA_Exported
.globl _foo, exported (XCOFF)
Definition: MCDirectives.h:34
llvm::XCOFF::C_EXT
@ C_EXT
Definition: XCOFF.h:182
llvm::XCOFF::SYM_V_EXPORTED
@ SYM_V_EXPORTED
Definition: XCOFF.h:240
llvm::MCAssembler
Definition: MCAssembler.h:73
llvm::MCXCOFFStreamer::MCXCOFFStreamer
MCXCOFFStreamer(MCContext &Context, std::unique_ptr< MCAsmBackend > MAB, std::unique_ptr< MCObjectWriter > OW, std::unique_ptr< MCCodeEmitter > Emitter)
Definition: MCXCOFFStreamer.cpp:27
llvm::MCAssembler::getEmitter
MCCodeEmitter & getEmitter() const
Definition: MCAssembler.h:331
llvm::createXCOFFStreamer
MCStreamer * createXCOFFStreamer(MCContext &Ctx, std::unique_ptr< MCAsmBackend > &&TAB, std::unique_ptr< MCObjectWriter > &&OW, std::unique_ptr< MCCodeEmitter > &&CE, bool RelaxAll)
Definition: MCXCOFFStreamer.cpp:124
uint64_t
move
compiles ldr LCPI1_0 ldr ldr mov lsr tst moveq r1 ldr LCPI1_1 and r0 bx lr It would be better to do something like to fold the shift into the conditional move
Definition: README.txt:546
MCSymbolXCOFF.h
llvm::XCOFF::C_HIDEXT
@ C_HIDEXT
Definition: XCOFF.h:190
llvm::move
OutputIt move(R &&Range, OutputIt Out)
Provide wrappers to std::move which take ranges instead of having to pass begin/end explicitly.
Definition: STLExtras.h:1663
llvm::MCXCOFFStreamer::emitXCOFFLocalCommonSymbol
void emitXCOFFLocalCommonSymbol(MCSymbol *LabelSym, uint64_t Size, MCSymbol *CsectSym, unsigned ByteAlign) override
Emits an lcomm directive with XCOFF csect information.
Definition: MCXCOFFStreamer.cpp:136
llvm::MCObjectStreamer::getAssembler
MCAssembler & getAssembler()
Definition: MCObjectStreamer.h:128
llvm::MCXCOFFStreamer::emitInstToData
void emitInstToData(const MCInst &Inst, const MCSubtargetInfo &) override
Definition: MCXCOFFStreamer.cpp:103
llvm::MCObjectStreamer::getOrCreateDataFragment
MCDataFragment * getOrCreateDataFragment(const MCSubtargetInfo *STI=nullptr)
Get a data fragment to write into, creating a new one if the current fragment is not a data fragment.
Definition: MCObjectStreamer.cpp:225
Fixup
PowerPC TLS Dynamic Call Fixup
Definition: PPCTLSDynamicCall.cpp:233
llvm::XCOFF::C_WEAKEXT
@ C_WEAKEXT
Definition: XCOFF.h:183
llvm::MCSection
Instances of this class represent a uniqued identifier for a section in the current translation unit.
Definition: MCSection.h:39
S
add sub stmia L5 ldr r0 bl L_printf $stub Instead of a and a wouldn t it be better to do three moves *Return an aggregate type is even return S
Definition: README.txt:210
llvm::XCOFF::SYM_V_HIDDEN
@ SYM_V_HIDDEN
Definition: XCOFF.h:238
llvm::MCXCOFFStreamer
Definition: MCXCOFFStreamer.h:16
MCObjectWriter.h
std
Definition: BitVector.h:851
Casting.h
llvm::MCSA_Global
@ MCSA_Global
.type _foo, @gnu_unique_object
Definition: MCDirectives.h:30
llvm::LCOMM::ByteAlignment
@ ByteAlignment
Definition: MCAsmInfo.h:50
llvm::ARMBuildAttrs::Symbol
@ Symbol
Definition: ARMBuildAttributes.h:83
llvm::MCSA_Weak
@ MCSA_Weak
.weak
Definition: MCDirectives.h:45
MCXCOFFStreamer.h
llvm::raw_svector_ostream
A raw_ostream that writes to an SmallVector or SmallString.
Definition: raw_ostream.h:662
llvm::MCDataFragment
Fragment for data and encoded instructions.
Definition: MCFragment.h:241
TargetRegistry.h
llvm::MCSubtargetInfo
Generic base class for all target subtargets.
Definition: MCSubtargetInfo.h:76
llvm::MCCodeEmitter::encodeInstruction
virtual void encodeInstruction(const MCInst &Inst, raw_ostream &OS, SmallVectorImpl< MCFixup > &Fixups, const MCSubtargetInfo &STI) const =0
EncodeInstruction - Encode the given Inst to bytes on the output stream OS.
llvm::MCStreamer::emitZeros
void emitZeros(uint64_t NumBytes)
Emit NumBytes worth of zeros.
Definition: MCStreamer.cpp:227