Index: src/crankshaft/ppc/lithium-ppc.cc |
diff --git a/src/crankshaft/ppc/lithium-ppc.cc b/src/crankshaft/ppc/lithium-ppc.cc |
index b38982a18b3ad30f911e7d774d3341c66431977e..bb134820ff5b619ceda39249edded680474003cb 100644 |
--- a/src/crankshaft/ppc/lithium-ppc.cc |
+++ b/src/crankshaft/ppc/lithium-ppc.cc |
@@ -2150,14 +2150,16 @@ LInstruction* LChunkBuilder::DoLoadKeyed(HLoadKeyed* instr) { |
} else { |
obj = UseRegisterAtStart(instr->elements()); |
} |
- result = DefineAsRegister(new (zone()) LLoadKeyed(obj, key)); |
+ result = DefineAsRegister(new (zone()) LLoadKeyed(obj, key, nullptr)); |
} else { |
DCHECK((instr->representation().IsInteger32() && |
!IsDoubleOrFloatElementsKind(elements_kind)) || |
(instr->representation().IsDouble() && |
IsDoubleOrFloatElementsKind(elements_kind))); |
LOperand* backing_store = UseRegister(instr->elements()); |
- result = DefineAsRegister(new (zone()) LLoadKeyed(backing_store, key)); |
+ LOperand* backing_store_owner = UseAny(instr->backing_store_owner()); |
+ result = DefineAsRegister( |
+ new (zone()) LLoadKeyed(backing_store, key, backing_store_owner)); |
} |
bool needs_environment; |
@@ -2220,7 +2222,7 @@ LInstruction* LChunkBuilder::DoStoreKeyed(HStoreKeyed* instr) { |
} |
} |
- return new (zone()) LStoreKeyed(object, key, val); |
+ return new (zone()) LStoreKeyed(object, key, val, nullptr); |
} |
DCHECK((instr->value()->representation().IsInteger32() && |
@@ -2231,7 +2233,8 @@ LInstruction* LChunkBuilder::DoStoreKeyed(HStoreKeyed* instr) { |
LOperand* val = UseRegister(instr->value()); |
LOperand* key = UseRegisterOrConstantAtStart(instr->key()); |
LOperand* backing_store = UseRegister(instr->elements()); |
- return new (zone()) LStoreKeyed(backing_store, key, val); |
+ LOperand* backing_store_owner = UseAny(instr->backing_store_owner()); |
+ return new (zone()) LStoreKeyed(backing_store, key, val, backing_store_owner); |
} |