xref: /llvm-project/llvm/lib/Target/SystemZ/MCTargetDesc/SystemZMCExpr.cpp (revision e25e8003ca2e9d623666b1cd65d4b98648416dd3)
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