| Index: src/mips/stub-cache-mips.cc | 
| diff --git a/src/mips/stub-cache-mips.cc b/src/mips/stub-cache-mips.cc | 
| index 2cd61f98c66e194712b68c0e86d85f8700a71068..59dc9051328c4c0adc5972dde191b221e8bbc850 100644 | 
| --- a/src/mips/stub-cache-mips.cc | 
| +++ b/src/mips/stub-cache-mips.cc | 
| @@ -415,13 +415,24 @@ void StoreStubCompiler::GenerateStoreTransition(MacroAssembler* masm, | 
| } else if (representation.IsSmi()) { | 
| __ JumpIfNotSmi(value_reg, miss_label); | 
| } else if (representation.IsHeapObject()) { | 
| +    __ JumpIfSmi(value_reg, miss_label); | 
| HeapType* field_type = descriptors->GetFieldType(descriptor); | 
| -    if (field_type->IsClass()) { | 
| -      __ CheckMap(value_reg, scratch1, field_type->AsClass()->Map(), | 
| -                  miss_label, DO_SMI_CHECK); | 
| -    } else { | 
| -      ASSERT(HeapType::Any()->Is(field_type)); | 
| -      __ JumpIfSmi(value_reg, miss_label); | 
| +    HeapType::Iterator<Map> it = field_type->Classes(); | 
| +    Handle<Map> current; | 
| +    if (!it.Done()) { | 
| +      __ lw(scratch1, FieldMemOperand(value_reg, HeapObject::kMapOffset)); | 
| +      Label do_store; | 
| +      while (true) { | 
| +        // Do the CompareMap() directly within the Branch() functions. | 
| +        current = it.Current(); | 
| +        it.Advance(); | 
| +        if (it.Done()) { | 
| +          __ Branch(miss_label, ne, scratch1, Operand(current)); | 
| +          break; | 
| +        } | 
| +        __ Branch(&do_store, eq, scratch1, Operand(current)); | 
| +      } | 
| +      __ bind(&do_store); | 
| } | 
| } else if (representation.IsDouble()) { | 
| Label do_store, heap_number; | 
| @@ -585,13 +596,24 @@ void StoreStubCompiler::GenerateStoreField(MacroAssembler* masm, | 
| if (representation.IsSmi()) { | 
| __ JumpIfNotSmi(value_reg, miss_label); | 
| } else if (representation.IsHeapObject()) { | 
| +    __ JumpIfSmi(value_reg, miss_label); | 
| HeapType* field_type = lookup->GetFieldType(); | 
| -    if (field_type->IsClass()) { | 
| -      __ CheckMap(value_reg, scratch1, field_type->AsClass()->Map(), | 
| -                  miss_label, DO_SMI_CHECK); | 
| -    } else { | 
| -      ASSERT(HeapType::Any()->Is(field_type)); | 
| -      __ JumpIfSmi(value_reg, miss_label); | 
| +    HeapType::Iterator<Map> it = field_type->Classes(); | 
| +    if (!it.Done()) { | 
| +      __ lw(scratch1, FieldMemOperand(value_reg, HeapObject::kMapOffset)); | 
| +      Label do_store; | 
| +      Handle<Map> current; | 
| +      while (true) { | 
| +        // Do the CompareMap() directly within the Branch() functions. | 
| +        current = it.Current(); | 
| +        it.Advance(); | 
| +        if (it.Done()) { | 
| +          __ Branch(miss_label, ne, scratch1, Operand(current)); | 
| +          break; | 
| +        } | 
| +        __ Branch(&do_store, eq, scratch1, Operand(current)); | 
| +      } | 
| +      __ bind(&do_store); | 
| } | 
| } else if (representation.IsDouble()) { | 
| // Load the double storage. | 
|  |