| //===-- 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 "RISCVBaseInfo.h" |
| #include "RISCVMCTargetDesc.h" |
| #include "llvm/Support/FormattedStream.h" |
| #include "llvm/Support/RISCVAttributes.h" |
| #include "llvm/Support/RISCVISAInfo.h" |
| |
| using namespace llvm; |
| |
| RISCVTargetStreamer::RISCVTargetStreamer(MCStreamer &S) : MCTargetStreamer(S) {} |
| |
| void RISCVTargetStreamer::finish() { finishAttributeSection(); } |
| |
| void RISCVTargetStreamer::emitDirectiveOptionPush() {} |
| void RISCVTargetStreamer::emitDirectiveOptionPop() {} |
| void RISCVTargetStreamer::emitDirectiveOptionPIC() {} |
| void RISCVTargetStreamer::emitDirectiveOptionNoPIC() {} |
| void RISCVTargetStreamer::emitDirectiveOptionRVC() {} |
| void RISCVTargetStreamer::emitDirectiveOptionNoRVC() {} |
| void RISCVTargetStreamer::emitDirectiveOptionRelax() {} |
| void RISCVTargetStreamer::emitDirectiveOptionNoRelax() {} |
| void RISCVTargetStreamer::emitAttribute(unsigned Attribute, unsigned Value) {} |
| void RISCVTargetStreamer::finishAttributeSection() {} |
| void RISCVTargetStreamer::emitTextAttribute(unsigned Attribute, |
| StringRef String) {} |
| void RISCVTargetStreamer::emitIntTextAttribute(unsigned Attribute, |
| unsigned IntValue, |
| StringRef StringValue) {} |
| |
| void RISCVTargetStreamer::emitTargetAttributes(const MCSubtargetInfo &STI) { |
| if (STI.hasFeature(RISCV::FeatureRV32E)) |
| emitAttribute(RISCVAttrs::STACK_ALIGN, RISCVAttrs::ALIGN_4); |
| else |
| emitAttribute(RISCVAttrs::STACK_ALIGN, RISCVAttrs::ALIGN_16); |
| |
| unsigned XLen = STI.hasFeature(RISCV::Feature64Bit) ? 64 : 32; |
| std::vector<std::string> FeatureVector; |
| RISCVFeatures::toFeatureVector(FeatureVector, STI.getFeatureBits()); |
| |
| auto ParseResult = llvm::RISCVISAInfo::parseFeatures(XLen, FeatureVector); |
| if (!ParseResult) { |
| /* Assume any error about features should handled earlier. */ |
| consumeError(ParseResult.takeError()); |
| llvm_unreachable("Parsing feature error when emitTargetAttributes?"); |
| } else { |
| auto &ISAInfo = *ParseResult; |
| emitTextAttribute(RISCVAttrs::ARCH, ISAInfo->toString()); |
| } |
| } |
| |
| // 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::emitDirectiveOptionPIC() { |
| OS << "\t.option\tpic\n"; |
| } |
| |
| void RISCVTargetAsmStreamer::emitDirectiveOptionNoPIC() { |
| OS << "\t.option\tnopic\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"; |
| } |
| |
| void RISCVTargetAsmStreamer::emitAttribute(unsigned Attribute, unsigned Value) { |
| OS << "\t.attribute\t" << Attribute << ", " << Twine(Value) << "\n"; |
| } |
| |
| void RISCVTargetAsmStreamer::emitTextAttribute(unsigned Attribute, |
| StringRef String) { |
| OS << "\t.attribute\t" << Attribute << ", \"" << String << "\"\n"; |
| } |
| |
| void RISCVTargetAsmStreamer::emitIntTextAttribute(unsigned Attribute, |
| unsigned IntValue, |
| StringRef StringValue) {} |
| |
| void RISCVTargetAsmStreamer::finishAttributeSection() {} |