blob: 306f068312f538569cc1eb9e394f00c00a5f065c [file] [log] [blame]
Evan Cheng965b3c72011-01-13 07:58:56 +00001//===-- ARMMCExpr.cpp - ARM specific MC expression classes ----------------===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
Evan Cheng965b3c72011-01-13 07:58:56 +000010#include "ARMMCExpr.h"
Chandler Carruthed0881b2012-12-03 16:50:05 +000011#include "llvm/MC/MCContext.h"
Pete Cooperef21bd42015-03-04 01:24:11 +000012#include "llvm/MC/MCStreamer.h"
Evan Cheng965b3c72011-01-13 07:58:56 +000013using namespace llvm;
14
Chandler Carruth84e68b22014-04-22 02:41:26 +000015#define DEBUG_TYPE "armmcexpr"
16
Evan Cheng965b3c72011-01-13 07:58:56 +000017const ARMMCExpr*
Jim Grosbach13760bd2015-05-30 01:25:56 +000018ARMMCExpr::create(VariantKind Kind, const MCExpr *Expr,
Evan Cheng965b3c72011-01-13 07:58:56 +000019 MCContext &Ctx) {
20 return new (Ctx) ARMMCExpr(Kind, Expr);
21}
22
Matt Arsenault8b643552015-06-09 00:31:39 +000023void ARMMCExpr::printImpl(raw_ostream &OS, const MCAsmInfo *MAI) const {
Evan Cheng965b3c72011-01-13 07:58:56 +000024 switch (Kind) {
Craig Toppere55c5562012-02-07 02:50:20 +000025 default: llvm_unreachable("Invalid kind!");
Evan Cheng965b3c72011-01-13 07:58:56 +000026 case VK_ARM_HI16: OS << ":upper16:"; break;
27 case VK_ARM_LO16: OS << ":lower16:"; break;
28 }
29
30 const MCExpr *Expr = getSubExpr();
31 if (Expr->getKind() != MCExpr::SymbolRef)
32 OS << '(';
Matt Arsenault8b643552015-06-09 00:31:39 +000033 Expr->print(OS, MAI);
Evan Cheng965b3c72011-01-13 07:58:56 +000034 if (Expr->getKind() != MCExpr::SymbolRef)
35 OS << ')';
36}
37
Rafael Espindolae2c66242014-06-25 15:45:33 +000038void ARMMCExpr::visitUsedExpr(MCStreamer &Streamer) const {
Rafael Espindola2be12812014-06-25 15:29:54 +000039 Streamer.visitUsedExpr(*getSubExpr());
Evan Cheng965b3c72011-01-13 07:58:56 +000040}