A64: Now that we have veneers, fix a couple of branches to directly jump to their target.

R=ulan@chromium.org

Review URL: https://codereview.chromium.org/207883002

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@20169 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent 04a418c5
...@@ -1481,12 +1481,7 @@ void RegExpMacroAssemblerARM64::BranchOrBacktrack(Condition condition, ...@@ -1481,12 +1481,7 @@ void RegExpMacroAssemblerARM64::BranchOrBacktrack(Condition condition,
if (to == NULL) { if (to == NULL) {
to = &backtrack_label_; to = &backtrack_label_;
} }
// TODO(ulan): do direct jump when jump distance is known and fits in imm19. __ B(condition, to);
Condition inverted_condition = InvertCondition(condition);
Label no_branch;
__ B(inverted_condition, &no_branch);
__ B(to);
__ Bind(&no_branch);
} }
void RegExpMacroAssemblerARM64::CompareAndBranchOrBacktrack(Register reg, void RegExpMacroAssemblerARM64::CompareAndBranchOrBacktrack(Register reg,
...@@ -1497,15 +1492,11 @@ void RegExpMacroAssemblerARM64::CompareAndBranchOrBacktrack(Register reg, ...@@ -1497,15 +1492,11 @@ void RegExpMacroAssemblerARM64::CompareAndBranchOrBacktrack(Register reg,
if (to == NULL) { if (to == NULL) {
to = &backtrack_label_; to = &backtrack_label_;
} }
// TODO(ulan): do direct jump when jump distance is known and fits in imm19.
Label no_branch;
if (condition == eq) { if (condition == eq) {
__ Cbnz(reg, &no_branch); __ Cbz(reg, to);
} else { } else {
__ Cbz(reg, &no_branch); __ Cbnz(reg, to);
} }
__ B(to);
__ Bind(&no_branch);
} else { } else {
__ Cmp(reg, immediate); __ Cmp(reg, immediate);
BranchOrBacktrack(condition, to); BranchOrBacktrack(condition, to);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment