summaryrefslogtreecommitdiff
path: root/lib/Target/Mips/MipsMCSymbolRefExpr.cpp
blob: 9a2bdae0e3391a5f188c8f9b9a21e41059c33a5e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
//===-- 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;
}