OLD | NEW |
1 // Copyright 2009 the V8 project authors. All rights reserved. | 1 // Copyright 2009 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 564 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
575 | 575 |
576 // Load the JavaScript builtin function from the builtins object. | 576 // Load the JavaScript builtin function from the builtins object. |
577 movq(rdi, FieldOperand(target, JSBuiltinsObject::OffsetOfFunctionWithId(id))); | 577 movq(rdi, FieldOperand(target, JSBuiltinsObject::OffsetOfFunctionWithId(id))); |
578 | 578 |
579 // Load the code entry point from the builtins object. | 579 // Load the code entry point from the builtins object. |
580 movq(target, FieldOperand(target, JSBuiltinsObject::OffsetOfCodeWithId(id))); | 580 movq(target, FieldOperand(target, JSBuiltinsObject::OffsetOfCodeWithId(id))); |
581 if (FLAG_debug_code) { | 581 if (FLAG_debug_code) { |
582 // Make sure the code objects in the builtins object and in the | 582 // Make sure the code objects in the builtins object and in the |
583 // builtin function are the same. | 583 // builtin function are the same. |
584 push(target); | 584 push(target); |
585 movq(target, FieldOperand(rdi, JSFunction::kSharedFunctionInfoOffset)); | 585 movq(target, FieldOperand(rdi, JSFunction::kCodeOffset)); |
586 movq(target, FieldOperand(target, SharedFunctionInfo::kCodeOffset)); | |
587 cmpq(target, Operand(rsp, 0)); | 586 cmpq(target, Operand(rsp, 0)); |
588 Assert(equal, "Builtin code object changed"); | 587 Assert(equal, "Builtin code object changed"); |
589 pop(target); | 588 pop(target); |
590 } | 589 } |
591 lea(target, FieldOperand(target, Code::kHeaderSize)); | 590 lea(target, FieldOperand(target, Code::kHeaderSize)); |
592 } | 591 } |
593 | 592 |
594 | 593 |
595 void MacroAssembler::Set(Register dst, int64_t x) { | 594 void MacroAssembler::Set(Register dst, int64_t x) { |
596 if (x == 0) { | 595 if (x == 0) { |
(...skipping 1686 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2283 | 2282 |
2284 | 2283 |
2285 void MacroAssembler::InvokeFunction(Register function, | 2284 void MacroAssembler::InvokeFunction(Register function, |
2286 const ParameterCount& actual, | 2285 const ParameterCount& actual, |
2287 InvokeFlag flag) { | 2286 InvokeFlag flag) { |
2288 ASSERT(function.is(rdi)); | 2287 ASSERT(function.is(rdi)); |
2289 movq(rdx, FieldOperand(function, JSFunction::kSharedFunctionInfoOffset)); | 2288 movq(rdx, FieldOperand(function, JSFunction::kSharedFunctionInfoOffset)); |
2290 movq(rsi, FieldOperand(function, JSFunction::kContextOffset)); | 2289 movq(rsi, FieldOperand(function, JSFunction::kContextOffset)); |
2291 movsxlq(rbx, | 2290 movsxlq(rbx, |
2292 FieldOperand(rdx, SharedFunctionInfo::kFormalParameterCountOffset)); | 2291 FieldOperand(rdx, SharedFunctionInfo::kFormalParameterCountOffset)); |
2293 movq(rdx, FieldOperand(rdx, SharedFunctionInfo::kCodeOffset)); | 2292 movq(rdx, FieldOperand(rdi, JSFunction::kCodeOffset)); |
2294 // Advances rdx to the end of the Code object header, to the start of | 2293 // Advances rdx to the end of the Code object header, to the start of |
2295 // the executable code. | 2294 // the executable code. |
2296 lea(rdx, FieldOperand(rdx, Code::kHeaderSize)); | 2295 lea(rdx, FieldOperand(rdx, Code::kHeaderSize)); |
2297 | 2296 |
2298 ParameterCount expected(rbx); | 2297 ParameterCount expected(rbx); |
2299 InvokeCode(rdx, expected, actual, flag); | 2298 InvokeCode(rdx, expected, actual, flag); |
2300 } | 2299 } |
2301 | 2300 |
2302 | 2301 |
2303 void MacroAssembler::InvokeFunction(JSFunction* function, | 2302 void MacroAssembler::InvokeFunction(JSFunction* function, |
(...skipping 644 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2948 CPU::FlushICache(address_, size_); | 2947 CPU::FlushICache(address_, size_); |
2949 | 2948 |
2950 // Check that the code was patched as expected. | 2949 // Check that the code was patched as expected. |
2951 ASSERT(masm_.pc_ == address_ + size_); | 2950 ASSERT(masm_.pc_ == address_ + size_); |
2952 ASSERT(masm_.reloc_info_writer.pos() == address_ + size_ + Assembler::kGap); | 2951 ASSERT(masm_.reloc_info_writer.pos() == address_ + size_ + Assembler::kGap); |
2953 } | 2952 } |
2954 | 2953 |
2955 } } // namespace v8::internal | 2954 } } // namespace v8::internal |
2956 | 2955 |
2957 #endif // V8_TARGET_ARCH_X64 | 2956 #endif // V8_TARGET_ARCH_X64 |
OLD | NEW |