forked from stichnot/subzero
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathIceTargetLoweringX8632.h
145 lines (134 loc) · 5.72 KB
/
IceTargetLoweringX8632.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
// -*- Mode: c++ -*-
/* Copyright 2014 The Native Client Authors. All rights reserved.
* Use of this source code is governed by a BSD-style license that can
* be found in the LICENSE file.
*/
#ifndef _IceTargetLoweringX8632_h
#define _IceTargetLoweringX8632_h
#include "IceDefs.h"
#include "IceTargetLowering.h"
class IceTargetX8632 : public IceTargetLowering {
public:
static IceTargetX8632 *create(IceCfg *Cfg) { return new IceTargetX8632(Cfg); }
virtual void translate(void);
virtual IceVariable *getPhysicalRegister(unsigned RegNum);
virtual IceString getRegName(int RegNum) const {
assert(RegNum >= 0);
assert(RegNum < Reg_NUM);
return RegNames[RegNum];
}
virtual llvm::SmallBitVector
getRegisterSet(RegSetMask Include = RegMask_All,
RegSetMask Exclude = RegMask_None) const;
virtual const llvm::SmallBitVector &
getRegisterSetForType(IceType Type) const {
return TypeToRegisterSet[Type];
}
virtual bool hasFramePointer(void) const { return IsEbpBasedFrame; }
virtual unsigned getFrameOrStackReg(void) const {
return IsEbpBasedFrame ? Reg_ebp : Reg_esp;
}
virtual uint32_t typeWidthOnStack(IceType Type) {
return (iceTypeWidth(Type) + 3) & ~3;
}
virtual void addProlog(IceCfgNode *Node);
virtual void addEpilog(IceCfgNode *Node);
uint32_t makeNextLabelNumber(void) { return NextLabelNumber++; }
// Ensure that a 64-bit IceVariable has been split into 2 32-bit
// IceVariables, creating them if necessary. This is needed for all
// I64 operations, and it is needed for pushing F64 arguments for
// function calls using the 32-bit push instruction (though the
// latter could be done by directly writing to the stack).
void split64(IceVariable *Var);
void setArgOffsetAndCopy(IceVariable *Arg, IceVariable *FramePtr,
int BasicFrameOffset, int &InArgsSizeBytes,
IceInstList &Expansion);
IceOperand *makeLowOperand(IceOperand *Operand);
IceOperand *makeHighOperand(IceOperand *Operand);
enum Registers {
Reg_eax = 0,
Reg_ecx = Reg_eax + 1,
Reg_edx = Reg_eax + 2,
Reg_ebx = Reg_eax + 3,
Reg_esp = Reg_eax + 4,
Reg_ebp = Reg_eax + 5,
Reg_esi = Reg_eax + 6,
Reg_edi = Reg_eax + 7,
Reg_xmm0,
Reg_xmm1 = Reg_xmm0 + 1,
Reg_xmm2 = Reg_xmm0 + 2,
Reg_xmm3 = Reg_xmm0 + 3,
Reg_xmm4 = Reg_xmm0 + 4,
Reg_xmm5 = Reg_xmm0 + 5,
Reg_xmm6 = Reg_xmm0 + 6,
Reg_xmm7 = Reg_xmm0 + 7,
Reg_NUM
};
protected:
IceTargetX8632(IceCfg *Cfg);
virtual IceInstList lowerAlloca(const IceInstAlloca *Inst,
const IceInst *Next, bool &DeleteNextInst);
virtual IceInstList lowerArithmetic(const IceInstArithmetic *Inst,
const IceInst *Next,
bool &DeleteNextInst);
virtual IceInstList lowerAssign(const IceInstAssign *Inst,
const IceInst *Next, bool &DeleteNextInst);
virtual IceInstList lowerBr(const IceInstBr *Inst, const IceInst *Next,
bool &DeleteNextInst);
virtual IceInstList lowerCall(const IceInstCall *Inst, const IceInst *Next,
bool &DeleteNextInst);
virtual IceInstList lowerCast(const IceInstCast *Inst, const IceInst *Next,
bool &DeleteNextInst);
virtual IceInstList lowerFcmp(const IceInstFcmp *Inst, const IceInst *Next,
bool &DeleteNextInst);
virtual IceInstList lowerIcmp(const IceInstIcmp *Inst, const IceInst *Next,
bool &DeleteNextInst);
virtual IceInstList lowerLoad(const IceInstLoad *Inst, const IceInst *Next,
bool &DeleteNextInst);
virtual IceInstList lowerPhi(const IceInstPhi *Inst, const IceInst *Next,
bool &DeleteNextInst);
virtual IceInstList lowerRet(const IceInstRet *Inst, const IceInst *Next,
bool &DeleteNextInst);
virtual IceInstList lowerSelect(const IceInstSelect *Inst,
const IceInst *Next, bool &DeleteNextInst);
virtual IceInstList lowerStore(const IceInstStore *Inst, const IceInst *Next,
bool &DeleteNextInst);
virtual IceInstList lowerSwitch(const IceInstSwitch *Inst,
const IceInst *Next, bool &DeleteNextInst);
virtual IceInstList doAddressOptLoad(const IceInstLoad *Inst);
virtual IceInstList doAddressOptStore(const IceInstStore *Inst);
enum OperandLegalization {
Legal_None = 0,
Legal_Reg = 1 << 0,
Legal_Imm = 1 << 1,
Legal_Mem = 1 << 2, // includes [eax+4*ecx] as well as [esp+12]
Legal_All = ~Legal_None
};
typedef uint32_t LegalMask;
IceOperand *legalizeOperand(IceOperand *From, LegalMask Allowed,
IceInstList &Insts, bool AllowOverlap = false,
int RegNum = -1);
IceVariable *legalizeOperandToVar(IceOperand *From, IceInstList &Insts,
bool AllowOverlap = false, int RegNum = -1);
bool IsEbpBasedFrame;
int FrameSizeLocals;
int LocalsSizeBytes;
llvm::SmallBitVector TypeToRegisterSet[IceType_NUM];
llvm::SmallBitVector ScratchRegs;
llvm::SmallBitVector RegsUsed;
uint32_t NextLabelNumber;
bool ComputedLiveRanges;
IceVarList PhysicalRegisters;
static IceString RegNames[];
};
class IceTargetX8632Fast : public IceTargetX8632 {
public:
static IceTargetX8632Fast *create(IceCfg *Cfg) {
return new IceTargetX8632Fast(Cfg);
}
virtual void translate(void);
protected:
IceTargetX8632Fast(IceCfg *Cfg) : IceTargetX8632(Cfg) {}
virtual void postLower(const IceInstList &Expansion);
};
#endif // _IceTargetLoweringX8632_h