xref: /freebsd-src/contrib/llvm-project/llvm/lib/Target/Xtensa/MCTargetDesc/XtensaMCExpr.cpp (revision 0fca6ea1d4eea4c934cfff25ac9ee8ad6fe95583)
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