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 259 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
270 Address Assembler::target_address_at(Address pc, Address constant_pool) { | 270 Address Assembler::target_address_at(Address pc, Address constant_pool) { |
271 return Memory::int32_at(pc) + pc + 4; | 271 return Memory::int32_at(pc) + pc + 4; |
272 } | 272 } |
273 | 273 |
274 | 274 |
275 void Assembler::set_target_address_at(Address pc, Address constant_pool, | 275 void Assembler::set_target_address_at(Address pc, Address constant_pool, |
276 Address target, | 276 Address target, |
277 ICacheFlushMode icache_flush_mode) { | 277 ICacheFlushMode icache_flush_mode) { |
278 Memory::int32_at(pc) = static_cast<int32_t>(target - pc - 4); | 278 Memory::int32_at(pc) = static_cast<int32_t>(target - pc - 4); |
279 if (icache_flush_mode != SKIP_ICACHE_FLUSH) { | 279 if (icache_flush_mode != SKIP_ICACHE_FLUSH) { |
280 CpuFeatures::FlushICache(pc, sizeof(int32_t)); | 280 Assembler::FlushICacheWithoutIsolate(pc, sizeof(int32_t)); |
281 } | 281 } |
282 } | 282 } |
283 | 283 |
284 | 284 |
285 void Assembler::deserialization_set_target_internal_reference_at( | 285 void Assembler::deserialization_set_target_internal_reference_at( |
286 Address pc, Address target, RelocInfo::Mode mode) { | 286 Address pc, Address target, RelocInfo::Mode mode) { |
287 Memory::Address_at(pc) = target; | 287 Memory::Address_at(pc) = target; |
288 } | 288 } |
289 | 289 |
290 | 290 |
(...skipping 106 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 CpuFeatures::FlushICache(pc_, sizeof(Address)); | 407 Assembler::FlushICacheWithoutIsolate(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 CpuFeatures::FlushICache(pc_, sizeof(Address)); | 454 Assembler::FlushICacheWithoutIsolate(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 CpuFeatures::FlushICache(pc_ + Assembler::kPatchDebugBreakSlotAddressOffset, | 530 Assembler::FlushICacheWithoutIsolate( |
531 sizeof(Address)); | 531 pc_ + Assembler::kPatchDebugBreakSlotAddressOffset, sizeof(Address)); |
532 if (host() != NULL) { | 532 if (host() != NULL) { |
533 Object* target_code = Code::GetCodeFromTargetAddress(target); | 533 Object* target_code = Code::GetCodeFromTargetAddress(target); |
534 host()->GetHeap()->incremental_marking()->RecordWriteIntoCode( | 534 host()->GetHeap()->incremental_marking()->RecordWriteIntoCode( |
535 host(), this, HeapObject::cast(target_code)); | 535 host(), this, HeapObject::cast(target_code)); |
536 } | 536 } |
537 } | 537 } |
538 | 538 |
539 | 539 |
540 void RelocInfo::Visit(Isolate* isolate, ObjectVisitor* visitor) { | 540 void RelocInfo::Visit(Isolate* isolate, ObjectVisitor* visitor) { |
541 RelocInfo::Mode mode = rmode(); | 541 RelocInfo::Mode mode = rmode(); |
542 if (mode == RelocInfo::EMBEDDED_OBJECT) { | 542 if (mode == RelocInfo::EMBEDDED_OBJECT) { |
543 visitor->VisitEmbeddedPointer(this); | 543 visitor->VisitEmbeddedPointer(this); |
544 CpuFeatures::FlushICache(pc_, sizeof(Address)); | 544 Assembler::FlushICacheWithoutIsolate(pc_, sizeof(Address)); |
545 } else if (RelocInfo::IsCodeTarget(mode)) { | 545 } else if (RelocInfo::IsCodeTarget(mode)) { |
546 visitor->VisitCodeTarget(this); | 546 visitor->VisitCodeTarget(this); |
547 } else if (mode == RelocInfo::CELL) { | 547 } else if (mode == RelocInfo::CELL) { |
548 visitor->VisitCell(this); | 548 visitor->VisitCell(this); |
549 } else if (mode == RelocInfo::EXTERNAL_REFERENCE) { | 549 } else if (mode == RelocInfo::EXTERNAL_REFERENCE) { |
550 visitor->VisitExternalReference(this); | 550 visitor->VisitExternalReference(this); |
551 } else if (mode == RelocInfo::INTERNAL_REFERENCE) { | 551 } else if (mode == RelocInfo::INTERNAL_REFERENCE) { |
552 visitor->VisitInternalReference(this); | 552 visitor->VisitInternalReference(this); |
553 } else if (RelocInfo::IsCodeAgeSequence(mode)) { | 553 } else if (RelocInfo::IsCodeAgeSequence(mode)) { |
554 visitor->VisitCodeAgeSequence(this); | 554 visitor->VisitCodeAgeSequence(this); |
555 } else if (RelocInfo::IsDebugBreakSlot(mode) && | 555 } else if (RelocInfo::IsDebugBreakSlot(mode) && |
556 IsPatchedDebugBreakSlotSequence()) { | 556 IsPatchedDebugBreakSlotSequence()) { |
557 visitor->VisitDebugTarget(this); | 557 visitor->VisitDebugTarget(this); |
558 } else if (RelocInfo::IsRuntimeEntry(mode)) { | 558 } else if (RelocInfo::IsRuntimeEntry(mode)) { |
559 visitor->VisitRuntimeEntry(this); | 559 visitor->VisitRuntimeEntry(this); |
560 } | 560 } |
561 } | 561 } |
562 | 562 |
563 | 563 |
564 template<typename StaticVisitor> | 564 template<typename StaticVisitor> |
565 void RelocInfo::Visit(Heap* heap) { | 565 void RelocInfo::Visit(Heap* heap) { |
566 RelocInfo::Mode mode = rmode(); | 566 RelocInfo::Mode mode = rmode(); |
567 if (mode == RelocInfo::EMBEDDED_OBJECT) { | 567 if (mode == RelocInfo::EMBEDDED_OBJECT) { |
568 StaticVisitor::VisitEmbeddedPointer(heap, this); | 568 StaticVisitor::VisitEmbeddedPointer(heap, this); |
569 CpuFeatures::FlushICache(pc_, sizeof(Address)); | 569 Assembler::FlushICache(heap->isolate(), pc_, sizeof(Address)); |
570 } else if (RelocInfo::IsCodeTarget(mode)) { | 570 } else if (RelocInfo::IsCodeTarget(mode)) { |
571 StaticVisitor::VisitCodeTarget(heap, this); | 571 StaticVisitor::VisitCodeTarget(heap, this); |
572 } else if (mode == RelocInfo::CELL) { | 572 } else if (mode == RelocInfo::CELL) { |
573 StaticVisitor::VisitCell(heap, this); | 573 StaticVisitor::VisitCell(heap, this); |
574 } else if (mode == RelocInfo::EXTERNAL_REFERENCE) { | 574 } else if (mode == RelocInfo::EXTERNAL_REFERENCE) { |
575 StaticVisitor::VisitExternalReference(this); | 575 StaticVisitor::VisitExternalReference(this); |
576 } else if (mode == RelocInfo::INTERNAL_REFERENCE) { | 576 } else if (mode == RelocInfo::INTERNAL_REFERENCE) { |
577 StaticVisitor::VisitInternalReference(this); | 577 StaticVisitor::VisitInternalReference(this); |
578 } else if (RelocInfo::IsCodeAgeSequence(mode)) { | 578 } else if (RelocInfo::IsCodeAgeSequence(mode)) { |
579 StaticVisitor::VisitCodeAgeSequence(heap, this); | 579 StaticVisitor::VisitCodeAgeSequence(heap, this); |
(...skipping 45 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
625 | 625 |
626 void Operand::set_disp64(int64_t disp) { | 626 void Operand::set_disp64(int64_t disp) { |
627 DCHECK_EQ(1, len_); | 627 DCHECK_EQ(1, len_); |
628 int64_t* p = reinterpret_cast<int64_t*>(&buf_[len_]); | 628 int64_t* p = reinterpret_cast<int64_t*>(&buf_[len_]); |
629 *p = disp; | 629 *p = disp; |
630 len_ += sizeof(disp); | 630 len_ += sizeof(disp); |
631 } | 631 } |
632 } } // namespace v8::internal | 632 } } // namespace v8::internal |
633 | 633 |
634 #endif // V8_X64_ASSEMBLER_X64_INL_H_ | 634 #endif // V8_X64_ASSEMBLER_X64_INL_H_ |
OLD | NEW |