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

Unified Diff: runtime/vm/assembler_arm.cc

Issue 1409733009: ARM: Fix double use of IP when storing object fields with large offsets. (Closed) Base URL: git@github.com:dart-lang/sdk.git@master
Patch Set: Created 5 years, 1 month 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
« no previous file with comments | « runtime/vm/assembler_arm.h ('k') | no next file » | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: runtime/vm/assembler_arm.cc
diff --git a/runtime/vm/assembler_arm.cc b/runtime/vm/assembler_arm.cc
index 31824b1a8484a323c3a1130b7da93fba372e11c3..6c016c9c21f64efcf27fc0305de4ca087c769d34 100644
--- a/runtime/vm/assembler_arm.cc
+++ b/runtime/vm/assembler_arm.cc
@@ -1724,7 +1724,9 @@ void Assembler::WriteShadowedFieldPair(Register base,
Register UseRegister(Register reg, RegList* used) {
+ ASSERT(reg != THR);
ASSERT(reg != SP);
+ ASSERT(reg != FP);
ASSERT(reg != PC);
ASSERT((*used & (1 << reg)) == 0);
*used |= (1 << reg);
@@ -1740,7 +1742,8 @@ Register AllocateRegister(RegList* used) {
}
-void Assembler::VerifiedWrite(const Address& address,
+void Assembler::VerifiedWrite(Register object,
+ const Address& address,
Register new_value,
FieldContent old_content) {
#if defined(DEBUG)
@@ -1750,6 +1753,9 @@ void Assembler::VerifiedWrite(const Address& address,
RegList used = 0;
UseRegister(new_value, &used);
Register base = UseRegister(address.rn(), &used);
+ if ((object != base) && (object != kNoRegister)) {
Florian Schneider 2015/11/05 01:50:35 I guess not checking (object != base) would be ok,
+ UseRegister(object, &used);
+ }
if (address.rm() != kNoRegister) {
UseRegister(address.rm(), &used);
}
@@ -1818,7 +1824,7 @@ void Assembler::StoreIntoObject(Register object,
Register value,
bool can_value_be_smi) {
ASSERT(object != value);
- VerifiedWrite(dest, value, kHeapObjectOrSmi);
+ VerifiedWrite(object, dest, value, kHeapObjectOrSmi);
Label done;
if (can_value_be_smi) {
StoreIntoObjectFilter(object, value, &done);
@@ -1861,7 +1867,7 @@ void Assembler::StoreIntoObjectNoBarrier(Register object,
const Address& dest,
Register value,
FieldContent old_content) {
- VerifiedWrite(dest, value, old_content);
+ VerifiedWrite(object, dest, value, old_content);
#if defined(DEBUG)
Label done;
StoreIntoObjectFilter(object, value, &done);
@@ -1895,7 +1901,7 @@ void Assembler::StoreIntoObjectNoBarrier(Register object,
(value.IsOld() && value.IsNotTemporaryScopedHandle()));
// No store buffer update.
LoadObject(IP, value);
- VerifiedWrite(dest, IP, old_content);
+ VerifiedWrite(object, dest, IP, old_content);
}
@@ -1908,8 +1914,11 @@ void Assembler::StoreIntoObjectNoBarrierOffset(Register object,
StoreIntoObjectNoBarrier(object, FieldAddress(object, offset), value,
old_content);
} else {
- AddImmediate(IP, object, offset - kHeapObjectTag);
- StoreIntoObjectNoBarrier(object, Address(IP), value, old_content);
+ Register base = object == R9 ? R8 : R9;
+ Push(base);
+ AddImmediate(base, object, offset - kHeapObjectTag);
+ StoreIntoObjectNoBarrier(object, Address(base), value, old_content);
+ Pop(base);
}
}
@@ -1973,7 +1982,7 @@ void Assembler::StoreIntoSmiField(const Address& dest, Register value) {
Stop("New value must be Smi.");
Bind(&done);
#endif // defined(DEBUG)
- VerifiedWrite(dest, value, kOnlySmi);
+ VerifiedWrite(kNoRegister, dest, value, kOnlySmi);
}
« no previous file with comments | « runtime/vm/assembler_arm.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698