2011-01-13 15:58:56 +08:00
|
|
|
//===-- ARMMCExpr.cpp - ARM 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.
|
|
|
|
//
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
|
|
|
|
#include "ARMMCExpr.h"
|
|
|
|
#include "llvm/MC/MCAssembler.h"
|
2012-12-04 00:50:05 +08:00
|
|
|
#include "llvm/MC/MCContext.h"
|
2011-01-13 15:58:56 +08:00
|
|
|
using namespace llvm;
|
|
|
|
|
2014-04-22 10:41:26 +08:00
|
|
|
#define DEBUG_TYPE "armmcexpr"
|
|
|
|
|
2011-01-13 15:58:56 +08:00
|
|
|
const ARMMCExpr*
|
|
|
|
ARMMCExpr::Create(VariantKind Kind, const MCExpr *Expr,
|
|
|
|
MCContext &Ctx) {
|
|
|
|
return new (Ctx) ARMMCExpr(Kind, Expr);
|
|
|
|
}
|
|
|
|
|
|
|
|
void ARMMCExpr::PrintImpl(raw_ostream &OS) const {
|
|
|
|
switch (Kind) {
|
2012-02-07 10:50:20 +08:00
|
|
|
default: llvm_unreachable("Invalid kind!");
|
2011-01-13 15:58:56 +08:00
|
|
|
case VK_ARM_HI16: OS << ":upper16:"; break;
|
|
|
|
case VK_ARM_LO16: OS << ":lower16:"; break;
|
|
|
|
}
|
|
|
|
|
|
|
|
const MCExpr *Expr = getSubExpr();
|
|
|
|
if (Expr->getKind() != MCExpr::SymbolRef)
|
|
|
|
OS << '(';
|
|
|
|
Expr->print(OS);
|
|
|
|
if (Expr->getKind() != MCExpr::SymbolRef)
|
|
|
|
OS << ')';
|
|
|
|
}
|
|
|
|
|
|
|
|
bool
|
|
|
|
ARMMCExpr::EvaluateAsRelocatableImpl(MCValue &Res,
|
|
|
|
const MCAsmLayout *Layout) const {
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
// FIXME: This basically copies MCObjectStreamer::AddValueSymbols. Perhaps
|
|
|
|
// that method should be made public?
|
|
|
|
static void AddValueSymbols_(const MCExpr *Value, MCAssembler *Asm) {
|
|
|
|
switch (Value->getKind()) {
|
|
|
|
case MCExpr::Target:
|
2012-02-07 10:50:20 +08:00
|
|
|
llvm_unreachable("Can't handle nested target expr!");
|
2011-01-13 15:58:56 +08:00
|
|
|
|
|
|
|
case MCExpr::Constant:
|
|
|
|
break;
|
|
|
|
|
|
|
|
case MCExpr::Binary: {
|
|
|
|
const MCBinaryExpr *BE = cast<MCBinaryExpr>(Value);
|
|
|
|
AddValueSymbols_(BE->getLHS(), Asm);
|
|
|
|
AddValueSymbols_(BE->getRHS(), Asm);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
case MCExpr::SymbolRef:
|
|
|
|
Asm->getOrCreateSymbolData(cast<MCSymbolRefExpr>(Value)->getSymbol());
|
|
|
|
break;
|
|
|
|
|
|
|
|
case MCExpr::Unary:
|
|
|
|
AddValueSymbols_(cast<MCUnaryExpr>(Value)->getSubExpr(), Asm);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void ARMMCExpr::AddValueSymbols(MCAssembler *Asm) const {
|
|
|
|
AddValueSymbols_(getSubExpr(), Asm);
|
|
|
|
}
|