OLD | NEW |
1 // Copyright 2013 the V8 project authors. All rights reserved. | 1 // Copyright 2013 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/v8.h" | 5 #include "src/v8.h" |
6 | 6 |
7 #if V8_TARGET_ARCH_ARM64 | 7 #if V8_TARGET_ARCH_ARM64 |
8 | 8 |
9 #include "src/code-stubs.h" | 9 #include "src/code-stubs.h" |
10 #include "src/cpu-profiler.h" | 10 #include "src/cpu-profiler.h" |
(...skipping 1443 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1454 if (to == NULL) { | 1454 if (to == NULL) { |
1455 Backtrack(); | 1455 Backtrack(); |
1456 return; | 1456 return; |
1457 } | 1457 } |
1458 __ B(to); | 1458 __ B(to); |
1459 return; | 1459 return; |
1460 } | 1460 } |
1461 if (to == NULL) { | 1461 if (to == NULL) { |
1462 to = &backtrack_label_; | 1462 to = &backtrack_label_; |
1463 } | 1463 } |
1464 // TODO(ulan): do direct jump when jump distance is known and fits in imm19. | 1464 __ B(condition, to); |
1465 Condition inverted_condition = NegateCondition(condition); | |
1466 Label no_branch; | |
1467 __ B(inverted_condition, &no_branch); | |
1468 __ B(to); | |
1469 __ Bind(&no_branch); | |
1470 } | 1465 } |
1471 | 1466 |
1472 void RegExpMacroAssemblerARM64::CompareAndBranchOrBacktrack(Register reg, | 1467 void RegExpMacroAssemblerARM64::CompareAndBranchOrBacktrack(Register reg, |
1473 int immediate, | 1468 int immediate, |
1474 Condition condition, | 1469 Condition condition, |
1475 Label* to) { | 1470 Label* to) { |
1476 if ((immediate == 0) && ((condition == eq) || (condition == ne))) { | 1471 if ((immediate == 0) && ((condition == eq) || (condition == ne))) { |
1477 if (to == NULL) { | 1472 if (to == NULL) { |
1478 to = &backtrack_label_; | 1473 to = &backtrack_label_; |
1479 } | 1474 } |
1480 // TODO(ulan): do direct jump when jump distance is known and fits in imm19. | |
1481 Label no_branch; | |
1482 if (condition == eq) { | 1475 if (condition == eq) { |
1483 __ Cbnz(reg, &no_branch); | 1476 __ Cbz(reg, to); |
1484 } else { | 1477 } else { |
1485 __ Cbz(reg, &no_branch); | 1478 __ Cbnz(reg, to); |
1486 } | 1479 } |
1487 __ B(to); | |
1488 __ Bind(&no_branch); | |
1489 } else { | 1480 } else { |
1490 __ Cmp(reg, immediate); | 1481 __ Cmp(reg, immediate); |
1491 BranchOrBacktrack(condition, to); | 1482 BranchOrBacktrack(condition, to); |
1492 } | 1483 } |
1493 } | 1484 } |
1494 | 1485 |
1495 | 1486 |
1496 void RegExpMacroAssemblerARM64::CheckPreemption() { | 1487 void RegExpMacroAssemblerARM64::CheckPreemption() { |
1497 // Check for preemption. | 1488 // Check for preemption. |
1498 ExternalReference stack_limit = | 1489 ExternalReference stack_limit = |
(...skipping 200 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1699 __ Ldrh(current_character(), MemOperand(input_end(), offset, SXTW)); | 1690 __ Ldrh(current_character(), MemOperand(input_end(), offset, SXTW)); |
1700 } | 1691 } |
1701 } | 1692 } |
1702 } | 1693 } |
1703 | 1694 |
1704 #endif // V8_INTERPRETED_REGEXP | 1695 #endif // V8_INTERPRETED_REGEXP |
1705 | 1696 |
1706 }} // namespace v8::internal | 1697 }} // namespace v8::internal |
1707 | 1698 |
1708 #endif // V8_TARGET_ARCH_ARM64 | 1699 #endif // V8_TARGET_ARCH_ARM64 |
OLD | NEW |