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

Side by Side Diff: src/compiler/machine-operator.cc

Issue 1850383002: Reland of Turbofan: Add MachineOperators for SIMD. (Closed) Base URL: https://chromium.googlesource.com/v8/v8.git@master
Patch Set: Created 4 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/compiler/machine-operator.h ('k') | src/compiler/opcodes.h » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
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
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)
206 390
207 #define PURE_OPTIONAL_OP_LIST(V) \ 391 #define PURE_OPTIONAL_OP_LIST(V) \
208 V(Word32Ctz, Operator::kNoProperties, 1, 0, 1) \ 392 V(Word32Ctz, Operator::kNoProperties, 1, 0, 1) \
209 V(Word64Ctz, Operator::kNoProperties, 1, 0, 1) \ 393 V(Word64Ctz, Operator::kNoProperties, 1, 0, 1) \
210 V(Word32ReverseBits, Operator::kNoProperties, 1, 0, 1) \ 394 V(Word32ReverseBits, Operator::kNoProperties, 1, 0, 1) \
211 V(Word64ReverseBits, Operator::kNoProperties, 1, 0, 1) \ 395 V(Word64ReverseBits, Operator::kNoProperties, 1, 0, 1) \
212 V(Word32Popcnt, Operator::kNoProperties, 1, 0, 1) \ 396 V(Word32Popcnt, Operator::kNoProperties, 1, 0, 1) \
213 V(Word64Popcnt, Operator::kNoProperties, 1, 0, 1) \ 397 V(Word64Popcnt, Operator::kNoProperties, 1, 0, 1) \
214 V(Float32Max, Operator::kNoProperties, 2, 0, 1) \ 398 V(Float32Max, Operator::kNoProperties, 2, 0, 1) \
215 V(Float32Min, Operator::kNoProperties, 2, 0, 1) \ 399 V(Float32Min, Operator::kNoProperties, 2, 0, 1) \
(...skipping 267 matching lines...) Expand 10 before | Expand all | Expand 10 after
483 667
484 // On 32 bit platforms we need to get a reference to optional operators of 668 // On 32 bit platforms we need to get a reference to optional operators of
485 // 64-bit instructions for later Int64Lowering, even though 32 bit platforms 669 // 64-bit instructions for later Int64Lowering, even though 32 bit platforms
486 // don't support the original 64-bit instruction. 670 // don't support the original 64-bit instruction.
487 const Operator* MachineOperatorBuilder::Word64CtzPlaceholder() { 671 const Operator* MachineOperatorBuilder::Word64CtzPlaceholder() {
488 return &cache_.kWord64Ctz; 672 return &cache_.kWord64Ctz;
489 } 673 }
490 } // namespace compiler 674 } // namespace compiler
491 } // namespace internal 675 } // namespace internal
492 } // namespace v8 676 } // namespace v8
OLDNEW
« no previous file with comments | « src/compiler/machine-operator.h ('k') | src/compiler/opcodes.h » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698