mirror of
https://github.com/nodejs/node.git
synced 2025-05-20 01:45:06 +00:00
Fix bug in x64 RegExp detecting start of string.
Also add missing MIPS case in regexp tracer. Fixes issues v8:1748 and v8:1746 BUG=v8:1748, v8:1746 TEST=mjsunit/regress/regress-1748.js Review URL: http://codereview.chromium.org/8116001 git-svn-id: https://v8.googlecode.com/svn/branches/bleeding_edge@9504 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
This commit is contained in:
parent
0f74729758
commit
5d69bbfbdb
4
deps/v8/src/regexp-macro-assembler-tracer.cc
vendored
4
deps/v8/src/regexp-macro-assembler-tracer.cc
vendored
@ -37,8 +37,8 @@ RegExpMacroAssemblerTracer::RegExpMacroAssemblerTracer(
|
||||
RegExpMacroAssembler* assembler) :
|
||||
assembler_(assembler) {
|
||||
unsigned int type = assembler->Implementation();
|
||||
ASSERT(type < 4);
|
||||
const char* impl_names[4] = {"IA32", "ARM", "X64", "Bytecode"};
|
||||
ASSERT(type < 5);
|
||||
const char* impl_names[4] = {"IA32", "ARM", "MIPS", "X64", "Bytecode"};
|
||||
PrintF("RegExpMacroAssembler%s();\n", impl_names[type]);
|
||||
}
|
||||
|
||||
|
@ -193,7 +193,7 @@ void RegExpMacroAssemblerX64::CheckCharacterGT(uc16 limit, Label* on_greater) {
|
||||
void RegExpMacroAssemblerX64::CheckAtStart(Label* on_at_start) {
|
||||
Label not_at_start;
|
||||
// Did we start the match at the start of the string at all?
|
||||
__ cmpb(Operand(rbp, kStartIndex), Immediate(0));
|
||||
__ cmpl(Operand(rbp, kStartIndex), Immediate(0));
|
||||
BranchOrBacktrack(not_equal, ¬_at_start);
|
||||
// If we did, are we still at the start of the input?
|
||||
__ lea(rax, Operand(rsi, rdi, times_1, 0));
|
||||
@ -205,7 +205,7 @@ void RegExpMacroAssemblerX64::CheckAtStart(Label* on_at_start) {
|
||||
|
||||
void RegExpMacroAssemblerX64::CheckNotAtStart(Label* on_not_at_start) {
|
||||
// Did we start the match at the start of the string at all?
|
||||
__ cmpb(Operand(rbp, kStartIndex), Immediate(0));
|
||||
__ cmpl(Operand(rbp, kStartIndex), Immediate(0));
|
||||
BranchOrBacktrack(not_equal, on_not_at_start);
|
||||
// If we did, are we still at the start of the input?
|
||||
__ lea(rax, Operand(rsi, rdi, times_1, 0));
|
||||
|
35
deps/v8/test/mjsunit/regress/regress-1748.js
vendored
Normal file
35
deps/v8/test/mjsunit/regress/regress-1748.js
vendored
Normal file
@ -0,0 +1,35 @@
|
||||
// Copyright 2011 the V8 project authors. All rights reserved.
|
||||
// Redistribution and use in source and binary forms, with or without
|
||||
// modification, are permitted provided that the following conditions are
|
||||
// met:
|
||||
//
|
||||
// * Redistributions of source code must retain the above copyright
|
||||
// notice, this list of conditions and the following disclaimer.
|
||||
// * Redistributions in binary form must reproduce the above
|
||||
// copyright notice, this list of conditions and the following
|
||||
// disclaimer in the documentation and/or other materials provided
|
||||
// with the distribution.
|
||||
// * Neither the name of Google Inc. nor the names of its
|
||||
// contributors may be used to endorse or promote products derived
|
||||
// from this software without specific prior written permission.
|
||||
//
|
||||
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
||||
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
||||
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
||||
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
||||
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
||||
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
||||
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
||||
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
||||
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
||||
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
||||
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
||||
|
||||
// Test that /^/ only matches at beginning of string.
|
||||
// Bug in x64 caused it to match when executing the RegExp on a part
|
||||
// of a string that starts at a multiplum of 256.
|
||||
|
||||
var str = Array(10000).join("X");
|
||||
str.replace(/^|X/g, function(m, i, s) {
|
||||
if (i > 0) assertEquals("X", m, "at position 0x" + i.toString(16));
|
||||
});
|
Loading…
Reference in New Issue
Block a user