| OLD | NEW |
| 1 // Copyright 2011 the V8 project authors. All rights reserved. | 1 // Copyright 2011 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 298 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 309 USE(node_id); | 309 USE(node_id); |
| 310 ASSERT(node_id == ast_id); | 310 ASSERT(node_id == ast_id); |
| 311 JSFunction* function = JSFunction::cast(ComputeLiteral(iterator.Next())); | 311 JSFunction* function = JSFunction::cast(ComputeLiteral(iterator.Next())); |
| 312 USE(function); | 312 USE(function); |
| 313 ASSERT(function == function_); | 313 ASSERT(function == function_); |
| 314 unsigned height = iterator.Next(); | 314 unsigned height = iterator.Next(); |
| 315 unsigned height_in_bytes = height * kPointerSize; | 315 unsigned height_in_bytes = height * kPointerSize; |
| 316 USE(height_in_bytes); | 316 USE(height_in_bytes); |
| 317 | 317 |
| 318 unsigned fixed_size = ComputeFixedSize(function_); | 318 unsigned fixed_size = ComputeFixedSize(function_); |
| 319 unsigned input_frame_size = static_cast<unsigned>(input_->GetFrameSize()); | 319 unsigned input_frame_size = input_->GetFrameSize(); |
| 320 ASSERT(fixed_size + height_in_bytes == input_frame_size); | 320 ASSERT(fixed_size + height_in_bytes == input_frame_size); |
| 321 | 321 |
| 322 unsigned stack_slot_size = optimized_code_->stack_slots() * kPointerSize; | 322 unsigned stack_slot_size = optimized_code_->stack_slots() * kPointerSize; |
| 323 unsigned outgoing_height = data->ArgumentsStackHeight(bailout_id)->value(); | 323 unsigned outgoing_height = data->ArgumentsStackHeight(bailout_id)->value(); |
| 324 unsigned outgoing_size = outgoing_height * kPointerSize; | 324 unsigned outgoing_size = outgoing_height * kPointerSize; |
| 325 unsigned output_frame_size = fixed_size + stack_slot_size + outgoing_size; | 325 unsigned output_frame_size = fixed_size + stack_slot_size + outgoing_size; |
| 326 ASSERT(outgoing_size == 0); // OSR does not happen in the middle of a call. | 326 ASSERT(outgoing_size == 0); // OSR does not happen in the middle of a call. |
| 327 | 327 |
| 328 if (FLAG_trace_osr) { | 328 if (FLAG_trace_osr) { |
| 329 PrintF("[on-stack replacement: begin 0x%08" V8PRIxPTR " ", | 329 PrintF("[on-stack replacement: begin 0x%08" V8PRIxPTR " ", |
| (...skipping 114 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 444 unsigned height_in_bytes = height * kPointerSize; | 444 unsigned height_in_bytes = height * kPointerSize; |
| 445 if (FLAG_trace_deopt) { | 445 if (FLAG_trace_deopt) { |
| 446 PrintF(" translating "); | 446 PrintF(" translating "); |
| 447 function->PrintName(); | 447 function->PrintName(); |
| 448 PrintF(" => node=%d, height=%d\n", node_id, height_in_bytes); | 448 PrintF(" => node=%d, height=%d\n", node_id, height_in_bytes); |
| 449 } | 449 } |
| 450 | 450 |
| 451 // The 'fixed' part of the frame consists of the incoming parameters and | 451 // The 'fixed' part of the frame consists of the incoming parameters and |
| 452 // the part described by JavaScriptFrameConstants. | 452 // the part described by JavaScriptFrameConstants. |
| 453 unsigned fixed_frame_size = ComputeFixedSize(function); | 453 unsigned fixed_frame_size = ComputeFixedSize(function); |
| 454 unsigned input_frame_size = static_cast<unsigned>(input_->GetFrameSize()); | 454 unsigned input_frame_size = input_->GetFrameSize(); |
| 455 unsigned output_frame_size = height_in_bytes + fixed_frame_size; | 455 unsigned output_frame_size = height_in_bytes + fixed_frame_size; |
| 456 | 456 |
| 457 // Allocate and store the output frame description. | 457 // Allocate and store the output frame description. |
| 458 FrameDescription* output_frame = | 458 FrameDescription* output_frame = |
| 459 new(output_frame_size) FrameDescription(output_frame_size, function); | 459 new(output_frame_size) FrameDescription(output_frame_size, function); |
| 460 #ifdef DEBUG | 460 #ifdef DEBUG |
| 461 output_frame->SetKind(Code::FUNCTION); | 461 output_frame->SetKind(Code::FUNCTION); |
| 462 #endif | 462 #endif |
| 463 | 463 |
| 464 bool is_bottommost = (0 == frame_index); | 464 bool is_bottommost = (0 == frame_index); |
| (...skipping 144 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 609 for (int i = 0; i < Register::kNumRegisters; i++) { | 609 for (int i = 0; i < Register::kNumRegisters; i++) { |
| 610 input_->SetRegister(i, i * 4); | 610 input_->SetRegister(i, i * 4); |
| 611 } | 611 } |
| 612 input_->SetRegister(rsp.code(), reinterpret_cast<intptr_t>(frame->sp())); | 612 input_->SetRegister(rsp.code(), reinterpret_cast<intptr_t>(frame->sp())); |
| 613 input_->SetRegister(rbp.code(), reinterpret_cast<intptr_t>(frame->fp())); | 613 input_->SetRegister(rbp.code(), reinterpret_cast<intptr_t>(frame->fp())); |
| 614 for (int i = 0; i < DoubleRegister::kNumAllocatableRegisters; i++) { | 614 for (int i = 0; i < DoubleRegister::kNumAllocatableRegisters; i++) { |
| 615 input_->SetDoubleRegister(i, 0.0); | 615 input_->SetDoubleRegister(i, 0.0); |
| 616 } | 616 } |
| 617 | 617 |
| 618 // Fill the frame content from the actual data on the frame. | 618 // Fill the frame content from the actual data on the frame. |
| 619 for (intptr_t i = 0; i < input_->GetFrameSize(); i += kPointerSize) { | 619 for (unsigned i = 0; i < input_->GetFrameSize(); i += kPointerSize) { |
| 620 input_->SetFrameSlot(i, Memory::uint64_at(tos + i)); | 620 input_->SetFrameSlot(i, Memory::uint64_at(tos + i)); |
| 621 } | 621 } |
| 622 } | 622 } |
| 623 | 623 |
| 624 | 624 |
| 625 #define __ masm()-> | 625 #define __ masm()-> |
| 626 | 626 |
| 627 void Deoptimizer::EntryGenerator::Generate() { | 627 void Deoptimizer::EntryGenerator::Generate() { |
| 628 GeneratePrologue(); | 628 GeneratePrologue(); |
| 629 | 629 |
| (...skipping 202 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 832 } | 832 } |
| 833 __ bind(&done); | 833 __ bind(&done); |
| 834 } | 834 } |
| 835 | 835 |
| 836 #undef __ | 836 #undef __ |
| 837 | 837 |
| 838 | 838 |
| 839 } } // namespace v8::internal | 839 } } // namespace v8::internal |
| 840 | 840 |
| 841 #endif // V8_TARGET_ARCH_X64 | 841 #endif // V8_TARGET_ARCH_X64 |
| OLD | NEW |