| Index: src/arm/lithium-arm.cc
|
| diff --git a/src/arm/lithium-arm.cc b/src/arm/lithium-arm.cc
|
| index ffb745750a1b0f240c2bffbe4ef4e266dc00572a..f9660878759408ff636155b7917f1ed85fc7e862 100644
|
| --- a/src/arm/lithium-arm.cc
|
| +++ b/src/arm/lithium-arm.cc
|
| @@ -228,6 +228,13 @@ void LIsObjectAndBranch::PrintDataTo(StringStream* stream) {
|
| }
|
|
|
|
|
| +void LIsStringAndBranch::PrintDataTo(StringStream* stream) {
|
| + stream->Add("if is_string(");
|
| + InputAt(0)->PrintTo(stream);
|
| + stream->Add(") then B%d else B%d", true_block_id(), false_block_id());
|
| +}
|
| +
|
| +
|
| void LIsSmiAndBranch::PrintDataTo(StringStream* stream) {
|
| stream->Add("if is_smi(");
|
| InputAt(0)->PrintTo(stream);
|
| @@ -242,6 +249,14 @@ void LIsUndetectableAndBranch::PrintDataTo(StringStream* stream) {
|
| }
|
|
|
|
|
| +void LStringCompareAndBranch::PrintDataTo(StringStream* stream) {
|
| + stream->Add("if compare_generic(");
|
| + InputAt(0)->PrintTo(stream);
|
| + InputAt(1)->PrintTo(stream);
|
| + stream->Add(") then B%d else B%d", true_block_id(), false_block_id());
|
| +}
|
| +
|
| +
|
| void LHasInstanceTypeAndBranch::PrintDataTo(StringStream* stream) {
|
| stream->Add("if has_instance_type(");
|
| InputAt(0)->PrintTo(stream);
|
| @@ -1451,6 +1466,13 @@ LInstruction* LChunkBuilder::DoIsObjectAndBranch(HIsObjectAndBranch* instr) {
|
| }
|
|
|
|
|
| +LInstruction* LChunkBuilder::DoIsStringAndBranch(HIsStringAndBranch* instr) {
|
| + ASSERT(instr->value()->representation().IsTagged());
|
| + LOperand* temp = TempRegister();
|
| + return new LIsStringAndBranch(UseRegisterAtStart(instr->value()), temp);
|
| +}
|
| +
|
| +
|
| LInstruction* LChunkBuilder::DoIsSmiAndBranch(HIsSmiAndBranch* instr) {
|
| ASSERT(instr->value()->representation().IsTagged());
|
| return new LIsSmiAndBranch(Use(instr->value()));
|
| @@ -1465,6 +1487,18 @@ LInstruction* LChunkBuilder::DoIsUndetectableAndBranch(
|
| }
|
|
|
|
|
| +LInstruction* LChunkBuilder::DoStringCompareAndBranch(
|
| + HStringCompareAndBranch* instr) {
|
| +
|
| + ASSERT(instr->left()->representation().IsTagged());
|
| + ASSERT(instr->right()->representation().IsTagged());
|
| + LOperand* left = UseFixed(instr->left(), r1);
|
| + LOperand* right = UseFixed(instr->right(), r0);
|
| + LStringCompareAndBranch* result = new LStringCompareAndBranch(left, right);
|
| + return MarkAsCall(result, instr);
|
| +}
|
| +
|
| +
|
| LInstruction* LChunkBuilder::DoHasInstanceTypeAndBranch(
|
| HHasInstanceTypeAndBranch* instr) {
|
| ASSERT(instr->value()->representation().IsTagged());
|
|
|