| Index: src/x64/full-codegen-x64.cc
|
| diff --git a/src/x64/full-codegen-x64.cc b/src/x64/full-codegen-x64.cc
|
| index d5a220f9e3a2c626e68ef12edee60eea05a53e85..9a9be17d62b6e12514ce328710e4bd5163f4c17e 100644
|
| --- a/src/x64/full-codegen-x64.cc
|
| +++ b/src/x64/full-codegen-x64.cc
|
| @@ -865,7 +865,7 @@ void FullCodeGenerator::VisitForInStatement(ForInStatement* stmt) {
|
| // Convert the object to a JS object.
|
| Label convert, done_convert;
|
| __ JumpIfSmi(rax, &convert);
|
| - __ CmpObjectType(rax, FIRST_JS_OBJECT_TYPE, rcx);
|
| + __ CmpObjectType(rax, FIRST_OBJECT_OR_FUNCTION_CLASS_TYPE, rcx);
|
| __ j(above_equal, &done_convert);
|
| __ bind(&convert);
|
| __ push(rax);
|
| @@ -2357,9 +2357,9 @@ void FullCodeGenerator::EmitIsObject(ZoneList<Expression*>* args) {
|
| Immediate(1 << Map::kIsUndetectable));
|
| __ j(not_zero, if_false);
|
| __ movzxbq(rbx, FieldOperand(rbx, Map::kInstanceTypeOffset));
|
| - __ cmpq(rbx, Immediate(FIRST_JS_OBJECT_TYPE));
|
| + __ cmpq(rbx, Immediate(FIRST_OBJECT_CLASS_TYPE));
|
| __ j(below, if_false);
|
| - __ cmpq(rbx, Immediate(LAST_JS_OBJECT_TYPE));
|
| + __ cmpq(rbx, Immediate(LAST_OBJECT_CLASS_TYPE));
|
| PrepareForBailoutBeforeSplit(TOS_REG, true, if_true, if_false);
|
| Split(below_equal, if_true, if_false, fall_through);
|
|
|
| @@ -2380,7 +2380,7 @@ void FullCodeGenerator::EmitIsSpecObject(ZoneList<Expression*>* args) {
|
| &if_true, &if_false, &fall_through);
|
|
|
| __ JumpIfSmi(rax, if_false);
|
| - __ CmpObjectType(rax, FIRST_JS_OBJECT_TYPE, rbx);
|
| + __ CmpObjectType(rax, FIRST_OBJECT_OR_FUNCTION_CLASS_TYPE, rbx);
|
| PrepareForBailoutBeforeSplit(TOS_REG, true, if_true, if_false);
|
| Split(above_equal, if_true, if_false, fall_through);
|
|
|
| @@ -2659,16 +2659,17 @@ void FullCodeGenerator::EmitClassOf(ZoneList<Expression*>* args) {
|
|
|
| // Check that the object is a JS object but take special care of JS
|
| // functions to make sure they have 'Function' as their class.
|
| - __ CmpObjectType(rax, FIRST_JS_OBJECT_TYPE, rax); // Map is now in rax.
|
| + __ CmpObjectType(rax, FIRST_OBJECT_OR_FUNCTION_CLASS_TYPE, rax);
|
| + // Map is now in rax.
|
| __ j(below, &null);
|
|
|
| - // 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);
|
| - __ CmpInstanceType(rax, JS_FUNCTION_TYPE);
|
| - __ j(equal, &function);
|
| + // As long as LAST_FUNCTION_CLASS_TYPE is the last instance type, and
|
| + // FIRST_FUNCTION_CLASS_TYPE comes right after LAST_OBJECT_CLASS_TYPE,
|
| + // we can avoid checking for LAST_OBJECT_CLASS_TYPE.
|
| + ASSERT(LAST_TYPE == LAST_FUNCTION_CLASS_TYPE);
|
| + ASSERT(FIRST_FUNCTION_CLASS_TYPE == LAST_OBJECT_CLASS_TYPE + 1);
|
| + __ CmpInstanceType(rax, FIRST_FUNCTION_CLASS_TYPE);
|
| + __ j(above_equal, &function);
|
|
|
| // Check if the constructor in the map is a function.
|
| __ movq(rax, FieldOperand(rax, Map::kConstructorOffset));
|
| @@ -4022,9 +4023,9 @@ bool FullCodeGenerator::TryLiteralCompare(Token::Value op,
|
| __ JumpIfSmi(rax, if_false);
|
| __ CompareRoot(rax, Heap::kNullValueRootIndex);
|
| __ j(equal, if_true);
|
| - __ CmpObjectType(rax, FIRST_JS_OBJECT_TYPE, rdx);
|
| + __ CmpObjectType(rax, FIRST_OBJECT_CLASS_TYPE, rdx);
|
| __ j(below, if_false);
|
| - __ CmpInstanceType(rdx, FIRST_FUNCTION_CLASS_TYPE);
|
| + __ CmpInstanceType(rdx, LAST_OBJECT_CLASS_TYPE);
|
| __ j(above_equal, if_false);
|
| // Check for undetectable objects => false.
|
| __ testb(FieldOperand(rdx, Map::kBitFieldOffset),
|
|
|