| Index: src/ic/arm64/handler-compiler-arm64.cc
|
| diff --git a/src/ic/arm64/handler-compiler-arm64.cc b/src/ic/arm64/handler-compiler-arm64.cc
|
| index 9e1b55b82c1d137e8516f65fada5678a78533702..1f097e8ed85f7d9392dc411adb7686198afd2b62 100644
|
| --- a/src/ic/arm64/handler-compiler-arm64.cc
|
| +++ b/src/ic/arm64/handler-compiler-arm64.cc
|
| @@ -370,10 +370,22 @@ void NamedStoreHandlerCompiler::GenerateRestoreName(Label* label,
|
| }
|
|
|
|
|
| -void NamedStoreHandlerCompiler::GenerateRestoreNameAndMap(
|
| - Handle<Name> name, Handle<Map> transition) {
|
| +void NamedStoreHandlerCompiler::GenerateRestoreName(Handle<Name> name) {
|
| __ Mov(this->name(), Operand(name));
|
| - __ Mov(StoreTransitionDescriptor::MapRegister(), Operand(transition));
|
| +}
|
| +
|
| +
|
| +void NamedStoreHandlerCompiler::GenerateRestoreMap(Handle<Map> transition,
|
| + Register scratch,
|
| + Label* miss) {
|
| + Handle<WeakCell> cell = Map::WeakCellForMap(transition);
|
| + Register map_reg = StoreTransitionDescriptor::MapRegister();
|
| + DCHECK(!map_reg.is(scratch));
|
| + __ LoadWeakValue(map_reg, cell, miss);
|
| + if (transition->CanBeDeprecated()) {
|
| + __ Ldrsw(scratch, FieldMemOperand(map_reg, Map::kBitField3Offset));
|
| + __ TestAndBranchIfAnySet(scratch, Map::Deprecated::kMask, miss);
|
| + }
|
| }
|
|
|
|
|
|
|