| 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 #if V8_TARGET_ARCH_X87 | 5 #if V8_TARGET_ARCH_X87 |
| 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/codegen.h" | 9 #include "src/codegen.h" |
| 10 #include "src/debug/debug.h" | 10 #include "src/debug/debug.h" |
| (...skipping 1359 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1370 __ bind(&done); | 1370 __ bind(&done); |
| 1371 context()->Plug(eax); | 1371 context()->Plug(eax); |
| 1372 break; | 1372 break; |
| 1373 } | 1373 } |
| 1374 } | 1374 } |
| 1375 } | 1375 } |
| 1376 | 1376 |
| 1377 | 1377 |
| 1378 void FullCodeGenerator::VisitRegExpLiteral(RegExpLiteral* expr) { | 1378 void FullCodeGenerator::VisitRegExpLiteral(RegExpLiteral* expr) { |
| 1379 Comment cmnt(masm_, "[ RegExpLiteral"); | 1379 Comment cmnt(masm_, "[ RegExpLiteral"); |
| 1380 Label materialized; | |
| 1381 // Registers will be used as follows: | |
| 1382 // edi = JS function. | |
| 1383 // ecx = literals array. | |
| 1384 // ebx = regexp literal. | |
| 1385 // eax = regexp literal clone. | |
| 1386 __ mov(edi, Operand(ebp, JavaScriptFrameConstants::kFunctionOffset)); | 1380 __ mov(edi, Operand(ebp, JavaScriptFrameConstants::kFunctionOffset)); |
| 1387 __ mov(ecx, FieldOperand(edi, JSFunction::kLiteralsOffset)); | 1381 __ Move(eax, Immediate(Smi::FromInt(expr->literal_index()))); |
| 1388 int literal_offset = LiteralsArray::OffsetOfLiteralAt(expr->literal_index()); | 1382 __ Move(ecx, Immediate(expr->pattern())); |
| 1389 __ mov(ebx, FieldOperand(ecx, literal_offset)); | 1383 __ Move(edx, Immediate(expr->flags())); |
| 1390 __ cmp(ebx, isolate()->factory()->undefined_value()); | 1384 FastCloneRegExpStub stub(isolate()); |
| 1391 __ j(not_equal, &materialized, Label::kNear); | 1385 __ CallStub(&stub); |
| 1392 | |
| 1393 // Create regexp literal using runtime function | |
| 1394 // Result will be in eax. | |
| 1395 __ push(ecx); | |
| 1396 __ push(Immediate(Smi::FromInt(expr->literal_index()))); | |
| 1397 __ push(Immediate(expr->pattern())); | |
| 1398 __ push(Immediate(expr->flags())); | |
| 1399 __ CallRuntime(Runtime::kMaterializeRegExpLiteral, 4); | |
| 1400 __ mov(ebx, eax); | |
| 1401 | |
| 1402 __ bind(&materialized); | |
| 1403 int size = JSRegExp::kSize + JSRegExp::kInObjectFieldCount * kPointerSize; | |
| 1404 Label allocated, runtime_allocate; | |
| 1405 __ Allocate(size, eax, ecx, edx, &runtime_allocate, TAG_OBJECT); | |
| 1406 __ jmp(&allocated); | |
| 1407 | |
| 1408 __ bind(&runtime_allocate); | |
| 1409 __ push(ebx); | |
| 1410 __ push(Immediate(Smi::FromInt(size))); | |
| 1411 __ CallRuntime(Runtime::kAllocateInNewSpace, 1); | |
| 1412 __ pop(ebx); | |
| 1413 | |
| 1414 __ bind(&allocated); | |
| 1415 // Copy the content into the newly allocated memory. | |
| 1416 // (Unroll copy loop once for better throughput). | |
| 1417 for (int i = 0; i < size - kPointerSize; i += 2 * kPointerSize) { | |
| 1418 __ mov(edx, FieldOperand(ebx, i)); | |
| 1419 __ mov(ecx, FieldOperand(ebx, i + kPointerSize)); | |
| 1420 __ mov(FieldOperand(eax, i), edx); | |
| 1421 __ mov(FieldOperand(eax, i + kPointerSize), ecx); | |
| 1422 } | |
| 1423 if ((size % (2 * kPointerSize)) != 0) { | |
| 1424 __ mov(edx, FieldOperand(ebx, size - kPointerSize)); | |
| 1425 __ mov(FieldOperand(eax, size - kPointerSize), edx); | |
| 1426 } | |
| 1427 context()->Plug(eax); | 1386 context()->Plug(eax); |
| 1428 } | 1387 } |
| 1429 | 1388 |
| 1430 | 1389 |
| 1431 void FullCodeGenerator::EmitAccessor(ObjectLiteralProperty* property) { | 1390 void FullCodeGenerator::EmitAccessor(ObjectLiteralProperty* property) { |
| 1432 Expression* expression = (property == NULL) ? NULL : property->value(); | 1391 Expression* expression = (property == NULL) ? NULL : property->value(); |
| 1433 if (expression == NULL) { | 1392 if (expression == NULL) { |
| 1434 __ push(Immediate(isolate()->factory()->null_value())); | 1393 __ push(Immediate(isolate()->factory()->null_value())); |
| 1435 } else { | 1394 } else { |
| 1436 VisitForStackValue(expression); | 1395 VisitForStackValue(expression); |
| (...skipping 3474 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 4911 Assembler::target_address_at(call_target_address, | 4870 Assembler::target_address_at(call_target_address, |
| 4912 unoptimized_code)); | 4871 unoptimized_code)); |
| 4913 return OSR_AFTER_STACK_CHECK; | 4872 return OSR_AFTER_STACK_CHECK; |
| 4914 } | 4873 } |
| 4915 | 4874 |
| 4916 | 4875 |
| 4917 } // namespace internal | 4876 } // namespace internal |
| 4918 } // namespace v8 | 4877 } // namespace v8 |
| 4919 | 4878 |
| 4920 #endif // V8_TARGET_ARCH_X87 | 4879 #endif // V8_TARGET_ARCH_X87 |
| OLD | NEW |