| Venkatraman Govindaraju | bf683fd | 2013-12-26 01:49:59 +0000 | [diff] [blame] | 1 | //===-- SparcTargetStreamer.h - Sparc 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 |  | 
| Benjamin Kramer | a7c40ef | 2014-08-13 16:26:38 +0000 | [diff] [blame] | 10 | #ifndef LLVM_LIB_TARGET_SPARC_SPARCTARGETSTREAMER_H | 
|  | 11 | #define LLVM_LIB_TARGET_SPARC_SPARCTARGETSTREAMER_H | 
| Venkatraman Govindaraju | bf683fd | 2013-12-26 01:49:59 +0000 | [diff] [blame] | 12 |  | 
|  | 13 | #include "llvm/MC/MCELFStreamer.h" | 
|  | 14 | #include "llvm/MC/MCStreamer.h" | 
|  | 15 |  | 
|  | 16 | namespace llvm { | 
|  | 17 | class SparcTargetStreamer : public MCTargetStreamer { | 
|  | 18 | virtual void anchor(); | 
|  | 19 |  | 
|  | 20 | public: | 
| Rafael Espindola | 24ea09e | 2014-01-26 06:06:37 +0000 | [diff] [blame] | 21 | SparcTargetStreamer(MCStreamer &S); | 
| Venkatraman Govindaraju | bf683fd | 2013-12-26 01:49:59 +0000 | [diff] [blame] | 22 | /// Emit ".register <reg>, #ignore". | 
|  | 23 | virtual void emitSparcRegisterIgnore(unsigned reg) = 0; | 
|  | 24 | /// Emit ".register <reg>, #scratch". | 
|  | 25 | virtual void emitSparcRegisterScratch(unsigned reg) = 0; | 
|  | 26 | }; | 
|  | 27 |  | 
|  | 28 | // This part is for ascii assembly output | 
|  | 29 | class SparcTargetAsmStreamer : public SparcTargetStreamer { | 
|  | 30 | formatted_raw_ostream &OS; | 
|  | 31 |  | 
|  | 32 | public: | 
| Rafael Espindola | 24ea09e | 2014-01-26 06:06:37 +0000 | [diff] [blame] | 33 | SparcTargetAsmStreamer(MCStreamer &S, formatted_raw_ostream &OS); | 
| Craig Topper | b0c941b | 2014-04-29 07:57:13 +0000 | [diff] [blame] | 34 | void emitSparcRegisterIgnore(unsigned reg) override; | 
|  | 35 | void emitSparcRegisterScratch(unsigned reg) override; | 
| Venkatraman Govindaraju | bf683fd | 2013-12-26 01:49:59 +0000 | [diff] [blame] | 36 |  | 
|  | 37 | }; | 
|  | 38 |  | 
|  | 39 | // This part is for ELF object output | 
|  | 40 | class SparcTargetELFStreamer : public SparcTargetStreamer { | 
|  | 41 | public: | 
| Rafael Espindola | 24ea09e | 2014-01-26 06:06:37 +0000 | [diff] [blame] | 42 | SparcTargetELFStreamer(MCStreamer &S); | 
| Venkatraman Govindaraju | bf683fd | 2013-12-26 01:49:59 +0000 | [diff] [blame] | 43 | MCELFStreamer &getStreamer(); | 
| Craig Topper | b0c941b | 2014-04-29 07:57:13 +0000 | [diff] [blame] | 44 | void emitSparcRegisterIgnore(unsigned reg) override {} | 
|  | 45 | void emitSparcRegisterScratch(unsigned reg) override {} | 
| Venkatraman Govindaraju | bf683fd | 2013-12-26 01:49:59 +0000 | [diff] [blame] | 46 | }; | 
|  | 47 | } // end namespace llvm | 
|  | 48 |  | 
|  | 49 | #endif |