| Index: src/full-codegen/x64/full-codegen-x64.cc
|
| diff --git a/src/full-codegen/x64/full-codegen-x64.cc b/src/full-codegen/x64/full-codegen-x64.cc
|
| index 88b37a30a08b08049a28372714efb1e80f98de7f..6c4ffc056337c3adb560ed162af5f05c5d78fe5f 100644
|
| --- a/src/full-codegen/x64/full-codegen-x64.cc
|
| +++ b/src/full-codegen/x64/full-codegen-x64.cc
|
| @@ -134,7 +134,7 @@ void FullCodeGenerator::Generate() {
|
| __ subp(rcx, Immediate(locals_count * kPointerSize));
|
| __ CompareRoot(rcx, Heap::kRealStackLimitRootIndex);
|
| __ j(above_equal, &ok, Label::kNear);
|
| - __ CallRuntime(Runtime::kThrowStackOverflow, 0);
|
| + __ CallRuntime(Runtime::kThrowStackOverflow);
|
| __ bind(&ok);
|
| }
|
| __ LoadRoot(rax, Heap::kUndefinedValueRootIndex);
|
| @@ -171,7 +171,7 @@ void FullCodeGenerator::Generate() {
|
| if (info->scope()->is_script_scope()) {
|
| __ Push(rdi);
|
| __ Push(info->scope()->GetScopeInfo(info->isolate()));
|
| - __ CallRuntime(Runtime::kNewScriptContext, 2);
|
| + __ CallRuntime(Runtime::kNewScriptContext);
|
| PrepareForBailoutForId(BailoutId::ScriptContext(), TOS_REG);
|
| // The new target value is not used, clobbering is safe.
|
| DCHECK_NULL(info->scope()->new_target_var());
|
| @@ -186,7 +186,7 @@ void FullCodeGenerator::Generate() {
|
| need_write_barrier = false;
|
| } else {
|
| __ Push(rdi);
|
| - __ CallRuntime(Runtime::kNewFunctionContext, 1);
|
| + __ CallRuntime(Runtime::kNewFunctionContext);
|
| }
|
| if (info->scope()->new_target_var() != nullptr) {
|
| __ Pop(rdx); // Restore new target.
|
| @@ -304,7 +304,7 @@ void FullCodeGenerator::Generate() {
|
| }
|
|
|
| if (FLAG_trace) {
|
| - __ CallRuntime(Runtime::kTraceEnter, 0);
|
| + __ CallRuntime(Runtime::kTraceEnter);
|
| }
|
|
|
| // Visit the declarations and body unless there is an illegal
|
| @@ -414,7 +414,7 @@ void FullCodeGenerator::EmitReturnSequence() {
|
| __ bind(&return_label_);
|
| if (FLAG_trace) {
|
| __ Push(rax);
|
| - __ CallRuntime(Runtime::kTraceExit, 1);
|
| + __ CallRuntime(Runtime::kTraceExit);
|
| }
|
| // Pretend that the exit is a backwards jump to the entry.
|
| int weight = 1;
|
| @@ -808,7 +808,7 @@ void FullCodeGenerator::VisitVariableDeclaration(
|
| __ Push(Smi::FromInt(0)); // Indicates no initial value.
|
| }
|
| __ Push(Smi::FromInt(variable->DeclarationPropertyAttributes()));
|
| - __ CallRuntime(Runtime::kDeclareLookupSlot, 3);
|
| + __ CallRuntime(Runtime::kDeclareLookupSlot);
|
| break;
|
| }
|
| }
|
| @@ -862,7 +862,7 @@ void FullCodeGenerator::VisitFunctionDeclaration(
|
| __ Push(variable->name());
|
| VisitForStackValue(declaration->fun());
|
| __ Push(Smi::FromInt(variable->DeclarationPropertyAttributes()));
|
| - __ CallRuntime(Runtime::kDeclareLookupSlot, 3);
|
| + __ CallRuntime(Runtime::kDeclareLookupSlot);
|
| break;
|
| }
|
| }
|
| @@ -873,7 +873,7 @@ void FullCodeGenerator::DeclareGlobals(Handle<FixedArray> pairs) {
|
| // Call the runtime to declare the globals.
|
| __ Push(pairs);
|
| __ Push(Smi::FromInt(DeclareGlobalsFlags()));
|
| - __ CallRuntime(Runtime::kDeclareGlobals, 2);
|
| + __ CallRuntime(Runtime::kDeclareGlobals);
|
| // Return value is ignored.
|
| }
|
|
|
| @@ -881,7 +881,7 @@ void FullCodeGenerator::DeclareGlobals(Handle<FixedArray> pairs) {
|
| void FullCodeGenerator::DeclareModules(Handle<FixedArray> descriptions) {
|
| // Call the runtime to declare the modules.
|
| __ Push(descriptions);
|
| - __ CallRuntime(Runtime::kDeclareModules, 1);
|
| + __ CallRuntime(Runtime::kDeclareModules);
|
| // Return value is ignored.
|
| }
|
|
|
| @@ -1035,7 +1035,7 @@ void FullCodeGenerator::VisitForInStatement(ForInStatement* stmt) {
|
| // Get the set of properties to enumerate.
|
| __ bind(&call_runtime);
|
| __ Push(rax); // Duplicate the enumerable object on the stack.
|
| - __ CallRuntime(Runtime::kGetPropertyNamesFast, 1);
|
| + __ CallRuntime(Runtime::kGetPropertyNamesFast);
|
| PrepareForBailoutForId(stmt->EnumId(), TOS_REG);
|
|
|
| // If we got a map from the runtime call, we can do a fast
|
| @@ -1117,7 +1117,7 @@ void FullCodeGenerator::VisitForInStatement(ForInStatement* stmt) {
|
| // just skip it.
|
| __ Push(rcx); // Enumerable.
|
| __ Push(rbx); // Current entry.
|
| - __ CallRuntime(Runtime::kForInFilter, 2);
|
| + __ CallRuntime(Runtime::kForInFilter);
|
| PrepareForBailoutForId(stmt->FilterId(), TOS_REG);
|
| __ CompareRoot(rax, Heap::kUndefinedValueRootIndex);
|
| __ j(equal, loop_statement.continue_label());
|
| @@ -1175,8 +1175,8 @@ void FullCodeGenerator::EmitNewClosure(Handle<SharedFunctionInfo> info,
|
| __ CallStub(&stub);
|
| } else {
|
| __ Push(info);
|
| - __ CallRuntime(
|
| - pretenure ? Runtime::kNewClosure_Tenured : Runtime::kNewClosure, 1);
|
| + __ CallRuntime(pretenure ? Runtime::kNewClosure_Tenured
|
| + : Runtime::kNewClosure);
|
| }
|
| context()->Plug(rax);
|
| }
|
| @@ -1315,7 +1315,7 @@ void FullCodeGenerator::EmitDynamicLookupFastCase(VariableProxy* proxy,
|
| __ LoadRoot(rax, Heap::kUndefinedValueRootIndex);
|
| } else { // LET || CONST
|
| __ Push(var->name());
|
| - __ CallRuntime(Runtime::kThrowReferenceError, 1);
|
| + __ CallRuntime(Runtime::kThrowReferenceError);
|
| }
|
| }
|
| __ jmp(done);
|
| @@ -1370,7 +1370,7 @@ void FullCodeGenerator::EmitVariableLoad(VariableProxy* proxy,
|
| // Throw a reference error when using an uninitialized let/const
|
| // binding in harmony mode.
|
| __ Push(var->name());
|
| - __ CallRuntime(Runtime::kThrowReferenceError, 1);
|
| + __ CallRuntime(Runtime::kThrowReferenceError);
|
| } else {
|
| // Uninitialized legacy const bindings are unholed.
|
| DCHECK(var->mode() == CONST_LEGACY);
|
| @@ -1397,7 +1397,7 @@ void FullCodeGenerator::EmitVariableLoad(VariableProxy* proxy,
|
| typeof_mode == NOT_INSIDE_TYPEOF
|
| ? Runtime::kLoadLookupSlot
|
| : Runtime::kLoadLookupSlotNoReferenceError;
|
| - __ CallRuntime(function_id, 2);
|
| + __ CallRuntime(function_id);
|
| __ bind(&done);
|
| context()->Plug(rax);
|
| break;
|
| @@ -1444,7 +1444,7 @@ void FullCodeGenerator::VisitObjectLiteral(ObjectLiteral* expr) {
|
| __ Push(Smi::FromInt(expr->literal_index()));
|
| __ Push(constant_properties);
|
| __ Push(Smi::FromInt(flags));
|
| - __ CallRuntime(Runtime::kCreateObjectLiteral, 4);
|
| + __ CallRuntime(Runtime::kCreateObjectLiteral);
|
| } else {
|
| __ movp(rax, Operand(rbp, JavaScriptFrameConstants::kFunctionOffset));
|
| __ Move(rbx, Smi::FromInt(expr->literal_index()));
|
| @@ -1507,7 +1507,7 @@ void FullCodeGenerator::VisitObjectLiteral(ObjectLiteral* expr) {
|
| EmitSetHomeObject(value, 2, property->GetSlot());
|
| }
|
| __ Push(Smi::FromInt(SLOPPY)); // Language mode
|
| - __ CallRuntime(Runtime::kSetProperty, 4);
|
| + __ CallRuntime(Runtime::kSetProperty);
|
| } else {
|
| __ Drop(3);
|
| }
|
| @@ -1516,7 +1516,7 @@ void FullCodeGenerator::VisitObjectLiteral(ObjectLiteral* expr) {
|
| __ Push(Operand(rsp, 0)); // Duplicate receiver.
|
| VisitForStackValue(value);
|
| DCHECK(property->emit_store());
|
| - __ CallRuntime(Runtime::kInternalSetPrototype, 2);
|
| + __ CallRuntime(Runtime::kInternalSetPrototype);
|
| break;
|
| case ObjectLiteral::Property::GETTER:
|
| if (property->emit_store()) {
|
| @@ -1541,7 +1541,7 @@ void FullCodeGenerator::VisitObjectLiteral(ObjectLiteral* expr) {
|
| EmitAccessor(it->second->getter);
|
| EmitAccessor(it->second->setter);
|
| __ Push(Smi::FromInt(NONE));
|
| - __ CallRuntime(Runtime::kDefineAccessorPropertyUnchecked, 5);
|
| + __ CallRuntime(Runtime::kDefineAccessorPropertyUnchecked);
|
| }
|
|
|
| // Object literals have two parts. The "static" part on the left contains no
|
| @@ -1568,7 +1568,7 @@ void FullCodeGenerator::VisitObjectLiteral(ObjectLiteral* expr) {
|
| DCHECK(!property->is_computed_name());
|
| VisitForStackValue(value);
|
| DCHECK(property->emit_store());
|
| - __ CallRuntime(Runtime::kInternalSetPrototype, 2);
|
| + __ CallRuntime(Runtime::kInternalSetPrototype);
|
| } else {
|
| EmitPropertyKey(property, expr->GetIdForProperty(property_index));
|
| VisitForStackValue(value);
|
| @@ -1582,7 +1582,7 @@ void FullCodeGenerator::VisitObjectLiteral(ObjectLiteral* expr) {
|
| case ObjectLiteral::Property::COMPUTED:
|
| if (property->emit_store()) {
|
| __ Push(Smi::FromInt(NONE));
|
| - __ CallRuntime(Runtime::kDefineDataPropertyUnchecked, 4);
|
| + __ CallRuntime(Runtime::kDefineDataPropertyUnchecked);
|
| } else {
|
| __ Drop(3);
|
| }
|
| @@ -1594,12 +1594,12 @@ void FullCodeGenerator::VisitObjectLiteral(ObjectLiteral* expr) {
|
|
|
| case ObjectLiteral::Property::GETTER:
|
| __ Push(Smi::FromInt(NONE));
|
| - __ CallRuntime(Runtime::kDefineGetterPropertyUnchecked, 4);
|
| + __ CallRuntime(Runtime::kDefineGetterPropertyUnchecked);
|
| break;
|
|
|
| case ObjectLiteral::Property::SETTER:
|
| __ Push(Smi::FromInt(NONE));
|
| - __ CallRuntime(Runtime::kDefineSetterPropertyUnchecked, 4);
|
| + __ CallRuntime(Runtime::kDefineSetterPropertyUnchecked);
|
| break;
|
| }
|
| }
|
| @@ -1608,7 +1608,7 @@ void FullCodeGenerator::VisitObjectLiteral(ObjectLiteral* expr) {
|
| if (expr->has_function()) {
|
| DCHECK(result_saved);
|
| __ Push(Operand(rsp, 0));
|
| - __ CallRuntime(Runtime::kToFastProperties, 1);
|
| + __ CallRuntime(Runtime::kToFastProperties);
|
| }
|
|
|
| if (result_saved) {
|
| @@ -1638,7 +1638,7 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
| __ Push(Smi::FromInt(expr->literal_index()));
|
| __ Push(constant_elements);
|
| __ Push(Smi::FromInt(expr->ComputeFlags()));
|
| - __ CallRuntime(Runtime::kCreateArrayLiteral, 4);
|
| + __ CallRuntime(Runtime::kCreateArrayLiteral);
|
| } else {
|
| __ movp(rax, Operand(rbp, JavaScriptFrameConstants::kFunctionOffset));
|
| __ Move(rbx, Smi::FromInt(expr->literal_index()));
|
| @@ -1698,7 +1698,7 @@ void FullCodeGenerator::VisitArrayLiteral(ArrayLiteral* expr) {
|
| CALL_FUNCTION);
|
| } else {
|
| VisitForStackValue(subexpr);
|
| - __ CallRuntime(Runtime::kAppendElement, 2);
|
| + __ CallRuntime(Runtime::kAppendElement);
|
| }
|
|
|
| PrepareForBailoutForId(expr->GetIdForElement(array_index), NO_REGISTERS);
|
| @@ -2095,7 +2095,7 @@ void FullCodeGenerator::EmitGeneratorResume(Expression *generator,
|
| __ Push(rbx);
|
| __ Push(result_register());
|
| __ Push(Smi::FromInt(resume_mode));
|
| - __ CallRuntime(Runtime::kResumeJSGeneratorObject, 3);
|
| + __ CallRuntime(Runtime::kResumeJSGeneratorObject);
|
| // Not reached: the runtime call returns elsewhere.
|
| __ Abort(kGeneratorFailedToResume);
|
|
|
| @@ -2112,7 +2112,7 @@ void FullCodeGenerator::EmitCreateIteratorResult(bool done) {
|
|
|
| __ bind(&allocate);
|
| __ Push(Smi::FromInt(JSIteratorResult::kSize));
|
| - __ CallRuntime(Runtime::kAllocateInNewSpace, 1);
|
| + __ CallRuntime(Runtime::kAllocateInNewSpace);
|
|
|
| __ bind(&done_allocate);
|
| __ LoadNativeContextSlot(Context::ITERATOR_RESULT_MAP_INDEX, rbx);
|
| @@ -2148,7 +2148,7 @@ void FullCodeGenerator::EmitNamedSuperPropertyLoad(Property* prop) {
|
|
|
| __ Push(key->value());
|
| __ Push(Smi::FromInt(language_mode()));
|
| - __ CallRuntime(Runtime::kLoadFromSuper, 4);
|
| + __ CallRuntime(Runtime::kLoadFromSuper);
|
| }
|
|
|
|
|
| @@ -2165,7 +2165,7 @@ void FullCodeGenerator::EmitKeyedSuperPropertyLoad(Property* prop) {
|
| // Stack: receiver, home_object, key.
|
| SetExpressionPosition(prop);
|
| __ Push(Smi::FromInt(language_mode()));
|
| - __ CallRuntime(Runtime::kLoadKeyedFromSuper, 4);
|
| + __ CallRuntime(Runtime::kLoadKeyedFromSuper);
|
| }
|
|
|
|
|
| @@ -2257,7 +2257,7 @@ void FullCodeGenerator::EmitClassDefineProperties(ClassLiteral* lit) {
|
| // need to check for an own read only property we special case this so we do
|
| // not need to do this for every property.
|
| if (property->is_static() && property->is_computed_name()) {
|
| - __ CallRuntime(Runtime::kThrowIfStaticPrototype, 1);
|
| + __ CallRuntime(Runtime::kThrowIfStaticPrototype);
|
| __ Push(rax);
|
| }
|
|
|
| @@ -2272,17 +2272,17 @@ void FullCodeGenerator::EmitClassDefineProperties(ClassLiteral* lit) {
|
| case ObjectLiteral::Property::PROTOTYPE:
|
| UNREACHABLE();
|
| case ObjectLiteral::Property::COMPUTED:
|
| - __ CallRuntime(Runtime::kDefineClassMethod, 3);
|
| + __ CallRuntime(Runtime::kDefineClassMethod);
|
| break;
|
|
|
| case ObjectLiteral::Property::GETTER:
|
| __ Push(Smi::FromInt(DONT_ENUM));
|
| - __ CallRuntime(Runtime::kDefineGetterPropertyUnchecked, 4);
|
| + __ CallRuntime(Runtime::kDefineGetterPropertyUnchecked);
|
| break;
|
|
|
| case ObjectLiteral::Property::SETTER:
|
| __ Push(Smi::FromInt(DONT_ENUM));
|
| - __ CallRuntime(Runtime::kDefineSetterPropertyUnchecked, 4);
|
| + __ CallRuntime(Runtime::kDefineSetterPropertyUnchecked);
|
| break;
|
|
|
| default:
|
| @@ -2292,7 +2292,7 @@ void FullCodeGenerator::EmitClassDefineProperties(ClassLiteral* lit) {
|
|
|
| // Set both the prototype and constructor to have fast properties, and also
|
| // freeze them in strong mode.
|
| - __ CallRuntime(Runtime::kFinalizeClassDefinition, 2);
|
| + __ CallRuntime(Runtime::kFinalizeClassDefinition);
|
| }
|
|
|
|
|
| @@ -2417,7 +2417,7 @@ void FullCodeGenerator::EmitVariableAssignment(Variable* var, Token::Value op,
|
| __ CompareRoot(rdx, Heap::kTheHoleValueRootIndex);
|
| __ j(not_equal, &assign, Label::kNear);
|
| __ Push(var->name());
|
| - __ CallRuntime(Runtime::kThrowReferenceError, 1);
|
| + __ CallRuntime(Runtime::kThrowReferenceError);
|
| __ bind(&assign);
|
| EmitStoreToStackLocalOrContextSlot(var, location);
|
|
|
| @@ -2431,9 +2431,9 @@ void FullCodeGenerator::EmitVariableAssignment(Variable* var, Token::Value op,
|
| __ CompareRoot(rdx, Heap::kTheHoleValueRootIndex);
|
| __ j(not_equal, &const_error, Label::kNear);
|
| __ Push(var->name());
|
| - __ CallRuntime(Runtime::kThrowReferenceError, 1);
|
| + __ CallRuntime(Runtime::kThrowReferenceError);
|
| __ bind(&const_error);
|
| - __ CallRuntime(Runtime::kThrowConstAssignError, 0);
|
| + __ CallRuntime(Runtime::kThrowConstAssignError);
|
|
|
| } else if (var->is_this() && var->mode() == CONST && op == Token::INIT) {
|
| // Initializing assignment to const {this} needs a write barrier.
|
| @@ -2444,7 +2444,7 @@ void FullCodeGenerator::EmitVariableAssignment(Variable* var, Token::Value op,
|
| __ CompareRoot(rdx, Heap::kTheHoleValueRootIndex);
|
| __ j(equal, &uninitialized_this);
|
| __ Push(var->name());
|
| - __ CallRuntime(Runtime::kThrowReferenceError, 1);
|
| + __ CallRuntime(Runtime::kThrowReferenceError);
|
| __ bind(&uninitialized_this);
|
| EmitStoreToStackLocalOrContextSlot(var, location);
|
|
|
| @@ -2456,7 +2456,7 @@ void FullCodeGenerator::EmitVariableAssignment(Variable* var, Token::Value op,
|
| __ Push(rsi); // Context.
|
| __ Push(var->name());
|
| __ Push(Smi::FromInt(language_mode()));
|
| - __ CallRuntime(Runtime::kStoreLookupSlot, 4);
|
| + __ CallRuntime(Runtime::kStoreLookupSlot);
|
| } else {
|
| // Assignment to var or initializing assignment to let/const in harmony
|
| // mode.
|
| @@ -2478,7 +2478,7 @@ void FullCodeGenerator::EmitVariableAssignment(Variable* var, Token::Value op,
|
| __ Push(rax);
|
| __ Push(rsi);
|
| __ Push(var->name());
|
| - __ CallRuntime(Runtime::kInitializeLegacyConstLookupSlot, 3);
|
| + __ CallRuntime(Runtime::kInitializeLegacyConstLookupSlot);
|
| } else {
|
| DCHECK(var->IsStackLocal() || var->IsContextSlot());
|
| Label skip;
|
| @@ -2493,7 +2493,7 @@ void FullCodeGenerator::EmitVariableAssignment(Variable* var, Token::Value op,
|
| } else {
|
| DCHECK(var->mode() == CONST_LEGACY && op != Token::INIT);
|
| if (is_strict(language_mode())) {
|
| - __ CallRuntime(Runtime::kThrowConstAssignError, 0);
|
| + __ CallRuntime(Runtime::kThrowConstAssignError);
|
| }
|
| // Silently ignore store in sloppy mode.
|
| }
|
| @@ -2527,8 +2527,7 @@ void FullCodeGenerator::EmitNamedSuperPropertyStore(Property* prop) {
|
| __ Push(key->value());
|
| __ Push(rax);
|
| __ CallRuntime((is_strict(language_mode()) ? Runtime::kStoreToSuper_Strict
|
| - : Runtime::kStoreToSuper_Sloppy),
|
| - 4);
|
| + : Runtime::kStoreToSuper_Sloppy));
|
| }
|
|
|
|
|
| @@ -2539,10 +2538,9 @@ void FullCodeGenerator::EmitKeyedSuperPropertyStore(Property* prop) {
|
| DCHECK(prop != NULL);
|
|
|
| __ Push(rax);
|
| - __ CallRuntime(
|
| - (is_strict(language_mode()) ? Runtime::kStoreKeyedToSuper_Strict
|
| - : Runtime::kStoreKeyedToSuper_Sloppy),
|
| - 4);
|
| + __ CallRuntime((is_strict(language_mode())
|
| + ? Runtime::kStoreKeyedToSuper_Strict
|
| + : Runtime::kStoreKeyedToSuper_Sloppy));
|
| }
|
|
|
|
|
| @@ -2664,7 +2662,7 @@ void FullCodeGenerator::EmitSuperCallWithLoadIC(Call* expr) {
|
| // - home_object
|
| // - key
|
| // - language_mode
|
| - __ CallRuntime(Runtime::kLoadFromSuper, 4);
|
| + __ CallRuntime(Runtime::kLoadFromSuper);
|
|
|
| // Replace home_object with target function.
|
| __ movp(Operand(rsp, kPointerSize), rax);
|
| @@ -2723,7 +2721,7 @@ void FullCodeGenerator::EmitKeyedSuperCallWithLoadIC(Call* expr) {
|
| // - home_object
|
| // - key
|
| // - language_mode
|
| - __ CallRuntime(Runtime::kLoadKeyedFromSuper, 4);
|
| + __ CallRuntime(Runtime::kLoadKeyedFromSuper);
|
|
|
| // Replace home_object with target function.
|
| __ movp(Operand(rsp, kPointerSize), rax);
|
| @@ -2779,7 +2777,7 @@ void FullCodeGenerator::EmitResolvePossiblyDirectEval(int arg_count) {
|
| __ Push(Smi::FromInt(scope()->start_position()));
|
|
|
| // Do the runtime call.
|
| - __ CallRuntime(Runtime::kResolvePossiblyDirectEval, 5);
|
| + __ CallRuntime(Runtime::kResolvePossiblyDirectEval);
|
| }
|
|
|
|
|
| @@ -2797,7 +2795,7 @@ void FullCodeGenerator::PushCalleeAndWithBaseObject(Call* expr) {
|
| // the object holding it (returned in rdx).
|
| __ Push(context_register());
|
| __ Push(callee->name());
|
| - __ CallRuntime(Runtime::kLoadLookupSlot, 2);
|
| + __ CallRuntime(Runtime::kLoadLookupSlot);
|
| __ Push(rax); // Function.
|
| __ Push(rdx); // Receiver.
|
| PrepareForBailoutForId(expr->LookupId(), NO_REGISTERS);
|
| @@ -3446,7 +3444,7 @@ void FullCodeGenerator::EmitToInteger(CallRuntime* expr) {
|
| Label done_convert;
|
| __ JumpIfSmi(rax, &done_convert, Label::kNear);
|
| __ Push(rax);
|
| - __ CallRuntime(Runtime::kToInteger, 1);
|
| + __ CallRuntime(Runtime::kToInteger);
|
| __ bind(&done_convert);
|
| context()->Plug(rax);
|
| }
|
| @@ -3467,7 +3465,7 @@ void FullCodeGenerator::EmitToName(CallRuntime* expr) {
|
| __ j(below_equal, &done_convert, Label::kNear);
|
| __ bind(&convert);
|
| __ Push(rax);
|
| - __ CallRuntime(Runtime::kToName, 1);
|
| + __ CallRuntime(Runtime::kToName);
|
| __ bind(&done_convert);
|
| context()->Plug(rax);
|
| }
|
| @@ -3977,7 +3975,7 @@ void FullCodeGenerator::EmitCreateIterResultObject(CallRuntime* expr) {
|
| __ jmp(&done, Label::kNear);
|
|
|
| __ bind(&runtime);
|
| - __ CallRuntime(Runtime::kCreateIterResultObject, 2);
|
| + __ CallRuntime(Runtime::kCreateIterResultObject);
|
|
|
| __ bind(&done);
|
| context()->Plug(rax);
|
| @@ -4068,8 +4066,7 @@ void FullCodeGenerator::VisitUnaryOperation(UnaryOperation* expr) {
|
| VisitForStackValue(property->key());
|
| __ CallRuntime(is_strict(language_mode())
|
| ? Runtime::kDeleteProperty_Strict
|
| - : Runtime::kDeleteProperty_Sloppy,
|
| - 2);
|
| + : Runtime::kDeleteProperty_Sloppy);
|
| context()->Plug(rax);
|
| } else if (proxy != NULL) {
|
| Variable* var = proxy->var();
|
| @@ -4081,7 +4078,7 @@ void FullCodeGenerator::VisitUnaryOperation(UnaryOperation* expr) {
|
| __ movp(rax, NativeContextOperand());
|
| __ Push(ContextOperand(rax, Context::EXTENSION_INDEX));
|
| __ Push(var->name());
|
| - __ CallRuntime(Runtime::kDeleteProperty_Sloppy, 2);
|
| + __ CallRuntime(Runtime::kDeleteProperty_Sloppy);
|
| context()->Plug(rax);
|
| } else if (var->IsStackAllocated() || var->IsContextSlot()) {
|
| // Result of deleting non-global variables is false. 'this' is
|
| @@ -4093,7 +4090,7 @@ void FullCodeGenerator::VisitUnaryOperation(UnaryOperation* expr) {
|
| // context where the variable was introduced.
|
| __ Push(context_register());
|
| __ Push(var->name());
|
| - __ CallRuntime(Runtime::kDeleteLookupSlot, 2);
|
| + __ CallRuntime(Runtime::kDeleteLookupSlot);
|
| context()->Plug(rax);
|
| }
|
| } else {
|
| @@ -4528,7 +4525,7 @@ void FullCodeGenerator::VisitCompareOperation(CompareOperation* expr) {
|
| switch (op) {
|
| case Token::IN:
|
| VisitForStackValue(expr->right());
|
| - __ CallRuntime(Runtime::kHasProperty, 2);
|
| + __ CallRuntime(Runtime::kHasProperty);
|
| PrepareForBailoutBeforeSplit(expr, false, NULL, NULL);
|
| __ CompareRoot(rax, Heap::kTrueValueRootIndex);
|
| Split(equal, if_true, if_false, fall_through);
|
|
|