003 File Manager
Current Path:
/usr/src/contrib/llvm-project/llvm/lib/Target/Sparc/MCTargetDesc
usr
/
src
/
contrib
/
llvm-project
/
llvm
/
lib
/
Target
/
Sparc
/
MCTargetDesc
/
📁
..
📄
SparcAsmBackend.cpp
(12.49 KB)
📄
SparcELFObjectWriter.cpp
(6.09 KB)
📄
SparcFixupKinds.h
(2.97 KB)
📄
SparcInstPrinter.cpp
(6.65 KB)
📄
SparcInstPrinter.h
(2.43 KB)
📄
SparcMCAsmInfo.cpp
(2.41 KB)
📄
SparcMCAsmInfo.h
(1.25 KB)
📄
SparcMCCodeEmitter.cpp
(8.46 KB)
📄
SparcMCExpr.cpp
(9.13 KB)
📄
SparcMCExpr.h
(3.09 KB)
📄
SparcMCTargetDesc.cpp
(4.59 KB)
📄
SparcMCTargetDesc.h
(1.82 KB)
📄
SparcTargetStreamer.cpp
(1.52 KB)
📄
SparcTargetStreamer.h
(1.53 KB)
Editing: SparcMCAsmInfo.cpp
//===- SparcMCAsmInfo.cpp - Sparc asm properties --------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// // // This file contains the declarations of the SparcMCAsmInfo properties. // //===----------------------------------------------------------------------===// #include "SparcMCAsmInfo.h" #include "SparcMCExpr.h" #include "llvm/ADT/Triple.h" #include "llvm/BinaryFormat/Dwarf.h" #include "llvm/MC/MCExpr.h" #include "llvm/MC/MCStreamer.h" #include "llvm/MC/MCTargetOptions.h" using namespace llvm; void SparcELFMCAsmInfo::anchor() {} SparcELFMCAsmInfo::SparcELFMCAsmInfo(const Triple &TheTriple) { bool isV9 = (TheTriple.getArch() == Triple::sparcv9); IsLittleEndian = (TheTriple.getArch() == Triple::sparcel); if (isV9) { CodePointerSize = CalleeSaveStackSlotSize = 8; } Data16bitsDirective = "\t.half\t"; Data32bitsDirective = "\t.word\t"; // .xword is only supported by V9. Data64bitsDirective = (isV9) ? "\t.xword\t" : nullptr; ZeroDirective = "\t.skip\t"; CommentString = "!"; SupportsDebugInformation = true; ExceptionsType = ExceptionHandling::DwarfCFI; SunStyleELFSectionSwitchSyntax = true; UsesELFSectionDirectiveForBSS = true; } const MCExpr* SparcELFMCAsmInfo::getExprForPersonalitySymbol(const MCSymbol *Sym, unsigned Encoding, MCStreamer &Streamer) const { if (Encoding & dwarf::DW_EH_PE_pcrel) { MCContext &Ctx = Streamer.getContext(); return SparcMCExpr::create(SparcMCExpr::VK_Sparc_R_DISP32, MCSymbolRefExpr::create(Sym, Ctx), Ctx); } return MCAsmInfo::getExprForPersonalitySymbol(Sym, Encoding, Streamer); } const MCExpr* SparcELFMCAsmInfo::getExprForFDESymbol(const MCSymbol *Sym, unsigned Encoding, MCStreamer &Streamer) const { if (Encoding & dwarf::DW_EH_PE_pcrel) { MCContext &Ctx = Streamer.getContext(); return SparcMCExpr::create(SparcMCExpr::VK_Sparc_R_DISP32, MCSymbolRefExpr::create(Sym, Ctx), Ctx); } return MCAsmInfo::getExprForFDESymbol(Sym, Encoding, Streamer); }
Upload File
Create Folder