| Index: src/mips/code-stubs-mips.cc | 
| diff --git a/src/mips/code-stubs-mips.cc b/src/mips/code-stubs-mips.cc | 
| index 91203c6b65ad7dd0ff0fc5164b7d8398faaaf955..feba6eb53d9215e02535e21440e2736cc04a320f 100644 | 
| --- a/src/mips/code-stubs-mips.cc | 
| +++ b/src/mips/code-stubs-mips.cc | 
| @@ -7138,6 +7138,60 @@ void ICCompareStub::GenerateInternalizedStrings(MacroAssembler* masm) { | 
| } | 
|  | 
|  | 
| +void ICCompareStub::GenerateUniqueNames(MacroAssembler* masm) { | 
| +  ASSERT(state_ == CompareIC::UNIQUE_NAME); | 
| +  ASSERT(GetCondition() == eq); | 
| +  Label miss; | 
| + | 
| +  // Registers containing left and right operands respectively. | 
| +  Register left = a1; | 
| +  Register right = a0; | 
| +  Register tmp1 = a2; | 
| +  Register tmp2 = a3; | 
| + | 
| +  // Check that both operands are heap objects. | 
| +  __ JumpIfEitherSmi(left, right, &miss); | 
| + | 
| +  // Check that both operands are unique names. This leaves the instance | 
| +  // types loaded in tmp1 and tmp2. | 
| +  STATIC_ASSERT(kInternalizedTag != 0); | 
| +  __ lw(tmp1, FieldMemOperand(left, HeapObject::kMapOffset)); | 
| +  __ lw(tmp2, FieldMemOperand(right, HeapObject::kMapOffset)); | 
| +  __ lbu(tmp1, FieldMemOperand(tmp1, Map::kInstanceTypeOffset)); | 
| +  __ lbu(tmp2, FieldMemOperand(tmp2, Map::kInstanceTypeOffset)); | 
| + | 
| +  Label succeed1; | 
| +  __ And(at, tmp1, Operand(kIsInternalizedMask)); | 
| +  __ Branch(&succeed1, ne, at, Operand(zero_reg)); | 
| +  __ Branch(&miss, ne, tmp1, Operand(SYMBOL_TYPE)); | 
| +  __ bind(&succeed1); | 
| + | 
| +  Label succeed2; | 
| +  __ And(at, tmp2, Operand(kIsInternalizedMask)); | 
| +  __ Branch(&succeed2, ne, at, Operand(zero_reg)); | 
| +  __ Branch(&miss, ne, tmp2, Operand(SYMBOL_TYPE)); | 
| +  __ bind(&succeed2); | 
| + | 
| +  // Use a0 as result | 
| +  __ mov(v0, a0); | 
| + | 
| +  // Unique names are compared by identity. | 
| +  Label done; | 
| +  __ Branch(&done, ne, left, Operand(right)); | 
| +  // Make sure a0 is non-zero. At this point input operands are | 
| +  // guaranteed to be non-zero. | 
| +  ASSERT(right.is(a0)); | 
| +  STATIC_ASSERT(EQUAL == 0); | 
| +  STATIC_ASSERT(kSmiTag == 0); | 
| +  __ li(v0, Operand(Smi::FromInt(EQUAL))); | 
| +  __ bind(&done); | 
| +  __ Ret(); | 
| + | 
| +  __ bind(&miss); | 
| +  GenerateMiss(masm); | 
| +} | 
| + | 
| + | 
| void ICCompareStub::GenerateStrings(MacroAssembler* masm) { | 
| ASSERT(state_ == CompareIC::STRING); | 
| Label miss; | 
|  |