Index: src/arm/stub-cache-arm.cc |
diff --git a/src/arm/stub-cache-arm.cc b/src/arm/stub-cache-arm.cc |
index 3994aa0fdf946a7e2a8329bf38c862a1ef05f0ee..fefd4622ba808d979d380548f64042523433688b 100644 |
--- a/src/arm/stub-cache-arm.cc |
+++ b/src/arm/stub-cache-arm.cc |
@@ -3054,7 +3054,20 @@ Handle<Code> BaseLoadStoreStubCompiler::CompilePolymorphicIC( |
GenerateNameCheck(name, this->name(), &miss); |
} |
- __ JumpIfSmi(receiver(), &miss); |
+ Label number_case; |
+ Label* smi_handler = &miss; |
+ for (int i = 0; i < receiver_maps->length(); ++i) { |
+ Handle<Map> map = receiver_maps->at(i); |
+ if (map.is_identical_to(isolate()->factory()->heap_number_map())) { |
+ // Do not jump to the handler directly to ensure maps / handlers are still |
+ // in sync so updating a polymorphic IC can gather maps / handlers in |
+ // sequence. |
+ smi_handler = &number_case; |
+ break; |
+ } |
+ } |
+ __ JumpIfSmi(receiver(), smi_handler); |
+ |
Register map_reg = scratch1(); |
int receiver_count = receiver_maps->length(); |
@@ -3066,6 +3079,10 @@ Handle<Code> BaseLoadStoreStubCompiler::CompilePolymorphicIC( |
number_of_handled_maps++; |
__ mov(ip, Operand(receiver_maps->at(current))); |
__ cmp(map_reg, ip); |
+ if (map.is_identical_to(isolate()->factory()->heap_number_map())) { |
+ ASSERT(!number_case.is_unused()); |
+ __ bind(&number_case); |
+ } |
__ Jump(handlers->at(current), RelocInfo::CODE_TARGET, eq); |
} |
} |