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) |
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 Loading... |
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 |
OLD | NEW |