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 #include <limits.h> // For LONG_MIN, LONG_MAX. | 5 #include <limits.h> // For LONG_MIN, LONG_MAX. |
6 | 6 |
7 #if V8_TARGET_ARCH_ARM | 7 #if V8_TARGET_ARCH_ARM |
8 | 8 |
9 #include "src/base/bits.h" | 9 #include "src/base/bits.h" |
10 #include "src/base/division-by-constant.h" | 10 #include "src/base/division-by-constant.h" |
(...skipping 3786 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3797 | 3797 |
3798 void MacroAssembler::TestJSArrayForAllocationMemento( | 3798 void MacroAssembler::TestJSArrayForAllocationMemento( |
3799 Register receiver_reg, | 3799 Register receiver_reg, |
3800 Register scratch_reg, | 3800 Register scratch_reg, |
3801 Label* no_memento_found) { | 3801 Label* no_memento_found) { |
3802 Label map_check; | 3802 Label map_check; |
3803 Label top_check; | 3803 Label top_check; |
3804 ExternalReference new_space_allocation_top_adr = | 3804 ExternalReference new_space_allocation_top_adr = |
3805 ExternalReference::new_space_allocation_top_address(isolate()); | 3805 ExternalReference::new_space_allocation_top_address(isolate()); |
3806 const int kMementoMapOffset = JSArray::kSize - kHeapObjectTag; | 3806 const int kMementoMapOffset = JSArray::kSize - kHeapObjectTag; |
3807 const int kMementoEndOffset = kMementoMapOffset + AllocationMemento::kSize; | 3807 const int kMementoLastWordOffset = |
| 3808 kMementoMapOffset + AllocationMemento::kSize - kPointerSize; |
3808 | 3809 |
3809 // Bail out if the object is not in new space. | 3810 // Bail out if the object is not in new space. |
3810 JumpIfNotInNewSpace(receiver_reg, scratch_reg, no_memento_found); | 3811 JumpIfNotInNewSpace(receiver_reg, scratch_reg, no_memento_found); |
3811 // If the object is in new space, we need to check whether it is on the same | 3812 // If the object is in new space, we need to check whether it is on the same |
3812 // page as the current top. | 3813 // page as the current top. |
3813 add(scratch_reg, receiver_reg, Operand(kMementoEndOffset)); | 3814 add(scratch_reg, receiver_reg, Operand(kMementoLastWordOffset)); |
3814 mov(ip, Operand(new_space_allocation_top_adr)); | 3815 mov(ip, Operand(new_space_allocation_top_adr)); |
3815 ldr(ip, MemOperand(ip)); | 3816 ldr(ip, MemOperand(ip)); |
3816 eor(scratch_reg, scratch_reg, Operand(ip)); | 3817 eor(scratch_reg, scratch_reg, Operand(ip)); |
3817 tst(scratch_reg, Operand(~Page::kPageAlignmentMask)); | 3818 tst(scratch_reg, Operand(~Page::kPageAlignmentMask)); |
3818 b(eq, &top_check); | 3819 b(eq, &top_check); |
3819 // The object is on a different page than allocation top. Bail out if the | 3820 // The object is on a different page than allocation top. Bail out if the |
3820 // object sits on the page boundary as no memento can follow and we cannot | 3821 // object sits on the page boundary as no memento can follow and we cannot |
3821 // touch the memory following it. | 3822 // touch the memory following it. |
3822 add(scratch_reg, receiver_reg, Operand(kMementoEndOffset)); | 3823 add(scratch_reg, receiver_reg, Operand(kMementoLastWordOffset)); |
3823 eor(scratch_reg, scratch_reg, Operand(receiver_reg)); | 3824 eor(scratch_reg, scratch_reg, Operand(receiver_reg)); |
3824 tst(scratch_reg, Operand(~Page::kPageAlignmentMask)); | 3825 tst(scratch_reg, Operand(~Page::kPageAlignmentMask)); |
3825 b(ne, no_memento_found); | 3826 b(ne, no_memento_found); |
3826 // Continue with the actual map check. | 3827 // Continue with the actual map check. |
3827 jmp(&map_check); | 3828 jmp(&map_check); |
3828 // If top is on the same page as the current object, we need to check whether | 3829 // If top is on the same page as the current object, we need to check whether |
3829 // we are below top. | 3830 // we are below top. |
3830 bind(&top_check); | 3831 bind(&top_check); |
3831 add(scratch_reg, receiver_reg, Operand(kMementoEndOffset)); | 3832 add(scratch_reg, receiver_reg, Operand(kMementoLastWordOffset)); |
3832 mov(ip, Operand(new_space_allocation_top_adr)); | 3833 mov(ip, Operand(new_space_allocation_top_adr)); |
3833 ldr(ip, MemOperand(ip)); | 3834 ldr(ip, MemOperand(ip)); |
3834 cmp(scratch_reg, ip); | 3835 cmp(scratch_reg, ip); |
3835 b(gt, no_memento_found); | 3836 b(ge, no_memento_found); |
3836 // Memento map check. | 3837 // Memento map check. |
3837 bind(&map_check); | 3838 bind(&map_check); |
3838 ldr(scratch_reg, MemOperand(receiver_reg, kMementoMapOffset)); | 3839 ldr(scratch_reg, MemOperand(receiver_reg, kMementoMapOffset)); |
3839 cmp(scratch_reg, Operand(isolate()->factory()->allocation_memento_map())); | 3840 cmp(scratch_reg, Operand(isolate()->factory()->allocation_memento_map())); |
3840 } | 3841 } |
3841 | 3842 |
3842 Register GetRegisterThatIsNotOneOf(Register reg1, | 3843 Register GetRegisterThatIsNotOneOf(Register reg1, |
3843 Register reg2, | 3844 Register reg2, |
3844 Register reg3, | 3845 Register reg3, |
3845 Register reg4, | 3846 Register reg4, |
(...skipping 151 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3997 } | 3998 } |
3998 } | 3999 } |
3999 if (mag.shift > 0) mov(result, Operand(result, ASR, mag.shift)); | 4000 if (mag.shift > 0) mov(result, Operand(result, ASR, mag.shift)); |
4000 add(result, result, Operand(dividend, LSR, 31)); | 4001 add(result, result, Operand(dividend, LSR, 31)); |
4001 } | 4002 } |
4002 | 4003 |
4003 } // namespace internal | 4004 } // namespace internal |
4004 } // namespace v8 | 4005 } // namespace v8 |
4005 | 4006 |
4006 #endif // V8_TARGET_ARCH_ARM | 4007 #endif // V8_TARGET_ARCH_ARM |
OLD | NEW |