Index: src/arm64/macro-assembler-arm64.cc |
diff --git a/src/arm64/macro-assembler-arm64.cc b/src/arm64/macro-assembler-arm64.cc |
index 8b559755a0bdde64d32145e3e493791205a23e3a..0289efe5623158b35c90dba7a776f2af052b7ecd 100644 |
--- a/src/arm64/macro-assembler-arm64.cc |
+++ b/src/arm64/macro-assembler-arm64.cc |
@@ -3705,6 +3705,19 @@ void MacroAssembler::LoadElementsKindFromMap(Register result, Register map) { |
} |
+void MacroAssembler::GetMapConstructor(Register result, Register map, |
+ Register temp, Register temp2) { |
+ Label done, loop; |
+ Ldr(result, FieldMemOperand(map, Map::kConstructorOrBackPointerOffset)); |
+ Bind(&loop); |
+ CompareObjectType(result, temp, temp2, MAP_TYPE); |
+ B(ne, &done); |
+ Ldr(result, FieldMemOperand(result, Map::kConstructorOrBackPointerOffset)); |
+ B(&loop); |
+ Bind(&done); |
+} |
+ |
+ |
void MacroAssembler::TryGetFunctionPrototype(Register function, |
Register result, |
Register scratch, |
@@ -3756,7 +3769,7 @@ void MacroAssembler::TryGetFunctionPrototype(Register function, |
// Non-instance prototype: fetch prototype from constructor field in initial |
// map. |
Bind(&non_instance); |
- Ldr(result, FieldMemOperand(result, Map::kConstructorOffset)); |
+ Ldr(result, FieldMemOperand(result, Map::kConstructorOrBackPointerOffset)); |
} |
// All done. |