| Index: src/arm/lithium-codegen-arm.cc
|
| diff --git a/src/arm/lithium-codegen-arm.cc b/src/arm/lithium-codegen-arm.cc
|
| index 059aa13322adb4dde769c9be9cf594fac8133cb4..60b9cbc1cf7fb47de208e425118e4ad53285d714 100644
|
| --- a/src/arm/lithium-codegen-arm.cc
|
| +++ b/src/arm/lithium-codegen-arm.cc
|
| @@ -2217,25 +2217,6 @@ void LCodeGen::DoDebugBreak(LDebugBreak* instr) {
|
| }
|
|
|
|
|
| -void LCodeGen::DoIsNumberAndBranch(LIsNumberAndBranch* instr) {
|
| - Representation r = instr->hydrogen()->value()->representation();
|
| - if (r.IsSmiOrInteger32() || r.IsDouble()) {
|
| - EmitBranch(instr, al);
|
| - } else {
|
| - ASSERT(r.IsTagged());
|
| - Register reg = ToRegister(instr->value());
|
| - HType type = instr->hydrogen()->value()->type();
|
| - if (type.IsTaggedNumber()) {
|
| - EmitBranch(instr, al);
|
| - }
|
| - __ JumpIfSmi(reg, instr->TrueLabel(chunk_));
|
| - __ ldr(scratch0(), FieldMemOperand(reg, HeapObject::kMapOffset));
|
| - __ CompareRoot(scratch0(), Heap::kHeapNumberMapRootIndex);
|
| - EmitBranch(instr, eq);
|
| - }
|
| -}
|
| -
|
| -
|
| void LCodeGen::DoBranch(LBranch* instr) {
|
| Representation r = instr->hydrogen()->value()->representation();
|
| if (r.IsInteger32() || r.IsSmi()) {
|
| @@ -3168,6 +3149,12 @@ void LCodeGen::DoLoadFunctionPrototype(LLoadFunctionPrototype* instr) {
|
| }
|
|
|
|
|
| +void LCodeGen::DoLoadRoot(LLoadRoot* instr) {
|
| + Register result = ToRegister(instr->result());
|
| + __ LoadRoot(result, instr->index());
|
| +}
|
| +
|
| +
|
| void LCodeGen::DoLoadExternalArrayPointer(
|
| LLoadExternalArrayPointer* instr) {
|
| Register to_reg = ToRegister(instr->result());
|
| @@ -4331,16 +4318,23 @@ void LCodeGen::DoStoreKeyedExternalArray(LStoreKeyed* instr) {
|
|
|
| if (elements_kind == EXTERNAL_FLOAT_ELEMENTS ||
|
| elements_kind == EXTERNAL_DOUBLE_ELEMENTS) {
|
| + Register address = scratch0();
|
| DwVfpRegister value(ToDoubleRegister(instr->value()));
|
| - Operand operand(key_is_constant
|
| - ? Operand(constant_key << element_size_shift)
|
| - : Operand(key, LSL, shift_size));
|
| - __ add(scratch0(), external_pointer, operand);
|
| + if (key_is_constant) {
|
| + if (constant_key != 0) {
|
| + __ add(address, external_pointer,
|
| + Operand(constant_key << element_size_shift));
|
| + } else {
|
| + address = external_pointer;
|
| + }
|
| + } else {
|
| + __ add(address, external_pointer, Operand(key, LSL, shift_size));
|
| + }
|
| if (elements_kind == EXTERNAL_FLOAT_ELEMENTS) {
|
| __ vcvt_f32_f64(double_scratch0().low(), value);
|
| - __ vstr(double_scratch0().low(), scratch0(), additional_offset);
|
| + __ vstr(double_scratch0().low(), address, additional_offset);
|
| } else { // i.e. elements_kind == EXTERNAL_DOUBLE_ELEMENTS
|
| - __ vstr(value, scratch0(), additional_offset);
|
| + __ vstr(value, address, additional_offset);
|
| }
|
| } else {
|
| Register value(ToRegister(instr->value()));
|
| @@ -4382,32 +4376,28 @@ void LCodeGen::DoStoreKeyedExternalArray(LStoreKeyed* instr) {
|
| void LCodeGen::DoStoreKeyedFixedDoubleArray(LStoreKeyed* instr) {
|
| DwVfpRegister value = ToDoubleRegister(instr->value());
|
| Register elements = ToRegister(instr->elements());
|
| - Register key = no_reg;
|
| Register scratch = scratch0();
|
| + DwVfpRegister double_scratch = double_scratch0();
|
| bool key_is_constant = instr->key()->IsConstantOperand();
|
| - int constant_key = 0;
|
|
|
| // Calculate the effective address of the slot in the array to store the
|
| // double value.
|
| + int element_size_shift = ElementsKindToShiftSize(FAST_DOUBLE_ELEMENTS);
|
| if (key_is_constant) {
|
| - constant_key = ToInteger32(LConstantOperand::cast(instr->key()));
|
| + int constant_key = ToInteger32(LConstantOperand::cast(instr->key()));
|
| if (constant_key & 0xF0000000) {
|
| Abort(kArrayIndexConstantValueTooBig);
|
| }
|
| + __ add(scratch, elements,
|
| + Operand((constant_key << element_size_shift) +
|
| + FixedDoubleArray::kHeaderSize - kHeapObjectTag));
|
| } else {
|
| - key = ToRegister(instr->key());
|
| - }
|
| - int element_size_shift = ElementsKindToShiftSize(FAST_DOUBLE_ELEMENTS);
|
| - int shift_size = (instr->hydrogen()->key()->representation().IsSmi())
|
| - ? (element_size_shift - kSmiTagSize) : element_size_shift;
|
| - Operand operand = key_is_constant
|
| - ? Operand((constant_key << element_size_shift) +
|
| - FixedDoubleArray::kHeaderSize - kHeapObjectTag)
|
| - : Operand(key, LSL, shift_size);
|
| - __ add(scratch, elements, operand);
|
| - if (!key_is_constant) {
|
| - __ add(scratch, scratch,
|
| + int shift_size = (instr->hydrogen()->key()->representation().IsSmi())
|
| + ? (element_size_shift - kSmiTagSize) : element_size_shift;
|
| + __ add(scratch, elements,
|
| Operand(FixedDoubleArray::kHeaderSize - kHeapObjectTag));
|
| + __ add(scratch, scratch,
|
| + Operand(ToRegister(instr->key()), LSL, shift_size));
|
| }
|
|
|
| if (instr->NeedsCanonicalization()) {
|
| @@ -4417,9 +4407,12 @@ void LCodeGen::DoStoreKeyedFixedDoubleArray(LStoreKeyed* instr) {
|
| __ tst(ip, Operand(kVFPDefaultNaNModeControlBit));
|
| __ Assert(ne, kDefaultNaNModeNotSet);
|
| }
|
| - __ VFPCanonicalizeNaN(value);
|
| + __ VFPCanonicalizeNaN(double_scratch, value);
|
| + __ vstr(double_scratch, scratch,
|
| + instr->additional_index() << element_size_shift);
|
| + } else {
|
| + __ vstr(value, scratch, instr->additional_index() << element_size_shift);
|
| }
|
| - __ vstr(value, scratch, instr->additional_index() << element_size_shift);
|
| }
|
|
|
|
|
| @@ -5157,7 +5150,7 @@ void LCodeGen::DoCheckInstanceType(LCheckInstanceType* instr) {
|
|
|
| void LCodeGen::DoCheckValue(LCheckValue* instr) {
|
| Register reg = ToRegister(instr->value());
|
| - Handle<HeapObject> object = instr->hydrogen()->object();
|
| + Handle<HeapObject> object = instr->hydrogen()->object().handle();
|
| AllowDeferredHandleDereference smi_check;
|
| if (isolate()->heap()->InNewSpace(*object)) {
|
| Register reg = ToRegister(instr->value());
|
| @@ -5209,7 +5202,6 @@ void LCodeGen::DoCheckMaps(LCheckMaps* instr) {
|
| ASSERT(input->IsRegister());
|
| Register reg = ToRegister(input);
|
|
|
| - SmallMapList* map_set = instr->hydrogen()->map_set();
|
| __ ldr(map_reg, FieldMemOperand(reg, HeapObject::kMapOffset));
|
|
|
| DeferredCheckMaps* deferred = NULL;
|
| @@ -5218,14 +5210,15 @@ void LCodeGen::DoCheckMaps(LCheckMaps* instr) {
|
| __ bind(deferred->check_maps());
|
| }
|
|
|
| + UniqueSet<Map> map_set = instr->hydrogen()->map_set();
|
| Label success;
|
| - for (int i = 0; i < map_set->length() - 1; i++) {
|
| - Handle<Map> map = map_set->at(i);
|
| + for (int i = 0; i < map_set.size() - 1; i++) {
|
| + Handle<Map> map = map_set.at(i).handle();
|
| __ CompareMap(map_reg, map, &success);
|
| __ b(eq, &success);
|
| }
|
|
|
| - Handle<Map> map = map_set->last();
|
| + Handle<Map> map = map_set.at(map_set.size() - 1).handle();
|
| __ CompareMap(map_reg, map, &success);
|
| if (instr->hydrogen()->has_migration_target()) {
|
| __ b(ne, deferred->entry());
|
|
|