From 3df99e7eb74421ca823e39d6d5cf7098a6673254 Mon Sep 17 00:00:00 2001 From: "svenpanne@chromium.org" Date: Tue, 28 Feb 2012 10:32:02 +0000 Subject: [PATCH] Thread the current isolate through a few places, avoiding Isolate::Current(). This removes approx. 12k calls of Isolate::Current() in string-tagcloud. Review URL: https://chromiumcodereview.appspot.com/9490004 git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@10856 ce2b1a6d-e550-0410-aec6-3dcde31c8c00 --- src/arm/regexp-macro-assembler-arm.cc | 2 +- src/execution.cc | 3 +-- src/execution.h | 8 ++++++-- src/ia32/regexp-macro-assembler-ia32.cc | 2 +- src/jsregexp.cc | 12 +++++++----- src/jsregexp.h | 4 ++-- src/mips/regexp-macro-assembler-mips.cc | 2 +- src/runtime.cc | 10 +++++----- src/x64/regexp-macro-assembler-x64.cc | 2 +- 9 files changed, 25 insertions(+), 20 deletions(-) diff --git a/src/arm/regexp-macro-assembler-arm.cc b/src/arm/regexp-macro-assembler-arm.cc index 880c37253..de83c13e1 100644 --- a/src/arm/regexp-macro-assembler-arm.cc +++ b/src/arm/regexp-macro-assembler-arm.cc @@ -1055,7 +1055,7 @@ int RegExpMacroAssemblerARM::CheckStackGuardState(Address* return_address, ASSERT(*return_address <= re_code->instruction_start() + re_code->instruction_size()); - MaybeObject* result = Execution::HandleStackGuardInterrupt(); + MaybeObject* result = Execution::HandleStackGuardInterrupt(isolate); if (*code_handle != re_code) { // Return address no longer valid int delta = code_handle->address() - re_code->address(); diff --git a/src/execution.cc b/src/execution.cc index 00806a7ce..1f019820b 100644 --- a/src/execution.cc +++ b/src/execution.cc @@ -872,8 +872,7 @@ void Execution::ProcessDebugMessages(bool debug_command_only) { #endif -MaybeObject* Execution::HandleStackGuardInterrupt() { - Isolate* isolate = Isolate::Current(); +MaybeObject* Execution::HandleStackGuardInterrupt(Isolate* isolate) { StackGuard* stack_guard = isolate->stack_guard(); if (stack_guard->IsGCRequest()) { diff --git a/src/execution.h b/src/execution.h index 014736ee8..d9ec9dccf 100644 --- a/src/execution.h +++ b/src/execution.h @@ -45,6 +45,10 @@ enum InterruptFlag { GC_REQUEST = 1 << 6 }; + +class Isolate; + + class Execution : public AllStatic { public: // Call a function, the caller supplies a receiver and an array @@ -141,7 +145,8 @@ class Execution : public AllStatic { // If the stack guard is triggered, but it is not an actual // stack overflow, then handle the interruption accordingly. - MUST_USE_RESULT static MaybeObject* HandleStackGuardInterrupt(); + MUST_USE_RESULT static MaybeObject* HandleStackGuardInterrupt( + Isolate* isolate); // Get a function delegate (or undefined) for the given non-function // object. Used for support calling objects as functions. @@ -158,7 +163,6 @@ class Execution : public AllStatic { class ExecutionAccess; -class Isolate; // StackGuard contains the handling of the limits that are used to limit the diff --git a/src/ia32/regexp-macro-assembler-ia32.cc b/src/ia32/regexp-macro-assembler-ia32.cc index e613a06c3..2c9b60c86 100644 --- a/src/ia32/regexp-macro-assembler-ia32.cc +++ b/src/ia32/regexp-macro-assembler-ia32.cc @@ -1085,7 +1085,7 @@ int RegExpMacroAssemblerIA32::CheckStackGuardState(Address* return_address, ASSERT(*return_address <= re_code->instruction_start() + re_code->instruction_size()); - MaybeObject* result = Execution::HandleStackGuardInterrupt(); + MaybeObject* result = Execution::HandleStackGuardInterrupt(isolate); if (*code_handle != re_code) { // Return address no longer valid int delta = code_handle->address() - re_code->address(); diff --git a/src/jsregexp.cc b/src/jsregexp.cc index 82b495819..7e695bb22 100644 --- a/src/jsregexp.cc +++ b/src/jsregexp.cc @@ -175,7 +175,8 @@ Handle RegExpImpl::Exec(Handle regexp, case JSRegExp::IRREGEXP: { Handle result = IrregexpExec(regexp, subject, index, last_match_info); - ASSERT(!result.is_null() || Isolate::Current()->has_pending_exception()); + ASSERT(!result.is_null() || + regexp->GetIsolate()->has_pending_exception()); return result; } default: @@ -527,6 +528,7 @@ Handle RegExpImpl::IrregexpExec(Handle jsregexp, Handle subject, int previous_index, Handle last_match_info) { + Isolate* isolate = jsregexp->GetIsolate(); ASSERT_EQ(jsregexp->TypeTag(), JSRegExp::IRREGEXP); // Prepare space for the return values. @@ -542,11 +544,11 @@ Handle RegExpImpl::IrregexpExec(Handle jsregexp, int required_registers = RegExpImpl::IrregexpPrepare(jsregexp, subject); if (required_registers < 0) { // Compiling failed with an exception. - ASSERT(Isolate::Current()->has_pending_exception()); + ASSERT(isolate->has_pending_exception()); return Handle::null(); } - OffsetsVector registers(required_registers); + OffsetsVector registers(required_registers, isolate); IrregexpResult res = RegExpImpl::IrregexpExecOnce( jsregexp, subject, previous_index, Vector(registers.vector(), @@ -568,11 +570,11 @@ Handle RegExpImpl::IrregexpExec(Handle jsregexp, return last_match_info; } if (res == RE_EXCEPTION) { - ASSERT(Isolate::Current()->has_pending_exception()); + ASSERT(isolate->has_pending_exception()); return Handle::null(); } ASSERT(res == RE_FAILURE); - return Isolate::Current()->factory()->null_value(); + return isolate->factory()->null_value(); } diff --git a/src/jsregexp.h b/src/jsregexp.h index 42c76fbd6..8875de9eb 100644 --- a/src/jsregexp.h +++ b/src/jsregexp.h @@ -1466,12 +1466,12 @@ class RegExpEngine: public AllStatic { class OffsetsVector { public: - explicit inline OffsetsVector(int num_registers) + inline OffsetsVector(int num_registers, Isolate* isolate) : offsets_vector_length_(num_registers) { if (offsets_vector_length_ > Isolate::kJSRegexpStaticOffsetsVectorSize) { vector_ = NewArray(offsets_vector_length_); } else { - vector_ = Isolate::Current()->jsregexp_static_offsets_vector(); + vector_ = isolate->jsregexp_static_offsets_vector(); } } inline ~OffsetsVector() { diff --git a/src/mips/regexp-macro-assembler-mips.cc b/src/mips/regexp-macro-assembler-mips.cc index cb210fed0..330ff2b8d 100644 --- a/src/mips/regexp-macro-assembler-mips.cc +++ b/src/mips/regexp-macro-assembler-mips.cc @@ -1056,7 +1056,7 @@ int RegExpMacroAssemblerMIPS::CheckStackGuardState(Address* return_address, ASSERT(*return_address <= re_code->instruction_start() + re_code->instruction_size()); - MaybeObject* result = Execution::HandleStackGuardInterrupt(); + MaybeObject* result = Execution::HandleStackGuardInterrupt(isolate); if (*code_handle != re_code) { // Return address no longer valid. int delta = code_handle->address() - re_code->address(); diff --git a/src/runtime.cc b/src/runtime.cc index fdbe1f547..d9c5bedc8 100644 --- a/src/runtime.cc +++ b/src/runtime.cc @@ -3763,7 +3763,7 @@ static RegExpImpl::IrregexpResult SearchRegExpNoCaptureMultiple( int required_registers = RegExpImpl::IrregexpPrepare(regexp, subject); if (required_registers < 0) return RegExpImpl::RE_EXCEPTION; - OffsetsVector registers(required_registers); + OffsetsVector registers(required_registers, isolate); Vector register_vector(registers.vector(), registers.length()); int subject_length = subject->length(); bool first = true; @@ -3836,7 +3836,7 @@ static RegExpImpl::IrregexpResult SearchRegExpMultiple( int required_registers = RegExpImpl::IrregexpPrepare(regexp, subject); if (required_registers < 0) return RegExpImpl::RE_EXCEPTION; - OffsetsVector registers(required_registers); + OffsetsVector registers(required_registers, isolate); Vector register_vector(registers.vector(), registers.length()); RegExpImpl::IrregexpResult result = @@ -3855,7 +3855,7 @@ static RegExpImpl::IrregexpResult SearchRegExpMultiple( if (result == RegExpImpl::RE_SUCCESS) { // Need to keep a copy of the previous match for creating last_match_info // at the end, so we have two vectors that we swap between. - OffsetsVector registers2(required_registers); + OffsetsVector registers2(required_registers, isolate); Vector prev_register_vector(registers2.vector(), registers2.length()); bool first = true; do { @@ -9200,13 +9200,13 @@ RUNTIME_FUNCTION(MaybeObject*, Runtime_StackGuard) { return isolate->StackOverflow(); } - return Execution::HandleStackGuardInterrupt(); + return Execution::HandleStackGuardInterrupt(isolate); } RUNTIME_FUNCTION(MaybeObject*, Runtime_Interrupt) { ASSERT(args.length() == 0); - return Execution::HandleStackGuardInterrupt(); + return Execution::HandleStackGuardInterrupt(isolate); } diff --git a/src/x64/regexp-macro-assembler-x64.cc b/src/x64/regexp-macro-assembler-x64.cc index 16730d21b..773fc4c16 100644 --- a/src/x64/regexp-macro-assembler-x64.cc +++ b/src/x64/regexp-macro-assembler-x64.cc @@ -1192,7 +1192,7 @@ int RegExpMacroAssemblerX64::CheckStackGuardState(Address* return_address, ASSERT(*return_address <= re_code->instruction_start() + re_code->instruction_size()); - MaybeObject* result = Execution::HandleStackGuardInterrupt(); + MaybeObject* result = Execution::HandleStackGuardInterrupt(isolate); if (*code_handle != re_code) { // Return address no longer valid intptr_t delta = code_handle->address() - re_code->address(); -- 2.34.1