mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-18 13:34:04 +00:00
64 lines
1.9 KiB
C++
64 lines
1.9 KiB
C++
|
//===-- MipsMCSymbolRefExpr.cpp - Mips specific MC expression classes -----===//
|
||
|
//
|
||
|
// The LLVM Compiler Infrastructure
|
||
|
//
|
||
|
// This file is distributed under the University of Illinois Open Source
|
||
|
// License. See LICENSE.TXT for details.
|
||
|
//
|
||
|
//===----------------------------------------------------------------------===//
|
||
|
|
||
|
#define DEBUG_TYPE "mipsmcsymbolrefexpr"
|
||
|
#include "MipsMCSymbolRefExpr.h"
|
||
|
#include "llvm/MC/MCAssembler.h"
|
||
|
#include "llvm/MC/MCContext.h"
|
||
|
#include "llvm/MC/MCSymbol.h"
|
||
|
using namespace llvm;
|
||
|
|
||
|
const MipsMCSymbolRefExpr*
|
||
|
MipsMCSymbolRefExpr::Create(VariantKind Kind, const MCSymbol *Symbol,
|
||
|
int Offset, MCContext &Ctx) {
|
||
|
return new (Ctx) MipsMCSymbolRefExpr(Kind, Symbol, Offset);
|
||
|
}
|
||
|
|
||
|
void MipsMCSymbolRefExpr::PrintImpl(raw_ostream &OS) const {
|
||
|
switch (Kind) {
|
||
|
default: assert(0 && "Invalid kind!");
|
||
|
case VK_Mips_None: break;
|
||
|
case VK_Mips_GPREL: OS << "%gp_rel("; break;
|
||
|
case VK_Mips_GOT_CALL: OS << "%call16("; break;
|
||
|
case VK_Mips_GOT: OS << "%got("; break;
|
||
|
case VK_Mips_ABS_HI: OS << "%hi("; break;
|
||
|
case VK_Mips_ABS_LO: OS << "%lo("; break;
|
||
|
case VK_Mips_TLSGD: OS << "%tlsgd("; break;
|
||
|
case VK_Mips_GOTTPREL: OS << "%gottprel("; break;
|
||
|
case VK_Mips_TPREL_HI: OS << "%tprel_hi("; break;
|
||
|
case VK_Mips_TPREL_LO: OS << "%tprel_lo("; break;
|
||
|
}
|
||
|
|
||
|
OS << *Symbol;
|
||
|
|
||
|
if (Offset) {
|
||
|
if (Offset > 0)
|
||
|
OS << '+';
|
||
|
OS << Offset;
|
||
|
}
|
||
|
|
||
|
if (Kind != VK_Mips_None)
|
||
|
OS << ')';
|
||
|
}
|
||
|
|
||
|
bool
|
||
|
MipsMCSymbolRefExpr::EvaluateAsRelocatableImpl(MCValue &Res,
|
||
|
const MCAsmLayout *Layout) const {
|
||
|
return false;
|
||
|
}
|
||
|
|
||
|
void MipsMCSymbolRefExpr::AddValueSymbols(MCAssembler *Asm) const {
|
||
|
Asm->getOrCreateSymbolData(*Symbol);
|
||
|
}
|
||
|
|
||
|
const MCSection *MipsMCSymbolRefExpr::FindAssociatedSection() const {
|
||
|
return Symbol->isDefined() ? &Symbol->getSection() : NULL;
|
||
|
}
|
||
|
|