| Index: src/compiler/ia32/instruction-selector-ia32.cc | 
| diff --git a/src/compiler/ia32/instruction-selector-ia32.cc b/src/compiler/ia32/instruction-selector-ia32.cc | 
| index fcb0b484faa181c17e2d912ff78e74a692496ccc..24da91a0ee42d72afa96d2b7c74dd4be2f474722 100644 | 
| --- a/src/compiler/ia32/instruction-selector-ia32.cc | 
| +++ b/src/compiler/ia32/instruction-selector-ia32.cc | 
| @@ -1756,6 +1756,48 @@ void InstructionSelector::VisitAtomicExchange(Node* node) { | 
| Emit(code, 1, outputs, input_count, inputs); | 
| } | 
|  | 
| +void InstructionSelector::VisitAtomicCompareExchange(Node* node) { | 
| +  IA32OperandGenerator g(this); | 
| +  Node* base = node->InputAt(0); | 
| +  Node* index = node->InputAt(1); | 
| +  Node* old_value = node->InputAt(2); | 
| +  Node* new_value = node->InputAt(3); | 
| + | 
| +  MachineType type = AtomicCompareExchangeRepresentationOf(node->op()); | 
| +  ArchOpcode opcode = kArchNop; | 
| +  if (type == MachineType::Int8()) { | 
| +    opcode = kAtomicCompareExchangeInt8; | 
| +  } else if (type == MachineType::Uint8()) { | 
| +    opcode = kAtomicCompareExchangeUint8; | 
| +  } else if (type == MachineType::Int16()) { | 
| +    opcode = kAtomicCompareExchangeInt16; | 
| +  } else if (type == MachineType::Uint16()) { | 
| +    opcode = kAtomicCompareExchangeUint16; | 
| +  } else if (type == MachineType::Int32() || type == MachineType::Uint32()) { | 
| +    opcode = kAtomicCompareExchangeWord32; | 
| +  } else { | 
| +    UNREACHABLE(); | 
| +    return; | 
| +  } | 
| +  InstructionOperand outputs[1]; | 
| +  AddressingMode addressing_mode; | 
| +  InstructionOperand inputs[4]; | 
| +  size_t input_count = 0; | 
| +  inputs[input_count++] = g.UseFixed(old_value, eax); | 
| +  inputs[input_count++] = g.UseUniqueRegister(new_value); | 
| +  inputs[input_count++] = g.UseUniqueRegister(base); | 
| +  if (g.CanBeImmediate(index)) { | 
| +    inputs[input_count++] = g.UseImmediate(index); | 
| +    addressing_mode = kMode_MRI; | 
| +  } else { | 
| +    inputs[input_count++] = g.UseUniqueRegister(index); | 
| +    addressing_mode = kMode_MR1; | 
| +  } | 
| +  outputs[0] = g.DefineAsFixed(node, eax); | 
| +  InstructionCode code = opcode | AddressingModeField::encode(addressing_mode); | 
| +  Emit(code, 1, outputs, input_count, inputs); | 
| +} | 
| + | 
| // static | 
| MachineOperatorBuilder::Flags | 
| InstructionSelector::SupportedMachineOperatorFlags() { | 
|  |