blob: 4edecc4cd11a60482303ff8f9550df4a926e48d1 [file] [log] [blame]
Rafael Espindola320296a2013-10-08 13:08:17 +00001//===-- MipsTargetStreamer.h - Mips Target Streamer ------------*- C++ -*--===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9
10#ifndef MIPSTARGETSTREAMER_H
11#define MIPSTARGETSTREAMER_H
12
Jack Carter4c1625b2013-11-18 23:55:27 +000013#include "llvm/MC/MCELFStreamer.h"
Rafael Espindola320296a2013-10-08 13:08:17 +000014#include "llvm/MC/MCStreamer.h"
15
16namespace llvm {
17class MipsTargetStreamer : public MCTargetStreamer {
Jack Carter4c1625b2013-11-18 23:55:27 +000018 virtual void anchor();
Eric Christophere40e68a2013-11-19 02:01:07 +000019
Rafael Espindola320296a2013-10-08 13:08:17 +000020public:
21 virtual void emitMipsHackELFFlags(unsigned Flags) = 0;
Jack Cartere53969b2013-11-19 01:25:18 +000022 virtual void emitSymSTO(MCSymbol *Sym, unsigned Val) = 0;
Rafael Espindola320296a2013-10-08 13:08:17 +000023};
Jack Carter4c1625b2013-11-18 23:55:27 +000024
25// This part is for ascii assembly output
26class MipsTargetAsmStreamer : public MipsTargetStreamer {
Jack Carter4c1625b2013-11-18 23:55:27 +000027public:
Jack Carter4c1625b2013-11-18 23:55:27 +000028 virtual void emitMipsHackELFFlags(unsigned Flags);
Jack Cartere53969b2013-11-19 01:25:18 +000029 virtual void emitSymSTO(MCSymbol *Sym, unsigned Val);
Jack Carter4c1625b2013-11-18 23:55:27 +000030};
31
32// This part is for ELF object output
33class MipsTargetELFStreamer : public MipsTargetStreamer {
34public:
35 MCELFStreamer &getStreamer();
Jack Carter4c1625b2013-11-18 23:55:27 +000036 virtual void emitMipsHackELFFlags(unsigned Flags);
Jack Cartere53969b2013-11-19 01:25:18 +000037 virtual void emitSymSTO(MCSymbol *Sym, unsigned Val);
Jack Carter4c1625b2013-11-18 23:55:27 +000038};
Rafael Espindola320296a2013-10-08 13:08:17 +000039}
40
41#endif