Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(113)

Unified Diff: src/arm/lithium-arm.cc

Issue 324093002: ARM/ARM64: Optimise HLoadNamedField and HStoreNamedField. Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
Patch Set: Upload the correct patch (minor diff in hydrogen.h) Created 6 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: src/arm/lithium-arm.cc
diff --git a/src/arm/lithium-arm.cc b/src/arm/lithium-arm.cc
index 93dc830dab30e3630bac62966133e5c35f3e8843..323c1a3680983b70226d330808595156a60e3d61 100644
--- a/src/arm/lithium-arm.cc
+++ b/src/arm/lithium-arm.cc
@@ -2132,7 +2132,10 @@ LInstruction* LChunkBuilder::DoStoreContextSlot(HStoreContextSlot* instr) {
LInstruction* LChunkBuilder::DoLoadNamedField(HLoadNamedField* instr) {
LOperand* obj = UseRegisterAtStart(instr->object());
- return DefineAsRegister(new(zone()) LLoadNamedField(obj));
+ HValue* h_obj_properties = instr->object_properties();
+ LOperand* obj_properties =
+ (h_obj_properties != NULL) ? UseRegisterAtStart(h_obj_properties) : NULL;
+ return DefineAsRegister(new(zone()) LLoadNamedField(obj, obj_properties));
}
@@ -2323,7 +2326,11 @@ LInstruction* LChunkBuilder::DoStoreNamedField(HStoreNamedField* instr) {
// We need a temporary register for write barrier of the map field.
LOperand* temp = needs_write_barrier_for_map ? TempRegister() : NULL;
- return new(zone()) LStoreNamedField(obj, val, temp);
+ HValue* h_obj_properties = instr->object_properties();
+ LOperand* obj_properties =
+ (h_obj_properties != NULL) ? UseRegister(h_obj_properties) : NULL;
+
+ return new(zone()) LStoreNamedField(obj, val, temp, obj_properties);
}

Powered by Google App Engine
This is Rietveld 408576698