xref: /aosp_15_r20/external/llvm/lib/Target/ARM/MCTargetDesc/ARMTargetStreamer.cpp (revision 9880d6810fe72a1726cb53787c6711e909410d58)
1*9880d681SAndroid Build Coastguard Worker //===- ARMTargetStreamer.cpp - ARMTargetStreamer class --*- C++ -*---------===//
2*9880d681SAndroid Build Coastguard Worker //
3*9880d681SAndroid Build Coastguard Worker //                     The LLVM Compiler Infrastructure
4*9880d681SAndroid Build Coastguard Worker //
5*9880d681SAndroid Build Coastguard Worker // This file is distributed under the University of Illinois Open Source
6*9880d681SAndroid Build Coastguard Worker // License. See LICENSE.TXT for details.
7*9880d681SAndroid Build Coastguard Worker //
8*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
9*9880d681SAndroid Build Coastguard Worker //
10*9880d681SAndroid Build Coastguard Worker // This file implements the ARMTargetStreamer class.
11*9880d681SAndroid Build Coastguard Worker //
12*9880d681SAndroid Build Coastguard Worker //===----------------------------------------------------------------------===//
13*9880d681SAndroid Build Coastguard Worker #include "llvm/ADT/MapVector.h"
14*9880d681SAndroid Build Coastguard Worker #include "llvm/MC/ConstantPools.h"
15*9880d681SAndroid Build Coastguard Worker #include "llvm/MC/MCContext.h"
16*9880d681SAndroid Build Coastguard Worker #include "llvm/MC/MCExpr.h"
17*9880d681SAndroid Build Coastguard Worker #include "llvm/MC/MCStreamer.h"
18*9880d681SAndroid Build Coastguard Worker 
19*9880d681SAndroid Build Coastguard Worker using namespace llvm;
20*9880d681SAndroid Build Coastguard Worker //
21*9880d681SAndroid Build Coastguard Worker // ARMTargetStreamer Implemenation
22*9880d681SAndroid Build Coastguard Worker //
ARMTargetStreamer(MCStreamer & S)23*9880d681SAndroid Build Coastguard Worker ARMTargetStreamer::ARMTargetStreamer(MCStreamer &S)
24*9880d681SAndroid Build Coastguard Worker     : MCTargetStreamer(S), ConstantPools(new AssemblerConstantPools()) {}
25*9880d681SAndroid Build Coastguard Worker 
~ARMTargetStreamer()26*9880d681SAndroid Build Coastguard Worker ARMTargetStreamer::~ARMTargetStreamer() {}
27*9880d681SAndroid Build Coastguard Worker 
28*9880d681SAndroid Build Coastguard Worker // The constant pool handling is shared by all ARMTargetStreamer
29*9880d681SAndroid Build Coastguard Worker // implementations.
addConstantPoolEntry(const MCExpr * Expr,SMLoc Loc)30*9880d681SAndroid Build Coastguard Worker const MCExpr *ARMTargetStreamer::addConstantPoolEntry(const MCExpr *Expr, SMLoc Loc) {
31*9880d681SAndroid Build Coastguard Worker   return ConstantPools->addEntry(Streamer, Expr, 4, Loc);
32*9880d681SAndroid Build Coastguard Worker }
33*9880d681SAndroid Build Coastguard Worker 
emitCurrentConstantPool()34*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitCurrentConstantPool() {
35*9880d681SAndroid Build Coastguard Worker   ConstantPools->emitForCurrentSection(Streamer);
36*9880d681SAndroid Build Coastguard Worker }
37*9880d681SAndroid Build Coastguard Worker 
38*9880d681SAndroid Build Coastguard Worker // finish() - write out any non-empty assembler constant pools.
finish()39*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::finish() { ConstantPools->emitAll(Streamer); }
40*9880d681SAndroid Build Coastguard Worker 
41*9880d681SAndroid Build Coastguard Worker // reset() - Reset any state
reset()42*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::reset() {}
43*9880d681SAndroid Build Coastguard Worker 
44*9880d681SAndroid Build Coastguard Worker // The remaining callbacks should be handled separately by each
45*9880d681SAndroid Build Coastguard Worker // streamer.
emitFnStart()46*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitFnStart() {}
emitFnEnd()47*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitFnEnd() {}
emitCantUnwind()48*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitCantUnwind() {}
emitPersonality(const MCSymbol * Personality)49*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitPersonality(const MCSymbol *Personality) {}
emitPersonalityIndex(unsigned Index)50*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitPersonalityIndex(unsigned Index) {}
emitHandlerData()51*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitHandlerData() {}
emitSetFP(unsigned FpReg,unsigned SpReg,int64_t Offset)52*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitSetFP(unsigned FpReg, unsigned SpReg,
53*9880d681SAndroid Build Coastguard Worker                                   int64_t Offset) {}
emitMovSP(unsigned Reg,int64_t Offset)54*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitMovSP(unsigned Reg, int64_t Offset) {}
emitPad(int64_t Offset)55*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitPad(int64_t Offset) {}
emitRegSave(const SmallVectorImpl<unsigned> & RegList,bool isVector)56*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitRegSave(const SmallVectorImpl<unsigned> &RegList,
57*9880d681SAndroid Build Coastguard Worker                                     bool isVector) {}
emitUnwindRaw(int64_t StackOffset,const SmallVectorImpl<uint8_t> & Opcodes)58*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitUnwindRaw(int64_t StackOffset,
59*9880d681SAndroid Build Coastguard Worker                                       const SmallVectorImpl<uint8_t> &Opcodes) {
60*9880d681SAndroid Build Coastguard Worker }
switchVendor(StringRef Vendor)61*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::switchVendor(StringRef Vendor) {}
emitAttribute(unsigned Attribute,unsigned Value)62*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitAttribute(unsigned Attribute, unsigned Value) {}
emitTextAttribute(unsigned Attribute,StringRef String)63*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitTextAttribute(unsigned Attribute,
64*9880d681SAndroid Build Coastguard Worker                                           StringRef String) {}
emitIntTextAttribute(unsigned Attribute,unsigned IntValue,StringRef StringValue)65*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitIntTextAttribute(unsigned Attribute,
66*9880d681SAndroid Build Coastguard Worker                                              unsigned IntValue,
67*9880d681SAndroid Build Coastguard Worker                                              StringRef StringValue) {}
emitArch(unsigned Arch)68*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitArch(unsigned Arch) {}
emitArchExtension(unsigned ArchExt)69*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitArchExtension(unsigned ArchExt) {}
emitObjectArch(unsigned Arch)70*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitObjectArch(unsigned Arch) {}
emitFPU(unsigned FPU)71*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitFPU(unsigned FPU) {}
finishAttributeSection()72*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::finishAttributeSection() {}
emitInst(uint32_t Inst,char Suffix)73*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitInst(uint32_t Inst, char Suffix) {}
74*9880d681SAndroid Build Coastguard Worker void
AnnotateTLSDescriptorSequence(const MCSymbolRefExpr * SRE)75*9880d681SAndroid Build Coastguard Worker ARMTargetStreamer::AnnotateTLSDescriptorSequence(const MCSymbolRefExpr *SRE) {}
76*9880d681SAndroid Build Coastguard Worker 
emitThumbSet(MCSymbol * Symbol,const MCExpr * Value)77*9880d681SAndroid Build Coastguard Worker void ARMTargetStreamer::emitThumbSet(MCSymbol *Symbol, const MCExpr *Value) {}
78