| Index: src/x64/lithium-codegen-x64.cc
|
| diff --git a/src/x64/lithium-codegen-x64.cc b/src/x64/lithium-codegen-x64.cc
|
| index b42e660d21090ca4e33f64b20651467cd2b044df..adbe64cb27fbec70d31ffd9029f2e0afd4572252 100644
|
| --- a/src/x64/lithium-codegen-x64.cc
|
| +++ b/src/x64/lithium-codegen-x64.cc
|
| @@ -2074,16 +2074,32 @@ void LCodeGen::DoCmpIDAndBranch(LCmpIDAndBranch* instr) {
|
| int32_t value;
|
| if (right->IsConstantOperand()) {
|
| value = ToInteger32(LConstantOperand::cast(right));
|
| - __ cmpl(ToRegister(left), Immediate(value));
|
| + if (instr->hydrogen_value()->representation().IsSmi()) {
|
| + __ Cmp(ToRegister(left), Smi::FromInt(value));
|
| + } else {
|
| + __ cmpl(ToRegister(left), Immediate(value));
|
| + }
|
| } else if (left->IsConstantOperand()) {
|
| value = ToInteger32(LConstantOperand::cast(left));
|
| - if (right->IsRegister()) {
|
| + if (instr->hydrogen_value()->representation().IsSmi()) {
|
| + if (right->IsRegister()) {
|
| + __ Cmp(ToRegister(right), Smi::FromInt(value));
|
| + } else {
|
| + __ Cmp(ToOperand(right), Smi::FromInt(value));
|
| + }
|
| + } else if (right->IsRegister()) {
|
| __ cmpl(ToRegister(right), Immediate(value));
|
| } else {
|
| __ cmpl(ToOperand(right), Immediate(value));
|
| }
|
| // We transposed the operands. Reverse the condition.
|
| cc = ReverseCondition(cc);
|
| + } else if (instr->hydrogen_value()->representation().IsSmi()) {
|
| + if (right->IsRegister()) {
|
| + __ cmpq(ToRegister(left), ToRegister(right));
|
| + } else {
|
| + __ cmpq(ToRegister(left), ToOperand(right));
|
| + }
|
| } else {
|
| if (right->IsRegister()) {
|
| __ cmpl(ToRegister(left), ToRegister(right));
|
|
|