| Index: src/arm/macro-assembler-arm.cc
|
| diff --git a/src/arm/macro-assembler-arm.cc b/src/arm/macro-assembler-arm.cc
|
| index 82066a6c6706f997f0c8be535d70684199a93443..ad5bd76a60c5e5317d0431439d921f5fabc68928 100644
|
| --- a/src/arm/macro-assembler-arm.cc
|
| +++ b/src/arm/macro-assembler-arm.cc
|
| @@ -858,96 +858,6 @@ void MacroAssembler::VmovLow(DwVfpRegister dst, Register src) {
|
| }
|
|
|
|
|
| -void MacroAssembler::LoadNumber(Register object,
|
| - LowDwVfpRegister dst,
|
| - Register heap_number_map,
|
| - Register scratch,
|
| - Label* not_number) {
|
| - Label is_smi, done;
|
| -
|
| - UntagAndJumpIfSmi(scratch, object, &is_smi);
|
| - JumpIfNotHeapNumber(object, heap_number_map, scratch, not_number);
|
| -
|
| - vldr(dst, FieldMemOperand(object, HeapNumber::kValueOffset));
|
| - b(&done);
|
| -
|
| - // Handle loading a double from a smi.
|
| - bind(&is_smi);
|
| - vmov(dst.high(), scratch);
|
| - vcvt_f64_s32(dst, dst.high());
|
| -
|
| - bind(&done);
|
| -}
|
| -
|
| -
|
| -void MacroAssembler::LoadNumberAsInt32Double(Register object,
|
| - DwVfpRegister double_dst,
|
| - Register heap_number_map,
|
| - Register scratch,
|
| - LowDwVfpRegister double_scratch,
|
| - Label* not_int32) {
|
| - ASSERT(!scratch.is(object));
|
| - ASSERT(!heap_number_map.is(object) && !heap_number_map.is(scratch));
|
| -
|
| - Label done, obj_is_not_smi;
|
| -
|
| - UntagAndJumpIfNotSmi(scratch, object, &obj_is_not_smi);
|
| - vmov(double_scratch.low(), scratch);
|
| - vcvt_f64_s32(double_dst, double_scratch.low());
|
| - b(&done);
|
| -
|
| - bind(&obj_is_not_smi);
|
| - JumpIfNotHeapNumber(object, heap_number_map, scratch, not_int32);
|
| -
|
| - // Load the number.
|
| - // Load the double value.
|
| - vldr(double_dst, FieldMemOperand(object, HeapNumber::kValueOffset));
|
| -
|
| - TestDoubleIsInt32(double_dst, double_scratch);
|
| - // Jump to not_int32 if the operation did not succeed.
|
| - b(ne, not_int32);
|
| -
|
| - bind(&done);
|
| -}
|
| -
|
| -
|
| -void MacroAssembler::LoadNumberAsInt32(Register object,
|
| - Register dst,
|
| - Register heap_number_map,
|
| - Register scratch,
|
| - DwVfpRegister double_scratch0,
|
| - LowDwVfpRegister double_scratch1,
|
| - Label* not_int32) {
|
| - ASSERT(!dst.is(object));
|
| - ASSERT(!scratch.is(object));
|
| -
|
| - Label done, maybe_undefined;
|
| -
|
| - UntagAndJumpIfSmi(dst, object, &done);
|
| -
|
| - JumpIfNotHeapNumber(object, heap_number_map, scratch, &maybe_undefined);
|
| -
|
| - // Object is a heap number.
|
| - // Convert the floating point value to a 32-bit integer.
|
| - // Load the double value.
|
| - vldr(double_scratch0, FieldMemOperand(object, HeapNumber::kValueOffset));
|
| -
|
| - TryDoubleToInt32Exact(dst, double_scratch0, double_scratch1);
|
| - // Jump to not_int32 if the operation did not succeed.
|
| - b(ne, not_int32);
|
| - b(&done);
|
| -
|
| - bind(&maybe_undefined);
|
| - CompareRoot(object, Heap::kUndefinedValueRootIndex);
|
| - b(ne, not_int32);
|
| - // |undefined| is truncated to 0.
|
| - mov(dst, Operand(Smi::FromInt(0)));
|
| - // Fall through.
|
| -
|
| - bind(&done);
|
| -}
|
| -
|
| -
|
| void MacroAssembler::Prologue(PrologueFrameMode frame_mode) {
|
| if (frame_mode == BUILD_STUB_FRAME) {
|
| stm(db_w, sp, cp.bit() | fp.bit() | lr.bit());
|
| @@ -1590,6 +1500,9 @@ void MacroAssembler::CheckAccessGlobalProxy(Register holder_reg,
|
| }
|
|
|
|
|
| +// Compute the hash code from the untagged key. This must be kept in sync with
|
| +// ComputeIntegerHash in utils.h and KeyedLoadGenericElementStub in
|
| +// code-stub-hydrogen.cc
|
| void MacroAssembler::GetNumberHash(Register t0, Register scratch) {
|
| // First of all we assign the hash seed to scratch.
|
| LoadRoot(scratch, Heap::kHashSeedRootIndex);
|
| @@ -1656,8 +1569,7 @@ void MacroAssembler::LoadFromNumberDictionary(Label* miss,
|
| sub(t1, t1, Operand(1));
|
|
|
| // Generate an unrolled loop that performs a few probes before giving up.
|
| - static const int kProbes = 4;
|
| - for (int i = 0; i < kProbes; i++) {
|
| + for (int i = 0; i < kNumberDictionaryProbes; i++) {
|
| // Use t2 for index calculations and keep the hash intact in t0.
|
| mov(t2, t0);
|
| // Compute the masked index: (hash + i + i * i) & mask.
|
| @@ -1674,7 +1586,7 @@ void MacroAssembler::LoadFromNumberDictionary(Label* miss,
|
| add(t2, elements, Operand(t2, LSL, kPointerSizeLog2));
|
| ldr(ip, FieldMemOperand(t2, SeededNumberDictionary::kElementsStartOffset));
|
| cmp(key, Operand(ip));
|
| - if (i != kProbes - 1) {
|
| + if (i != kNumberDictionaryProbes - 1) {
|
| b(eq, &done);
|
| } else {
|
| b(ne, miss);
|
|
|