LLVM  14.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/MCCodeEmitter.h"
17 #include "llvm/MC/MCDirectives.h"
18 #include "llvm/MC/MCObjectWriter.h"
19 #include "llvm/MC/MCSectionXCOFF.h"
20 #include "llvm/MC/MCSymbolXCOFF.h"
21 #include "llvm/MC/TargetRegistry.h"
22 
23 using namespace llvm;
24 
26  std::unique_ptr<MCAsmBackend> MAB,
27  std::unique_ptr<MCObjectWriter> OW,
28  std::unique_ptr<MCCodeEmitter> Emitter)
29  : MCObjectStreamer(Context, std::move(MAB), std::move(OW),
30  std::move(Emitter)) {}
31 
34  auto *Symbol = cast<MCSymbolXCOFF>(Sym);
36 
37  switch (Attribute) {
38  case MCSA_Global:
39  case MCSA_Extern:
40  Symbol->setStorageClass(XCOFF::C_EXT);
41  Symbol->setExternal(true);
42  break;
43  case MCSA_LGlobal:
44  Symbol->setStorageClass(XCOFF::C_HIDEXT);
45  Symbol->setExternal(true);
46  break;
47  case llvm::MCSA_Weak:
48  Symbol->setStorageClass(XCOFF::C_WEAKEXT);
49  Symbol->setExternal(true);
50  break;
51  case llvm::MCSA_Hidden:
52  Symbol->setVisibilityType(XCOFF::SYM_V_HIDDEN);
53  break;
55  Symbol->setVisibilityType(XCOFF::SYM_V_PROTECTED);
56  break;
57  default:
58  report_fatal_error("Not implemented yet.");
59  }
60  return true;
61 }
62 
65 
67 
68  // When the caller passes `MCSA_Invalid` for the visibility, do not emit one.
69  if (Visibility == MCSA_Invalid)
70  return;
71 
72  emitSymbolAttribute(Symbol, Visibility);
73 }
74 
76  unsigned ByteAlignment) {
78  Symbol->setExternal(cast<MCSymbolXCOFF>(Symbol)->getStorageClass() !=
80  Symbol->setCommon(Size, ByteAlignment);
81 
82  // Default csect align is 4, but common symbols have explicit alignment values
83  // and we should honor it.
84  cast<MCSymbolXCOFF>(Symbol)->getRepresentedCsect()->setAlignment(
86 
87  // Emit the alignment and storage for the variable to the section.
89  emitZeros(Size);
90 }
91 
93  uint64_t Size, unsigned ByteAlignment,
94  SMLoc Loc) {
95  report_fatal_error("Zero fill not implemented for XCOFF.");
96 }
97 
99  const MCSubtargetInfo &STI) {
100  MCAssembler &Assembler = getAssembler();
102  SmallString<256> Code;
103  raw_svector_ostream VecOS(Code);
104  Assembler.getEmitter().encodeInstruction(Inst, VecOS, Fixups, STI);
105 
106  // Add the fixups and data.
108  const size_t ContentsSize = DF->getContents().size();
109  auto &DataFragmentFixups = DF->getFixups();
110  for (auto &Fixup : Fixups) {
111  Fixup.setOffset(Fixup.getOffset() + ContentsSize);
112  DataFragmentFixups.push_back(Fixup);
113  }
114 
115  DF->setHasInstructions(STI);
116  DF->getContents().append(Code.begin(), Code.end());
117 }
118 
120  std::unique_ptr<MCAsmBackend> &&MAB,
121  std::unique_ptr<MCObjectWriter> &&OW,
122  std::unique_ptr<MCCodeEmitter> &&CE,
123  bool RelaxAll) {
125  std::move(OW), std::move(CE));
126  if (RelaxAll)
127  S->getAssembler().setRelaxAll(true);
128  return S;
129 }
130 
132  uint64_t Size,
133  MCSymbol *CsectSym,
134  unsigned ByteAlignment) {
135  emitCommonSymbol(CsectSym, Size, ByteAlignment);
136 }
llvm::Check::Size
@ Size
Definition: FileCheck.h:73
llvm
This file implements support for optimizing divisions by a constant.
Definition: AllocatorList.h:23
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:63
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:463
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:597
llvm::MCContext
Context object for machine code objects.
Definition: MCContext.h:72
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:1168
llvm::MCXCOFFStreamer::emitCommonSymbol
void emitCommonSymbol(MCSymbol *Symbol, uint64_t Size, unsigned ByteAlignment) override
Emit a common symbol.
Definition: MCXCOFFStreamer.cpp:75
llvm::MCXCOFFStreamer::emitSymbolAttribute
bool emitSymbolAttribute(MCSymbol *Symbol, MCSymbolAttr Attribute) override
Add the given Attribute to Symbol.
Definition: MCXCOFFStreamer.cpp:32
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:198
llvm::MCSymbolAttr
MCSymbolAttr
Definition: MCDirectives.h:18
Context
LLVMContext & Context
Definition: NVVMIntrRange.cpp:66
llvm::ARMBuildAttrs::Section
@ Section
Legacy Tags.
Definition: ARMBuildAttributes.h:78
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:92
llvm::MCStreamer
Streaming machine code generation interface.
Definition: MCStreamer.h:199
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:42
llvm::MCSA_LGlobal
@ MCSA_LGlobal
.lglobl (XCOFF)
Definition: MCDirectives.h:31
llvm::MCObjectStreamer
Streaming object file generation interface.
Definition: MCObjectStreamer.h:36
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:140
llvm::MCSA_Hidden
@ MCSA_Hidden
.hidden (ELF)
Definition: MCDirectives.h:33
Align
uint64_t Align
Definition: ELFObjHandler.cpp:83
MCSectionXCOFF.h
DF
static RegisterPass< DebugifyFunctionPass > DF("debugify-function", "Attach debug info to a function")
llvm::SmallString< 256 >
llvm::XCOFF::C_EXT
@ C_EXT
Definition: XCOFF.h:141
llvm::MCAssembler
Definition: MCAssembler.h:60
llvm::MCXCOFFStreamer::MCXCOFFStreamer
MCXCOFFStreamer(MCContext &Context, std::unique_ptr< MCAsmBackend > MAB, std::unique_ptr< MCObjectWriter > OW, std::unique_ptr< MCCodeEmitter > Emitter)
Definition: MCXCOFFStreamer.cpp:25
llvm::MCAssembler::getEmitter
MCCodeEmitter & getEmitter() const
Definition: MCAssembler.h:302
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:119
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:149
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:1609
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:131
llvm::MCObjectStreamer::getAssembler
MCAssembler & getAssembler()
Definition: MCObjectStreamer.h:112
llvm::MCXCOFFStreamer::emitInstToData
void emitInstToData(const MCInst &Inst, const MCSubtargetInfo &) override
Definition: MCXCOFFStreamer.cpp:98
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:203
Fixup
PowerPC TLS Dynamic Call Fixup
Definition: PPCTLSDynamicCall.cpp:235
llvm::XCOFF::C_WEAKEXT
@ C_WEAKEXT
Definition: XCOFF.h:142
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:197
llvm::MCXCOFFStreamer
Definition: MCXCOFFStreamer.h:16
MCObjectWriter.h
std
Definition: BitVector.h:838
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:79
llvm::MCSA_Weak
@ MCSA_Weak
.weak
Definition: MCDirectives.h:44
MCXCOFFStreamer.h
llvm::raw_svector_ostream
A raw_ostream that writes to an SmallVector or SmallString.
Definition: raw_ostream.h:658
llvm::MCDataFragment
Fragment for data and encoded instructions.
Definition: MCFragment.h:242
TargetRegistry.h
llvm::MCSubtargetInfo
Generic base class for all target subtargets.
Definition: MCSubtargetInfo.h:75
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:226