Commit 73aea9c1 authored by mbrandy's avatar mbrandy Committed by Commit bot

PPC: [regexp] implement case-insensitive unicode regexps.

Port a2baaaac

R=yangguo@chromium.org, joransiu@ca.ibm.com, jyan@ca.ibm.com, michael_dawson@ca.ibm.com
BUG=v8:2952
LOG=N

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

Cr-Commit-Position: refs/heads/master@{#33565}
parent 4bf8bf78
...@@ -225,9 +225,8 @@ void RegExpMacroAssemblerPPC::CheckGreedyLoop(Label* on_equal) { ...@@ -225,9 +225,8 @@ void RegExpMacroAssemblerPPC::CheckGreedyLoop(Label* on_equal) {
BranchOrBacktrack(eq, on_equal); BranchOrBacktrack(eq, on_equal);
} }
void RegExpMacroAssemblerPPC::CheckNotBackReferenceIgnoreCase( void RegExpMacroAssemblerPPC::CheckNotBackReferenceIgnoreCase(
int start_reg, bool read_backward, Label* on_no_match) { int start_reg, bool read_backward, bool unicode, Label* on_no_match) {
Label fallthrough; Label fallthrough;
__ LoadP(r3, register_location(start_reg), r0); // Index of start of capture __ LoadP(r3, register_location(start_reg), r0); // Index of start of capture
__ LoadP(r4, register_location(start_reg + 1), r0); // Index of end __ LoadP(r4, register_location(start_reg + 1), r0); // Index of end
...@@ -322,7 +321,7 @@ void RegExpMacroAssemblerPPC::CheckNotBackReferenceIgnoreCase( ...@@ -322,7 +321,7 @@ void RegExpMacroAssemblerPPC::CheckNotBackReferenceIgnoreCase(
// r3: Address byte_offset1 - Address captured substring's start. // r3: Address byte_offset1 - Address captured substring's start.
// r4: Address byte_offset2 - Address of current character position. // r4: Address byte_offset2 - Address of current character position.
// r5: size_t byte_length - length of capture in bytes(!) // r5: size_t byte_length - length of capture in bytes(!)
// r6: Isolate* isolate // r6: Isolate* isolate or 0 if unicode flag.
// Address of start of capture. // Address of start of capture.
__ add(r3, r3, end_of_input_address()); __ add(r3, r3, end_of_input_address());
...@@ -336,7 +335,14 @@ void RegExpMacroAssemblerPPC::CheckNotBackReferenceIgnoreCase( ...@@ -336,7 +335,14 @@ void RegExpMacroAssemblerPPC::CheckNotBackReferenceIgnoreCase(
__ sub(r4, r4, r25); __ sub(r4, r4, r25);
} }
// Isolate. // Isolate.
__ mov(r6, Operand(ExternalReference::isolate_address(isolate()))); #ifdef V8_I18N_SUPPORT
if (unicode) {
__ li(r6, Operand::Zero());
} else // NOLINT
#endif // V8_I18N_SUPPORT
{
__ mov(r6, Operand(ExternalReference::isolate_address(isolate())));
}
{ {
AllowExternalCallThatCantCauseGC scope(masm_); AllowExternalCallThatCantCauseGC scope(masm_);
......
...@@ -38,7 +38,7 @@ class RegExpMacroAssemblerPPC : public NativeRegExpMacroAssembler { ...@@ -38,7 +38,7 @@ class RegExpMacroAssemblerPPC : public NativeRegExpMacroAssembler {
virtual void CheckNotBackReference(int start_reg, bool read_backward, virtual void CheckNotBackReference(int start_reg, bool read_backward,
Label* on_no_match); Label* on_no_match);
virtual void CheckNotBackReferenceIgnoreCase(int start_reg, virtual void CheckNotBackReferenceIgnoreCase(int start_reg,
bool read_backward, bool read_backward, bool unicode,
Label* on_no_match); Label* on_no_match);
virtual void CheckNotCharacter(unsigned c, Label* on_not_equal); virtual void CheckNotCharacter(unsigned c, Label* on_not_equal);
virtual void CheckNotCharacterAfterAnd(unsigned c, unsigned mask, virtual void CheckNotCharacterAfterAnd(unsigned c, unsigned mask,
......
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