Chromium Code Reviews| OLD | NEW |
|---|---|
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 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/builtins/builtins.h" | 5 #include "src/builtins/builtins.h" |
| 6 | 6 |
| 7 #include "src/api-arguments.h" | 7 #include "src/api-arguments.h" |
| 8 #include "src/api-natives.h" | 8 #include "src/api-natives.h" |
| 9 #include "src/api.h" | 9 #include "src/api.h" |
| 10 #include "src/base/ieee754.h" | 10 #include "src/base/ieee754.h" |
| (...skipping 325 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 336 assembler->Return(assembler->BooleanConstant(true)); | 336 assembler->Return(assembler->BooleanConstant(true)); |
| 337 | 337 |
| 338 assembler->Bind(&return_false); | 338 assembler->Bind(&return_false); |
| 339 assembler->Return(assembler->BooleanConstant(false)); | 339 assembler->Return(assembler->BooleanConstant(false)); |
| 340 | 340 |
| 341 assembler->Bind(&call_runtime); | 341 assembler->Bind(&call_runtime); |
| 342 assembler->Return( | 342 assembler->Return( |
| 343 assembler->CallRuntime(Runtime::kArrayIsArray, context, object)); | 343 assembler->CallRuntime(Runtime::kArrayIsArray, context, object)); |
| 344 } | 344 } |
| 345 | 345 |
| 346 void Builtins::Generate_ArrayIncludes(CodeStubAssembler* assembler) { | |
| 347 typedef compiler::Node Node; | |
| 348 typedef CodeStubAssembler::Label Label; | |
| 349 typedef CodeStubAssembler::Variable Variable; | |
| 350 | |
| 351 Node* array = assembler->Parameter(0); | |
| 352 Node* search_element = assembler->Parameter(1); | |
| 353 Node* start_from = assembler->Parameter(2); | |
| 354 Node* context = assembler->Parameter(3 + 2); | |
| 355 | |
| 356 Node* int32_zero = assembler->Int32Constant(0); | |
| 357 Node* int32_one = assembler->Int32Constant(1); | |
| 358 | |
| 359 Variable len(assembler, MachineRepresentation::kWord32), | |
| 360 k(assembler, MachineRepresentation::kWord32), | |
| 361 n(assembler, MachineRepresentation::kWord32); | |
| 362 | |
| 363 Label init_k(assembler), return_true(assembler), return_false(assembler), | |
| 364 call_runtime(assembler); | |
| 365 | |
| 366 { // Prologue | |
| 367 // 1. Bailout to slow path if `array` is not a JSArray | |
| 368 assembler->GotoIf(assembler->WordIsSmi(array), &call_runtime); | |
| 369 Node* instance_type = assembler->LoadInstanceType(array); | |
| 370 assembler->GotoUnless( | |
| 371 assembler->Word32Equal(instance_type, | |
| 372 assembler->Int32Constant(JS_ARRAY_TYPE)), | |
| 373 &call_runtime); | |
| 374 | |
| 375 // 2. Bailout to slow path if elements kind is not fast | |
| 376 Node* map = assembler->LoadMap(array); | |
| 377 Node* bit_field2 = assembler->LoadMapBitField2(map); | |
| 378 Node* elements_kind = | |
| 379 assembler->BitFieldDecode<Map::ElementsKindBits>(bit_field2); | |
| 380 assembler->GotoIf( | |
| 381 assembler->Uint32LessThan( | |
| 382 assembler->Int32Constant(LAST_FAST_ELEMENTS_KIND), elements_kind), | |
| 383 &call_runtime); | |
| 384 | |
| 385 len.Bind(assembler->SmiToWord( | |
| 386 assembler->LoadObjectField(array, JSArray::kLengthOffset))); | |
| 387 assembler->GotoUnless(assembler->Word32Equal(len.value(), int32_zero), | |
| 388 &init_k); | |
| 389 assembler->Return(assembler->BooleanConstant(false)); | |
| 390 } | |
| 391 | |
| 392 assembler->Bind(&init_k); | |
| 393 { | |
| 394 Label done(assembler), if_neg(assembler), init_k_smi(assembler), | |
| 395 init_k_zero(assembler); | |
| 396 Callable call_to_integer = CodeFactory::ToInteger(assembler->isolate()); | |
| 397 Node* tagged_n = assembler->CallStub(call_to_integer, context, start_from); | |
| 398 | |
| 399 assembler->GotoIf(assembler->Float64Equal( | |
|
caitp
2016/07/14 18:01:18
This init_k block is based on the understanding th
| |
| 400 tagged_n, assembler->Float64Constant(V8_INFINITY)), | |
| 401 &return_false); | |
| 402 | |
| 403 assembler->GotoUnless(assembler->WordIsSmi(tagged_n), &init_k_zero); | |
| 404 | |
| 405 n.Bind(assembler->SmiToWord32(tagged_n)); | |
| 406 | |
| 407 assembler->GotoUnless( | |
| 408 assembler->Int32GreaterThanOrEqual(n.value(), int32_zero), &if_neg); | |
| 409 k.Bind(n.value()); | |
| 410 assembler->Goto(&done); | |
| 411 | |
| 412 assembler->Bind(&if_neg); | |
| 413 k.Bind(assembler->Int32Add(len.value(), n.value())); | |
| 414 assembler->BranchIf(assembler->Int32LessThan(k.value(), int32_zero), | |
| 415 &init_k_zero, &done); | |
| 416 | |
| 417 assembler->Bind(&init_k_zero); | |
| 418 k.Bind(int32_zero); | |
| 419 | |
| 420 assembler->Goto(&done); | |
| 421 assembler->Bind(&done); | |
| 422 } | |
| 423 | |
| 424 { // Repeat while k < len | |
| 425 Label loop_body(assembler, &k); | |
| 426 assembler->Goto(&loop_body); | |
| 427 assembler->Bind(&loop_body); | |
| 428 | |
| 429 assembler->GotoUnless(assembler->Uint32LessThan(k.value(), len.value()), | |
| 430 &return_false); | |
| 431 | |
| 432 Callable call_get_property = CodeFactory::GetProperty(assembler->isolate()); | |
| 433 Node* element_k = assembler->CallStub(call_get_property, context, array, | |
| 434 assembler->SmiFromWord32(k.value())); | |
| 435 | |
| 436 Callable call_same_value_zero = | |
| 437 CodeFactory::SameValueZero(assembler->isolate()); | |
| 438 Node* result = assembler->CallStub(call_same_value_zero, context, | |
| 439 search_element, element_k); | |
| 440 assembler->GotoIf( | |
| 441 assembler->WordEqual(result, assembler->BooleanConstant(true)), | |
| 442 &return_true); | |
| 443 | |
| 444 k.Bind(assembler->Int32Add(k.value(), int32_one)); | |
| 445 assembler->Goto(&loop_body); | |
| 446 } | |
| 447 | |
| 448 assembler->Bind(&return_true); | |
| 449 assembler->Return(assembler->BooleanConstant(true)); | |
| 450 | |
| 451 assembler->Bind(&return_false); | |
| 452 assembler->Return(assembler->BooleanConstant(false)); | |
| 453 | |
| 454 assembler->Bind(&call_runtime); | |
| 455 assembler->Return(assembler->CallRuntime(Runtime::kArrayIncludes_Slow, | |
| 456 context, array, search_element, | |
| 457 start_from)); | |
| 458 } | |
| 459 | |
| 346 void Builtins::Generate_ObjectHasOwnProperty(CodeStubAssembler* assembler) { | 460 void Builtins::Generate_ObjectHasOwnProperty(CodeStubAssembler* assembler) { |
| 347 typedef compiler::Node Node; | 461 typedef compiler::Node Node; |
| 348 typedef CodeStubAssembler::Label Label; | 462 typedef CodeStubAssembler::Label Label; |
| 349 typedef CodeStubAssembler::Variable Variable; | 463 typedef CodeStubAssembler::Variable Variable; |
| 350 | 464 |
| 351 Node* object = assembler->Parameter(0); | 465 Node* object = assembler->Parameter(0); |
| 352 Node* key = assembler->Parameter(1); | 466 Node* key = assembler->Parameter(1); |
| 353 Node* context = assembler->Parameter(4); | 467 Node* context = assembler->Parameter(4); |
| 354 | 468 |
| 355 Label call_runtime(assembler), return_true(assembler), | 469 Label call_runtime(assembler), return_true(assembler), |
| (...skipping 6469 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 6825 #define DEFINE_BUILTIN_ACCESSOR(Name, ...) \ | 6939 #define DEFINE_BUILTIN_ACCESSOR(Name, ...) \ |
| 6826 Handle<Code> Builtins::Name() { \ | 6940 Handle<Code> Builtins::Name() { \ |
| 6827 Code** code_address = reinterpret_cast<Code**>(builtin_address(k##Name)); \ | 6941 Code** code_address = reinterpret_cast<Code**>(builtin_address(k##Name)); \ |
| 6828 return Handle<Code>(code_address); \ | 6942 return Handle<Code>(code_address); \ |
| 6829 } | 6943 } |
| 6830 BUILTIN_LIST_ALL(DEFINE_BUILTIN_ACCESSOR) | 6944 BUILTIN_LIST_ALL(DEFINE_BUILTIN_ACCESSOR) |
| 6831 #undef DEFINE_BUILTIN_ACCESSOR | 6945 #undef DEFINE_BUILTIN_ACCESSOR |
| 6832 | 6946 |
| 6833 } // namespace internal | 6947 } // namespace internal |
| 6834 } // namespace v8 | 6948 } // namespace v8 |
| OLD | NEW |