| Index: src/ia32/lithium-codegen-ia32.cc
|
| diff --git a/src/ia32/lithium-codegen-ia32.cc b/src/ia32/lithium-codegen-ia32.cc
|
| index 4be78e692e736047aa667f1638dd4a159d7a8b3b..c0f4e71caa4a42cd0f2bb7033204762997275960 100644
|
| --- a/src/ia32/lithium-codegen-ia32.cc
|
| +++ b/src/ia32/lithium-codegen-ia32.cc
|
| @@ -1393,9 +1393,13 @@ void LCodeGen::DoBranch(LBranch* instr) {
|
| } else {
|
| ASSERT(r.IsTagged());
|
| Register reg = ToRegister(instr->InputAt(0));
|
| - if (instr->hydrogen()->value()->type().IsBoolean()) {
|
| + HType type = instr->hydrogen()->value()->type();
|
| + if (type.IsBoolean()) {
|
| __ cmp(reg, factory()->true_value());
|
| EmitBranch(true_block, false_block, equal);
|
| + } else if (type.IsSmi()) {
|
| + __ test(reg, Operand(reg));
|
| + EmitBranch(true_block, false_block, not_equal);
|
| } else {
|
| Label* true_label = chunk_->GetAssemblyLabel(true_block);
|
| Label* false_label = chunk_->GetAssemblyLabel(false_block);
|
| @@ -1455,7 +1459,7 @@ void LCodeGen::DoBranch(LBranch* instr) {
|
| DeoptimizeIf(zero, instr->environment());
|
| }
|
|
|
| - Register map;
|
| + Register map = no_reg;
|
| if (expected.NeedsMap()) {
|
| map = ToRegister(instr->TempAt(0));
|
| ASSERT(!map.is(reg));
|
|
|