OLD | NEW |
1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/compiler/machine-operator.h" | 5 #include "src/compiler/machine-operator.h" |
6 | 6 |
7 #include "src/base/lazy-instance.h" | 7 #include "src/base/lazy-instance.h" |
8 #include "src/compiler/opcodes.h" | 8 #include "src/compiler/opcodes.h" |
9 #include "src/compiler/operator.h" | 9 #include "src/compiler/operator.h" |
10 | 10 |
(...skipping 184 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
195 V(Float64InsertLowWord32, Operator::kNoProperties, 2, 0, 1) \ | 195 V(Float64InsertLowWord32, Operator::kNoProperties, 2, 0, 1) \ |
196 V(Float64InsertHighWord32, Operator::kNoProperties, 2, 0, 1) \ | 196 V(Float64InsertHighWord32, Operator::kNoProperties, 2, 0, 1) \ |
197 V(LoadStackPointer, Operator::kNoProperties, 0, 0, 1) \ | 197 V(LoadStackPointer, Operator::kNoProperties, 0, 0, 1) \ |
198 V(LoadFramePointer, Operator::kNoProperties, 0, 0, 1) \ | 198 V(LoadFramePointer, Operator::kNoProperties, 0, 0, 1) \ |
199 V(LoadParentFramePointer, Operator::kNoProperties, 0, 0, 1) \ | 199 V(LoadParentFramePointer, Operator::kNoProperties, 0, 0, 1) \ |
200 V(Int32PairAdd, Operator::kNoProperties, 4, 0, 2) \ | 200 V(Int32PairAdd, Operator::kNoProperties, 4, 0, 2) \ |
201 V(Int32PairSub, Operator::kNoProperties, 4, 0, 2) \ | 201 V(Int32PairSub, Operator::kNoProperties, 4, 0, 2) \ |
202 V(Int32PairMul, Operator::kNoProperties, 4, 0, 2) \ | 202 V(Int32PairMul, Operator::kNoProperties, 4, 0, 2) \ |
203 V(Word32PairShl, Operator::kNoProperties, 3, 0, 2) \ | 203 V(Word32PairShl, Operator::kNoProperties, 3, 0, 2) \ |
204 V(Word32PairShr, Operator::kNoProperties, 3, 0, 2) \ | 204 V(Word32PairShr, Operator::kNoProperties, 3, 0, 2) \ |
205 V(Word32PairSar, Operator::kNoProperties, 3, 0, 2) \ | 205 V(Word32PairSar, Operator::kNoProperties, 3, 0, 2) |
206 V(CreateFloat32x4, Operator::kNoProperties, 4, 0, 1) \ | |
207 V(Float32x4ExtractLane, Operator::kNoProperties, 2, 0, 1) \ | |
208 V(Float32x4ReplaceLane, Operator::kNoProperties, 3, 0, 1) \ | |
209 V(Float32x4Abs, Operator::kNoProperties, 1, 0, 1) \ | |
210 V(Float32x4Neg, Operator::kNoProperties, 1, 0, 1) \ | |
211 V(Float32x4Sqrt, Operator::kNoProperties, 1, 0, 1) \ | |
212 V(Float32x4RecipApprox, Operator::kNoProperties, 1, 0, 1) \ | |
213 V(Float32x4RecipSqrtApprox, Operator::kNoProperties, 1, 0, 1) \ | |
214 V(Float32x4Add, Operator::kCommutative, 2, 0, 1) \ | |
215 V(Float32x4Sub, Operator::kNoProperties, 2, 0, 1) \ | |
216 V(Float32x4Mul, Operator::kCommutative, 2, 0, 1) \ | |
217 V(Float32x4Div, Operator::kNoProperties, 2, 0, 1) \ | |
218 V(Float32x4Min, Operator::kCommutative, 2, 0, 1) \ | |
219 V(Float32x4Max, Operator::kCommutative, 2, 0, 1) \ | |
220 V(Float32x4MinNum, Operator::kCommutative, 2, 0, 1) \ | |
221 V(Float32x4MaxNum, Operator::kCommutative, 2, 0, 1) \ | |
222 V(Float32x4Equal, Operator::kCommutative, 2, 0, 1) \ | |
223 V(Float32x4NotEqual, Operator::kCommutative, 2, 0, 1) \ | |
224 V(Float32x4LessThan, Operator::kNoProperties, 2, 0, 1) \ | |
225 V(Float32x4LessThanOrEqual, Operator::kNoProperties, 2, 0, 1) \ | |
226 V(Float32x4GreaterThan, Operator::kNoProperties, 2, 0, 1) \ | |
227 V(Float32x4GreaterThanOrEqual, Operator::kNoProperties, 2, 0, 1) \ | |
228 V(Float32x4Select, Operator::kNoProperties, 3, 0, 1) \ | |
229 V(Float32x4Swizzle, Operator::kNoProperties, 5, 0, 1) \ | |
230 V(Float32x4Shuffle, Operator::kNoProperties, 6, 0, 1) \ | |
231 V(Float32x4FromInt32x4, Operator::kNoProperties, 1, 0, 1) \ | |
232 V(Float32x4FromUint32x4, Operator::kNoProperties, 1, 0, 1) \ | |
233 V(Float32x4Load1, Operator::kNoProperties, 2, 0, 1) \ | |
234 V(Float32x4Load2, Operator::kNoProperties, 2, 0, 1) \ | |
235 V(Float32x4Load3, Operator::kNoProperties, 2, 0, 1) \ | |
236 V(Float32x4Store1, Operator::kNoProperties, 3, 0, 1) \ | |
237 V(Float32x4Store2, Operator::kNoProperties, 3, 0, 1) \ | |
238 V(Float32x4Store3, Operator::kNoProperties, 3, 0, 1) \ | |
239 V(CreateInt32x4, Operator::kNoProperties, 4, 0, 1) \ | |
240 V(Int32x4ExtractLane, Operator::kNoProperties, 2, 0, 1) \ | |
241 V(Int32x4ReplaceLane, Operator::kNoProperties, 3, 0, 1) \ | |
242 V(Int32x4Neg, Operator::kNoProperties, 1, 0, 1) \ | |
243 V(Int32x4Add, Operator::kCommutative, 2, 0, 1) \ | |
244 V(Int32x4Sub, Operator::kNoProperties, 2, 0, 1) \ | |
245 V(Int32x4Mul, Operator::kCommutative, 2, 0, 1) \ | |
246 V(Int32x4Min, Operator::kCommutative, 2, 0, 1) \ | |
247 V(Int32x4Max, Operator::kCommutative, 2, 0, 1) \ | |
248 V(Int32x4And, Operator::kAssociative | Operator::kCommutative, 2, 0, 1) \ | |
249 V(Int32x4Or, Operator::kAssociative | Operator::kCommutative, 2, 0, 1) \ | |
250 V(Int32x4Xor, Operator::kAssociative | Operator::kCommutative, 2, 0, 1) \ | |
251 V(Int32x4Not, Operator::kNoProperties, 1, 0, 1) \ | |
252 V(Int32x4ShiftLeftByScalar, Operator::kNoProperties, 2, 0, 1) \ | |
253 V(Int32x4ShiftRightByScalar, Operator::kNoProperties, 2, 0, 1) \ | |
254 V(Int32x4Equal, Operator::kCommutative, 2, 0, 1) \ | |
255 V(Int32x4NotEqual, Operator::kCommutative, 2, 0, 1) \ | |
256 V(Int32x4LessThan, Operator::kNoProperties, 2, 0, 1) \ | |
257 V(Int32x4LessThanOrEqual, Operator::kNoProperties, 2, 0, 1) \ | |
258 V(Int32x4GreaterThan, Operator::kNoProperties, 2, 0, 1) \ | |
259 V(Int32x4GreaterThanOrEqual, Operator::kNoProperties, 2, 0, 1) \ | |
260 V(Int32x4Select, Operator::kNoProperties, 3, 0, 1) \ | |
261 V(Int32x4Swizzle, Operator::kNoProperties, 5, 0, 1) \ | |
262 V(Int32x4Shuffle, Operator::kNoProperties, 6, 0, 1) \ | |
263 V(Int32x4FromFloat32x4, Operator::kNoProperties, 1, 0, 1) \ | |
264 V(Int32x4Load1, Operator::kNoProperties, 2, 0, 1) \ | |
265 V(Int32x4Load2, Operator::kNoProperties, 2, 0, 1) \ | |
266 V(Int32x4Load3, Operator::kNoProperties, 2, 0, 1) \ | |
267 V(Int32x4Store1, Operator::kNoProperties, 3, 0, 1) \ | |
268 V(Int32x4Store2, Operator::kNoProperties, 3, 0, 1) \ | |
269 V(Int32x4Store3, Operator::kNoProperties, 3, 0, 1) \ | |
270 V(Uint32x4Min, Operator::kCommutative, 2, 0, 1) \ | |
271 V(Uint32x4Max, Operator::kCommutative, 2, 0, 1) \ | |
272 V(Uint32x4ShiftLeftByScalar, Operator::kNoProperties, 2, 0, 1) \ | |
273 V(Uint32x4ShiftRightByScalar, Operator::kNoProperties, 2, 0, 1) \ | |
274 V(Uint32x4LessThan, Operator::kNoProperties, 2, 0, 1) \ | |
275 V(Uint32x4LessThanOrEqual, Operator::kNoProperties, 2, 0, 1) \ | |
276 V(Uint32x4GreaterThan, Operator::kNoProperties, 2, 0, 1) \ | |
277 V(Uint32x4GreaterThanOrEqual, Operator::kNoProperties, 2, 0, 1) \ | |
278 V(Uint32x4FromFloat32x4, Operator::kNoProperties, 1, 0, 1) \ | |
279 V(CreateBool32x4, Operator::kNoProperties, 4, 0, 1) \ | |
280 V(Bool32x4ExtractLane, Operator::kNoProperties, 2, 0, 1) \ | |
281 V(Bool32x4ReplaceLane, Operator::kNoProperties, 3, 0, 1) \ | |
282 V(Bool32x4And, Operator::kAssociative | Operator::kCommutative, 2, 0, 1) \ | |
283 V(Bool32x4Or, Operator::kAssociative | Operator::kCommutative, 2, 0, 1) \ | |
284 V(Bool32x4Xor, Operator::kAssociative | Operator::kCommutative, 2, 0, 1) \ | |
285 V(Bool32x4Not, Operator::kNoProperties, 1, 0, 1) \ | |
286 V(Bool32x4AnyTrue, Operator::kNoProperties, 1, 0, 1) \ | |
287 V(Bool32x4AllTrue, Operator::kNoProperties, 1, 0, 1) \ | |
288 V(Bool32x4Swizzle, Operator::kNoProperties, 5, 0, 1) \ | |
289 V(Bool32x4Shuffle, Operator::kNoProperties, 6, 0, 1) \ | |
290 V(Bool32x4Equal, Operator::kCommutative, 2, 0, 1) \ | |
291 V(Bool32x4NotEqual, Operator::kCommutative, 2, 0, 1) \ | |
292 V(CreateInt16x8, Operator::kNoProperties, 8, 0, 1) \ | |
293 V(Int16x8ExtractLane, Operator::kNoProperties, 2, 0, 1) \ | |
294 V(Int16x8ReplaceLane, Operator::kNoProperties, 3, 0, 1) \ | |
295 V(Int16x8Neg, Operator::kNoProperties, 1, 0, 1) \ | |
296 V(Int16x8Add, Operator::kCommutative, 2, 0, 1) \ | |
297 V(Int16x8AddSaturate, Operator::kCommutative, 2, 0, 1) \ | |
298 V(Int16x8Sub, Operator::kNoProperties, 2, 0, 1) \ | |
299 V(Int16x8SubSaturate, Operator::kNoProperties, 2, 0, 1) \ | |
300 V(Int16x8Mul, Operator::kCommutative, 2, 0, 1) \ | |
301 V(Int16x8Min, Operator::kCommutative, 2, 0, 1) \ | |
302 V(Int16x8Max, Operator::kCommutative, 2, 0, 1) \ | |
303 V(Int16x8And, Operator::kAssociative | Operator::kCommutative, 2, 0, 1) \ | |
304 V(Int16x8Or, Operator::kAssociative | Operator::kCommutative, 2, 0, 1) \ | |
305 V(Int16x8Xor, Operator::kAssociative | Operator::kCommutative, 2, 0, 1) \ | |
306 V(Int16x8Not, Operator::kNoProperties, 1, 0, 1) \ | |
307 V(Int16x8ShiftLeftByScalar, Operator::kNoProperties, 2, 0, 1) \ | |
308 V(Int16x8ShiftRightByScalar, Operator::kNoProperties, 2, 0, 1) \ | |
309 V(Int16x8Equal, Operator::kCommutative, 2, 0, 1) \ | |
310 V(Int16x8NotEqual, Operator::kCommutative, 2, 0, 1) \ | |
311 V(Int16x8LessThan, Operator::kNoProperties, 2, 0, 1) \ | |
312 V(Int16x8LessThanOrEqual, Operator::kNoProperties, 2, 0, 1) \ | |
313 V(Int16x8GreaterThan, Operator::kNoProperties, 2, 0, 1) \ | |
314 V(Int16x8GreaterThanOrEqual, Operator::kNoProperties, 2, 0, 1) \ | |
315 V(Int16x8Select, Operator::kNoProperties, 3, 0, 1) \ | |
316 V(Int16x8Swizzle, Operator::kNoProperties, 9, 0, 1) \ | |
317 V(Int16x8Shuffle, Operator::kNoProperties, 10, 0, 1) \ | |
318 V(Uint16x8AddSaturate, Operator::kCommutative, 2, 0, 1) \ | |
319 V(Uint16x8SubSaturate, Operator::kNoProperties, 2, 0, 1) \ | |
320 V(Uint16x8Min, Operator::kCommutative, 2, 0, 1) \ | |
321 V(Uint16x8Max, Operator::kCommutative, 2, 0, 1) \ | |
322 V(Uint16x8ShiftLeftByScalar, Operator::kNoProperties, 2, 0, 1) \ | |
323 V(Uint16x8ShiftRightByScalar, Operator::kNoProperties, 2, 0, 1) \ | |
324 V(Uint16x8LessThan, Operator::kNoProperties, 2, 0, 1) \ | |
325 V(Uint16x8LessThanOrEqual, Operator::kNoProperties, 2, 0, 1) \ | |
326 V(Uint16x8GreaterThan, Operator::kNoProperties, 2, 0, 1) \ | |
327 V(Uint16x8GreaterThanOrEqual, Operator::kNoProperties, 2, 0, 1) \ | |
328 V(CreateBool16x8, Operator::kNoProperties, 8, 0, 1) \ | |
329 V(Bool16x8ExtractLane, Operator::kNoProperties, 2, 0, 1) \ | |
330 V(Bool16x8ReplaceLane, Operator::kNoProperties, 3, 0, 1) \ | |
331 V(Bool16x8And, Operator::kAssociative | Operator::kCommutative, 2, 0, 1) \ | |
332 V(Bool16x8Or, Operator::kAssociative | Operator::kCommutative, 2, 0, 1) \ | |
333 V(Bool16x8Xor, Operator::kAssociative | Operator::kCommutative, 2, 0, 1) \ | |
334 V(Bool16x8Not, Operator::kNoProperties, 1, 0, 1) \ | |
335 V(Bool16x8AnyTrue, Operator::kNoProperties, 1, 0, 1) \ | |
336 V(Bool16x8AllTrue, Operator::kNoProperties, 1, 0, 1) \ | |
337 V(Bool16x8Swizzle, Operator::kNoProperties, 9, 0, 1) \ | |
338 V(Bool16x8Shuffle, Operator::kNoProperties, 10, 0, 1) \ | |
339 V(Bool16x8Equal, Operator::kCommutative, 2, 0, 1) \ | |
340 V(Bool16x8NotEqual, Operator::kCommutative, 2, 0, 1) \ | |
341 V(CreateInt8x16, Operator::kNoProperties, 16, 0, 1) \ | |
342 V(Int8x16ExtractLane, Operator::kNoProperties, 2, 0, 1) \ | |
343 V(Int8x16ReplaceLane, Operator::kNoProperties, 3, 0, 1) \ | |
344 V(Int8x16Neg, Operator::kNoProperties, 1, 0, 1) \ | |
345 V(Int8x16Add, Operator::kCommutative, 2, 0, 1) \ | |
346 V(Int8x16AddSaturate, Operator::kCommutative, 2, 0, 1) \ | |
347 V(Int8x16Sub, Operator::kNoProperties, 2, 0, 1) \ | |
348 V(Int8x16SubSaturate, Operator::kNoProperties, 2, 0, 1) \ | |
349 V(Int8x16Mul, Operator::kCommutative, 2, 0, 1) \ | |
350 V(Int8x16Min, Operator::kCommutative, 2, 0, 1) \ | |
351 V(Int8x16Max, Operator::kCommutative, 2, 0, 1) \ | |
352 V(Int8x16And, Operator::kAssociative | Operator::kCommutative, 2, 0, 1) \ | |
353 V(Int8x16Or, Operator::kAssociative | Operator::kCommutative, 2, 0, 1) \ | |
354 V(Int8x16Xor, Operator::kAssociative | Operator::kCommutative, 2, 0, 1) \ | |
355 V(Int8x16Not, Operator::kNoProperties, 1, 0, 1) \ | |
356 V(Int8x16ShiftLeftByScalar, Operator::kNoProperties, 2, 0, 1) \ | |
357 V(Int8x16ShiftRightByScalar, Operator::kNoProperties, 2, 0, 1) \ | |
358 V(Int8x16Equal, Operator::kCommutative, 2, 0, 1) \ | |
359 V(Int8x16NotEqual, Operator::kCommutative, 2, 0, 1) \ | |
360 V(Int8x16LessThan, Operator::kNoProperties, 2, 0, 1) \ | |
361 V(Int8x16LessThanOrEqual, Operator::kNoProperties, 2, 0, 1) \ | |
362 V(Int8x16GreaterThan, Operator::kNoProperties, 2, 0, 1) \ | |
363 V(Int8x16GreaterThanOrEqual, Operator::kNoProperties, 2, 0, 1) \ | |
364 V(Int8x16Select, Operator::kNoProperties, 3, 0, 1) \ | |
365 V(Int8x16Swizzle, Operator::kNoProperties, 17, 0, 1) \ | |
366 V(Int8x16Shuffle, Operator::kNoProperties, 18, 0, 1) \ | |
367 V(Uint8x16AddSaturate, Operator::kCommutative, 2, 0, 1) \ | |
368 V(Uint8x16SubSaturate, Operator::kNoProperties, 2, 0, 1) \ | |
369 V(Uint8x16Min, Operator::kCommutative, 2, 0, 1) \ | |
370 V(Uint8x16Max, Operator::kCommutative, 2, 0, 1) \ | |
371 V(Uint8x16ShiftLeftByScalar, Operator::kNoProperties, 2, 0, 1) \ | |
372 V(Uint8x16ShiftRightByScalar, Operator::kNoProperties, 2, 0, 1) \ | |
373 V(Uint8x16LessThan, Operator::kNoProperties, 2, 0, 1) \ | |
374 V(Uint8x16LessThanOrEqual, Operator::kNoProperties, 2, 0, 1) \ | |
375 V(Uint8x16GreaterThan, Operator::kNoProperties, 2, 0, 1) \ | |
376 V(Uint8x16GreaterThanOrEqual, Operator::kNoProperties, 2, 0, 1) \ | |
377 V(CreateBool8x16, Operator::kNoProperties, 16, 0, 1) \ | |
378 V(Bool8x16ExtractLane, Operator::kNoProperties, 2, 0, 1) \ | |
379 V(Bool8x16ReplaceLane, Operator::kNoProperties, 3, 0, 1) \ | |
380 V(Bool8x16And, Operator::kAssociative | Operator::kCommutative, 2, 0, 1) \ | |
381 V(Bool8x16Or, Operator::kAssociative | Operator::kCommutative, 2, 0, 1) \ | |
382 V(Bool8x16Xor, Operator::kAssociative | Operator::kCommutative, 2, 0, 1) \ | |
383 V(Bool8x16Not, Operator::kNoProperties, 1, 0, 1) \ | |
384 V(Bool8x16AnyTrue, Operator::kNoProperties, 1, 0, 1) \ | |
385 V(Bool8x16AllTrue, Operator::kNoProperties, 1, 0, 1) \ | |
386 V(Bool8x16Swizzle, Operator::kNoProperties, 17, 0, 1) \ | |
387 V(Bool8x16Shuffle, Operator::kNoProperties, 18, 0, 1) \ | |
388 V(Bool8x16Equal, Operator::kCommutative, 2, 0, 1) \ | |
389 V(Bool8x16NotEqual, Operator::kCommutative, 2, 0, 1) | |
390 | 206 |
391 #define PURE_OPTIONAL_OP_LIST(V) \ | 207 #define PURE_OPTIONAL_OP_LIST(V) \ |
392 V(Word32Ctz, Operator::kNoProperties, 1, 0, 1) \ | 208 V(Word32Ctz, Operator::kNoProperties, 1, 0, 1) \ |
393 V(Word64Ctz, Operator::kNoProperties, 1, 0, 1) \ | 209 V(Word64Ctz, Operator::kNoProperties, 1, 0, 1) \ |
394 V(Word32ReverseBits, Operator::kNoProperties, 1, 0, 1) \ | 210 V(Word32ReverseBits, Operator::kNoProperties, 1, 0, 1) \ |
395 V(Word64ReverseBits, Operator::kNoProperties, 1, 0, 1) \ | 211 V(Word64ReverseBits, Operator::kNoProperties, 1, 0, 1) \ |
396 V(Word32Popcnt, Operator::kNoProperties, 1, 0, 1) \ | 212 V(Word32Popcnt, Operator::kNoProperties, 1, 0, 1) \ |
397 V(Word64Popcnt, Operator::kNoProperties, 1, 0, 1) \ | 213 V(Word64Popcnt, Operator::kNoProperties, 1, 0, 1) \ |
398 V(Float32Max, Operator::kNoProperties, 2, 0, 1) \ | 214 V(Float32Max, Operator::kNoProperties, 2, 0, 1) \ |
399 V(Float32Min, Operator::kNoProperties, 2, 0, 1) \ | 215 V(Float32Min, Operator::kNoProperties, 2, 0, 1) \ |
(...skipping 267 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
667 | 483 |
668 // On 32 bit platforms we need to get a reference to optional operators of | 484 // On 32 bit platforms we need to get a reference to optional operators of |
669 // 64-bit instructions for later Int64Lowering, even though 32 bit platforms | 485 // 64-bit instructions for later Int64Lowering, even though 32 bit platforms |
670 // don't support the original 64-bit instruction. | 486 // don't support the original 64-bit instruction. |
671 const Operator* MachineOperatorBuilder::Word64CtzPlaceholder() { | 487 const Operator* MachineOperatorBuilder::Word64CtzPlaceholder() { |
672 return &cache_.kWord64Ctz; | 488 return &cache_.kWord64Ctz; |
673 } | 489 } |
674 } // namespace compiler | 490 } // namespace compiler |
675 } // namespace internal | 491 } // namespace internal |
676 } // namespace v8 | 492 } // namespace v8 |
OLD | NEW |