Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(418)

Side by Side Diff: src/IceTargetLoweringX8632.h

Issue 1257643004: Subzero. Buildable, non-functional TargetLoweringX8664. (Closed) Base URL: https://chromium.googlesource.com/native_client/pnacl-subzero.git@master
Patch Set: Fixes naming bug in IceInstX8632.h Created 5 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch
OLDNEW
1 //===- subzero/src/IceTargetLoweringX8632.h - x86-32 lowering ---*- C++ -*-===// 1 //===- subzero/src/IceTargetLoweringX8632.h - x86-32 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 20 matching lines...) Expand all
31 : public ::Ice::X86Internal::TargetX86Base<TargetX8632> { 31 : public ::Ice::X86Internal::TargetX86Base<TargetX8632> {
32 TargetX8632() = delete; 32 TargetX8632() = delete;
33 TargetX8632(const TargetX8632 &) = delete; 33 TargetX8632(const TargetX8632 &) = delete;
34 TargetX8632 &operator=(const TargetX8632 &) = delete; 34 TargetX8632 &operator=(const TargetX8632 &) = delete;
35 35
36 public: 36 public:
37 using X86InstructionSet = X8632::Traits::InstructionSet; 37 using X86InstructionSet = X8632::Traits::InstructionSet;
38 38
39 static TargetX8632 *create(Cfg *Func) { return new TargetX8632(Func); } 39 static TargetX8632 *create(Cfg *Func) { return new TargetX8632(Func); }
40 40
41 protected: 41 private:
42 friend class ::Ice::X86Internal::TargetX86Base<TargetX8632>;
43
42 Operand *createNaClReadTPSrcOperand() { 44 Operand *createNaClReadTPSrcOperand() {
43 Constant *Zero = Ctx->getConstantZero(IceType_i32); 45 Constant *Zero = Ctx->getConstantZero(IceType_i32);
44 return Traits::X86OperandMem::create(Func, IceType_i32, nullptr, Zero, 46 return Traits::X86OperandMem::create(Func, IceType_i32, nullptr, Zero,
45 nullptr, 0, 47 nullptr, 0,
46 Traits::X86OperandMem::SegReg_GS); 48 Traits::X86OperandMem::SegReg_GS);
47 } 49 }
48 50
49 private: 51 private:
jvoung (off chromium) 2015/07/30 21:16:21 This "private:" is already covered by the (new) pr
John 2015/07/31 21:05:54 Done.
50 friend class ::Ice::X86Internal::TargetX86Base<TargetX8632>;
51
52 explicit TargetX8632(Cfg *Func) : TargetX86Base(Func) {} 52 explicit TargetX8632(Cfg *Func) : TargetX86Base(Func) {}
53 }; 53 };
54 54
55 class TargetDataX8632 final : public TargetDataLowering { 55 class TargetDataX8632 final : public TargetDataLowering {
56 TargetDataX8632() = delete; 56 TargetDataX8632() = delete;
57 TargetDataX8632(const TargetDataX8632 &) = delete; 57 TargetDataX8632(const TargetDataX8632 &) = delete;
58 TargetDataX8632 &operator=(const TargetDataX8632 &) = delete; 58 TargetDataX8632 &operator=(const TargetDataX8632 &) = delete;
59 59
60 public: 60 public:
61 ~TargetDataX8632() override = default;
62
61 static std::unique_ptr<TargetDataLowering> create(GlobalContext *Ctx) { 63 static std::unique_ptr<TargetDataLowering> create(GlobalContext *Ctx) {
62 return std::unique_ptr<TargetDataLowering>(new TargetDataX8632(Ctx)); 64 return makeUnique<TargetDataX8632>(Ctx);
63 } 65 }
64 66
65 void lowerGlobals(const VariableDeclarationList &Vars, 67 void lowerGlobals(const VariableDeclarationList &Vars,
66 const IceString &SectionSuffix) override; 68 const IceString &SectionSuffix) override;
67 void lowerConstants() override; 69 void lowerConstants() override;
68 70
69 protected: 71 private:
72 ENABLE_MAKE_UNIQUE;
73
70 explicit TargetDataX8632(GlobalContext *Ctx); 74 explicit TargetDataX8632(GlobalContext *Ctx);
71
72 private:
73 ~TargetDataX8632() override = default;
74 template <typename T> static void emitConstantPool(GlobalContext *Ctx); 75 template <typename T> static void emitConstantPool(GlobalContext *Ctx);
75 }; 76 };
76 77
77 class TargetHeaderX8632 final : public TargetHeaderLowering { 78 class TargetHeaderX8632 final : public TargetHeaderLowering {
78 TargetHeaderX8632() = delete; 79 TargetHeaderX8632() = delete;
79 TargetHeaderX8632(const TargetHeaderX8632 &) = delete; 80 TargetHeaderX8632(const TargetHeaderX8632 &) = delete;
80 TargetHeaderX8632 &operator=(const TargetHeaderX8632 &) = delete; 81 TargetHeaderX8632 &operator=(const TargetHeaderX8632 &) = delete;
81 82
82 public: 83 public:
83 static std::unique_ptr<TargetHeaderLowering> create(GlobalContext *Ctx) { 84 static std::unique_ptr<TargetHeaderLowering> create(GlobalContext *Ctx) {
84 return std::unique_ptr<TargetHeaderLowering>(new TargetHeaderX8632(Ctx)); 85 return std::unique_ptr<TargetHeaderLowering>(new TargetHeaderX8632(Ctx));
85 } 86 }
86 87
87 protected: 88 protected:
88 explicit TargetHeaderX8632(GlobalContext *Ctx); 89 explicit TargetHeaderX8632(GlobalContext *Ctx);
89 90
90 private: 91 private:
91 ~TargetHeaderX8632() = default; 92 ~TargetHeaderX8632() = default;
92 }; 93 };
93 94
94 } // end of namespace Ice 95 } // end of namespace Ice
95 96
96 #endif // SUBZERO_SRC_ICETARGETLOWERINGX8632_H 97 #endif // SUBZERO_SRC_ICETARGETLOWERINGX8632_H
OLDNEW
« no previous file with comments | « src/IceInstX86Base.h ('k') | src/IceTargetLoweringX8664.h » ('j') | src/IceTargetLoweringX8664.h » ('J')

Powered by Google App Engine
This is Rietveld 408576698