Index: src/arm/lithium-codegen-arm.cc |
diff --git a/src/arm/lithium-codegen-arm.cc b/src/arm/lithium-codegen-arm.cc |
index 485396547f18b5d05f00ea29b45d23140ccb2ed2..f83238582f3fd70ca0f5ce4a32338ad04015d974 100644 |
--- a/src/arm/lithium-codegen-arm.cc |
+++ b/src/arm/lithium-codegen-arm.cc |
@@ -1779,9 +1779,9 @@ Condition LCodeGen::EmitIsObject(Register input, |
// Load instance type and check that it is in object type range. |
__ ldrb(temp2, FieldMemOperand(temp1, Map::kInstanceTypeOffset)); |
- __ cmp(temp2, Operand(FIRST_JS_OBJECT_TYPE)); |
+ __ cmp(temp2, Operand(FIRST_NONCALLABLE_SPEC_OBJECT_TYPE)); |
__ b(lt, is_not_object); |
- __ cmp(temp2, Operand(LAST_JS_OBJECT_TYPE)); |
+ __ cmp(temp2, Operand(LAST_NONCALLABLE_SPEC_OBJECT_TYPE)); |
return le; |
} |
@@ -1988,26 +1988,27 @@ void LCodeGen::EmitClassOfTest(Label* is_true, |
ASSERT(!temp.is(temp2)); // But input and temp2 may be the same register. |
__ tst(input, Operand(kSmiTagMask)); |
__ b(eq, is_false); |
- __ CompareObjectType(input, temp, temp2, FIRST_JS_OBJECT_TYPE); |
+ __ CompareObjectType(input, temp, temp2, FIRST_SPEC_OBJECT_TYPE); |
__ b(lt, is_false); |
// Map is now in temp. |
// Functions have class 'Function'. |
- __ CompareInstanceType(temp, temp2, JS_FUNCTION_TYPE); |
+ __ CompareInstanceType(temp, temp2, FIRST_CALLABLE_SPEC_OBJECT_TYPE); |
if (class_name->IsEqualTo(CStrVector("Function"))) { |
- __ b(eq, is_true); |
+ __ b(ge, is_true); |
} else { |
- __ b(eq, is_false); |
+ __ b(ge, is_false); |
} |
// Check if the constructor in the map is a function. |
__ ldr(temp, FieldMemOperand(temp, Map::kConstructorOffset)); |
- // As long as JS_FUNCTION_TYPE is the last instance type and it is |
- // right after LAST_JS_OBJECT_TYPE, we can avoid checking for |
- // LAST_JS_OBJECT_TYPE. |
- ASSERT(LAST_TYPE == JS_FUNCTION_TYPE); |
- ASSERT(JS_FUNCTION_TYPE == LAST_JS_OBJECT_TYPE + 1); |
+ // As long as LAST_CALLABLE_SPEC_OBJECT_TYPE is the last instance type and |
+ // FIRST_CALLABLE_SPEC_OBJECT_TYPE comes right after |
+ // LAST_NONCALLABLE_SPEC_OBJECT_TYPE, we can avoid checking for the latter. |
+ STATIC_ASSERT(LAST_TYPE == LAST_CALLABLE_SPEC_OBJECT_TYPE); |
+ STATIC_ASSERT(FIRST_CALLABLE_SPEC_OBJECT_TYPE == |
+ LAST_NONCALLABLE_SPEC_OBJECT_TYPE + 1); |
// Objects with a non-function constructor have class 'Object'. |
__ CompareObjectType(temp, temp2, temp2, JS_FUNCTION_TYPE); |
@@ -2743,8 +2744,8 @@ void LCodeGen::DoApplyArguments(LApplyArguments* instr) { |
// Deoptimize if the receiver is not a JS object. |
__ tst(receiver, Operand(kSmiTagMask)); |
DeoptimizeIf(eq, instr->environment()); |
- __ CompareObjectType(receiver, scratch, scratch, FIRST_JS_OBJECT_TYPE); |
- DeoptimizeIf(lo, instr->environment()); |
+ __ CompareObjectType(receiver, scratch, scratch, FIRST_SPEC_OBJECT_TYPE); |
+ DeoptimizeIf(lt, instr->environment()); |
__ jmp(&receiver_ok); |
__ bind(&global_object); |
@@ -4402,17 +4403,19 @@ Condition LCodeGen::EmitTypeofIs(Label* true_label, |
} else if (type_name->Equals(heap()->function_symbol())) { |
__ JumpIfSmi(input, false_label); |
- __ CompareObjectType(input, input, scratch, FIRST_FUNCTION_CLASS_TYPE); |
+ __ CompareObjectType(input, input, scratch, |
+ FIRST_CALLABLE_SPEC_OBJECT_TYPE); |
final_branch_condition = ge; |
} else if (type_name->Equals(heap()->object_symbol())) { |
__ JumpIfSmi(input, false_label); |
__ CompareRoot(input, Heap::kNullValueRootIndex); |
__ b(eq, true_label); |
- __ CompareObjectType(input, input, scratch, FIRST_JS_OBJECT_TYPE); |
- __ b(lo, false_label); |
- __ CompareInstanceType(input, scratch, FIRST_FUNCTION_CLASS_TYPE); |
- __ b(hs, false_label); |
+ __ CompareObjectType(input, input, scratch, |
+ FIRST_NONCALLABLE_SPEC_OBJECT_TYPE); |
+ __ b(lt, false_label); |
+ __ CompareInstanceType(input, scratch, LAST_NONCALLABLE_SPEC_OBJECT_TYPE); |
+ __ b(gt, false_label); |
// Check for undetectable objects => false. |
__ ldrb(ip, FieldMemOperand(input, Map::kBitFieldOffset)); |
__ tst(ip, Operand(1 << Map::kIsUndetectable)); |