| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
| 4 // met: | 4 // met: |
| 5 // | 5 // |
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
| (...skipping 3627 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 3638 } | 3638 } |
| 3639 | 3639 |
| 3640 | 3640 |
| 3641 void FullCodeGenerator::EmitStringAdd(CallRuntime* expr) { | 3641 void FullCodeGenerator::EmitStringAdd(CallRuntime* expr) { |
| 3642 ZoneList<Expression*>* args = expr->arguments(); | 3642 ZoneList<Expression*>* args = expr->arguments(); |
| 3643 ASSERT_EQ(2, args->length()); | 3643 ASSERT_EQ(2, args->length()); |
| 3644 | 3644 |
| 3645 VisitForStackValue(args->at(0)); | 3645 VisitForStackValue(args->at(0)); |
| 3646 VisitForStackValue(args->at(1)); | 3646 VisitForStackValue(args->at(1)); |
| 3647 | 3647 |
| 3648 StringAddStub stub(NO_STRING_ADD_FLAGS); | 3648 StringAddStub stub(STRING_ADD_CHECK_BOTH); |
| 3649 __ CallStub(&stub); | 3649 __ CallStub(&stub); |
| 3650 context()->Plug(rax); | 3650 context()->Plug(rax); |
| 3651 } | 3651 } |
| 3652 | 3652 |
| 3653 | 3653 |
| 3654 void FullCodeGenerator::EmitStringCompare(CallRuntime* expr) { | 3654 void FullCodeGenerator::EmitStringCompare(CallRuntime* expr) { |
| 3655 ZoneList<Expression*>* args = expr->arguments(); | 3655 ZoneList<Expression*>* args = expr->arguments(); |
| 3656 ASSERT_EQ(2, args->length()); | 3656 ASSERT_EQ(2, args->length()); |
| 3657 | 3657 |
| 3658 VisitForStackValue(args->at(0)); | 3658 VisitForStackValue(args->at(0)); |
| (...skipping 754 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 4413 // We need a second deoptimization point after loading the value | 4413 // We need a second deoptimization point after loading the value |
| 4414 // in case evaluating the property load my have a side effect. | 4414 // in case evaluating the property load my have a side effect. |
| 4415 if (assign_type == VARIABLE) { | 4415 if (assign_type == VARIABLE) { |
| 4416 PrepareForBailout(expr->expression(), TOS_REG); | 4416 PrepareForBailout(expr->expression(), TOS_REG); |
| 4417 } else { | 4417 } else { |
| 4418 PrepareForBailoutForId(prop->LoadId(), TOS_REG); | 4418 PrepareForBailoutForId(prop->LoadId(), TOS_REG); |
| 4419 } | 4419 } |
| 4420 | 4420 |
| 4421 // Call ToNumber only if operand is not a smi. | 4421 // Call ToNumber only if operand is not a smi. |
| 4422 Label no_conversion; | 4422 Label no_conversion; |
| 4423 __ JumpIfSmi(rax, &no_conversion, Label::kNear); | 4423 if (ShouldInlineSmiCase(expr->op())) { |
| 4424 __ JumpIfSmi(rax, &no_conversion, Label::kNear); |
| 4425 } |
| 4424 ToNumberStub convert_stub; | 4426 ToNumberStub convert_stub; |
| 4425 __ CallStub(&convert_stub); | 4427 __ CallStub(&convert_stub); |
| 4426 __ bind(&no_conversion); | 4428 __ bind(&no_conversion); |
| 4427 | 4429 |
| 4428 // Save result for postfix expressions. | 4430 // Save result for postfix expressions. |
| 4429 if (expr->is_postfix()) { | 4431 if (expr->is_postfix()) { |
| 4430 if (!context()->IsEffect()) { | 4432 if (!context()->IsEffect()) { |
| 4431 // Save the result on the stack. If we have a named or keyed property | 4433 // Save the result on the stack. If we have a named or keyed property |
| 4432 // we store the result under the receiver that is currently on top | 4434 // we store the result under the receiver that is currently on top |
| 4433 // of the stack. | 4435 // of the stack. |
| (...skipping 469 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 4903 *context_length = 0; | 4905 *context_length = 0; |
| 4904 return previous_; | 4906 return previous_; |
| 4905 } | 4907 } |
| 4906 | 4908 |
| 4907 | 4909 |
| 4908 #undef __ | 4910 #undef __ |
| 4909 | 4911 |
| 4910 } } // namespace v8::internal | 4912 } } // namespace v8::internal |
| 4911 | 4913 |
| 4912 #endif // V8_TARGET_ARCH_X64 | 4914 #endif // V8_TARGET_ARCH_X64 |
| OLD | NEW |