| Index: src/compiler/mips/instruction-selector-mips.cc | 
| diff --git a/src/compiler/mips/instruction-selector-mips.cc b/src/compiler/mips/instruction-selector-mips.cc | 
| index 4ee81a7486804efe72692542a32776562f997aaf..afa56da5a7424a0b366233aaac5def84087a9e4a 100644 | 
| --- a/src/compiler/mips/instruction-selector-mips.cc | 
| +++ b/src/compiler/mips/instruction-selector-mips.cc | 
| @@ -483,6 +483,75 @@ void InstructionSelector::VisitCall(Node* node) { | 
| } | 
|  | 
|  | 
| +void InstructionSelector::VisitCheckedLoad(Node* node) { | 
| +  MachineType rep = RepresentationOf(OpParameter<MachineType>(node)); | 
| +  MachineType typ = TypeOf(OpParameter<MachineType>(node)); | 
| +  MipsOperandGenerator g(this); | 
| +  Node* const buffer = node->InputAt(0); | 
| +  Node* const offset = node->InputAt(1); | 
| +  Node* const length = node->InputAt(2); | 
| +  ArchOpcode opcode; | 
| +  switch (rep) { | 
| +    case kRepWord8: | 
| +      opcode = typ == kTypeInt32 ? kCheckedLoadInt8 : kCheckedLoadUint8; | 
| +      break; | 
| +    case kRepWord16: | 
| +      opcode = typ == kTypeInt32 ? kCheckedLoadInt16 : kCheckedLoadUint16; | 
| +      break; | 
| +    case kRepWord32: | 
| +      opcode = kCheckedLoadWord32; | 
| +      break; | 
| +    case kRepFloat32: | 
| +      opcode = kCheckedLoadFloat32; | 
| +      break; | 
| +    case kRepFloat64: | 
| +      opcode = kCheckedLoadFloat64; | 
| +      break; | 
| +    default: | 
| +      UNREACHABLE(); | 
| +      return; | 
| +  } | 
| +  InstructionOperand* offset_operand = g.UseRegister(offset); | 
| +  Emit(opcode | AddressingModeField::encode(kMode_MRI), | 
| +       g.DefineAsRegister(node), offset_operand, g.UseRegister(length), | 
| +       g.UseRegister(buffer)); | 
| +} | 
| + | 
| + | 
| +void InstructionSelector::VisitCheckedStore(Node* node) { | 
| +  MachineType rep = RepresentationOf(OpParameter<MachineType>(node)); | 
| +  MipsOperandGenerator g(this); | 
| +  Node* const buffer = node->InputAt(0); | 
| +  Node* const offset = node->InputAt(1); | 
| +  Node* const length = node->InputAt(2); | 
| +  Node* const value = node->InputAt(3); | 
| +  ArchOpcode opcode; | 
| +  switch (rep) { | 
| +    case kRepWord8: | 
| +      opcode = kCheckedStoreWord8; | 
| +      break; | 
| +    case kRepWord16: | 
| +      opcode = kCheckedStoreWord16; | 
| +      break; | 
| +    case kRepWord32: | 
| +      opcode = kCheckedStoreWord32; | 
| +      break; | 
| +    case kRepFloat32: | 
| +      opcode = kCheckedStoreFloat32; | 
| +      break; | 
| +    case kRepFloat64: | 
| +      opcode = kCheckedStoreFloat64; | 
| +      break; | 
| +    default: | 
| +      UNREACHABLE(); | 
| +      return; | 
| +  } | 
| +  InstructionOperand* offset_operand = g.UseRegister(offset); | 
| +  Emit(opcode | AddressingModeField::encode(kMode_MRI), nullptr, offset_operand, | 
| +       g.UseRegister(length), g.UseRegister(value), g.UseRegister(buffer)); | 
| +} | 
| + | 
| + | 
| namespace { | 
|  | 
| // Shared routine for multiple compare operations. | 
|  |