Index: src/x64/lithium-codegen-x64.cc |
diff --git a/src/x64/lithium-codegen-x64.cc b/src/x64/lithium-codegen-x64.cc |
index 48d413016bc1957c3404a22f9388a920462e7b9e..0f060e873c5c8d1528e963abfbeb1319ce7caa97 100644 |
--- a/src/x64/lithium-codegen-x64.cc |
+++ b/src/x64/lithium-codegen-x64.cc |
@@ -797,6 +797,13 @@ void LCodeGen::DoFixedArrayLength(LFixedArrayLength* instr) { |
} |
+void LCodeGen::DoPixelArrayLength(LPixelArrayLength* instr) { |
+ Register result = ToRegister(instr->result()); |
+ Register array = ToRegister(instr->InputAt(0)); |
+ __ movq(result, FieldOperand(array, PixelArray::kLengthOffset)); |
+} |
+ |
+ |
void LCodeGen::DoValueOf(LValueOf* instr) { |
Abort("Unimplemented: %s", "DoValueOf"); |
} |
@@ -963,7 +970,11 @@ void LCodeGen::EmitGoto(int block, LDeferredCode* deferred_stack_check) { |
void LCodeGen::DoDeferredStackCheck(LGoto* instr) { |
- Abort("Unimplemented: %s", "DoDeferredStackCheck"); |
+ __ Pushad(); |
+ __ CallRuntimeSaveDoubles(Runtime::kStackGuard); |
+ RecordSafepointWithRegisters( |
+ instr->pointer_map(), 0, Safepoint::kNoDeoptimizationIndex); |
+ __ Popad(); |
} |
@@ -1573,15 +1584,18 @@ void LCodeGen::DoLoadFunctionPrototype(LLoadFunctionPrototype* instr) { |
void LCodeGen::DoLoadElements(LLoadElements* instr) { |
- ASSERT(instr->result()->Equals(instr->InputAt(0))); |
- Register reg = ToRegister(instr->InputAt(0)); |
- __ movq(reg, FieldOperand(reg, JSObject::kElementsOffset)); |
+ Register result = ToRegister(instr->result()); |
+ Register input = ToRegister(instr->InputAt(0)); |
+ __ movq(result, FieldOperand(input, JSObject::kElementsOffset)); |
if (FLAG_debug_code) { |
NearLabel done; |
- __ Cmp(FieldOperand(reg, HeapObject::kMapOffset), |
+ __ Cmp(FieldOperand(result, HeapObject::kMapOffset), |
Factory::fixed_array_map()); |
__ j(equal, &done); |
- __ Cmp(FieldOperand(reg, HeapObject::kMapOffset), |
+ __ Cmp(FieldOperand(result, HeapObject::kMapOffset), |
+ Factory::pixel_array_map()); |
+ __ j(equal, &done); |
+ __ Cmp(FieldOperand(result, HeapObject::kMapOffset), |
Factory::fixed_cow_array_map()); |
__ Check(equal, "Check for fast elements failed."); |
__ bind(&done); |
@@ -1589,6 +1603,14 @@ void LCodeGen::DoLoadElements(LLoadElements* instr) { |
} |
+void LCodeGen::DoLoadPixelArrayExternalPointer( |
+ LLoadPixelArrayExternalPointer* instr) { |
+ Register result = ToRegister(instr->result()); |
+ Register input = ToRegister(instr->InputAt(0)); |
+ __ movq(result, FieldOperand(input, PixelArray::kExternalPointerOffset)); |
+} |
+ |
+ |
void LCodeGen::DoAccessArgumentsAt(LAccessArgumentsAt* instr) { |
Abort("Unimplemented: %s", "DoAccessArgumentsAt"); |
} |
@@ -1612,6 +1634,17 @@ void LCodeGen::DoLoadKeyedFastElement(LLoadKeyedFastElement* instr) { |
} |
+void LCodeGen::DoLoadPixelArrayElement(LLoadPixelArrayElement* instr) { |
+ Register external_elements = ToRegister(instr->external_pointer()); |
+ Register key = ToRegister(instr->key()); |
+ Register result = ToRegister(instr->result()); |
+ ASSERT(result.is(external_elements)); |
+ |
+ // Load the result. |
+ __ movzxbq(result, Operand(external_elements, key, times_1, 0)); |
+} |
+ |
+ |
void LCodeGen::DoLoadKeyedGeneric(LLoadKeyedGeneric* instr) { |
Abort("Unimplemented: %s", "DoLoadKeyedGeneric"); |
} |
@@ -1926,7 +1959,9 @@ void LCodeGen::DoDeferredNumberTagD(LNumberTagD* instr) { |
void LCodeGen::DoSmiTag(LSmiTag* instr) { |
- Abort("Unimplemented: %s", "DoSmiTag"); |
+ Register to_reg = ToRegister(instr->result()); |
+ Register from_reg = ToRegister(instr->InputAt(0)); |
+ __ Integer32ToSmi(to_reg, from_reg); |
} |