| //===-- RISCVTargetStreamer.cpp - RISCV Target Streamer Methods -----------===// |
| // |
| // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
| // See https://llvm.org/LICENSE.txt for license information. |
| // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
| // |
| //===----------------------------------------------------------------------===// |
| // |
| // This file provides RISCV specific target streamer methods. |
| // |
| //===----------------------------------------------------------------------===// |
| |
| #include "RISCVTargetStreamer.h" |
| #include "llvm/Support/FormattedStream.h" |
| |
| using namespace llvm; |
| |
| RISCVTargetStreamer::RISCVTargetStreamer(MCStreamer &S) : MCTargetStreamer(S) {} |
| |
| // This part is for ascii assembly output |
| RISCVTargetAsmStreamer::RISCVTargetAsmStreamer(MCStreamer &S, |
| formatted_raw_ostream &OS) |
| : RISCVTargetStreamer(S), OS(OS) {} |
| |
| void RISCVTargetAsmStreamer::emitDirectiveOptionPush() { |
| OS << "\t.option\tpush\n"; |
| } |
| |
| void RISCVTargetAsmStreamer::emitDirectiveOptionPop() { |
| OS << "\t.option\tpop\n"; |
| } |
| |
| void RISCVTargetAsmStreamer::emitDirectiveOptionRVC() { |
| OS << "\t.option\trvc\n"; |
| } |
| |
| void RISCVTargetAsmStreamer::emitDirectiveOptionNoRVC() { |
| OS << "\t.option\tnorvc\n"; |
| } |
| |
| void RISCVTargetAsmStreamer::emitDirectiveOptionRelax() { |
| OS << "\t.option\trelax\n"; |
| } |
| |
| void RISCVTargetAsmStreamer::emitDirectiveOptionNoRelax() { |
| OS << "\t.option\tnorelax\n"; |
| } |