Index: src/ic/mips/ic-compiler-mips.cc |
diff --git a/src/ic/mips/ic-compiler-mips.cc b/src/ic/mips/ic-compiler-mips.cc |
index 2ff7f897a556a04e482b5e4563de08eb4fb82e30..179531235d7aa09c4efe92139ade737efe6b99a8 100644 |
--- a/src/ic/mips/ic-compiler-mips.cc |
+++ b/src/ic/mips/ic-compiler-mips.cc |
@@ -15,7 +15,7 @@ namespace internal { |
#define __ ACCESS_MASM(masm()) |
-Handle<Code> PropertyICCompiler::CompilePolymorphic(TypeHandleList* types, |
+Handle<Code> PropertyICCompiler::CompilePolymorphic(MapHandleList* maps, |
CodeHandleList* handlers, |
Handle<Name> name, |
Code::StubType type, |
@@ -42,7 +42,7 @@ Handle<Code> PropertyICCompiler::CompilePolymorphic(TypeHandleList* types, |
Label number_case; |
Register match = scratch2(); |
- Label* smi_target = IncludesNumberType(types) ? &number_case : &miss; |
+ Label* smi_target = IncludesNumberMap(maps) ? &number_case : &miss; |
__ JumpIfSmi(receiver(), smi_target, match); // Reg match is 0 if Smi. |
// Polymorphic keyed stores may use the map register |
@@ -50,12 +50,11 @@ Handle<Code> PropertyICCompiler::CompilePolymorphic(TypeHandleList* types, |
DCHECK(kind() != Code::KEYED_STORE_IC || |
map_reg.is(ElementTransitionAndStoreDescriptor::MapRegister())); |
- int receiver_count = types->length(); |
+ int receiver_count = maps->length(); |
int number_of_handled_maps = 0; |
__ lw(map_reg, FieldMemOperand(receiver(), HeapObject::kMapOffset)); |
for (int current = 0; current < receiver_count; ++current) { |
- Handle<HeapType> type = types->at(current); |
- Handle<Map> map = IC::TypeToMap(*type, isolate()); |
+ Handle<Map> map = maps->at(current); |
if (!map->is_deprecated()) { |
number_of_handled_maps++; |
// Check map and tail call if there's a match. |
@@ -63,7 +62,7 @@ Handle<Code> PropertyICCompiler::CompilePolymorphic(TypeHandleList* types, |
Handle<WeakCell> cell = Map::WeakCellForMap(map); |
__ GetWeakValue(match, cell); |
__ Subu(match, match, Operand(map_reg)); |
- if (type->Is(HeapType::Number())) { |
+ if (map->instance_type() == HEAP_NUMBER_TYPE) { |
DCHECK(!number_case.is_unused()); |
__ bind(&number_case); |
} |