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 #ifndef V8_X64_ASSEMBLER_X64_INL_H_ | 5 #ifndef V8_X64_ASSEMBLER_X64_INL_H_ |
6 #define V8_X64_ASSEMBLER_X64_INL_H_ | 6 #define V8_X64_ASSEMBLER_X64_INL_H_ |
7 | 7 |
8 #include "src/x64/assembler-x64.h" | 8 #include "src/x64/assembler-x64.h" |
9 | 9 |
10 #include "src/base/cpu.h" | 10 #include "src/base/cpu.h" |
(...skipping 386 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
397 return reinterpret_cast<Address>(pc_); | 397 return reinterpret_cast<Address>(pc_); |
398 } | 398 } |
399 | 399 |
400 | 400 |
401 void RelocInfo::set_target_object(Object* target, | 401 void RelocInfo::set_target_object(Object* target, |
402 WriteBarrierMode write_barrier_mode, | 402 WriteBarrierMode write_barrier_mode, |
403 ICacheFlushMode icache_flush_mode) { | 403 ICacheFlushMode icache_flush_mode) { |
404 DCHECK(IsCodeTarget(rmode_) || rmode_ == EMBEDDED_OBJECT); | 404 DCHECK(IsCodeTarget(rmode_) || rmode_ == EMBEDDED_OBJECT); |
405 Memory::Object_at(pc_) = target; | 405 Memory::Object_at(pc_) = target; |
406 if (icache_flush_mode != SKIP_ICACHE_FLUSH) { | 406 if (icache_flush_mode != SKIP_ICACHE_FLUSH) { |
407 Assembler::FlushICacheWithoutIsolate(pc_, sizeof(Address)); | 407 Assembler::FlushICache(isolate_, pc_, sizeof(Address)); |
408 } | 408 } |
409 if (write_barrier_mode == UPDATE_WRITE_BARRIER && | 409 if (write_barrier_mode == UPDATE_WRITE_BARRIER && |
410 host() != NULL && | 410 host() != NULL && |
411 target->IsHeapObject()) { | 411 target->IsHeapObject()) { |
412 host()->GetHeap()->incremental_marking()->RecordWrite( | 412 host()->GetHeap()->incremental_marking()->RecordWrite( |
413 host(), &Memory::Object_at(pc_), HeapObject::cast(target)); | 413 host(), &Memory::Object_at(pc_), HeapObject::cast(target)); |
414 } | 414 } |
415 } | 415 } |
416 | 416 |
417 | 417 |
(...skipping 26 matching lines...) Expand all Loading... |
444 } | 444 } |
445 | 445 |
446 | 446 |
447 void RelocInfo::set_target_cell(Cell* cell, | 447 void RelocInfo::set_target_cell(Cell* cell, |
448 WriteBarrierMode write_barrier_mode, | 448 WriteBarrierMode write_barrier_mode, |
449 ICacheFlushMode icache_flush_mode) { | 449 ICacheFlushMode icache_flush_mode) { |
450 DCHECK(rmode_ == RelocInfo::CELL); | 450 DCHECK(rmode_ == RelocInfo::CELL); |
451 Address address = cell->address() + Cell::kValueOffset; | 451 Address address = cell->address() + Cell::kValueOffset; |
452 Memory::Address_at(pc_) = address; | 452 Memory::Address_at(pc_) = address; |
453 if (icache_flush_mode != SKIP_ICACHE_FLUSH) { | 453 if (icache_flush_mode != SKIP_ICACHE_FLUSH) { |
454 Assembler::FlushICacheWithoutIsolate(pc_, sizeof(Address)); | 454 Assembler::FlushICache(isolate_, pc_, sizeof(Address)); |
455 } | 455 } |
456 if (write_barrier_mode == UPDATE_WRITE_BARRIER && | 456 if (write_barrier_mode == UPDATE_WRITE_BARRIER && |
457 host() != NULL) { | 457 host() != NULL) { |
458 // TODO(1550) We are passing NULL as a slot because cell can never be on | 458 // TODO(1550) We are passing NULL as a slot because cell can never be on |
459 // evacuation candidate. | 459 // evacuation candidate. |
460 host()->GetHeap()->incremental_marking()->RecordWrite( | 460 host()->GetHeap()->incremental_marking()->RecordWrite( |
461 host(), NULL, cell); | 461 host(), NULL, cell); |
462 } | 462 } |
463 } | 463 } |
464 | 464 |
(...skipping 55 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
520 Address RelocInfo::debug_call_address() { | 520 Address RelocInfo::debug_call_address() { |
521 DCHECK(IsDebugBreakSlot(rmode()) && IsPatchedDebugBreakSlotSequence()); | 521 DCHECK(IsDebugBreakSlot(rmode()) && IsPatchedDebugBreakSlotSequence()); |
522 return Memory::Address_at(pc_ + Assembler::kPatchDebugBreakSlotAddressOffset); | 522 return Memory::Address_at(pc_ + Assembler::kPatchDebugBreakSlotAddressOffset); |
523 } | 523 } |
524 | 524 |
525 | 525 |
526 void RelocInfo::set_debug_call_address(Address target) { | 526 void RelocInfo::set_debug_call_address(Address target) { |
527 DCHECK(IsDebugBreakSlot(rmode()) && IsPatchedDebugBreakSlotSequence()); | 527 DCHECK(IsDebugBreakSlot(rmode()) && IsPatchedDebugBreakSlotSequence()); |
528 Memory::Address_at(pc_ + Assembler::kPatchDebugBreakSlotAddressOffset) = | 528 Memory::Address_at(pc_ + Assembler::kPatchDebugBreakSlotAddressOffset) = |
529 target; | 529 target; |
530 Assembler::FlushICacheWithoutIsolate( | 530 Assembler::FlushICache(isolate_, |
531 pc_ + Assembler::kPatchDebugBreakSlotAddressOffset, sizeof(Address)); | 531 pc_ + Assembler::kPatchDebugBreakSlotAddressOffset, |
| 532 sizeof(Address)); |
532 if (host() != NULL) { | 533 if (host() != NULL) { |
533 Object* target_code = Code::GetCodeFromTargetAddress(target); | 534 Object* target_code = Code::GetCodeFromTargetAddress(target); |
534 host()->GetHeap()->incremental_marking()->RecordWriteIntoCode( | 535 host()->GetHeap()->incremental_marking()->RecordWriteIntoCode( |
535 host(), this, HeapObject::cast(target_code)); | 536 host(), this, HeapObject::cast(target_code)); |
536 } | 537 } |
537 } | 538 } |
538 | 539 |
539 | 540 |
540 void RelocInfo::Visit(Isolate* isolate, ObjectVisitor* visitor) { | 541 void RelocInfo::Visit(Isolate* isolate, ObjectVisitor* visitor) { |
541 RelocInfo::Mode mode = rmode(); | 542 RelocInfo::Mode mode = rmode(); |
542 if (mode == RelocInfo::EMBEDDED_OBJECT) { | 543 if (mode == RelocInfo::EMBEDDED_OBJECT) { |
543 visitor->VisitEmbeddedPointer(this); | 544 visitor->VisitEmbeddedPointer(this); |
544 Assembler::FlushICacheWithoutIsolate(pc_, sizeof(Address)); | 545 Assembler::FlushICache(isolate, pc_, sizeof(Address)); |
545 } else if (RelocInfo::IsCodeTarget(mode)) { | 546 } else if (RelocInfo::IsCodeTarget(mode)) { |
546 visitor->VisitCodeTarget(this); | 547 visitor->VisitCodeTarget(this); |
547 } else if (mode == RelocInfo::CELL) { | 548 } else if (mode == RelocInfo::CELL) { |
548 visitor->VisitCell(this); | 549 visitor->VisitCell(this); |
549 } else if (mode == RelocInfo::EXTERNAL_REFERENCE) { | 550 } else if (mode == RelocInfo::EXTERNAL_REFERENCE) { |
550 visitor->VisitExternalReference(this); | 551 visitor->VisitExternalReference(this); |
551 } else if (mode == RelocInfo::INTERNAL_REFERENCE) { | 552 } else if (mode == RelocInfo::INTERNAL_REFERENCE) { |
552 visitor->VisitInternalReference(this); | 553 visitor->VisitInternalReference(this); |
553 } else if (RelocInfo::IsCodeAgeSequence(mode)) { | 554 } else if (RelocInfo::IsCodeAgeSequence(mode)) { |
554 visitor->VisitCodeAgeSequence(this); | 555 visitor->VisitCodeAgeSequence(this); |
(...skipping 71 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
626 void Operand::set_disp64(int64_t disp) { | 627 void Operand::set_disp64(int64_t disp) { |
627 DCHECK_EQ(1, len_); | 628 DCHECK_EQ(1, len_); |
628 int64_t* p = reinterpret_cast<int64_t*>(&buf_[len_]); | 629 int64_t* p = reinterpret_cast<int64_t*>(&buf_[len_]); |
629 *p = disp; | 630 *p = disp; |
630 len_ += sizeof(disp); | 631 len_ += sizeof(disp); |
631 } | 632 } |
632 } // namespace internal | 633 } // namespace internal |
633 } // namespace v8 | 634 } // namespace v8 |
634 | 635 |
635 #endif // V8_X64_ASSEMBLER_X64_INL_H_ | 636 #endif // V8_X64_ASSEMBLER_X64_INL_H_ |
OLD | NEW |