1 //===- lib/MC/MCXCOFFStreamer.cpp - XCOFF Object Output -------------------===//
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 assembles .s files and emits XCOFF .o object files.
11 //===----------------------------------------------------------------------===//
13 #include "llvm/BinaryFormat/XCOFF.h"
14 #include "llvm/MC/MCAsmBackend.h"
15 #include "llvm/MC/MCCodeEmitter.h"
16 #include "llvm/MC/MCObjectWriter.h"
17 #include "llvm/MC/MCSymbolXCOFF.h"
18 #include "llvm/MC/MCXCOFFStreamer.h"
19 #include "llvm/Support/TargetRegistry.h"
23 MCXCOFFStreamer::MCXCOFFStreamer(MCContext
&Context
,
24 std::unique_ptr
<MCAsmBackend
> MAB
,
25 std::unique_ptr
<MCObjectWriter
> OW
,
26 std::unique_ptr
<MCCodeEmitter
> Emitter
)
27 : MCObjectStreamer(Context
, std::move(MAB
), std::move(OW
),
28 std::move(Emitter
)) {}
30 bool MCXCOFFStreamer::EmitSymbolAttribute(MCSymbol
*Sym
,
31 MCSymbolAttr Attribute
) {
32 auto *Symbol
= cast
<MCSymbolXCOFF
>(Sym
);
33 getAssembler().registerSymbol(*Symbol
);
37 Symbol
->setStorageClass(XCOFF::C_EXT
);
38 Symbol
->setExternal(true);
41 report_fatal_error("Not implemented yet.");
46 void MCXCOFFStreamer::EmitCommonSymbol(MCSymbol
*Symbol
, uint64_t Size
,
47 unsigned ByteAlignment
) {
48 getAssembler().registerSymbol(*Symbol
);
49 Symbol
->setExternal(cast
<MCSymbolXCOFF
>(Symbol
)->getStorageClass() !=
51 Symbol
->setCommon(Size
, ByteAlignment
);
53 // Need to add this symbol to the current Fragment which will belong to the
55 auto *F
= dyn_cast_or_null
<MCDataFragment
>(getCurrentFragment());
56 assert(F
&& "Expected a valid section with a fragment set.");
57 Symbol
->setFragment(F
);
59 // Emit the alignment and storage for the variable to the section.
60 EmitValueToAlignment(ByteAlignment
);
64 void MCXCOFFStreamer::EmitZerofill(MCSection
*Section
, MCSymbol
*Symbol
,
65 uint64_t Size
, unsigned ByteAlignment
,
67 report_fatal_error("Zero fill not implemented for XCOFF.");
70 void MCXCOFFStreamer::EmitInstToData(const MCInst
&Inst
,
71 const MCSubtargetInfo
&STI
) {
72 MCAssembler
&Assembler
= getAssembler();
73 SmallVector
<MCFixup
, 4> Fixups
;
74 SmallString
<256> Code
;
75 raw_svector_ostream
VecOS(Code
);
76 Assembler
.getEmitter().encodeInstruction(Inst
, VecOS
, Fixups
, STI
);
78 // TODO: Handle Fixups later
80 MCDataFragment
*DF
= getOrCreateDataFragment(&STI
);
81 DF
->setHasInstructions(STI
);
82 DF
->getContents().append(Code
.begin(), Code
.end());
85 MCStreamer
*llvm::createXCOFFStreamer(MCContext
&Context
,
86 std::unique_ptr
<MCAsmBackend
> &&MAB
,
87 std::unique_ptr
<MCObjectWriter
> &&OW
,
88 std::unique_ptr
<MCCodeEmitter
> &&CE
,
90 MCXCOFFStreamer
*S
= new MCXCOFFStreamer(Context
, std::move(MAB
),
91 std::move(OW
), std::move(CE
));
93 S
->getAssembler().setRelaxAll(true);
97 void MCXCOFFStreamer::EmitXCOFFLocalCommonSymbol(MCSymbol
*Symbol
,
99 unsigned ByteAlignment
) {
100 EmitCommonSymbol(Symbol
, Size
, ByteAlignment
);