| Zoran Jovanovic | ada38ef | 2014-03-27 12:38:40 +0000 | [diff] [blame] | 1 | //===-- MipsAsmBackend.h - Mips Asm Backend  ------------------------------===// | 
|  | 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 | // This file defines the MipsAsmBackend class. | 
|  | 11 | // | 
|  | 12 | //===----------------------------------------------------------------------===// | 
|  | 13 | // | 
|  | 14 |  | 
| Benjamin Kramer | a7c40ef | 2014-08-13 16:26:38 +0000 | [diff] [blame] | 15 | #ifndef LLVM_LIB_TARGET_MIPS_MCTARGETDESC_MIPSASMBACKEND_H | 
|  | 16 | #define LLVM_LIB_TARGET_MIPS_MCTARGETDESC_MIPSASMBACKEND_H | 
| Zoran Jovanovic | ada38ef | 2014-03-27 12:38:40 +0000 | [diff] [blame] | 17 |  | 
|  | 18 | #include "MCTargetDesc/MipsFixupKinds.h" | 
| Daniel Sanders | 50f1723 | 2015-09-15 16:17:27 +0000 | [diff] [blame] | 19 | #include "llvm/ADT/Triple.h" | 
| Chandler Carruth | d990388 | 2015-01-14 11:23:27 +0000 | [diff] [blame] | 20 | #include "llvm/MC/MCAsmBackend.h" | 
| Zoran Jovanovic | ada38ef | 2014-03-27 12:38:40 +0000 | [diff] [blame] | 21 |  | 
|  | 22 | namespace llvm { | 
|  | 23 |  | 
|  | 24 | class MCAssembler; | 
| Aaron Ballman | be648a3 | 2014-03-27 14:10:00 +0000 | [diff] [blame] | 25 | struct MCFixupKindInfo; | 
| Zoran Jovanovic | ada38ef | 2014-03-27 12:38:40 +0000 | [diff] [blame] | 26 | class MCObjectWriter; | 
| Simon Atanasyan | 6d79586 | 2017-09-07 12:54:26 +0000 | [diff] [blame] | 27 | class MCRegisterInfo; | 
|  | 28 | class Target; | 
| Zoran Jovanovic | ada38ef | 2014-03-27 12:38:40 +0000 | [diff] [blame] | 29 |  | 
|  | 30 | class MipsAsmBackend : public MCAsmBackend { | 
| Simon Atanasyan | 6d79586 | 2017-09-07 12:54:26 +0000 | [diff] [blame] | 31 | Triple TheTriple; | 
| Simon Atanasyan | 11766558 | 2017-09-21 10:44:26 +0000 | [diff] [blame] | 32 | bool IsN32; | 
| Zoran Jovanovic | ada38ef | 2014-03-27 12:38:40 +0000 | [diff] [blame] | 33 |  | 
|  | 34 | public: | 
| Simon Atanasyan | 6d79586 | 2017-09-07 12:54:26 +0000 | [diff] [blame] | 35 | MipsAsmBackend(const Target &T, const MCRegisterInfo &MRI, const Triple &TT, | 
| Simon Atanasyan | 11766558 | 2017-09-21 10:44:26 +0000 | [diff] [blame] | 36 | StringRef CPU, bool N32) | 
| Peter Collingbourne | 571a330 | 2018-05-21 17:57:19 +0000 | [diff] [blame] | 37 | : MCAsmBackend(TT.isLittleEndian() ? support::little : support::big), | 
|  | 38 | TheTriple(TT), IsN32(N32) {} | 
| Zoran Jovanovic | ada38ef | 2014-03-27 12:38:40 +0000 | [diff] [blame] | 39 |  | 
| Lang Hames | 60fbc7c | 2017-10-10 16:28:07 +0000 | [diff] [blame] | 40 | std::unique_ptr<MCObjectWriter> | 
|  | 41 | createObjectWriter(raw_pwrite_stream &OS) const override; | 
| Zoran Jovanovic | ada38ef | 2014-03-27 12:38:40 +0000 | [diff] [blame] | 42 |  | 
| Rafael Espindola | 801b42d | 2017-06-23 22:52:36 +0000 | [diff] [blame] | 43 | void applyFixup(const MCAssembler &Asm, const MCFixup &Fixup, | 
|  | 44 | const MCValue &Target, MutableArrayRef<char> Data, | 
| Rafael Espindola | 1beb702 | 2017-07-11 23:18:25 +0000 | [diff] [blame] | 45 | uint64_t Value, bool IsResolved) const override; | 
| Zoran Jovanovic | ada38ef | 2014-03-27 12:38:40 +0000 | [diff] [blame] | 46 |  | 
| David Majnemer | ce10842 | 2016-01-19 23:05:27 +0000 | [diff] [blame] | 47 | Optional<MCFixupKind> getFixupKind(StringRef Name) const override; | 
| Craig Topper | 56c590a | 2014-04-29 07:58:02 +0000 | [diff] [blame] | 48 | const MCFixupKindInfo &getFixupKindInfo(MCFixupKind Kind) const override; | 
| Zoran Jovanovic | ada38ef | 2014-03-27 12:38:40 +0000 | [diff] [blame] | 49 |  | 
| Craig Topper | 56c590a | 2014-04-29 07:58:02 +0000 | [diff] [blame] | 50 | unsigned getNumFixupKinds() const override { | 
| Zoran Jovanovic | ada38ef | 2014-03-27 12:38:40 +0000 | [diff] [blame] | 51 | return Mips::NumTargetFixupKinds; | 
|  | 52 | } | 
|  | 53 |  | 
|  | 54 | /// @name Target Relaxation Interfaces | 
|  | 55 | /// @{ | 
|  | 56 |  | 
|  | 57 | /// MayNeedRelaxation - Check whether the given instruction may need | 
|  | 58 | /// relaxation. | 
|  | 59 | /// | 
|  | 60 | /// \param Inst - The instruction to test. | 
| Craig Topper | 56c590a | 2014-04-29 07:58:02 +0000 | [diff] [blame] | 61 | bool mayNeedRelaxation(const MCInst &Inst) const override { | 
| Zoran Jovanovic | ada38ef | 2014-03-27 12:38:40 +0000 | [diff] [blame] | 62 | return false; | 
|  | 63 | } | 
|  | 64 |  | 
|  | 65 | /// fixupNeedsRelaxation - Target specific predicate for whether a given | 
|  | 66 | /// fixup requires the associated instruction to be relaxed. | 
|  | 67 | bool fixupNeedsRelaxation(const MCFixup &Fixup, uint64_t Value, | 
|  | 68 | const MCRelaxableFragment *DF, | 
| Craig Topper | 56c590a | 2014-04-29 07:58:02 +0000 | [diff] [blame] | 69 | const MCAsmLayout &Layout) const override { | 
| Zoran Jovanovic | ada38ef | 2014-03-27 12:38:40 +0000 | [diff] [blame] | 70 | // FIXME. | 
| Craig Topper | 35b2f75 | 2014-06-19 06:10:58 +0000 | [diff] [blame] | 71 | llvm_unreachable("RelaxInstruction() unimplemented"); | 
| Zoran Jovanovic | ada38ef | 2014-03-27 12:38:40 +0000 | [diff] [blame] | 72 | return false; | 
|  | 73 | } | 
|  | 74 |  | 
|  | 75 | /// RelaxInstruction - Relax the instruction in the given fragment | 
|  | 76 | /// to the next wider instruction. | 
|  | 77 | /// | 
|  | 78 | /// \param Inst - The instruction to relax, which may be the same | 
|  | 79 | /// as the output. | 
|  | 80 | /// \param [out] Res On return, the relaxed instruction. | 
| Nirav Dave | 8603062 | 2016-07-11 14:23:53 +0000 | [diff] [blame] | 81 | void relaxInstruction(const MCInst &Inst, const MCSubtargetInfo &STI, | 
|  | 82 | MCInst &Res) const override {} | 
| Zoran Jovanovic | ada38ef | 2014-03-27 12:38:40 +0000 | [diff] [blame] | 83 |  | 
|  | 84 | /// @} | 
|  | 85 |  | 
| Peter Collingbourne | 571a330 | 2018-05-21 17:57:19 +0000 | [diff] [blame] | 86 | bool writeNopData(raw_ostream &OS, uint64_t Count) const override; | 
| Zoran Jovanovic | ada38ef | 2014-03-27 12:38:40 +0000 | [diff] [blame] | 87 |  | 
| Zoran Jovanovic | ada38ef | 2014-03-27 12:38:40 +0000 | [diff] [blame] | 88 | }; // class MipsAsmBackend | 
|  | 89 |  | 
| Alexander Kornienko | f00654e | 2015-06-23 09:49:53 +0000 | [diff] [blame] | 90 | } // namespace | 
| Zoran Jovanovic | ada38ef | 2014-03-27 12:38:40 +0000 | [diff] [blame] | 91 |  | 
|  | 92 | #endif |