• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1 // Copyright 2015 the V8 project authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file.
4 
5 #include "src/compiler/instruction-scheduler.h"
6 
7 namespace v8 {
8 namespace internal {
9 namespace compiler {
10 
SchedulerSupported()11 bool InstructionScheduler::SchedulerSupported() { return true; }
12 
13 
GetTargetInstructionFlags(const Instruction * instr) const14 int InstructionScheduler::GetTargetInstructionFlags(
15     const Instruction* instr) const {
16   switch (instr->arch_opcode()) {
17     case kPPC_And:
18     case kPPC_AndComplement:
19     case kPPC_Or:
20     case kPPC_OrComplement:
21     case kPPC_Xor:
22     case kPPC_ShiftLeft32:
23     case kPPC_ShiftLeft64:
24     case kPPC_ShiftLeftPair:
25     case kPPC_ShiftRight32:
26     case kPPC_ShiftRight64:
27     case kPPC_ShiftRightPair:
28     case kPPC_ShiftRightAlg32:
29     case kPPC_ShiftRightAlg64:
30     case kPPC_ShiftRightAlgPair:
31     case kPPC_RotRight32:
32     case kPPC_RotRight64:
33     case kPPC_Not:
34     case kPPC_RotLeftAndMask32:
35     case kPPC_RotLeftAndClear64:
36     case kPPC_RotLeftAndClearLeft64:
37     case kPPC_RotLeftAndClearRight64:
38     case kPPC_Add:
39     case kPPC_AddWithOverflow32:
40     case kPPC_AddPair:
41     case kPPC_AddDouble:
42     case kPPC_Sub:
43     case kPPC_SubWithOverflow32:
44     case kPPC_SubPair:
45     case kPPC_SubDouble:
46     case kPPC_Mul32:
47     case kPPC_Mul32WithHigh32:
48     case kPPC_Mul64:
49     case kPPC_MulHigh32:
50     case kPPC_MulHighU32:
51     case kPPC_MulPair:
52     case kPPC_MulDouble:
53     case kPPC_Div32:
54     case kPPC_Div64:
55     case kPPC_DivU32:
56     case kPPC_DivU64:
57     case kPPC_DivDouble:
58     case kPPC_Mod32:
59     case kPPC_Mod64:
60     case kPPC_ModU32:
61     case kPPC_ModU64:
62     case kPPC_ModDouble:
63     case kPPC_Neg:
64     case kPPC_NegDouble:
65     case kPPC_SqrtDouble:
66     case kPPC_FloorDouble:
67     case kPPC_CeilDouble:
68     case kPPC_TruncateDouble:
69     case kPPC_RoundDouble:
70     case kPPC_MaxDouble:
71     case kPPC_MinDouble:
72     case kPPC_AbsDouble:
73     case kPPC_Cntlz32:
74     case kPPC_Cntlz64:
75     case kPPC_Popcnt32:
76     case kPPC_Popcnt64:
77     case kPPC_Cmp32:
78     case kPPC_Cmp64:
79     case kPPC_CmpDouble:
80     case kPPC_Tst32:
81     case kPPC_Tst64:
82     case kPPC_ExtendSignWord8:
83     case kPPC_ExtendSignWord16:
84     case kPPC_ExtendSignWord32:
85     case kPPC_Uint32ToUint64:
86     case kPPC_Int64ToInt32:
87     case kPPC_Int64ToFloat32:
88     case kPPC_Int64ToDouble:
89     case kPPC_Uint64ToFloat32:
90     case kPPC_Uint64ToDouble:
91     case kPPC_Int32ToFloat32:
92     case kPPC_Int32ToDouble:
93     case kPPC_Uint32ToFloat32:
94     case kPPC_Uint32ToDouble:
95     case kPPC_Float32ToDouble:
96     case kPPC_Float64SilenceNaN:
97     case kPPC_DoubleToInt32:
98     case kPPC_DoubleToUint32:
99     case kPPC_DoubleToInt64:
100     case kPPC_DoubleToUint64:
101     case kPPC_DoubleToFloat32:
102     case kPPC_DoubleExtractLowWord32:
103     case kPPC_DoubleExtractHighWord32:
104     case kPPC_DoubleInsertLowWord32:
105     case kPPC_DoubleInsertHighWord32:
106     case kPPC_DoubleConstruct:
107     case kPPC_BitcastInt32ToFloat32:
108     case kPPC_BitcastFloat32ToInt32:
109     case kPPC_BitcastInt64ToDouble:
110     case kPPC_BitcastDoubleToInt64:
111       return kNoOpcodeFlags;
112 
113     case kPPC_LoadWordS8:
114     case kPPC_LoadWordU8:
115     case kPPC_LoadWordS16:
116     case kPPC_LoadWordU16:
117     case kPPC_LoadWordS32:
118     case kPPC_LoadWordU32:
119     case kPPC_LoadWord64:
120     case kPPC_LoadFloat32:
121     case kPPC_LoadDouble:
122       return kIsLoadOperation;
123 
124     case kPPC_StoreWord8:
125     case kPPC_StoreWord16:
126     case kPPC_StoreWord32:
127     case kPPC_StoreWord64:
128     case kPPC_StoreFloat32:
129     case kPPC_StoreDouble:
130     case kPPC_Push:
131     case kPPC_PushFrame:
132     case kPPC_StoreToStackSlot:
133       return kHasSideEffect;
134 
135 #define CASE(Name) case k##Name:
136     COMMON_ARCH_OPCODE_LIST(CASE)
137 #undef CASE
138       // Already covered in architecture independent code.
139       UNREACHABLE();
140   }
141 
142   UNREACHABLE();
143   return kNoOpcodeFlags;
144 }
145 
146 
GetInstructionLatency(const Instruction * instr)147 int InstructionScheduler::GetInstructionLatency(const Instruction* instr) {
148   // TODO(all): Add instruction cost modeling.
149   return 1;
150 }
151 
152 }  // namespace compiler
153 }  // namespace internal
154 }  // namespace v8
155