1bdd1243dSDimitry Andric //===-- XtensaMCExpr.cpp - Xtensa specific MC expression classes ----------===// 2bdd1243dSDimitry Andric // 3bdd1243dSDimitry Andric // The LLVM Compiler Infrastructure 4bdd1243dSDimitry Andric // 5bdd1243dSDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. 6bdd1243dSDimitry Andric // See https://llvm.org/LICENSE.txt for license information. 7bdd1243dSDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception 8bdd1243dSDimitry Andric // 9bdd1243dSDimitry Andric //===----------------------------------------------------------------------===// 10bdd1243dSDimitry Andric // 11bdd1243dSDimitry Andric // This file contains the implementation of the assembly expression modifiers 12bdd1243dSDimitry Andric // accepted by the Xtensa architecture 13bdd1243dSDimitry Andric // 14bdd1243dSDimitry Andric //===----------------------------------------------------------------------===// 15bdd1243dSDimitry Andric 16bdd1243dSDimitry Andric #include "XtensaMCExpr.h" 17bdd1243dSDimitry Andric #include "llvm/MC/MCAssembler.h" 18bdd1243dSDimitry Andric #include "llvm/MC/MCContext.h" 19bdd1243dSDimitry Andric #include "llvm/MC/MCStreamer.h" 20bdd1243dSDimitry Andric #include "llvm/MC/MCSymbolELF.h" 21bdd1243dSDimitry Andric #include "llvm/MC/MCValue.h" 22bdd1243dSDimitry Andric #include "llvm/Object/ELF.h" 23bdd1243dSDimitry Andric #include "llvm/Support/ErrorHandling.h" 24bdd1243dSDimitry Andric 25bdd1243dSDimitry Andric using namespace llvm; 26bdd1243dSDimitry Andric 27bdd1243dSDimitry Andric #define DEBUG_TYPE "xtensamcexpr" 28bdd1243dSDimitry Andric 29bdd1243dSDimitry Andric const XtensaMCExpr *XtensaMCExpr::create(const MCExpr *Expr, VariantKind Kind, 30bdd1243dSDimitry Andric MCContext &Ctx) { 31bdd1243dSDimitry Andric return new (Ctx) XtensaMCExpr(Expr, Kind); 32bdd1243dSDimitry Andric } 33bdd1243dSDimitry Andric 34bdd1243dSDimitry Andric void XtensaMCExpr::printImpl(raw_ostream &OS, const MCAsmInfo *MAI) const { 35bdd1243dSDimitry Andric bool HasVariant = getKind() != VK_Xtensa_None; 36bdd1243dSDimitry Andric if (HasVariant) 37bdd1243dSDimitry Andric OS << '%' << getVariantKindName(getKind()) << '('; 38bdd1243dSDimitry Andric Expr->print(OS, MAI); 39bdd1243dSDimitry Andric if (HasVariant) 40bdd1243dSDimitry Andric OS << ')'; 41bdd1243dSDimitry Andric } 42bdd1243dSDimitry Andric 43bdd1243dSDimitry Andric bool XtensaMCExpr::evaluateAsRelocatableImpl(MCValue &Res, 44*0fca6ea1SDimitry Andric const MCAssembler *Asm, 45bdd1243dSDimitry Andric const MCFixup *Fixup) const { 46*0fca6ea1SDimitry Andric return getSubExpr()->evaluateAsRelocatable(Res, Asm, Fixup); 47bdd1243dSDimitry Andric } 48bdd1243dSDimitry Andric 49bdd1243dSDimitry Andric void XtensaMCExpr::visitUsedExpr(MCStreamer &Streamer) const { 50bdd1243dSDimitry Andric Streamer.visitUsedExpr(*getSubExpr()); 51bdd1243dSDimitry Andric } 52bdd1243dSDimitry Andric 53bdd1243dSDimitry Andric XtensaMCExpr::VariantKind XtensaMCExpr::getVariantKindForName(StringRef name) { 54bdd1243dSDimitry Andric return StringSwitch<XtensaMCExpr::VariantKind>(name).Default( 55bdd1243dSDimitry Andric VK_Xtensa_Invalid); 56bdd1243dSDimitry Andric } 57bdd1243dSDimitry Andric 58bdd1243dSDimitry Andric StringRef XtensaMCExpr::getVariantKindName(VariantKind Kind) { 59bdd1243dSDimitry Andric switch (Kind) { 60bdd1243dSDimitry Andric default: 61bdd1243dSDimitry Andric llvm_unreachable("Invalid ELF symbol kind"); 62bdd1243dSDimitry Andric } 63bdd1243dSDimitry Andric } 64