LLVM 23.0.0git
MCObjectStreamer.cpp
Go to the documentation of this file.
1//===- lib/MC/MCObjectStreamer.cpp - Object File MCStreamer Interface -----===//
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
11#include "llvm/MC/MCAsmInfo.h"
12#include "llvm/MC/MCAssembler.h"
14#include "llvm/MC/MCCodeView.h"
15#include "llvm/MC/MCContext.h"
16#include "llvm/MC/MCDwarf.h"
17#include "llvm/MC/MCExpr.h"
21#include "llvm/MC/MCSFrame.h"
22#include "llvm/MC/MCSection.h"
23#include "llvm/MC/MCSymbol.h"
26using namespace llvm;
27
29 std::unique_ptr<MCAsmBackend> TAB,
30 std::unique_ptr<MCObjectWriter> OW,
31 std::unique_ptr<MCCodeEmitter> Emitter)
32 : MCStreamer(Context),
33 Assembler(std::make_unique<MCAssembler>(
34 Context, std::move(TAB), std::move(Emitter), std::move(OW))),
35 EmitEHFrame(true), EmitDebugFrame(false), EmitSFrame(false) {
36 assert(Assembler->getBackendPtr() && Assembler->getEmitterPtr());
37 IsObj = true;
38 setAllowAutoPadding(Assembler->getBackend().allowAutoPadding());
39 if (Context.getTargetOptions()->MCRelaxAll)
40 Assembler->setRelaxAll(true);
41}
42
44
47 return Assembler.get();
48 return nullptr;
49}
50
51constexpr size_t FragBlockSize = 16384;
52// Ensure the new fragment can at least store a few bytes.
53constexpr size_t NewFragHeadroom = 8;
54
55static_assert(NewFragHeadroom >= alignof(MCFragment));
56static_assert(FragBlockSize >= sizeof(MCFragment) + NewFragHeadroom);
57
59 auto Size = std::max(FragBlockSize, sizeof(MCFragment) + Headroom);
60 FragSpace = Size - sizeof(MCFragment);
61 auto Block = std::unique_ptr<uint8_t[]>(new uint8_t[Size]);
62 auto *F = reinterpret_cast<MCFragment *>(Block.get());
63 FragStorage.push_back(std::move(Block));
64 return F;
65}
66
69 if (LLVM_LIKELY(sizeof(MCFragment) + NewFragHeadroom <= FragSpace)) {
70 auto End = reinterpret_cast<size_t>(getCurFragEnd());
71 F = reinterpret_cast<MCFragment *>(
72 alignToPowerOf2(End, alignof(MCFragment)));
73 FragSpace -= size_t(F) - End + sizeof(MCFragment);
74 } else {
75 F = allocFragSpace(0);
76 }
77 new (F) MCFragment();
79}
80
81void MCObjectStreamer::ensureHeadroom(size_t Headroom) {
82 if (Headroom <= FragSpace)
83 return;
84 auto *F = allocFragSpace(Headroom);
85 new (F) MCFragment();
87}
88
89void MCObjectStreamer::addSpecialFragment(MCFragment *Frag) {
91 "Frag should have a variable-size tail");
92 // Frag is not connected to FragSpace. Before modifying CurFrag with
93 // addFragment(Frag), allocate an empty fragment to maintain FragSpace
94 // connectivity, potentially reusing CurFrag's associated space.
96 if (LLVM_LIKELY(sizeof(MCFragment) + NewFragHeadroom <= FragSpace)) {
97 auto End = reinterpret_cast<size_t>(getCurFragEnd());
98 F = reinterpret_cast<MCFragment *>(
99 alignToPowerOf2(End, alignof(MCFragment)));
100 FragSpace -= size_t(F) - End + sizeof(MCFragment);
101 } else {
102 F = allocFragSpace(0);
103 }
104 new (F) MCFragment();
105
106 addFragment(Frag);
107 addFragment(F);
108}
109
111 ensureHeadroom(Contents.size());
112 assert(FragSpace >= Contents.size());
113 // As this is performance-sensitive code, explicitly use std::memcpy.
114 // Optimization of std::copy to memmove is unreliable.
115 if (!Contents.empty())
116 std::memcpy(getCurFragEnd(), Contents.begin(), Contents.size());
117 CurFrag->FixedSize += Contents.size();
118 FragSpace -= Contents.size();
119}
120
122 ensureHeadroom(Num);
124 llvm::fill(Data, Elt);
125 CurFrag->FixedSize += Num;
126 FragSpace -= Num;
127}
128
132
133// As a compile-time optimization, avoid allocating and evaluating an MCExpr
134// tree for (Hi - Lo) when Hi and Lo are offsets into the same fragment's fixed
135// part.
136static std::optional<uint64_t> absoluteSymbolDiff(const MCSymbol *Hi,
137 const MCSymbol *Lo) {
138 assert(Hi && Lo);
139 if (Lo == Hi)
140 return 0;
141 if (Hi->isVariable() || Lo->isVariable())
142 return std::nullopt;
143 auto *LoF = Lo->getFragment();
144 if (!LoF || Hi->getFragment() != LoF || LoF->isLinkerRelaxable())
145 return std::nullopt;
146 // If either symbol resides in the variable part, bail out.
147 auto Fixed = LoF->getFixedSize();
148 if (Lo->getOffset() > Fixed || Hi->getOffset() > Fixed)
149 return std::nullopt;
150
151 return Hi->getOffset() - Lo->getOffset();
152}
153
155 const MCSymbol *Lo,
156 unsigned Size) {
157 if (std::optional<uint64_t> Diff = absoluteSymbolDiff(Hi, Lo))
158 emitIntValue(*Diff, Size);
159 else
161}
162
164 const MCSymbol *Lo) {
165 if (std::optional<uint64_t> Diff = absoluteSymbolDiff(Hi, Lo))
166 emitULEB128IntValue(*Diff);
167 else
169}
170
172 if (Assembler) {
173 Assembler->reset();
174 Assembler->setRelaxAll(getContext().getTargetOptions()->MCRelaxAll);
175 }
176 EmitEHFrame = true;
177 EmitDebugFrame = false;
178 FragStorage.clear();
179 FragSpace = 0;
180 SpecialFragAllocator.Reset();
182}
183
185 auto &Backend = getAssembler().getBackend();
186 for (auto &FI : DwarfFrameInfos)
187 FI.CompactUnwindEncoding =
189}
190
192 if (!getNumFrameInfos())
193 return;
194
195 if (EmitEHFrame)
196 MCDwarfFrameEmitter::emit(*this, true);
197 if (EmitDebugFrame)
198 MCDwarfFrameEmitter::emit(*this, false);
199
200 if (EmitSFrame || getContext().getTargetOptions()->EmitSFrameUnwind)
202}
203
205 Assembler->registerSymbol(Sym);
206}
207
208void MCObjectStreamer::emitCFISections(bool EH, bool Debug, bool SFrame) {
210 EmitEHFrame = EH;
211 EmitDebugFrame = Debug;
212 EmitSFrame = SFrame;
213}
214
216 SMLoc Loc) {
218
220
221 // Avoid fixups when possible.
222 int64_t AbsValue;
223 if (Value->evaluateAsAbsolute(AbsValue, getAssemblerPtr())) {
224 if (!isUIntN(8 * Size, AbsValue) && !isIntN(8 * Size, AbsValue)) {
226 Loc, "value evaluated as " + Twine(AbsValue) + " is out of range.");
227 return;
228 }
229 emitIntValue(AbsValue, Size);
230 return;
231 }
235}
236
238 MCSymbol *Label = getContext().createTempSymbol("cfi");
239 emitLabel(Label);
240 return Label;
241}
242
243void MCObjectStreamer::emitCFIStartProcImpl(MCDwarfFrameInfo &Frame) {
244 // We need to create a local symbol to avoid relocations.
246 emitLabel(Frame.Begin);
247}
248
249void MCObjectStreamer::emitCFIEndProcImpl(MCDwarfFrameInfo &Frame) {
250 Frame.End = getContext().createTempSymbol();
251 emitLabel(Frame.End);
252}
253
255 MCStreamer::emitLabel(Symbol, Loc);
256 // If Symbol is a non-redefiniable variable, emitLabel has reported an error.
257 // Bail out.
258 if (Symbol->isVariable())
259 return;
260
261 getAssembler().registerSymbol(*Symbol);
262
263 // Set the fragment and offset. This function might be called by
264 // changeSection, when the section stack top hasn't been changed to the new
265 // section.
267 Symbol->setFragment(F);
268 Symbol->setOffset(F->getFixedSize());
269
271}
272
274 auto Assignments = pendingAssignments.find(Symbol);
275 if (Assignments != pendingAssignments.end()) {
276 for (const PendingAssignment &A : Assignments->second)
277 emitAssignment(A.Symbol, A.Value);
278
279 pendingAssignments.erase(Assignments);
280 }
281}
282
283// Emit a label at a previously emitted fragment/offset position. This must be
284// within the currently-active section.
287 assert(F.getParent() == getCurrentSectionOnly());
288 MCStreamer::emitLabel(Symbol, Loc);
289 getAssembler().registerSymbol(*Symbol);
290 Symbol->setFragment(&F);
291 Symbol->setOffset(Offset);
292}
293
295 int64_t IntValue;
296 if (Value->evaluateAsAbsolute(IntValue, getAssembler())) {
297 emitULEB128IntValue(IntValue);
298 return;
299 }
300 auto *F = getCurrentFragment();
301 F->makeLEB(false, Value);
302 newFragment();
303}
304
306 int64_t IntValue;
307 if (Value->evaluateAsAbsolute(IntValue, getAssembler())) {
308 emitSLEB128IntValue(IntValue);
309 return;
310 }
311 auto *F = getCurrentFragment();
312 F->makeLEB(true, Value);
313 newFragment();
314}
315
317 const MCSymbol *Target) {
318 reportFatalUsageError("this file format doesn't support weak aliases");
319}
320
322 assert(Section && "Cannot switch to a null section!");
324
325 // Register the section and create an initial fragment for subsection 0
326 // if `Subsection` is non-zero.
327 bool NewSec = getAssembler().registerSection(*Section);
328 MCFragment *F0 = nullptr;
329 if (NewSec && Subsection) {
330 changeSection(Section, 0);
331 F0 = CurFrag;
332 }
333
334 // To maintain connectivity between CurFrag and FragSpace when CurFrag is
335 // modified, allocate an empty fragment and append it to the fragment list.
336 // (Subsections[I].second.Tail is not connected to FragSpace.)
337 MCFragment *F;
338 if (LLVM_LIKELY(sizeof(MCFragment) + NewFragHeadroom <= FragSpace)) {
339 auto End = reinterpret_cast<size_t>(getCurFragEnd());
340 F = reinterpret_cast<MCFragment *>(
341 alignToPowerOf2(End, alignof(MCFragment)));
342 FragSpace -= size_t(F) - End + sizeof(MCFragment);
343 } else {
344 F = allocFragSpace(0);
345 }
346 new (F) MCFragment();
347 F->setParent(Section);
348
349 auto &Subsections = Section->Subsections;
350 size_t I = 0, E = Subsections.size();
351 while (I != E && Subsections[I].first < Subsection)
352 ++I;
353 // If the subsection number is not in the sorted Subsections list, create a
354 // new fragment list.
355 if (I == E || Subsections[I].first != Subsection) {
356 Subsections.insert(Subsections.begin() + I,
357 {Subsection, MCSection::FragList{F, F}});
358 Section->CurFragList = &Subsections[I].second;
359 CurFrag = F;
360 } else {
361 Section->CurFragList = &Subsections[I].second;
362 CurFrag = Subsections[I].second.Tail;
363 // Ensure CurFrag is associated with FragSpace.
364 addFragment(F);
365 }
366
367 // Define the section symbol at subsection 0's initial fragment if required.
368 if (!NewSec)
369 return;
370 if (auto *Sym = Section->getBeginSymbol()) {
371 Sym->setFragment(Subsection ? F0 : CurFrag);
372 getAssembler().registerSymbol(*Sym);
373 }
374}
375
381
383 const MCExpr *Value) {
384 const MCSymbol *Target = &cast<MCSymbolRefExpr>(*Value).getSymbol();
385
386 // If the symbol already exists, emit the assignment. Otherwise, emit it
387 // later only if the symbol is also emitted.
388 if (Target->isRegistered())
389 emitAssignment(Symbol, Value);
390 else
391 pendingAssignments[Target].push_back({Symbol, Value});
392}
393
395 return Sec.hasInstructions();
396}
397
399 const MCSubtargetInfo &STI) {
400 if (LFIRewriter && LFIRewriter->rewriteInst(Inst, *this, STI))
401 return;
402
404
406 Sec->setHasInstructions(true);
407
408 // Now that a machine instruction has been assembled into this section, make
409 // a line entry for any .loc directive that has been seen.
411
412 // If this instruction doesn't need relaxation, just emit it as data.
413 MCAssembler &Assembler = getAssembler();
414 MCAsmBackend &Backend = Assembler.getBackend();
415 if (!(Backend.mayNeedRelaxation(Inst.getOpcode(), Inst.getOperands(), STI) ||
416 Backend.allowEnhancedRelaxation())) {
417 emitInstToData(Inst, STI);
418 return;
419 }
420
421 // Otherwise, relax and emit it as data if RelaxAll is specified.
422 if (Assembler.getRelaxAll()) {
423 MCInst Relaxed = Inst;
424 while (Backend.mayNeedRelaxation(Relaxed.getOpcode(), Relaxed.getOperands(),
425 STI))
426 Backend.relaxInstruction(Relaxed, STI);
427 emitInstToData(Relaxed, STI);
428 return;
429 }
430
431 emitInstToFragment(Inst, STI);
432}
433
434void MCObjectStreamer::emitInstToData(const MCInst &Inst,
435 const MCSubtargetInfo &STI) {
437
438 // Append the instruction to the data fragment.
439 size_t CodeOffset = getCurFragSize();
440 SmallString<16> Content;
442 getAssembler().getEmitter().encodeInstruction(Inst, Content, Fixups, STI);
443 appendContents(Content);
444 if (CurFrag != F) {
445 F = CurFrag;
446 CodeOffset = 0;
447 }
448 F->setHasInstructions(STI);
449
450 if (Fixups.empty())
451 return;
452 bool MarkedLinkerRelaxable = false;
453 for (auto &Fixup : Fixups) {
454 Fixup.setOffset(Fixup.getOffset() + CodeOffset);
455 if (!Fixup.isLinkerRelaxable() || MarkedLinkerRelaxable)
456 continue;
457 MarkedLinkerRelaxable = true;
458 // Set the fragment's order within the subsection for use by
459 // MCAssembler::relaxAlign.
460 auto *Sec = F->getParent();
461 if (!Sec->isLinkerRelaxable())
462 Sec->setFirstLinkerRelaxable(F->getLayoutOrder());
463 // Do not add data after a linker-relaxable instruction. The difference
464 // between a new label and a label at or before the linker-relaxable
465 // instruction cannot be resolved at assemble-time.
466 F->setLinkerRelaxable();
467 newFragment();
468 }
469 F->appendFixups(Fixups);
470}
471
473 const MCSubtargetInfo &STI) {
474 auto *F = getCurrentFragment();
477 getAssembler().getEmitter().encodeInstruction(Inst, Data, Fixups, STI);
478
480 F->setHasInstructions(STI);
481
482 F->setVarContents(Data);
483 F->setInst(Inst);
484
485 bool MarkedLinkerRelaxable = false;
486 for (auto &Fixup : Fixups) {
487 if (!Fixup.isLinkerRelaxable() || MarkedLinkerRelaxable)
488 continue;
489 MarkedLinkerRelaxable = true;
490 auto *Sec = F->getParent();
491 if (!Sec->isLinkerRelaxable())
492 Sec->setFirstLinkerRelaxable(F->getLayoutOrder());
493 F->setLinkerRelaxable();
494 }
495 F->setVarFixups(Fixups);
496
497 newFragment();
498}
499
500void MCObjectStreamer::emitDwarfLocDirective(unsigned FileNo, unsigned Line,
501 unsigned Column, unsigned Flags,
502 unsigned Isa,
503 unsigned Discriminator,
504 StringRef FileName,
505 StringRef Comment) {
506 // In case we see two .loc directives in a row, make sure the
507 // first one gets a line entry.
509
510 this->MCStreamer::emitDwarfLocDirective(FileNo, Line, Column, Flags, Isa,
511 Discriminator, FileName, Comment);
512}
513
515 const MCSymbol *B, SMLoc Loc) {
516 MCContext &Context = OS.getContext();
517 const MCExpr *ARef = MCSymbolRefExpr::create(A, Context);
518 const MCExpr *BRef = MCSymbolRefExpr::create(B, Context);
519 const MCExpr *AddrDelta =
520 MCBinaryExpr::create(MCBinaryExpr::Sub, ARef, BRef, Context, Loc);
521 return AddrDelta;
522}
523
526 int64_t LineDelta, const MCSymbol *Label,
527 int PointerSize) {
528 // emit the sequence to set the address
529 OS.emitIntValue(dwarf::DW_LNS_extended_op, 1);
530 OS.emitULEB128IntValue(PointerSize + 1);
531 OS.emitIntValue(dwarf::DW_LNE_set_address, 1);
532 OS.emitSymbolValue(Label, PointerSize);
533
534 // emit the sequence for the LineDelta (from 1) and a zero address delta.
535 MCDwarfLineAddr::Emit(&OS, Params, LineDelta, 0);
536}
537
539 const MCSymbol *LastLabel,
540 const MCSymbol *Label,
541 unsigned PointerSize) {
542 if (!LastLabel) {
543 emitDwarfSetLineAddr(*this, Assembler->getDWARFLinetableParams(), LineDelta,
544 Label, PointerSize);
545 return;
546 }
547
548 // If the two labels are within the same fragment, then the address-offset is
549 // already a fixed constant and is not relaxable. Emit the advance-line-addr
550 // data immediately to save time and memory.
551 if (auto OptAddrDelta = absoluteSymbolDiff(Label, LastLabel)) {
552 SmallString<16> Tmp;
553 MCDwarfLineAddr::encode(getContext(), Assembler->getDWARFLinetableParams(),
554 LineDelta, *OptAddrDelta, Tmp);
555 emitBytes(Tmp);
556 return;
557 }
558
559 auto *F = getCurrentFragment();
560 F->Kind = MCFragment::FT_Dwarf;
561 F->setDwarfAddrDelta(buildSymbolDiff(*this, Label, LastLabel, SMLoc()));
562 F->setDwarfLineDelta(LineDelta);
563 newFragment();
564}
565
567 MCSymbol *LastLabel,
568 MCSymbol *EndLabel) {
569 // Emit a DW_LNE_end_sequence into the line table. When EndLabel is null, it
570 // means we should emit the entry for the end of the section and therefore we
571 // use the section end label for the reference label. After having the
572 // appropriate reference label, we emit the address delta and use INT64_MAX as
573 // the line delta which is the signal that this is actually a
574 // DW_LNE_end_sequence.
575 if (!EndLabel)
576 EndLabel = endSection(Section);
577
578 // Switch back the dwarf line section, in case endSection had to switch the
579 // section.
580 MCContext &Ctx = getContext();
581 switchSection(Ctx.getObjectFileInfo()->getDwarfLineSection());
582
583 const MCAsmInfo *AsmInfo = Ctx.getAsmInfo();
584 emitDwarfAdvanceLineAddr(INT64_MAX, LastLabel, EndLabel,
585 AsmInfo->getCodePointerSize());
586}
587
589 const MCSymbol *Label,
590 SMLoc Loc) {
591 auto *F = getCurrentFragment();
593 F->setDwarfAddrDelta(buildSymbolDiff(*this, Label, LastLabel, Loc));
594 newFragment();
595}
596
598 const MCSymbol *FREBegin,
599 MCFragment *FDEFrag,
600 SMLoc Loc) {
601 assert(FuncBase && "No function base address");
602 assert(FREBegin && "FRE doesn't describe a location");
603 auto *F = getCurrentFragment();
604 F->Kind = MCFragment::FT_SFrame;
605 F->setSFrameAddrDelta(buildSymbolDiff(*this, FREBegin, FuncBase, Loc));
606 F->setSFrameFDE(FDEFrag);
607 newFragment();
608}
609
611 unsigned Line, unsigned Column,
612 bool PrologueEnd, bool IsStmt,
613 StringRef FileName, SMLoc Loc) {
614 // Validate the directive.
615 if (!checkCVLocSection(FunctionId, FileNo, Loc))
616 return;
617
618 // Emit a label at the current position and record it in the CodeViewContext.
619 MCSymbol *LineSym = getContext().createTempSymbol();
620 emitLabel(LineSym);
622 FileNo, Line, Column, PrologueEnd,
623 IsStmt);
624}
625
627 const MCSymbol *Begin,
628 const MCSymbol *End) {
630 End);
631 this->MCStreamer::emitCVLinetableDirective(FunctionId, Begin, End);
632}
633
635 unsigned PrimaryFunctionId, unsigned SourceFileId, unsigned SourceLineNum,
636 const MCSymbol *FnStartSym, const MCSymbol *FnEndSym) {
638 *this, PrimaryFunctionId, SourceFileId, SourceLineNum, FnStartSym,
639 FnEndSym);
641 PrimaryFunctionId, SourceFileId, SourceLineNum, FnStartSym, FnEndSym);
642}
643
645 ArrayRef<std::pair<const MCSymbol *, const MCSymbol *>> Ranges,
646 StringRef FixedSizePortion) {
647 getContext().getCVContext().emitDefRange(*this, Ranges, FixedSizePortion);
648 // Attach labels that were pending before we created the defrange fragment to
649 // the beginning of the new fragment.
650 this->MCStreamer::emitCVDefRangeDirective(Ranges, FixedSizePortion);
651}
652
659
663
668
670 uint8_t FillLen,
671 unsigned MaxBytesToEmit) {
672 if (MaxBytesToEmit == 0)
673 MaxBytesToEmit = Alignment.value();
675 F->makeAlign(Alignment, Fill, FillLen, MaxBytesToEmit);
676 newFragment();
677
678 // Update the maximum alignment on the current section if necessary.
679 F->getParent()->ensureMinAlignment(Alignment);
680}
681
683 const MCSubtargetInfo *STI,
684 unsigned MaxBytesToEmit) {
685 auto *F = getCurrentFragment();
686 emitValueToAlignment(Alignment, 0, 1, MaxBytesToEmit);
687 F->u.align.EmitNops = true;
688 F->STI = STI;
689}
690
692 bool EmitNops, uint8_t Fill,
693 const MCSubtargetInfo &STI) {
694 auto *F = getCurrentFragment();
695 F->makePrefAlign(Alignment, End, EmitNops, Fill);
696 if (EmitNops)
697 F->STI = &STI;
698 newFragment();
699}
700
706
708 const MCExpr *Expr, SMLoc Loc) {
709 std::optional<MCFixupKind> MaybeKind =
710 Assembler->getBackend().getFixupKind(Name);
711 if (!MaybeKind) {
712 getContext().reportError(Loc, "unknown relocation name");
713 return;
714 }
715
716 MCFixupKind Kind = *MaybeKind;
717 if (Expr)
718 visitUsedExpr(*Expr);
719 else
720 Expr =
721 MCSymbolRefExpr::create(getContext().createTempSymbol(), getContext());
722
723 auto *O = &Offset;
724 int64_t Val;
725 if (Offset.evaluateAsAbsolute(Val, nullptr)) {
726 auto *SecSym = getCurrentSectionOnly()->getBeginSymbol();
728 O, getContext(), Loc);
729 }
730 getAssembler().addRelocDirective({*O, Expr, Kind});
731}
732
733void MCObjectStreamer::emitFill(const MCExpr &NumBytes, uint64_t FillValue,
734 SMLoc Loc) {
735 assert(getCurrentSectionOnly() && "need a section");
736 newSpecialFragment<MCFillFragment>(FillValue, 1, NumBytes, Loc);
737}
738
739void MCObjectStreamer::emitFill(const MCExpr &NumValues, int64_t Size,
740 int64_t Expr, SMLoc Loc) {
741 int64_t IntNumValues;
742 // Do additional checking now if we can resolve the value.
743 if (NumValues.evaluateAsAbsolute(IntNumValues, getAssembler())) {
744 if (IntNumValues < 0) {
747 "'.fill' directive with negative repeat count has no effect");
748 return;
749 }
750 // Emit now if we can for better errors.
751 int64_t NonZeroSize = Size > 4 ? 4 : Size;
752 Expr &= ~0ULL >> (64 - NonZeroSize * 8);
753 for (uint64_t i = 0, e = IntNumValues; i != e; ++i) {
754 emitIntValue(Expr, NonZeroSize);
755 if (NonZeroSize < Size)
756 emitIntValue(0, Size - NonZeroSize);
757 }
758 return;
759 }
760
761 // Otherwise emit as fragment.
762 assert(getCurrentSectionOnly() && "need a section");
764}
765
766void MCObjectStreamer::emitNops(int64_t NumBytes, int64_t ControlledNopLength,
767 SMLoc Loc, const MCSubtargetInfo &STI) {
768 assert(getCurrentSectionOnly() && "need a section");
769 newSpecialFragment<MCNopsFragment>(NumBytes, ControlledNopLength, Loc, STI);
770}
771
773 MCAssembler &Asm = getAssembler();
774 Asm.getWriter().addFileName(Filename);
775}
776
778 StringRef CompilerVersion,
779 StringRef TimeStamp,
780 StringRef Description) {
782 W.addFileName(Filename);
783 if (CompilerVersion.size())
784 W.setCompilerVersion(CompilerVersion);
785 // TODO: add TimeStamp and Description to .file symbol table entry
786 // with the integrated assembler.
787}
788
792
796
799
800 // If we are generating dwarf for assembly source files dump out the sections.
801 if (getContext().getGenDwarfForAssembly())
803
804 // Dump out the dwarf file & directory tables and line tables.
805 MCDwarfLineTable::emit(this, getAssembler().getDWARFLinetableParams());
806
807 // Emit pseudo probes for the current module.
809
811}
assert(UImm &&(UImm !=~static_cast< T >(0)) &&"Invalid immediate!")
static GCRegistry::Add< ErlangGC > A("erlang", "erlang-compatible garbage collector")
static GCRegistry::Add< OcamlGC > B("ocaml", "ocaml 3.10-compatible GC")
#define LLVM_LIKELY(EXPR)
Definition Compiler.h:335
dxil DXContainer Global Emitter
This file declares the MCLFIRewriter class, an abstract class that encapsulates the rewriting logic f...
static const MCExpr * buildSymbolDiff(MCObjectStreamer &OS, const MCSymbol *A, const MCSymbol *B, SMLoc Loc)
constexpr size_t FragBlockSize
static void emitDwarfSetLineAddr(MCObjectStreamer &OS, MCDwarfLineTableParams Params, int64_t LineDelta, const MCSymbol *Label, int PointerSize)
static std::optional< uint64_t > absoluteSymbolDiff(const MCSymbol *Hi, const MCSymbol *Lo)
constexpr size_t NewFragHeadroom
#define F(x, y, z)
Definition MD5.cpp:54
#define I(x, y, z)
Definition MD5.cpp:57
static constexpr StringLiteral Filename
PowerPC TLS Dynamic Call Fixup
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
Definition ArrayRef.h:40
size_t size() const
size - Get the array size.
Definition ArrayRef.h:142
iterator begin() const
Definition ArrayRef.h:130
bool empty() const
empty - Check if the array is empty.
Definition ArrayRef.h:137
void emitLineTableForFunction(MCObjectStreamer &OS, unsigned FuncId, const MCSymbol *FuncBegin, const MCSymbol *FuncEnd)
Emits a line table substream.
void emitFileChecksums(MCObjectStreamer &OS)
Emits the file checksum substream.
void recordCVLoc(MCContext &Ctx, const MCSymbol *Label, unsigned FunctionId, unsigned FileNo, unsigned Line, unsigned Column, bool PrologueEnd, bool IsStmt)
Saves the information from the currently parsed .cv_loc directive and sets CVLocSeen.
void emitDefRange(MCObjectStreamer &OS, ArrayRef< std::pair< const MCSymbol *, const MCSymbol * > > Ranges, StringRef FixedSizePortion)
void emitFileChecksumOffset(MCObjectStreamer &OS, unsigned FileNo)
Emits the offset into the checksum table of the given file number.
void emitInlineLineTableForFunction(MCObjectStreamer &OS, unsigned PrimaryFunctionId, unsigned SourceFileId, unsigned SourceLineNum, const MCSymbol *FnStartSym, const MCSymbol *FnEndSym)
void emitStringTable(MCObjectStreamer &OS)
Emits the string table substream.
Generic interface to target specific assembler backends.
bool allowEnhancedRelaxation() const
Return true if this target allows an unrelaxable instruction to be emitted into RelaxableFragment and...
virtual void relaxInstruction(MCInst &Inst, const MCSubtargetInfo &STI) const
Relax the instruction in the given fragment to the next wider instruction.
virtual bool mayNeedRelaxation(unsigned Opcode, ArrayRef< MCOperand > Operands, const MCSubtargetInfo &STI) const
Check whether the given instruction (encoded as Opcode+Operands) may need relaxation.
virtual uint64_t generateCompactUnwindEncoding(const MCDwarfFrameInfo *FI, const MCContext *Ctxt) const
Generate the compact unwind encoding for the CFI instructions.
This class is intended to be used as a base class for asm properties and features specific to the tar...
Definition MCAsmInfo.h:64
unsigned getCodePointerSize() const
Get the code pointer size in bytes.
Definition MCAsmInfo.h:450
LLVM_ABI void Finish()
Finish - Do final processing and write the object to the output stream.
MCObjectWriter & getWriter() const
LLVM_ABI void addRelocDirective(RelocDirective RD)
MCCodeEmitter & getEmitter() const
MCAsmBackend & getBackend() const
LLVM_ABI bool registerSection(MCSection &Section)
LLVM_ABI bool registerSymbol(const MCSymbol &Symbol)
static const MCBinaryExpr * createAdd(const MCExpr *LHS, const MCExpr *RHS, MCContext &Ctx, SMLoc Loc=SMLoc())
Definition MCExpr.h:343
static LLVM_ABI const MCBinaryExpr * create(Opcode Op, const MCExpr *LHS, const MCExpr *RHS, MCContext &Ctx, SMLoc Loc=SMLoc())
Definition MCExpr.cpp:201
@ Sub
Subtraction.
Definition MCExpr.h:324
virtual void encodeInstruction(const MCInst &Inst, SmallVectorImpl< char > &CB, SmallVectorImpl< MCFixup > &Fixups, const MCSubtargetInfo &STI) const =0
Encode the given Inst to bytes and append to CB.
Context object for machine code objects.
Definition MCContext.h:83
LLVM_ABI MCSymbol * createTempSymbol()
Create a temporary symbol with a unique name.
LLVM_ABI void RemapDebugPaths()
void clearDwarfLocSeen()
Definition MCContext.h:767
LLVM_ABI CodeViewContext & getCVContext()
const SourceMgr * getSourceManager() const
Definition MCContext.h:398
LLVM_ABI void reportError(SMLoc L, const Twine &Msg)
static LLVM_ABI void emit(MCObjectStreamer &streamer, bool isEH)
Definition MCDwarf.cpp:1916
static LLVM_ABI void Emit(MCStreamer *MCOS, MCDwarfLineTableParams Params, int64_t LineDelta, uint64_t AddrDelta)
Utility function to emit the encoding to a streamer.
Definition MCDwarf.cpp:730
static LLVM_ABI void encode(MCContext &Context, MCDwarfLineTableParams Params, int64_t LineDelta, uint64_t AddrDelta, SmallVectorImpl< char > &OS)
Utility function to encode a Dwarf pair of LineDelta and AddrDeltas.
Definition MCDwarf.cpp:745
static LLVM_ABI void make(MCStreamer *MCOS, MCSection *Section)
Definition MCDwarf.cpp:91
static LLVM_ABI void emit(MCStreamer *MCOS, MCDwarfLineTableParams Params)
Definition MCDwarf.cpp:308
Base class for the full range of assembler expressions which are needed for parsing.
Definition MCExpr.h:34
static MCFixupKind getDataKindForSize(unsigned Size)
Return the generic fixup kind for a value with the given size.
Definition MCFixup.h:110
static MCFixup create(uint32_t Offset, const MCExpr *Value, MCFixupKind Kind, bool PCRel=false)
Consider bit fields if we need more flags.
Definition MCFixup.h:86
FragmentType getKind() const
Definition MCSection.h:179
static LLVM_ABI void Emit(MCStreamer *MCOS)
Definition MCDwarf.cpp:1205
Instances of this class represent a single low-level machine instruction.
Definition MCInst.h:188
unsigned getOpcode() const
Definition MCInst.h:202
ArrayRef< MCOperand > getOperands() const
Definition MCInst.h:214
Streaming object file generation interface.
void reset() override
state management
void emitFill(const MCExpr &NumBytes, uint64_t FillValue, SMLoc Loc=SMLoc()) override
Emit Size bytes worth of the value specified by FillValue.
FT * newSpecialFragment(Args &&...args)
void emitValueToAlignment(Align Alignment, int64_t Fill=0, uint8_t FillLen=1, unsigned MaxBytesToEmit=0) override
Emit some number of copies of Value until the byte alignment ByteAlignment is reached.
void emitAssignment(MCSymbol *Symbol, const MCExpr *Value) override
Emit an assignment of Value to Symbol.
void emitCFISections(bool EH, bool Debug, bool SFrame) override
void emitULEB128Value(const MCExpr *Value) override
void emitSLEB128Value(const MCExpr *Value) override
void emitNops(int64_t NumBytes, int64_t ControlledNopLength, SMLoc Loc, const MCSubtargetInfo &STI) override
void emitCVInlineLinetableDirective(unsigned PrimaryFunctionId, unsigned SourceFileId, unsigned SourceLineNum, const MCSymbol *FnStartSym, const MCSymbol *FnEndSym) override
This implements the CodeView '.cv_inline_linetable' assembler directive.
void emitCVStringTableDirective() override
This implements the CodeView '.cv_stringtable' assembler directive.
MCAssembler & getAssembler()
void emitDwarfAdvanceLineAddr(int64_t LineDelta, const MCSymbol *LastLabel, const MCSymbol *Label, unsigned PointerSize) override
If targets does not support representing debug line section by .loc/.file directives in assembly outp...
void emitWeakReference(MCSymbol *Alias, const MCSymbol *Target) override
Emit an weak reference from Alias to Symbol.
void appendContents(ArrayRef< char > Contents)
void emitCVLocDirective(unsigned FunctionId, unsigned FileNo, unsigned Line, unsigned Column, bool PrologueEnd, bool IsStmt, StringRef FileName, SMLoc Loc) override
This implements the CodeView '.cv_loc' assembler directive.
void emitRelocDirective(const MCExpr &Offset, StringRef Name, const MCExpr *Expr, SMLoc Loc={}) override
Record a relocation described by the .reloc directive.
void emitBytes(StringRef Data) override
Emit the bytes in Data into the output.
void emitPendingAssignments(MCSymbol *Symbol)
Emits pending conditional assignments that depend on Symbol being emitted.
void addFixup(const MCExpr *Value, MCFixupKind Kind)
void emitFileDirective(StringRef Filename) override
Switch to a new logical file.
void emitSFrameCalculateFuncOffset(const MCSymbol *FunCabsel, const MCSymbol *FREBegin, MCFragment *FDEFrag, SMLoc Loc)
void emitDwarfLocDirective(unsigned FileNo, unsigned Line, unsigned Column, unsigned Flags, unsigned Isa, unsigned Discriminator, StringRef FileName, StringRef Comment={}) override
This implements the DWARF2 '.loc fileno lineno ...' assembler directive.
MCSymbol * emitCFILabel() override
When emitting an object file, create and emit a real label.
void emitCVDefRangeDirective(ArrayRef< std::pair< const MCSymbol *, const MCSymbol * > > Ranges, StringRef FixedSizePortion) override
This implements the CodeView '.cv_def_range' assembler directive.
MCAssembler * getAssemblerPtr() override
void emitAddrsigSym(const MCSymbol *Sym) override
void emitDwarfLineEndEntry(MCSection *Section, MCSymbol *LastLabel, MCSymbol *EndLabel=nullptr) override
Emit the debug line end entry.
void emitInstruction(const MCInst &Inst, const MCSubtargetInfo &STI) override
Emit the given Instruction into the current section.
void visitUsedSymbol(const MCSymbol &Sym) override
void emitPrefAlign(Align Alignment, const MCSymbol &End, bool EmitNops, uint8_t Fill, const MCSubtargetInfo &STI) override
void emitInstToFragment(const MCInst &Inst, const MCSubtargetInfo &)
Emit an instruction to a special fragment, because this instruction can change its size during relaxa...
virtual void emitLabelAtPos(MCSymbol *Symbol, SMLoc Loc, MCFragment &F, uint64_t Offset)
void emitLabel(MCSymbol *Symbol, SMLoc Loc=SMLoc()) override
Emit a label for Symbol into the current section.
MCObjectStreamer(MCContext &Context, std::unique_ptr< MCAsmBackend > TAB, std::unique_ptr< MCObjectWriter > OW, std::unique_ptr< MCCodeEmitter > Emitter)
void emitValueImpl(const MCExpr *Value, unsigned Size, SMLoc Loc=SMLoc()) override
Emit the expression Value into the output as a native integer of the given Size bytes.
void finishImpl() override
Streamer specific finalization.
void changeSection(MCSection *Section, uint32_t Subsection=0) override
This is called by popSection and switchSection, if the current section changes.
void emitAbsoluteSymbolDiffAsULEB128(const MCSymbol *Hi, const MCSymbol *Lo) override
Emit the absolute difference between two symbols encoded with ULEB128.
MCFragment * allocFragSpace(size_t Headroom)
void emitDwarfAdvanceFrameAddr(const MCSymbol *LastLabel, const MCSymbol *Label, SMLoc Loc)
bool mayHaveInstructions(MCSection &Sec) const override
void emitCodeAlignment(Align ByteAlignment, const MCSubtargetInfo *STI, unsigned MaxBytesToEmit=0) override
Emit nops until the byte alignment ByteAlignment is reached.
~MCObjectStreamer() override
void ensureHeadroom(size_t Headroom)
void emitCVFileChecksumOffsetDirective(unsigned FileNo) override
This implements the CodeView '.cv_filechecksumoffset' assembler directive.
void emitConditionalAssignment(MCSymbol *Symbol, const MCExpr *Value) override
Emit an assignment of Value to Symbol, but only if Value is also emitted.
void emitCVFileChecksumsDirective() override
This implements the CodeView '.cv_filechecksums' assembler directive.
void emitCVLinetableDirective(unsigned FunctionId, const MCSymbol *Begin, const MCSymbol *End) override
This implements the CodeView '.cv_linetable' assembler directive.
void emitValueToOffset(const MCExpr *Offset, unsigned char Value, SMLoc Loc) override
Emit some number of copies of Value until the byte offset Offset is reached.
uint8_t * getCurFragEnd() const
void emitAbsoluteSymbolDiff(const MCSymbol *Hi, const MCSymbol *Lo, unsigned Size) override
Emit the absolute difference between two symbols if possible.
Defines the object file and target independent interfaces used by the assembler backend to write nati...
void emitAddrsigSection()
Tell the object writer to emit an address-significance table during writeObject().
void addAddrsigSymbol(const MCSymbol *Sym)
Record the given symbol in the address-significance table to be written diring writeObject().
static LLVM_ABI void emit(MCObjectStreamer *MCOS)
static void emit(MCObjectStreamer &Streamer)
Definition MCSFrame.cpp:587
Instances of this class represent a uniqued identifier for a section in the current translation unit.
Definition MCSection.h:569
bool hasInstructions() const
Definition MCSection.h:665
void setHasInstructions(bool Value)
Definition MCSection.h:666
MCSymbol * getBeginSymbol()
Definition MCSection.h:642
virtual void emitAssignment(MCSymbol *Symbol, const MCExpr *Value)
Emit an assignment of Value to Symbol.
std::unique_ptr< MCLFIRewriter > LFIRewriter
Definition MCStreamer.h:296
virtual void emitCFISections(bool EH, bool Debug, bool SFrame)
virtual void emitInstruction(const MCInst &Inst, const MCSubtargetInfo &STI)
Emit the given Instruction into the current section.
MCFragment * getCurrentFragment() const
Definition MCStreamer.h:439
SmallVector< MCDwarfFrameInfo, 0 > DwarfFrameInfos
Definition MCStreamer.h:270
virtual void emitAbsoluteSymbolDiffAsULEB128(const MCSymbol *Hi, const MCSymbol *Lo)
Emit the absolute difference between two symbols encoded with ULEB128.
bool getUseAssemblerInfoForParsing()
Definition MCStreamer.h:331
MCContext & getContext() const
Definition MCStreamer.h:323
void emitSymbolValue(const MCSymbol *Sym, unsigned Size, bool IsSectionRelative=false)
Special case of EmitValue that avoids the client having to pass in a MCExpr for MCSymbols.
bool checkCVLocSection(unsigned FuncId, unsigned FileNo, SMLoc Loc)
Returns true if the .cv_loc directive is in the right section.
virtual void emitAbsoluteSymbolDiff(const MCSymbol *Hi, const MCSymbol *Lo, unsigned Size)
Emit the absolute difference between two symbols.
virtual void emitLabel(MCSymbol *Symbol, SMLoc Loc=SMLoc())
Emit a label for Symbol into the current section.
void setAllowAutoPadding(bool v)
Definition MCStreamer.h:337
virtual void reset()
State management.
virtual void emitDwarfLocDirective(unsigned FileNo, unsigned Line, unsigned Column, unsigned Flags, unsigned Isa, unsigned Discriminator, StringRef FileName, StringRef Comment={})
This implements the DWARF2 '.loc fileno lineno ...' assembler directive.
virtual void emitCVLinetableDirective(unsigned FunctionId, const MCSymbol *FnStart, const MCSymbol *FnEnd)
This implements the CodeView '.cv_linetable' assembler directive.
MCStreamer(MCContext &Ctx)
MCFragment * CurFrag
Definition MCStreamer.h:268
virtual void emitIntValue(uint64_t Value, unsigned Size)
Special case of EmitValue that avoids the client having to pass in a MCExpr for constant integers.
unsigned getNumFrameInfos()
size_t getCurFragSize() const
Definition MCStreamer.h:448
unsigned emitULEB128IntValue(uint64_t Value, unsigned PadTo=0)
Special case of EmitULEB128Value that avoids the client having to pass in a MCExpr for constant integ...
MCSymbol * endSection(MCSection *Section)
virtual void switchSection(MCSection *Section, uint32_t Subsec=0)
Set the current section where code is being emitted to Section.
virtual void emitCVDefRangeDirective(ArrayRef< std::pair< const MCSymbol *, const MCSymbol * > > Ranges, StringRef FixedSizePortion)
This implements the CodeView '.cv_def_range' assembler directive.
MCSection * getCurrentSectionOnly() const
Definition MCStreamer.h:428
virtual void emitValueImpl(const MCExpr *Value, unsigned Size, SMLoc Loc=SMLoc())
Emit the expression Value into the output as a native integer of the given Size bytes.
void addFragment(MCFragment *F)
unsigned emitSLEB128IntValue(int64_t Value)
Special case of EmitSLEB128Value that avoids the client having to pass in a MCExpr for constant integ...
virtual void emitCVInlineLinetableDirective(unsigned PrimaryFunctionId, unsigned SourceFileId, unsigned SourceLineNum, const MCSymbol *FnStartSym, const MCSymbol *FnEndSym)
This implements the CodeView '.cv_inline_linetable' assembler directive.
void visitUsedExpr(const MCExpr &Expr)
Generic base class for all target subtargets.
static const MCSymbolRefExpr * create(const MCSymbol *Symbol, MCContext &Ctx, SMLoc Loc=SMLoc())
Definition MCExpr.h:214
MCSymbol - Instances of this class represent a symbol name in the MC file, and MCSymbols are created ...
Definition MCSymbol.h:42
MutableArrayRef - Represent a mutable reference to an array (0 or more elements consecutively in memo...
Definition ArrayRef.h:298
Represents a location in source code.
Definition SMLoc.h:22
SmallString - A SmallString is just a SmallVector with methods and accessors that make it work better...
Definition SmallString.h:26
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
LLVM_ABI void PrintMessage(raw_ostream &OS, SMLoc Loc, DiagKind Kind, const Twine &Msg, ArrayRef< SMRange > Ranges={}, ArrayRef< SMFixIt > FixIts={}, bool ShowColors=true) const
Emit a message about the specified location with the specified string.
StringRef - Represent a constant reference to a string, i.e.
Definition StringRef.h:55
constexpr size_t size() const
size - Get the string size.
Definition StringRef.h:143
Target - Wrapper for Target specific information.
Twine - A lightweight data structure for efficiently representing the concatenation of temporary valu...
Definition Twine.h:82
LLVM Value Representation.
Definition Value.h:75
This class represents a function that is read from a sample profile.
Definition FunctionId.h:36
#define INT64_MAX
Definition DataTypes.h:71
This is an optimization pass for GlobalISel generic memory operations.
@ Offset
Definition DWP.cpp:532
void fill(R &&Range, T &&Value)
Provide wrappers to std::fill which take ranges instead of having to pass begin/end explicitly.
Definition STLExtras.h:1759
@ Debug
Register 'use' is for debugging purpose.
constexpr bool isUIntN(unsigned N, uint64_t x)
Checks if an unsigned integer fits into the given (dynamic) bit width.
Definition MathExtras.h:243
uint16_t MCFixupKind
Extensible enumeration to represent the type of a fixup.
Definition MCFixup.h:22
constexpr T alignToPowerOf2(U Value, V Align)
Will overflow only if result is not representable in T.
Definition MathExtras.h:493
FunctionAddr VTableAddr uintptr_t uintptr_t Data
Definition InstrProf.h:221
ArrayRef(const T &OneElt) -> ArrayRef< T >
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:1917
decltype(auto) cast(const From &Val)
cast<X> - Return the argument parameter cast to the specified type.
Definition Casting.h:559
constexpr bool isIntN(unsigned N, int64_t x)
Checks if an signed integer fits into the given (dynamic) bit width.
Definition MathExtras.h:248
LLVM_ABI void reportFatalUsageError(Error Err)
Report a fatal error that does not indicate a bug in LLVM.
Definition Error.cpp:177
Implement std::hash so that hash_code can be used in STL containers.
Definition BitVector.h:870
This struct is a compact representation of a valid (non-zero power of two) alignment.
Definition Alignment.h:39
constexpr uint64_t value() const
This is a hole in the type system and should not be abused.
Definition Alignment.h:77