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

Side by Side Diff: src/IceTargetLoweringARM32.h

Issue 1075363002: Add a basic TargetARM32 skeleton which knows nothing. (Closed) Base URL: https://chromium.googlesource.com/native_client/pnacl-subzero.git@master
Patch Set: remove comments Created 5 years, 8 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
« no previous file with comments | « src/IceTargetLowering.cpp ('k') | src/IceTargetLoweringARM32.cpp » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
(Empty)
1 //===- subzero/src/IceTargetLoweringARM32.h - ARM32 lowering ----*- C++ -*-===//
2 //
3 // The Subzero Code Generator
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 declares the TargetLoweringARM32 class, which implements the
11 // TargetLowering interface for the ARM 32-bit architecture.
12 //
13 //===----------------------------------------------------------------------===//
14
15 #ifndef SUBZERO_SRC_ICETARGETLOWERINGARM32_H
16 #define SUBZERO_SRC_ICETARGETLOWERINGARM32_H
17
18 #include "IceDefs.h"
19 #include "IceRegistersARM32.h"
20 #include "IceTargetLowering.h"
21
22 namespace Ice {
23
24 class TargetARM32 : public TargetLowering {
25 TargetARM32() = delete;
26 TargetARM32(const TargetARM32 &) = delete;
27 TargetARM32 &operator=(const TargetARM32 &) = delete;
28
29 public:
30 // TODO(jvoung): return a unique_ptr.
31 static TargetARM32 *create(Cfg *Func) { return new TargetARM32(Func); }
32
33 void translateOm1() override;
34 void translateO2() override;
35 bool doBranchOpt(Inst *I, const CfgNode *NextNode) override;
36
37 SizeT getNumRegisters() const override { return RegARM32::Reg_NUM; }
38 Variable *getPhysicalRegister(SizeT RegNum, Type Ty = IceType_void) override;
39 IceString getRegName(SizeT RegNum, Type Ty) const override;
40 llvm::SmallBitVector getRegisterSet(RegSetMask Include,
41 RegSetMask Exclude) const override;
42 const llvm::SmallBitVector &getRegisterSetForType(Type Ty) const override {
43 return TypeToRegisterSet[Ty];
44 }
45 bool hasFramePointer() const override { return UsesFramePointer; }
46 SizeT getFrameOrStackReg() const override {
47 return UsesFramePointer ? RegARM32::Reg_fp : RegARM32::Reg_sp;
48 }
49 size_t typeWidthInBytesOnStack(Type Ty) const override {
50 // Round up to the next multiple of 4 bytes. In particular, i1,
51 // i8, and i16 are rounded up to 4 bytes.
52 return (typeWidthInBytes(Ty) + 3) & ~3;
53 }
54 void emitVariable(const Variable *Var) const override;
55 void lowerArguments() override;
56 void addProlog(CfgNode *Node) override;
57 void addEpilog(CfgNode *Node) override;
58
59 protected:
60 explicit TargetARM32(Cfg *Func);
61
62 void postLower() override;
63
64 void lowerAlloca(const InstAlloca *Inst) override;
65 void lowerArithmetic(const InstArithmetic *Inst) override;
66 void lowerAssign(const InstAssign *Inst) override;
67 void lowerBr(const InstBr *Inst) override;
68 void lowerCall(const InstCall *Inst) override;
69 void lowerCast(const InstCast *Inst) override;
70 void lowerExtractElement(const InstExtractElement *Inst) override;
71 void lowerFcmp(const InstFcmp *Inst) override;
72 void lowerIcmp(const InstIcmp *Inst) override;
73 void lowerIntrinsicCall(const InstIntrinsicCall *Inst) override;
74 void lowerInsertElement(const InstInsertElement *Inst) override;
75 void lowerLoad(const InstLoad *Inst) override;
76 void lowerPhi(const InstPhi *Inst) override;
77 void lowerRet(const InstRet *Inst) override;
78 void lowerSelect(const InstSelect *Inst) override;
79 void lowerStore(const InstStore *Inst) override;
80 void lowerSwitch(const InstSwitch *Inst) override;
81 void lowerUnreachable(const InstUnreachable *Inst) override;
82 void prelowerPhis() override;
83 void lowerPhiAssignments(CfgNode *Node,
84 const AssignList &Assignments) override;
85 void doAddressOptLoad() override;
86 void doAddressOptStore() override;
87 void randomlyInsertNop(float Probability) override;
88 void makeRandomRegisterPermutation(
89 llvm::SmallVectorImpl<int32_t> &Permutation,
90 const llvm::SmallBitVector &ExcludeRegisters) const override;
91
92 static Type stackSlotType();
93
94 bool UsesFramePointer;
95 bool NeedsStackAlignment;
96 llvm::SmallBitVector TypeToRegisterSet[IceType_NUM];
97 llvm::SmallBitVector ScratchRegs;
98 llvm::SmallBitVector RegsUsed;
99 VarList PhysicalRegisters[IceType_NUM];
100 static IceString RegNames[];
101
102 private:
103 ~TargetARM32() override {}
104 };
105
106 class TargetDataARM32 : public TargetDataLowering {
107 TargetDataARM32() = delete;
108 TargetDataARM32(const TargetDataARM32 &) = delete;
109 TargetDataARM32 &operator=(const TargetDataARM32 &) = delete;
110
111 public:
112 static TargetDataLowering *create(GlobalContext *Ctx) {
113 return new TargetDataARM32(Ctx);
114 }
115
116 void lowerGlobals(std::unique_ptr<VariableDeclarationList> Vars) const final;
117 void lowerConstants() const final;
118
119 protected:
120 explicit TargetDataARM32(GlobalContext *Ctx);
121
122 private:
123 void lowerGlobal(const VariableDeclaration &Var) const;
124 ~TargetDataARM32() override {}
125 template <typename T> static void emitConstantPool(GlobalContext *Ctx);
126 };
127
128 } // end of namespace Ice
129
130 #endif // SUBZERO_SRC_ICETARGETLOWERINGARM32_H
OLDNEW
« no previous file with comments | « src/IceTargetLowering.cpp ('k') | src/IceTargetLoweringARM32.cpp » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698