Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 //===- subzero/src/IceTargetLoweringMIPS32.h - MIPS32 lowering ---*- C++-*-===// | 1 //===- subzero/src/IceTargetLoweringMIPS32.h - MIPS32 lowering ---*- C++-*-===// |
| 2 // | 2 // |
| 3 // The Subzero Code Generator | 3 // The Subzero Code Generator |
| 4 // | 4 // |
| 5 // This file is distributed under the University of Illinois Open Source | 5 // This file is distributed under the University of Illinois Open Source |
| 6 // License. See LICENSE.TXT for details. | 6 // License. See LICENSE.TXT for details. |
| 7 // | 7 // |
| 8 //===----------------------------------------------------------------------===// | 8 //===----------------------------------------------------------------------===// |
| 9 /// | 9 /// |
| 10 /// \file | 10 /// \file |
| (...skipping 17 matching lines...) Expand all Loading... | |
| 28 class TargetMIPS32 : public TargetLowering { | 28 class TargetMIPS32 : public TargetLowering { |
| 29 TargetMIPS32() = delete; | 29 TargetMIPS32() = delete; |
| 30 TargetMIPS32(const TargetMIPS32 &) = delete; | 30 TargetMIPS32(const TargetMIPS32 &) = delete; |
| 31 TargetMIPS32 &operator=(const TargetMIPS32 &) = delete; | 31 TargetMIPS32 &operator=(const TargetMIPS32 &) = delete; |
| 32 | 32 |
| 33 public: | 33 public: |
| 34 ~TargetMIPS32() override = default; | 34 ~TargetMIPS32() override = default; |
| 35 | 35 |
| 36 static void staticInit(GlobalContext *Ctx); | 36 static void staticInit(GlobalContext *Ctx); |
| 37 static bool shouldBePooled(const Constant *C) { | 37 static bool shouldBePooled(const Constant *C) { |
| 38 if (auto *ConstDouble = llvm::dyn_cast<ConstantDouble>(C)) { | 38 if (llvm::isa<ConstantDouble>(C)) |
| 39 return !Utils::isPositiveZero(ConstDouble->getValue()); | 39 return true; |
|
Jim Stichnoth
2016/09/19 20:50:14
Question about this change.
Both ARM and x86 have
jaydeep.patil
2016/09/20 07:28:27
Yes, for float/double constant 0 we can use mtc1 $
| |
| 40 } | |
| 41 if (llvm::isa<ConstantFloat>(C)) | 40 if (llvm::isa<ConstantFloat>(C)) |
| 42 return true; | 41 return true; |
| 43 return false; | 42 return false; |
| 44 } | 43 } |
| 45 static std::unique_ptr<::Ice::TargetLowering> create(Cfg *Func) { | 44 static std::unique_ptr<::Ice::TargetLowering> create(Cfg *Func) { |
| 46 return makeUnique<TargetMIPS32>(Func); | 45 return makeUnique<TargetMIPS32>(Func); |
| 47 } | 46 } |
| 48 | 47 |
| 49 std::unique_ptr<::Ice::Assembler> createAssembler() const override { | 48 std::unique_ptr<::Ice::Assembler> createAssembler() const override { |
| 50 return makeUnique<MIPS32::AssemblerMIPS32>(); | 49 return makeUnique<MIPS32::AssemblerMIPS32>(); |
| (...skipping 766 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 817 void lowerGlobals(const VariableDeclarationList &Vars, | 816 void lowerGlobals(const VariableDeclarationList &Vars, |
| 818 const std::string &SectionSuffix) override; | 817 const std::string &SectionSuffix) override; |
| 819 void lowerConstants() override; | 818 void lowerConstants() override; |
| 820 void lowerJumpTables() override; | 819 void lowerJumpTables() override; |
| 821 | 820 |
| 822 protected: | 821 protected: |
| 823 explicit TargetDataMIPS32(GlobalContext *Ctx); | 822 explicit TargetDataMIPS32(GlobalContext *Ctx); |
| 824 | 823 |
| 825 private: | 824 private: |
| 826 ~TargetDataMIPS32() override = default; | 825 ~TargetDataMIPS32() override = default; |
| 827 template <typename T> static void emitConstantPool(GlobalContext *Ctx); | |
| 828 }; | 826 }; |
| 829 | 827 |
| 830 class TargetHeaderMIPS32 final : public TargetHeaderLowering { | 828 class TargetHeaderMIPS32 final : public TargetHeaderLowering { |
| 831 TargetHeaderMIPS32() = delete; | 829 TargetHeaderMIPS32() = delete; |
| 832 TargetHeaderMIPS32(const TargetHeaderMIPS32 &) = delete; | 830 TargetHeaderMIPS32(const TargetHeaderMIPS32 &) = delete; |
| 833 TargetHeaderMIPS32 &operator=(const TargetHeaderMIPS32 &) = delete; | 831 TargetHeaderMIPS32 &operator=(const TargetHeaderMIPS32 &) = delete; |
| 834 | 832 |
| 835 public: | 833 public: |
| 836 static std::unique_ptr<TargetHeaderLowering> create(GlobalContext *Ctx) { | 834 static std::unique_ptr<TargetHeaderLowering> create(GlobalContext *Ctx) { |
| 837 return std::unique_ptr<TargetHeaderLowering>(new TargetHeaderMIPS32(Ctx)); | 835 return std::unique_ptr<TargetHeaderLowering>(new TargetHeaderMIPS32(Ctx)); |
| 838 } | 836 } |
| 839 | 837 |
| 840 void lower() override; | 838 void lower() override; |
| 841 | 839 |
| 842 protected: | 840 protected: |
| 843 explicit TargetHeaderMIPS32(GlobalContext *Ctx); | 841 explicit TargetHeaderMIPS32(GlobalContext *Ctx); |
| 844 | 842 |
| 845 private: | 843 private: |
| 846 ~TargetHeaderMIPS32() = default; | 844 ~TargetHeaderMIPS32() = default; |
| 847 }; | 845 }; |
| 848 | 846 |
| 849 } // end of namespace MIPS32 | 847 } // end of namespace MIPS32 |
| 850 } // end of namespace Ice | 848 } // end of namespace Ice |
| 851 | 849 |
| 852 #endif // SUBZERO_SRC_ICETARGETLOWERINGMIPS32_H | 850 #endif // SUBZERO_SRC_ICETARGETLOWERINGMIPS32_H |
| OLD | NEW |