OLD | NEW |
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 #include "vm/globals.h" // NOLINT | 5 #include "vm/globals.h" // NOLINT |
6 #if defined(TARGET_ARCH_X64) | 6 #if defined(TARGET_ARCH_X64) |
7 | 7 |
8 #include "vm/assembler.h" | 8 #include "vm/assembler.h" |
9 #include "vm/cpu.h" | 9 #include "vm/cpu.h" |
10 #include "vm/heap.h" | 10 #include "vm/heap.h" |
(...skipping 75 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
86 ASSERT(allow_constant_pool()); | 86 ASSERT(allow_constant_pool()); |
87 intptr_t call_start = buffer_.GetPosition(); | 87 intptr_t call_start = buffer_.GetPosition(); |
88 const int32_t offset = ObjectPool::element_offset( | 88 const int32_t offset = ObjectPool::element_offset( |
89 object_pool_wrapper_.FindExternalLabel(label, kPatchable)); | 89 object_pool_wrapper_.FindExternalLabel(label, kPatchable)); |
90 call(Address::AddressBaseImm32(PP, offset - kHeapObjectTag)); | 90 call(Address::AddressBaseImm32(PP, offset - kHeapObjectTag)); |
91 ASSERT((buffer_.GetPosition() - call_start) == kCallExternalLabelSize); | 91 ASSERT((buffer_.GetPosition() - call_start) == kCallExternalLabelSize); |
92 } | 92 } |
93 | 93 |
94 | 94 |
95 void Assembler::Call(const ExternalLabel* label, Register pp) { | 95 void Assembler::Call(const ExternalLabel* label, Register pp) { |
96 if (Isolate::Current() == Dart::vm_isolate()) { | 96 const int32_t offset = ObjectPool::element_offset( |
97 call(label); | 97 object_pool_wrapper_.FindExternalLabel(label, kNotPatchable)); |
98 } else { | 98 call(Address::AddressBaseImm32(pp, offset - kHeapObjectTag)); |
99 const int32_t offset = ObjectPool::element_offset( | |
100 object_pool_wrapper_.FindExternalLabel(label, kNotPatchable)); | |
101 call(Address::AddressBaseImm32(pp, offset - kHeapObjectTag)); | |
102 } | |
103 } | 99 } |
104 | 100 |
105 | 101 |
106 void Assembler::pushq(Register reg) { | 102 void Assembler::pushq(Register reg) { |
107 AssemblerBuffer::EnsureCapacity ensured(&buffer_); | 103 AssemblerBuffer::EnsureCapacity ensured(&buffer_); |
108 EmitRegisterREX(reg, REX_NONE); | 104 EmitRegisterREX(reg, REX_NONE); |
109 EmitUint8(0x50 | (reg & 7)); | 105 EmitUint8(0x50 | (reg & 7)); |
110 } | 106 } |
111 | 107 |
112 | 108 |
(...skipping 2667 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2780 | 2776 |
2781 // TODO(zra, kmillikin): Also load other large immediates from the object | 2777 // TODO(zra, kmillikin): Also load other large immediates from the object |
2782 // pool | 2778 // pool |
2783 if (object.IsSmi()) { | 2779 if (object.IsSmi()) { |
2784 // If the raw smi does not fit into a 32-bit signed int, then we'll keep | 2780 // If the raw smi does not fit into a 32-bit signed int, then we'll keep |
2785 // the raw value in the object pool. | 2781 // the raw value in the object pool. |
2786 return !Utils::IsInt(32, reinterpret_cast<int64_t>(object.raw())); | 2782 return !Utils::IsInt(32, reinterpret_cast<int64_t>(object.raw())); |
2787 } | 2783 } |
2788 ASSERT(object.IsNotTemporaryScopedHandle()); | 2784 ASSERT(object.IsNotTemporaryScopedHandle()); |
2789 ASSERT(object.IsOld()); | 2785 ASSERT(object.IsOld()); |
2790 return (Isolate::Current() != Dart::vm_isolate()); | 2786 return true; |
2791 } | 2787 } |
2792 | 2788 |
2793 | 2789 |
2794 void Assembler::LoadWordFromPoolOffset(Register dst, Register pp, | 2790 void Assembler::LoadWordFromPoolOffset(Register dst, Register pp, |
2795 int32_t offset) { | 2791 int32_t offset) { |
2796 // This sequence must be of fixed size. AddressBaseImm32 | 2792 // This sequence must be of fixed size. AddressBaseImm32 |
2797 // forces the address operand to use a fixed-size imm32 encoding. | 2793 // forces the address operand to use a fixed-size imm32 encoding. |
2798 movq(dst, Address::AddressBaseImm32(pp, offset)); | 2794 movq(dst, Address::AddressBaseImm32(pp, offset)); |
2799 } | 2795 } |
2800 | 2796 |
2801 | 2797 |
2802 void Assembler::LoadIsolate(Register dst) { | 2798 void Assembler::LoadIsolate(Register dst) { |
2803 movq(dst, Address(THR, Thread::isolate_offset())); | 2799 movq(dst, Address(THR, Thread::isolate_offset())); |
2804 } | 2800 } |
2805 | 2801 |
2806 | 2802 |
2807 void Assembler::LoadObjectHelper(Register dst, | 2803 void Assembler::LoadObjectHelper(Register dst, |
2808 const Object& object, | 2804 const Object& object, |
2809 Register pp, | 2805 Register pp, |
2810 bool is_unique) { | 2806 bool is_unique) { |
2811 if (Thread::CanLoadFromThread(object)) { | 2807 if (Thread::CanLoadFromThread(object)) { |
2812 movq(dst, Address(THR, Thread::OffsetFromThread(object))); | 2808 movq(dst, Address(THR, Thread::OffsetFromThread(object))); |
2813 } else if (CanLoadFromObjectPool(object)) { | 2809 } else if (CanLoadFromObjectPool(object)) { |
2814 const int32_t offset = ObjectPool::element_offset( | 2810 const int32_t offset = ObjectPool::element_offset( |
2815 is_unique ? object_pool_wrapper_.AddObject(object) | 2811 is_unique ? object_pool_wrapper_.AddObject(object) |
2816 : object_pool_wrapper_.FindObject(object)); | 2812 : object_pool_wrapper_.FindObject(object)); |
2817 LoadWordFromPoolOffset(dst, pp, offset - kHeapObjectTag); | 2813 LoadWordFromPoolOffset(dst, pp, offset - kHeapObjectTag); |
2818 } else { | 2814 } else { |
2819 ASSERT((Isolate::Current() == Dart::vm_isolate()) || | 2815 ASSERT(object.IsSmi() || object.InVMHeap()); |
2820 object.IsSmi() || | |
2821 object.InVMHeap()); | |
2822 LoadImmediate(dst, Immediate(reinterpret_cast<int64_t>(object.raw())), pp); | 2816 LoadImmediate(dst, Immediate(reinterpret_cast<int64_t>(object.raw())), pp); |
2823 } | 2817 } |
2824 } | 2818 } |
2825 | 2819 |
2826 | 2820 |
2827 void Assembler::LoadObject(Register dst, const Object& object, Register pp) { | 2821 void Assembler::LoadObject(Register dst, const Object& object, Register pp) { |
2828 LoadObjectHelper(dst, object, pp, false); | 2822 LoadObjectHelper(dst, object, pp, false); |
2829 } | 2823 } |
2830 | 2824 |
2831 | 2825 |
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2870 ObjectPool::element_offset(object_pool_wrapper_.FindObject(object)); | 2864 ObjectPool::element_offset(object_pool_wrapper_.FindObject(object)); |
2871 cmpq(reg, Address(pp, offset-kHeapObjectTag)); | 2865 cmpq(reg, Address(pp, offset-kHeapObjectTag)); |
2872 } else { | 2866 } else { |
2873 CompareImmediate( | 2867 CompareImmediate( |
2874 reg, Immediate(reinterpret_cast<int64_t>(object.raw())), pp); | 2868 reg, Immediate(reinterpret_cast<int64_t>(object.raw())), pp); |
2875 } | 2869 } |
2876 } | 2870 } |
2877 | 2871 |
2878 | 2872 |
2879 intptr_t Assembler::FindImmediate(int64_t imm) { | 2873 intptr_t Assembler::FindImmediate(int64_t imm) { |
2880 ASSERT(Isolate::Current() != Dart::vm_isolate()); | |
2881 return object_pool_wrapper_.FindImmediate(imm); | 2874 return object_pool_wrapper_.FindImmediate(imm); |
2882 } | 2875 } |
2883 | 2876 |
2884 | 2877 |
2885 bool Assembler::CanLoadImmediateFromPool(const Immediate& imm, Register pp) { | 2878 bool Assembler::CanLoadImmediateFromPool(const Immediate& imm, Register pp) { |
2886 if (!allow_constant_pool()) { | 2879 if (!allow_constant_pool()) { |
2887 return false; | 2880 return false; |
2888 } | 2881 } |
2889 return !imm.is_int32() && | 2882 return !imm.is_int32() && (pp != kNoRegister); |
2890 (pp != kNoRegister) && | |
2891 (Isolate::Current() != Dart::vm_isolate()); | |
2892 } | 2883 } |
2893 | 2884 |
2894 | 2885 |
2895 void Assembler::LoadImmediate(Register reg, const Immediate& imm, Register pp) { | 2886 void Assembler::LoadImmediate(Register reg, const Immediate& imm, Register pp) { |
2896 if (CanLoadImmediateFromPool(imm, pp)) { | 2887 if (CanLoadImmediateFromPool(imm, pp)) { |
2897 // It's a 64-bit constant and we're not in the VM isolate, so load from | 2888 // It's a 64-bit constant and we're not in the VM isolate, so load from |
2898 // object pool. | 2889 // object pool. |
2899 int32_t offset = ObjectPool::element_offset(FindImmediate(imm.value())); | 2890 int32_t offset = ObjectPool::element_offset(FindImmediate(imm.value())); |
2900 LoadWordFromPoolOffset(reg, pp, offset - kHeapObjectTag); | 2891 LoadWordFromPoolOffset(reg, pp, offset - kHeapObjectTag); |
2901 } else { | 2892 } else { |
(...skipping 1017 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3919 | 3910 |
3920 | 3911 |
3921 const char* Assembler::FpuRegisterName(FpuRegister reg) { | 3912 const char* Assembler::FpuRegisterName(FpuRegister reg) { |
3922 ASSERT((0 <= reg) && (reg < kNumberOfXmmRegisters)); | 3913 ASSERT((0 <= reg) && (reg < kNumberOfXmmRegisters)); |
3923 return xmm_reg_names[reg]; | 3914 return xmm_reg_names[reg]; |
3924 } | 3915 } |
3925 | 3916 |
3926 } // namespace dart | 3917 } // namespace dart |
3927 | 3918 |
3928 #endif // defined TARGET_ARCH_X64 | 3919 #endif // defined TARGET_ARCH_X64 |
OLD | NEW |