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)); |