| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
| 2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
| 3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
| 4 | 4 |
| 5 #include "src/crankshaft/mips64/lithium-codegen-mips64.h" | 5 #include "src/crankshaft/mips64/lithium-codegen-mips64.h" |
| 6 | 6 |
| 7 #include "src/code-factory.h" | 7 #include "src/code-factory.h" |
| 8 #include "src/code-stubs.h" | 8 #include "src/code-stubs.h" |
| 9 #include "src/crankshaft/hydrogen-osr.h" | 9 #include "src/crankshaft/hydrogen-osr.h" |
| 10 #include "src/crankshaft/mips64/lithium-gap-resolver-mips64.h" | 10 #include "src/crankshaft/mips64/lithium-gap-resolver-mips64.h" |
| (...skipping 5491 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 5502 | 5502 |
| 5503 | 5503 |
| 5504 void LCodeGen::DoToFastProperties(LToFastProperties* instr) { | 5504 void LCodeGen::DoToFastProperties(LToFastProperties* instr) { |
| 5505 DCHECK(ToRegister(instr->value()).is(a0)); | 5505 DCHECK(ToRegister(instr->value()).is(a0)); |
| 5506 DCHECK(ToRegister(instr->result()).is(v0)); | 5506 DCHECK(ToRegister(instr->result()).is(v0)); |
| 5507 __ push(a0); | 5507 __ push(a0); |
| 5508 CallRuntime(Runtime::kToFastProperties, 1, instr); | 5508 CallRuntime(Runtime::kToFastProperties, 1, instr); |
| 5509 } | 5509 } |
| 5510 | 5510 |
| 5511 | 5511 |
| 5512 void LCodeGen::DoRegExpLiteral(LRegExpLiteral* instr) { | |
| 5513 DCHECK(ToRegister(instr->context()).is(cp)); | |
| 5514 Label materialized; | |
| 5515 // Registers will be used as follows: | |
| 5516 // a7 = literals array. | |
| 5517 // a1 = regexp literal. | |
| 5518 // a0 = regexp literal clone. | |
| 5519 // a2 and a4-a6 are used as temporaries. | |
| 5520 int literal_offset = | |
| 5521 LiteralsArray::OffsetOfLiteralAt(instr->hydrogen()->literal_index()); | |
| 5522 __ li(a7, instr->hydrogen()->literals()); | |
| 5523 __ ld(a1, FieldMemOperand(a7, literal_offset)); | |
| 5524 __ LoadRoot(at, Heap::kUndefinedValueRootIndex); | |
| 5525 __ Branch(&materialized, ne, a1, Operand(at)); | |
| 5526 | |
| 5527 // Create regexp literal using runtime function | |
| 5528 // Result will be in v0. | |
| 5529 __ li(a6, Operand(Smi::FromInt(instr->hydrogen()->literal_index()))); | |
| 5530 __ li(a5, Operand(instr->hydrogen()->pattern())); | |
| 5531 __ li(a4, Operand(instr->hydrogen()->flags())); | |
| 5532 __ Push(a7, a6, a5, a4); | |
| 5533 CallRuntime(Runtime::kMaterializeRegExpLiteral, 4, instr); | |
| 5534 __ mov(a1, v0); | |
| 5535 | |
| 5536 __ bind(&materialized); | |
| 5537 int size = JSRegExp::kSize + JSRegExp::kInObjectFieldCount * kPointerSize; | |
| 5538 Label allocated, runtime_allocate; | |
| 5539 | |
| 5540 __ Allocate(size, v0, a2, a3, &runtime_allocate, TAG_OBJECT); | |
| 5541 __ jmp(&allocated); | |
| 5542 | |
| 5543 __ bind(&runtime_allocate); | |
| 5544 __ li(a0, Operand(Smi::FromInt(size))); | |
| 5545 __ Push(a1, a0); | |
| 5546 CallRuntime(Runtime::kAllocateInNewSpace, 1, instr); | |
| 5547 __ pop(a1); | |
| 5548 | |
| 5549 __ bind(&allocated); | |
| 5550 // Copy the content into the newly allocated memory. | |
| 5551 // (Unroll copy loop once for better throughput). | |
| 5552 for (int i = 0; i < size - kPointerSize; i += 2 * kPointerSize) { | |
| 5553 __ ld(a3, FieldMemOperand(a1, i)); | |
| 5554 __ ld(a2, FieldMemOperand(a1, i + kPointerSize)); | |
| 5555 __ sd(a3, FieldMemOperand(v0, i)); | |
| 5556 __ sd(a2, FieldMemOperand(v0, i + kPointerSize)); | |
| 5557 } | |
| 5558 if ((size % (2 * kPointerSize)) != 0) { | |
| 5559 __ ld(a3, FieldMemOperand(a1, size - kPointerSize)); | |
| 5560 __ sd(a3, FieldMemOperand(v0, size - kPointerSize)); | |
| 5561 } | |
| 5562 } | |
| 5563 | |
| 5564 | |
| 5565 void LCodeGen::DoTypeof(LTypeof* instr) { | 5512 void LCodeGen::DoTypeof(LTypeof* instr) { |
| 5566 DCHECK(ToRegister(instr->value()).is(a3)); | 5513 DCHECK(ToRegister(instr->value()).is(a3)); |
| 5567 DCHECK(ToRegister(instr->result()).is(v0)); | 5514 DCHECK(ToRegister(instr->result()).is(v0)); |
| 5568 Label end, do_call; | 5515 Label end, do_call; |
| 5569 Register value_register = ToRegister(instr->value()); | 5516 Register value_register = ToRegister(instr->value()); |
| 5570 __ JumpIfNotSmi(value_register, &do_call); | 5517 __ JumpIfNotSmi(value_register, &do_call); |
| 5571 __ li(v0, Operand(isolate()->factory()->number_string())); | 5518 __ li(v0, Operand(isolate()->factory()->number_string())); |
| 5572 __ jmp(&end); | 5519 __ jmp(&end); |
| 5573 __ bind(&do_call); | 5520 __ bind(&do_call); |
| 5574 TypeofStub stub(isolate()); | 5521 TypeofStub stub(isolate()); |
| (...skipping 429 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 6004 __ Push(at, ToRegister(instr->function())); | 5951 __ Push(at, ToRegister(instr->function())); |
| 6005 CallRuntime(Runtime::kPushBlockContext, 2, instr); | 5952 CallRuntime(Runtime::kPushBlockContext, 2, instr); |
| 6006 RecordSafepoint(Safepoint::kNoLazyDeopt); | 5953 RecordSafepoint(Safepoint::kNoLazyDeopt); |
| 6007 } | 5954 } |
| 6008 | 5955 |
| 6009 | 5956 |
| 6010 #undef __ | 5957 #undef __ |
| 6011 | 5958 |
| 6012 } // namespace internal | 5959 } // namespace internal |
| 6013 } // namespace v8 | 5960 } // namespace v8 |
| OLD | NEW |