OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 2049 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
2060 __ add(Operand(esp), Immediate(kDoubleSize)); | 2060 __ add(Operand(esp), Immediate(kDoubleSize)); |
2061 break; | 2061 break; |
2062 } | 2062 } |
2063 default: | 2063 default: |
2064 UNREACHABLE(); | 2064 UNREACHABLE(); |
2065 break; | 2065 break; |
2066 } | 2066 } |
2067 } | 2067 } |
2068 | 2068 |
2069 | 2069 |
| 2070 void LCodeGen::DoNegateNoSSE2D(LNegateNoSSE2D* instr) { |
| 2071 __ push(Immediate(-1)); |
| 2072 __ fild_s(Operand(esp, 0)); |
| 2073 __ add(esp, Immediate(kPointerSize)); |
| 2074 __ fmulp(); |
| 2075 CurrentInstructionReturnsX87Result(); |
| 2076 } |
| 2077 |
| 2078 |
| 2079 |
2070 void LCodeGen::DoArithmeticT(LArithmeticT* instr) { | 2080 void LCodeGen::DoArithmeticT(LArithmeticT* instr) { |
2071 ASSERT(ToRegister(instr->context()).is(esi)); | 2081 ASSERT(ToRegister(instr->context()).is(esi)); |
2072 ASSERT(ToRegister(instr->left()).is(edx)); | 2082 ASSERT(ToRegister(instr->left()).is(edx)); |
2073 ASSERT(ToRegister(instr->right()).is(eax)); | 2083 ASSERT(ToRegister(instr->right()).is(eax)); |
2074 ASSERT(ToRegister(instr->result()).is(eax)); | 2084 ASSERT(ToRegister(instr->result()).is(eax)); |
2075 | 2085 |
2076 BinaryOpStub stub(instr->op(), NO_OVERWRITE); | 2086 BinaryOpStub stub(instr->op(), NO_OVERWRITE); |
2077 CallCode(stub.GetCode(isolate()), RelocInfo::CODE_TARGET, instr); | 2087 CallCode(stub.GetCode(isolate()), RelocInfo::CODE_TARGET, instr); |
2078 __ nop(); // Signals no inlined code. | 2088 __ nop(); // Signals no inlined code. |
2079 } | 2089 } |
2080 | 2090 |
2081 | 2091 |
2082 int LCodeGen::GetNextEmittedBlock() const { | 2092 int LCodeGen::GetNextEmittedBlock() const { |
2083 for (int i = current_block_ + 1; i < graph()->blocks()->length(); ++i) { | 2093 for (int i = current_block_ + 1; i < graph()->blocks()->length(); ++i) { |
2084 if (!chunk_->GetLabel(i)->HasReplacement()) return i; | 2094 if (!chunk_->GetLabel(i)->HasReplacement()) return i; |
2085 } | 2095 } |
2086 return -1; | 2096 return -1; |
2087 } | 2097 } |
2088 | 2098 |
2089 | 2099 |
2090 template<class InstrType> | 2100 template<class InstrType> |
2091 void LCodeGen::EmitBranch(InstrType instr, Condition cc) { | 2101 void LCodeGen::EmitBranch(InstrType instr, Condition cc) { |
| 2102 int left_block = instr->TrueDestination(chunk_); |
2092 int right_block = instr->FalseDestination(chunk_); | 2103 int right_block = instr->FalseDestination(chunk_); |
2093 int left_block = instr->TrueDestination(chunk_); | |
2094 | 2104 |
2095 int next_block = GetNextEmittedBlock(); | 2105 int next_block = GetNextEmittedBlock(); |
2096 | 2106 |
2097 if (right_block == left_block) { | 2107 if (right_block == left_block || cc == no_condition) { |
2098 EmitGoto(left_block); | 2108 EmitGoto(left_block); |
2099 } else if (left_block == next_block) { | 2109 } else if (left_block == next_block) { |
2100 __ j(NegateCondition(cc), chunk_->GetAssemblyLabel(right_block)); | 2110 __ j(NegateCondition(cc), chunk_->GetAssemblyLabel(right_block)); |
2101 } else if (right_block == next_block) { | 2111 } else if (right_block == next_block) { |
2102 __ j(cc, chunk_->GetAssemblyLabel(left_block)); | 2112 __ j(cc, chunk_->GetAssemblyLabel(left_block)); |
2103 } else { | 2113 } else { |
2104 __ j(cc, chunk_->GetAssemblyLabel(left_block)); | 2114 __ j(cc, chunk_->GetAssemblyLabel(left_block)); |
2105 __ jmp(chunk_->GetAssemblyLabel(right_block)); | 2115 __ jmp(chunk_->GetAssemblyLabel(right_block)); |
2106 } | 2116 } |
2107 } | 2117 } |
2108 | 2118 |
2109 | 2119 |
| 2120 void LCodeGen::DoIsNumberAndBranch(LIsNumberAndBranch* instr) { |
| 2121 Representation r = instr->hydrogen()->value()->representation(); |
| 2122 if (r.IsSmiOrInteger32() || r.IsDouble()) { |
| 2123 EmitBranch(instr, no_condition); |
| 2124 } else { |
| 2125 ASSERT(r.IsTagged()); |
| 2126 Register reg = ToRegister(instr->value()); |
| 2127 HType type = instr->hydrogen()->value()->type(); |
| 2128 if (type.IsTaggedNumber()) { |
| 2129 EmitBranch(instr, no_condition); |
| 2130 } |
| 2131 __ JumpIfSmi(reg, instr->TrueLabel(chunk_)); |
| 2132 __ cmp(FieldOperand(reg, HeapObject::kMapOffset), |
| 2133 factory()->heap_number_map()); |
| 2134 EmitBranch(instr, equal); |
| 2135 } |
| 2136 } |
| 2137 |
| 2138 |
2110 void LCodeGen::DoBranch(LBranch* instr) { | 2139 void LCodeGen::DoBranch(LBranch* instr) { |
2111 Representation r = instr->hydrogen()->value()->representation(); | 2140 Representation r = instr->hydrogen()->value()->representation(); |
2112 if (r.IsSmiOrInteger32()) { | 2141 if (r.IsSmiOrInteger32()) { |
2113 ASSERT(!info()->IsStub()); | 2142 ASSERT(!info()->IsStub()); |
2114 Register reg = ToRegister(instr->value()); | 2143 Register reg = ToRegister(instr->value()); |
2115 __ test(reg, Operand(reg)); | 2144 __ test(reg, Operand(reg)); |
2116 EmitBranch(instr, not_zero); | 2145 EmitBranch(instr, not_zero); |
2117 } else if (r.IsDouble()) { | 2146 } else if (r.IsDouble()) { |
2118 ASSERT(!info()->IsStub()); | 2147 ASSERT(!info()->IsStub()); |
2119 CpuFeatureScope scope(masm(), SSE2); | 2148 CpuFeatureScope scope(masm(), SSE2); |
(...skipping 4440 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
6560 FixedArray::kHeaderSize - kPointerSize)); | 6589 FixedArray::kHeaderSize - kPointerSize)); |
6561 __ bind(&done); | 6590 __ bind(&done); |
6562 } | 6591 } |
6563 | 6592 |
6564 | 6593 |
6565 #undef __ | 6594 #undef __ |
6566 | 6595 |
6567 } } // namespace v8::internal | 6596 } } // namespace v8::internal |
6568 | 6597 |
6569 #endif // V8_TARGET_ARCH_IA32 | 6598 #endif // V8_TARGET_ARCH_IA32 |
OLD | NEW |