Index: src/ia32/code-stubs-ia32.cc |
diff --git a/src/ia32/code-stubs-ia32.cc b/src/ia32/code-stubs-ia32.cc |
index a5968485141cb4e37977506a9fa7b96fbb5aeda0..30ad408886d3a6da21d5d68447ace36c8cae3daf 100644 |
--- a/src/ia32/code-stubs-ia32.cc |
+++ b/src/ia32/code-stubs-ia32.cc |
@@ -5119,7 +5119,6 @@ void InternalArrayConstructorStub::Generate(MacroAssembler* masm) { |
void LoadGlobalViaContextStub::Generate(MacroAssembler* masm) { |
Register context_reg = esi; |
Register slot_reg = ebx; |
- Register name_reg = ecx; |
Register result_reg = eax; |
Label slow_case; |
@@ -5143,25 +5142,23 @@ void LoadGlobalViaContextStub::Generate(MacroAssembler* masm) { |
__ SmiTag(slot_reg); |
__ Pop(result_reg); // Pop return address. |
__ Push(slot_reg); |
- __ Push(name_reg); |
__ Push(result_reg); // Push return address. |
- __ TailCallRuntime(Runtime::kLoadGlobalViaContext, 2, 1); |
+ __ TailCallRuntime(Runtime::kLoadGlobalViaContext, 1, 1); |
} |
void StoreGlobalViaContextStub::Generate(MacroAssembler* masm) { |
Register context_reg = esi; |
Register slot_reg = ebx; |
- Register name_reg = ecx; |
Register value_reg = eax; |
Register cell_reg = edi; |
Register cell_details_reg = edx; |
+ Register cell_value_reg = ecx; |
Label fast_heapobject_case, fast_smi_case, slow_case; |
if (FLAG_debug_code) { |
__ CompareRoot(value_reg, Heap::kTheHoleValueRootIndex); |
__ Check(not_equal, kUnexpectedValue); |
- __ AssertName(name_reg); |
} |
// Go up context chain to the script context. |
@@ -5175,8 +5172,6 @@ void StoreGlobalViaContextStub::Generate(MacroAssembler* masm) { |
// Check that cell value is not the_hole. |
{ |
- // TODO(bmeurer): use ecx (name_reg) when name parameter is removed. |
- Register cell_value_reg = cell_details_reg; |
__ mov(cell_value_reg, FieldOperand(cell_reg, PropertyCell::kValueOffset)); |
__ CompareRoot(cell_value_reg, Heap::kTheHoleValueRootIndex); |
__ j(equal, &slow_case, FLAG_debug_code ? Label::kFar : Label::kNear); |
@@ -5249,8 +5244,6 @@ void StoreGlobalViaContextStub::Generate(MacroAssembler* masm) { |
// Now either both old and new values must be SMIs or both must be heap |
// objects with same map. |
Label value_is_heap_object; |
- // TODO(bmeurer): use ecx (name_reg) when name parameter is removed. |
- Register cell_value_reg = cell_details_reg; |
__ mov(cell_value_reg, FieldOperand(cell_reg, PropertyCell::kValueOffset)); |
__ JumpIfNotSmi(value_reg, &value_is_heap_object, Label::kNear); |
__ JumpIfNotSmi(cell_value_reg, &slow_case, Label::kNear); |
@@ -5271,13 +5264,12 @@ void StoreGlobalViaContextStub::Generate(MacroAssembler* masm) { |
__ SmiTag(slot_reg); |
__ Pop(cell_reg); // Pop return address. |
__ Push(slot_reg); |
- __ Push(name_reg); |
__ Push(value_reg); |
__ Push(cell_reg); // Push return address. |
__ TailCallRuntime(is_strict(language_mode()) |
? Runtime::kStoreGlobalViaContext_Strict |
: Runtime::kStoreGlobalViaContext_Sloppy, |
- 3, 1); |
+ 2, 1); |
} |