1163aad6bSYusra Syeda //===-- SystemZMCExpr.cpp - SystemZ specific MC expression classes --------===//
2163aad6bSYusra Syeda //
3163aad6bSYusra Syeda // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4163aad6bSYusra Syeda // See https://llvm.org/LICENSE.txt for license information.
5163aad6bSYusra Syeda // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6163aad6bSYusra Syeda //
7163aad6bSYusra Syeda //===----------------------------------------------------------------------===//
8163aad6bSYusra Syeda
9163aad6bSYusra Syeda #include "SystemZMCExpr.h"
10163aad6bSYusra Syeda #include "llvm/MC/MCContext.h"
11163aad6bSYusra Syeda using namespace llvm;
12163aad6bSYusra Syeda
13163aad6bSYusra Syeda #define DEBUG_TYPE "systemzmcexpr"
14163aad6bSYusra Syeda
create(VariantKind Kind,const MCExpr * Expr,MCContext & Ctx)15163aad6bSYusra Syeda const SystemZMCExpr *SystemZMCExpr::create(VariantKind Kind, const MCExpr *Expr,
16163aad6bSYusra Syeda MCContext &Ctx) {
17163aad6bSYusra Syeda return new (Ctx) SystemZMCExpr(Kind, Expr);
18163aad6bSYusra Syeda }
19163aad6bSYusra Syeda
getVariantKindName() const20163aad6bSYusra Syeda StringRef SystemZMCExpr::getVariantKindName() const {
21163aad6bSYusra Syeda switch (static_cast<uint32_t>(getKind())) {
22163aad6bSYusra Syeda case VK_SystemZ_None:
23163aad6bSYusra Syeda return "A";
24163aad6bSYusra Syeda case VK_SystemZ_RCon:
25163aad6bSYusra Syeda return "R";
26163aad6bSYusra Syeda case VK_SystemZ_VCon:
27163aad6bSYusra Syeda return "V";
28163aad6bSYusra Syeda default:
29163aad6bSYusra Syeda llvm_unreachable("Invalid kind");
30163aad6bSYusra Syeda }
31163aad6bSYusra Syeda }
32163aad6bSYusra Syeda
printImpl(raw_ostream & OS,const MCAsmInfo * MAI) const33163aad6bSYusra Syeda void SystemZMCExpr::printImpl(raw_ostream &OS, const MCAsmInfo *MAI) const {
34163aad6bSYusra Syeda OS << getVariantKindName() << '(';
35163aad6bSYusra Syeda Expr->print(OS, MAI);
36163aad6bSYusra Syeda OS << ')';
37163aad6bSYusra Syeda }
38163aad6bSYusra Syeda
evaluateAsRelocatableImpl(MCValue & Res,const MCAssembler * Asm,const MCFixup * Fixup) const39163aad6bSYusra Syeda bool SystemZMCExpr::evaluateAsRelocatableImpl(MCValue &Res,
40*e25e8003SFangrui Song const MCAssembler *Asm,
41163aad6bSYusra Syeda const MCFixup *Fixup) const {
42*e25e8003SFangrui Song if (!getSubExpr()->evaluateAsRelocatable(Res, Asm, Fixup))
43163aad6bSYusra Syeda return false;
44163aad6bSYusra Syeda
45163aad6bSYusra Syeda Res =
46163aad6bSYusra Syeda MCValue::get(Res.getSymA(), Res.getSymB(), Res.getConstant(), getKind());
47163aad6bSYusra Syeda
48163aad6bSYusra Syeda return true;
49163aad6bSYusra Syeda }
50