|  | //===-- RISCVTargetStreamer.cpp - RISCV Target Streamer Methods -----------===// | 
|  | // | 
|  | //                     The LLVM Compiler Infrastructure | 
|  | // | 
|  | // This file is distributed under the University of Illinois Open Source | 
|  | // License. See LICENSE.TXT for details. | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  | // | 
|  | // 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"; | 
|  | } |