Commit 5c580644 authored by Martin Bidlingmaier's avatar Martin Bidlingmaier Committed by Commit Bot

[regexp] Use handle instead of raw object to fix gc issue

The problem was that a raw regexp value was handlified to account for
gc, but then afterwards we used the initial regexp value again instead
of the handle.  This resulted in memory violations if the gc decided to
move the regexp object.

Bug: chrome:1139304,v8:10765,v8:11021
Change-Id: Ib1c31ae4a960523c9939619bcca9606dbb507c81
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/2484771Reviewed-by: 's avatarJakob Gruber <jgruber@chromium.org>
Commit-Queue: Martin Bidlingmaier <mbid@google.com>
Cr-Commit-Position: refs/heads/master@{#70605}
parent 48a99add
...@@ -255,8 +255,9 @@ MaybeHandle<Object> ExperimentalRegExp::Exec( ...@@ -255,8 +255,9 @@ MaybeHandle<Object> ExperimentalRegExp::Exec(
} }
} }
int32_t ExperimentalRegExp::OneshotExecRaw(Isolate* isolate, JSRegExp regexp, int32_t ExperimentalRegExp::OneshotExecRaw(Isolate* isolate,
String subject, Handle<JSRegExp> regexp,
Handle<String> subject,
int32_t* output_registers, int32_t* output_registers,
int32_t output_register_count, int32_t output_register_count,
int32_t subject_index) { int32_t subject_index) {
...@@ -264,18 +265,17 @@ int32_t ExperimentalRegExp::OneshotExecRaw(Isolate* isolate, JSRegExp regexp, ...@@ -264,18 +265,17 @@ int32_t ExperimentalRegExp::OneshotExecRaw(Isolate* isolate, JSRegExp regexp,
if (FLAG_trace_experimental_regexp_engine) { if (FLAG_trace_experimental_regexp_engine) {
StdoutStream{} << "Experimental execution (oneshot) of regexp " StdoutStream{} << "Experimental execution (oneshot) of regexp "
<< regexp.Pattern() << std::endl; << regexp->Pattern() << std::endl;
} }
Handle<JSRegExp> regexp_handle(regexp, isolate);
base::Optional<CompilationResult> compilation_result = base::Optional<CompilationResult> compilation_result =
CompileImpl(isolate, regexp_handle); CompileImpl(isolate, regexp);
if (!compilation_result.has_value()) return RegExp::kInternalRegExpException; if (!compilation_result.has_value()) return RegExp::kInternalRegExpException;
DisallowHeapAllocation no_gc; DisallowHeapAllocation no_gc;
return ExecRawImpl(isolate, RegExp::kFromRuntime, return ExecRawImpl(isolate, RegExp::kFromRuntime,
*compilation_result->bytecode, subject, *compilation_result->bytecode, *subject,
regexp.CaptureCount(), output_registers, regexp->CaptureCount(), output_registers,
output_register_count, subject_index); output_register_count, subject_index);
} }
...@@ -297,7 +297,7 @@ MaybeHandle<Object> ExperimentalRegExp::OneshotExec( ...@@ -297,7 +297,7 @@ MaybeHandle<Object> ExperimentalRegExp::OneshotExec(
output_registers_release.reset(output_registers); output_registers_release.reset(output_registers);
} }
int num_matches = OneshotExecRaw(isolate, *regexp, *subject, output_registers, int num_matches = OneshotExecRaw(isolate, regexp, subject, output_registers,
output_register_count, subject_index); output_register_count, subject_index);
if (num_matches > 0) { if (num_matches > 0) {
......
...@@ -49,8 +49,9 @@ class ExperimentalRegExp final : public AllStatic { ...@@ -49,8 +49,9 @@ class ExperimentalRegExp final : public AllStatic {
static MaybeHandle<Object> OneshotExec( static MaybeHandle<Object> OneshotExec(
Isolate* isolate, Handle<JSRegExp> regexp, Handle<String> subject, Isolate* isolate, Handle<JSRegExp> regexp, Handle<String> subject,
int index, Handle<RegExpMatchInfo> last_match_info); int index, Handle<RegExpMatchInfo> last_match_info);
static int32_t OneshotExecRaw(Isolate* isolate, JSRegExp regexp, static int32_t OneshotExecRaw(Isolate* isolate, Handle<JSRegExp> regexp,
String subject, int32_t* output_registers, Handle<String> subject,
int32_t* output_registers,
int32_t output_register_count, int32_t output_register_count,
int32_t subject_index); int32_t subject_index);
......
...@@ -1066,7 +1066,7 @@ int32_t* RegExpGlobalCache::FetchNext() { ...@@ -1066,7 +1066,7 @@ int32_t* RegExpGlobalCache::FetchNext() {
// Fall back to experimental engine if needed and possible. // Fall back to experimental engine if needed and possible.
if (num_matches_ == RegExp::kInternalRegExpFallbackToExperimental) { if (num_matches_ == RegExp::kInternalRegExpFallbackToExperimental) {
num_matches_ = ExperimentalRegExp::OneshotExecRaw( num_matches_ = ExperimentalRegExp::OneshotExecRaw(
isolate_, *regexp_, *subject_, register_array_, register_array_size_, isolate_, regexp_, subject_, register_array_, register_array_size_,
last_end_index); last_end_index);
} }
......
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