Commit 67154399 authored by machenbach's avatar machenbach Committed by Commit bot

Revert of [complier] Enable parallel eager inner function compilation with...

Revert of [complier] Enable parallel eager inner function compilation with compiler dispatcher. (patchset #11 id:260001 of https://codereview.chromium.org/2611313002/ )

Reason for revert:
Some crashes on mac:
https://build.chromium.org/p/client.v8/builders/V8%20Mac%20-%20debug/builds/11982/steps/Ignition%20-%20turbofan/logs/regress-crbug-429159
https://build.chromium.org/p/client.v8/builders/V8%20Mac%20GC%20Stress/builds/10966

Original issue's description:
> [complier] Enable parallel eager inner function compilation with compiler dispatcher.
>
> Enable enqueueing of eager inner function compilation onto the compiler
> dispatcher. This enables these tasks to be performed in parallel to
> compilation of the outer functio (only for Ignition functions).
> We currently synchronize to ensure all inner function compilations
>  are complete before executing the outer function - future work will
> allow outer function execution to happenin parallel to inner function
> compilation.
>
> BUG=v8:5203,v8:5215
>
> Review-Url: https://codereview.chromium.org/2611313002
> Cr-Commit-Position: refs/heads/master@{#42413}
> Committed: https://chromium.googlesource.com/v8/v8/+/f12661a1ece4e9c9cb8df5c2d349db960356e604

TBR=jochen@chromium.org,marja@chromium.org,mstarzinger@chromium.org,rmcilroy@chromium.org
# Skipping CQ checks because original CL landed less than 1 days ago.
NOPRESUBMIT=true
NOTREECHECKS=true
NOTRY=true
BUG=v8:5203,v8:5215

Review-Url: https://codereview.chromium.org/2637123002
Cr-Commit-Position: refs/heads/master@{#42416}
parent 29aaefa1
...@@ -66,8 +66,7 @@ CompilerDispatcherJob::CompilerDispatcherJob(Isolate* isolate, ...@@ -66,8 +66,7 @@ CompilerDispatcherJob::CompilerDispatcherJob(Isolate* isolate,
CompilerDispatcherTracer* tracer, CompilerDispatcherTracer* tracer,
Handle<SharedFunctionInfo> shared, Handle<SharedFunctionInfo> shared,
size_t max_stack_size) size_t max_stack_size)
: status_(CompileJobStatus::kInitial), : isolate_(isolate),
isolate_(isolate),
tracer_(tracer), tracer_(tracer),
shared_(Handle<SharedFunctionInfo>::cast( shared_(Handle<SharedFunctionInfo>::cast(
isolate_->global_handles()->Create(*shared))), isolate_->global_handles()->Create(*shared))),
...@@ -80,35 +79,7 @@ CompilerDispatcherJob::CompilerDispatcherJob(Isolate* isolate, ...@@ -80,35 +79,7 @@ CompilerDispatcherJob::CompilerDispatcherJob(Isolate* isolate,
if (trace_compiler_dispatcher_jobs_) { if (trace_compiler_dispatcher_jobs_) {
PrintF("CompilerDispatcherJob[%p] created for ", static_cast<void*>(this)); PrintF("CompilerDispatcherJob[%p] created for ", static_cast<void*>(this));
shared_->ShortPrint(); shared_->ShortPrint();
PrintF(" in initial state.\n"); PrintF("\n");
}
}
CompilerDispatcherJob::CompilerDispatcherJob(Isolate* isolate,
CompilerDispatcherTracer* tracer,
Handle<SharedFunctionInfo> shared,
FunctionLiteral* literal,
size_t max_stack_size)
: status_(CompileJobStatus::kAnalyzed),
isolate_(isolate),
tracer_(tracer),
shared_(Handle<SharedFunctionInfo>::cast(
isolate_->global_handles()->Create(*shared))),
max_stack_size_(max_stack_size),
zone_(new Zone(isolate->allocator(), ZONE_NAME)),
parse_info_(new ParseInfo(
zone_.get(), Handle<Script>(Script::cast(shared->script())))),
compile_info_(
new CompilationInfo(parse_info_.get(), Handle<JSFunction>::null())),
trace_compiler_dispatcher_jobs_(FLAG_trace_compiler_dispatcher_jobs) {
parse_info_->set_literal(literal);
parse_info_->set_shared_info(shared);
parse_info_->set_function_literal_id(shared->function_literal_id());
parse_info_->set_language_mode(literal->scope()->language_mode());
if (trace_compiler_dispatcher_jobs_) {
PrintF("CompilerDispatcherJob[%p] created for ", static_cast<void*>(this));
shared_->ShortPrint();
PrintF(" in Analyzed state.\n");
} }
} }
...@@ -281,7 +252,7 @@ bool CompilerDispatcherJob::FinalizeParsingOnMainThread() { ...@@ -281,7 +252,7 @@ bool CompilerDispatcherJob::FinalizeParsingOnMainThread() {
if (parse_info_->literal() == nullptr) { if (parse_info_->literal() == nullptr) {
status_ = CompileJobStatus::kFailed; status_ = CompileJobStatus::kFailed;
} else { } else {
status_ = CompileJobStatus::kReadyToAnalyze; status_ = CompileJobStatus::kReadyToAnalyse;
} }
DeferredHandleScope scope(isolate_); DeferredHandleScope scope(isolate_);
...@@ -312,38 +283,25 @@ bool CompilerDispatcherJob::FinalizeParsingOnMainThread() { ...@@ -312,38 +283,25 @@ bool CompilerDispatcherJob::FinalizeParsingOnMainThread() {
return status_ != CompileJobStatus::kFailed; return status_ != CompileJobStatus::kFailed;
} }
bool CompilerDispatcherJob::AnalyzeOnMainThread() { bool CompilerDispatcherJob::PrepareToCompileOnMainThread() {
DCHECK(ThreadId::Current().Equals(isolate_->thread_id())); DCHECK(ThreadId::Current().Equals(isolate_->thread_id()));
DCHECK(status() == CompileJobStatus::kReadyToAnalyze); DCHECK(status() == CompileJobStatus::kReadyToAnalyse);
COMPILER_DISPATCHER_TRACE_SCOPE(tracer_, kAnalyze); COMPILER_DISPATCHER_TRACE_SCOPE(tracer_, kPrepareToCompile);
if (trace_compiler_dispatcher_jobs_) { if (trace_compiler_dispatcher_jobs_) {
PrintF("CompilerDispatcherJob[%p]: Analyzing\n", static_cast<void*>(this)); PrintF("CompilerDispatcherJob[%p]: Preparing to compile\n",
static_cast<void*>(this));
} }
compile_info_.reset( compile_info_.reset(
new CompilationInfo(parse_info_.get(), Handle<JSFunction>::null())); new CompilationInfo(parse_info_.get(), Handle<JSFunction>::null()));
DeferredHandleScope scope(isolate_); DeferredHandleScope scope(isolate_);
{
if (Compiler::Analyze(parse_info_.get())) { if (Compiler::Analyze(parse_info_.get())) {
status_ = CompileJobStatus::kAnalyzed; compile_job_.reset(
} else { Compiler::PrepareUnoptimizedCompilationJob(compile_info_.get()));
status_ = CompileJobStatus::kFailed;
if (!isolate_->has_pending_exception()) isolate_->StackOverflow();
}
} }
compile_info_->set_deferred_handles(scope.Detach()); compile_info_->set_deferred_handles(scope.Detach());
return status_ != CompileJobStatus::kFailed;
}
bool CompilerDispatcherJob::PrepareToCompileOnMainThread() {
DCHECK(ThreadId::Current().Equals(isolate_->thread_id()));
DCHECK(status() == CompileJobStatus::kAnalyzed);
COMPILER_DISPATCHER_TRACE_SCOPE(tracer_, kPrepareToCompile);
compile_job_.reset(
Compiler::PrepareUnoptimizedCompilationJob(compile_info_.get()));
if (!compile_job_.get()) { if (!compile_job_.get()) {
if (!isolate_->has_pending_exception()) isolate_->StackOverflow(); if (!isolate_->has_pending_exception()) isolate_->StackOverflow();
status_ = CompileJobStatus::kFailed; status_ = CompileJobStatus::kFailed;
...@@ -443,10 +401,7 @@ double CompilerDispatcherJob::EstimateRuntimeOfNextStepInMs() const { ...@@ -443,10 +401,7 @@ double CompilerDispatcherJob::EstimateRuntimeOfNextStepInMs() const {
case CompileJobStatus::kParsed: case CompileJobStatus::kParsed:
return tracer_->EstimateFinalizeParsingInMs(); return tracer_->EstimateFinalizeParsingInMs();
case CompileJobStatus::kReadyToAnalyze: case CompileJobStatus::kReadyToAnalyse:
return tracer_->EstimateAnalyzeInMs();
case CompileJobStatus::kAnalyzed:
return tracer_->EstimatePrepareToCompileInMs(); return tracer_->EstimatePrepareToCompileInMs();
case CompileJobStatus::kReadyToCompile: case CompileJobStatus::kReadyToCompile:
......
...@@ -16,11 +16,9 @@ ...@@ -16,11 +16,9 @@
namespace v8 { namespace v8 {
namespace internal { namespace internal {
class AstValueFactory;
class CompilerDispatcherTracer; class CompilerDispatcherTracer;
class CompilationInfo; class CompilationInfo;
class CompilationJob; class CompilationJob;
class FunctionLiteral;
class Isolate; class Isolate;
class ParseInfo; class ParseInfo;
class Parser; class Parser;
...@@ -34,8 +32,7 @@ enum class CompileJobStatus { ...@@ -34,8 +32,7 @@ enum class CompileJobStatus {
kInitial, kInitial,
kReadyToParse, kReadyToParse,
kParsed, kParsed,
kReadyToAnalyze, kReadyToAnalyse,
kAnalyzed,
kReadyToCompile, kReadyToCompile,
kCompiled, kCompiled,
kFailed, kFailed,
...@@ -44,14 +41,9 @@ enum class CompileJobStatus { ...@@ -44,14 +41,9 @@ enum class CompileJobStatus {
class V8_EXPORT_PRIVATE CompilerDispatcherJob { class V8_EXPORT_PRIVATE CompilerDispatcherJob {
public: public:
// Creates a CompilerDispatcherJob in the initial state.
CompilerDispatcherJob(Isolate* isolate, CompilerDispatcherTracer* tracer, CompilerDispatcherJob(Isolate* isolate, CompilerDispatcherTracer* tracer,
Handle<SharedFunctionInfo> shared, Handle<SharedFunctionInfo> shared,
size_t max_stack_size); size_t max_stack_size);
// Creates a CompilerDispatcherJob in the analyzed state.
CompilerDispatcherJob(Isolate* isolate, CompilerDispatcherTracer* tracer,
Handle<SharedFunctionInfo> shared,
FunctionLiteral* literal, size_t max_stack_size);
~CompilerDispatcherJob(); ~CompilerDispatcherJob();
CompileJobStatus status() const { return status_; } CompileJobStatus status() const { return status_; }
...@@ -66,15 +58,11 @@ class V8_EXPORT_PRIVATE CompilerDispatcherJob { ...@@ -66,15 +58,11 @@ class V8_EXPORT_PRIVATE CompilerDispatcherJob {
// Transition from kReadyToParse to kParsed. // Transition from kReadyToParse to kParsed.
void Parse(); void Parse();
// Transition from kParsed to kReadyToAnalyze (or kFailed). Returns false // Transition from kParsed to kReadyToAnalyse (or kFailed). Returns false
// when transitioning to kFailed. In that case, an exception is pending. // when transitioning to kFailed. In that case, an exception is pending.
bool FinalizeParsingOnMainThread(); bool FinalizeParsingOnMainThread();
// Transition from kReadyToAnalyze to kAnalyzed (or kFailed). Returns // Transition from kReadyToAnalyse to kReadyToCompile (or kFailed). Returns
// false when transitioning to kFailed. In that case, an exception is pending.
bool AnalyzeOnMainThread();
// Transition from kAnalyzed to kReadyToCompile (or kFailed). Returns
// false when transitioning to kFailed. In that case, an exception is pending. // false when transitioning to kFailed. In that case, an exception is pending.
bool PrepareToCompileOnMainThread(); bool PrepareToCompileOnMainThread();
...@@ -98,7 +86,7 @@ class V8_EXPORT_PRIVATE CompilerDispatcherJob { ...@@ -98,7 +86,7 @@ class V8_EXPORT_PRIVATE CompilerDispatcherJob {
private: private:
FRIEND_TEST(CompilerDispatcherJobTest, ScopeChain); FRIEND_TEST(CompilerDispatcherJobTest, ScopeChain);
CompileJobStatus status_; CompileJobStatus status_ = CompileJobStatus::kInitial;
Isolate* isolate_; Isolate* isolate_;
CompilerDispatcherTracer* tracer_; CompilerDispatcherTracer* tracer_;
Handle<SharedFunctionInfo> shared_; // Global handle. Handle<SharedFunctionInfo> shared_; // Global handle.
......
...@@ -39,9 +39,6 @@ CompilerDispatcherTracer::Scope::~Scope() { ...@@ -39,9 +39,6 @@ CompilerDispatcherTracer::Scope::~Scope() {
case ScopeID::kFinalizeParsing: case ScopeID::kFinalizeParsing:
tracer_->RecordFinalizeParsing(elapsed); tracer_->RecordFinalizeParsing(elapsed);
break; break;
case ScopeID::kAnalyze:
tracer_->RecordAnalyze(elapsed);
break;
case ScopeID::kPrepareToCompile: case ScopeID::kPrepareToCompile:
tracer_->RecordPrepareToCompile(elapsed); tracer_->RecordPrepareToCompile(elapsed);
break; break;
...@@ -63,8 +60,6 @@ const char* CompilerDispatcherTracer::Scope::Name(ScopeID scope_id) { ...@@ -63,8 +60,6 @@ const char* CompilerDispatcherTracer::Scope::Name(ScopeID scope_id) {
return "V8.BackgroundCompile_Parse"; return "V8.BackgroundCompile_Parse";
case ScopeID::kFinalizeParsing: case ScopeID::kFinalizeParsing:
return "V8.BackgroundCompile_FinalizeParsing"; return "V8.BackgroundCompile_FinalizeParsing";
case ScopeID::kAnalyze:
return "V8.BackgroundCompile_Analyze";
case ScopeID::kPrepareToCompile: case ScopeID::kPrepareToCompile:
return "V8.BackgroundCompile_PrepareToCompile"; return "V8.BackgroundCompile_PrepareToCompile";
case ScopeID::kCompile: case ScopeID::kCompile:
...@@ -102,11 +97,6 @@ void CompilerDispatcherTracer::RecordFinalizeParsing(double duration_ms) { ...@@ -102,11 +97,6 @@ void CompilerDispatcherTracer::RecordFinalizeParsing(double duration_ms) {
finalize_parsing_events_.Push(duration_ms); finalize_parsing_events_.Push(duration_ms);
} }
void CompilerDispatcherTracer::RecordAnalyze(double duration_ms) {
base::LockGuard<base::Mutex> lock(&mutex_);
analyze_events_.Push(duration_ms);
}
void CompilerDispatcherTracer::RecordPrepareToCompile(double duration_ms) { void CompilerDispatcherTracer::RecordPrepareToCompile(double duration_ms) {
base::LockGuard<base::Mutex> lock(&mutex_); base::LockGuard<base::Mutex> lock(&mutex_);
prepare_compile_events_.Push(duration_ms); prepare_compile_events_.Push(duration_ms);
...@@ -138,11 +128,6 @@ double CompilerDispatcherTracer::EstimateFinalizeParsingInMs() const { ...@@ -138,11 +128,6 @@ double CompilerDispatcherTracer::EstimateFinalizeParsingInMs() const {
return Average(finalize_parsing_events_); return Average(finalize_parsing_events_);
} }
double CompilerDispatcherTracer::EstimateAnalyzeInMs() const {
base::LockGuard<base::Mutex> lock(&mutex_);
return Average(analyze_events_);
}
double CompilerDispatcherTracer::EstimatePrepareToCompileInMs() const { double CompilerDispatcherTracer::EstimatePrepareToCompileInMs() const {
base::LockGuard<base::Mutex> lock(&mutex_); base::LockGuard<base::Mutex> lock(&mutex_);
return Average(prepare_compile_events_); return Average(prepare_compile_events_);
...@@ -163,12 +148,11 @@ void CompilerDispatcherTracer::DumpStatistics() const { ...@@ -163,12 +148,11 @@ void CompilerDispatcherTracer::DumpStatistics() const {
PrintF( PrintF(
"CompilerDispatcherTracer: " "CompilerDispatcherTracer: "
"prepare_parsing=%.2lfms parsing=%.2lfms/kb finalize_parsing=%.2lfms " "prepare_parsing=%.2lfms parsing=%.2lfms/kb finalize_parsing=%.2lfms "
"analyze=%.2lfms prepare_compiling=%.2lfms compiling=%.2lfms/kb " "prepare_compiling=%.2lfms compiling=%.2lfms/kb "
"finalize_compiling=%.2lfms\n", "finalize_compilig=%.2lfms\n",
EstimatePrepareToParseInMs(), EstimateParseInMs(1 * KB), EstimatePrepareToParseInMs(), EstimateParseInMs(1 * KB),
EstimateFinalizeParsingInMs(), EstimateAnalyzeInMs(), EstimateFinalizeParsingInMs(), EstimatePrepareToCompileInMs(),
EstimatePrepareToCompileInMs(), EstimateCompileInMs(1 * KB), EstimateCompileInMs(1 * KB), EstimateFinalizeCompilingInMs());
EstimateFinalizeCompilingInMs());
} }
double CompilerDispatcherTracer::Average( double CompilerDispatcherTracer::Average(
......
...@@ -35,7 +35,6 @@ class V8_EXPORT_PRIVATE CompilerDispatcherTracer { ...@@ -35,7 +35,6 @@ class V8_EXPORT_PRIVATE CompilerDispatcherTracer {
kPrepareToParse, kPrepareToParse,
kParse, kParse,
kFinalizeParsing, kFinalizeParsing,
kAnalyze,
kPrepareToCompile, kPrepareToCompile,
kCompile, kCompile,
kFinalizeCompiling kFinalizeCompiling
...@@ -63,7 +62,6 @@ class V8_EXPORT_PRIVATE CompilerDispatcherTracer { ...@@ -63,7 +62,6 @@ class V8_EXPORT_PRIVATE CompilerDispatcherTracer {
void RecordPrepareToParse(double duration_ms); void RecordPrepareToParse(double duration_ms);
void RecordParse(double duration_ms, size_t source_length); void RecordParse(double duration_ms, size_t source_length);
void RecordFinalizeParsing(double duration_ms); void RecordFinalizeParsing(double duration_ms);
void RecordAnalyze(double duration_ms);
void RecordPrepareToCompile(double duration_ms); void RecordPrepareToCompile(double duration_ms);
void RecordCompile(double duration_ms, size_t ast_size_in_bytes); void RecordCompile(double duration_ms, size_t ast_size_in_bytes);
void RecordFinalizeCompiling(double duration_ms); void RecordFinalizeCompiling(double duration_ms);
...@@ -71,7 +69,6 @@ class V8_EXPORT_PRIVATE CompilerDispatcherTracer { ...@@ -71,7 +69,6 @@ class V8_EXPORT_PRIVATE CompilerDispatcherTracer {
double EstimatePrepareToParseInMs() const; double EstimatePrepareToParseInMs() const;
double EstimateParseInMs(size_t source_length) const; double EstimateParseInMs(size_t source_length) const;
double EstimateFinalizeParsingInMs() const; double EstimateFinalizeParsingInMs() const;
double EstimateAnalyzeInMs() const;
double EstimatePrepareToCompileInMs() const; double EstimatePrepareToCompileInMs() const;
double EstimateCompileInMs(size_t ast_size_in_bytes) const; double EstimateCompileInMs(size_t ast_size_in_bytes) const;
double EstimateFinalizeCompilingInMs() const; double EstimateFinalizeCompilingInMs() const;
...@@ -87,7 +84,6 @@ class V8_EXPORT_PRIVATE CompilerDispatcherTracer { ...@@ -87,7 +84,6 @@ class V8_EXPORT_PRIVATE CompilerDispatcherTracer {
base::RingBuffer<double> prepare_parse_events_; base::RingBuffer<double> prepare_parse_events_;
base::RingBuffer<std::pair<size_t, double>> parse_events_; base::RingBuffer<std::pair<size_t, double>> parse_events_;
base::RingBuffer<double> finalize_parsing_events_; base::RingBuffer<double> finalize_parsing_events_;
base::RingBuffer<double> analyze_events_;
base::RingBuffer<double> prepare_compile_events_; base::RingBuffer<double> prepare_compile_events_;
base::RingBuffer<std::pair<size_t, double>> compile_events_; base::RingBuffer<std::pair<size_t, double>> compile_events_;
base::RingBuffer<double> finalize_compiling_events_; base::RingBuffer<double> finalize_compiling_events_;
......
...@@ -8,7 +8,6 @@ ...@@ -8,7 +8,6 @@
#include "include/v8.h" #include "include/v8.h"
#include "src/base/platform/time.h" #include "src/base/platform/time.h"
#include "src/cancelable-task.h" #include "src/cancelable-task.h"
#include "src/compilation-info.h"
#include "src/compiler-dispatcher/compiler-dispatcher-job.h" #include "src/compiler-dispatcher/compiler-dispatcher-job.h"
#include "src/compiler-dispatcher/compiler-dispatcher-tracer.h" #include "src/compiler-dispatcher/compiler-dispatcher-tracer.h"
#include "src/flags.h" #include "src/flags.h"
...@@ -37,11 +36,7 @@ bool DoNextStepOnMainThread(Isolate* isolate, CompilerDispatcherJob* job, ...@@ -37,11 +36,7 @@ bool DoNextStepOnMainThread(Isolate* isolate, CompilerDispatcherJob* job,
job->FinalizeParsingOnMainThread(); job->FinalizeParsingOnMainThread();
break; break;
case CompileJobStatus::kReadyToAnalyze: case CompileJobStatus::kReadyToAnalyse:
job->AnalyzeOnMainThread();
break;
case CompileJobStatus::kAnalyzed:
job->PrepareToCompileOnMainThread(); job->PrepareToCompileOnMainThread();
break; break;
...@@ -229,7 +224,7 @@ CompilerDispatcher::~CompilerDispatcher() { ...@@ -229,7 +224,7 @@ CompilerDispatcher::~CompilerDispatcher() {
task_manager_->CancelAndWait(); task_manager_->CancelAndWait();
} }
bool CompilerDispatcher::CanEnqueue(Handle<SharedFunctionInfo> function) { bool CompilerDispatcher::Enqueue(Handle<SharedFunctionInfo> function) {
if (!IsEnabled()) return false; if (!IsEnabled()) return false;
DCHECK(FLAG_ignition); DCHECK(FLAG_ignition);
...@@ -250,17 +245,12 @@ bool CompilerDispatcher::CanEnqueue(Handle<SharedFunctionInfo> function) { ...@@ -250,17 +245,12 @@ bool CompilerDispatcher::CanEnqueue(Handle<SharedFunctionInfo> function) {
return false; return false;
} }
return true;
}
bool CompilerDispatcher::Enqueue(Handle<SharedFunctionInfo> function) {
if (!CanEnqueue(function)) return false;
if (IsEnqueued(function)) return true; if (IsEnqueued(function)) return true;
if (trace_compiler_dispatcher_) { if (trace_compiler_dispatcher_) {
PrintF("CompilerDispatcher: enqueuing "); PrintF("CompilerDispatcher: enqueuing ");
function->ShortPrint(); function->ShortPrint();
PrintF(" for parse and compile\n"); PrintF("\n");
} }
std::unique_ptr<CompilerDispatcherJob> job(new CompilerDispatcherJob( std::unique_ptr<CompilerDispatcherJob> job(new CompilerDispatcherJob(
...@@ -287,44 +277,11 @@ bool CompilerDispatcher::EnqueueAndStep(Handle<SharedFunctionInfo> function) { ...@@ -287,44 +277,11 @@ bool CompilerDispatcher::EnqueueAndStep(Handle<SharedFunctionInfo> function) {
return true; return true;
} }
bool CompilerDispatcher::Enqueue(Handle<SharedFunctionInfo> function, bool CompilerDispatcher::IsEnabled() const {
FunctionLiteral* literal) { v8::Isolate* v8_isolate = reinterpret_cast<v8::Isolate*>(isolate_);
if (!CanEnqueue(function)) return false; return FLAG_compiler_dispatcher && platform_->IdleTasksEnabled(v8_isolate);
if (IsEnqueued(function)) return true;
if (trace_compiler_dispatcher_) {
PrintF("CompilerDispatcher: enqueuing ");
function->ShortPrint();
PrintF(" for compile\n");
}
std::unique_ptr<CompilerDispatcherJob> job(new CompilerDispatcherJob(
isolate_, tracer_.get(), function, literal, max_stack_size_));
std::pair<int, int> key(Script::cast(function->script())->id(),
function->function_literal_id());
jobs_.insert(std::make_pair(key, std::move(job)));
ScheduleIdleTaskIfNeeded();
return true;
}
bool CompilerDispatcher::EnqueueAndStep(Handle<SharedFunctionInfo> function,
FunctionLiteral* literal) {
if (!Enqueue(function, literal)) return false;
if (trace_compiler_dispatcher_) {
PrintF("CompilerDispatcher: stepping ");
function->ShortPrint();
PrintF("\n");
}
JobMap::const_iterator job = GetJobFor(function);
DoNextStepOnMainThread(isolate_, job->second.get(),
ExceptionHandling::kSwallow);
ConsiderJobForBackgroundProcessing(job->second.get());
return true;
} }
bool CompilerDispatcher::IsEnabled() const { return FLAG_compiler_dispatcher; }
bool CompilerDispatcher::IsEnqueued(Handle<SharedFunctionInfo> function) const { bool CompilerDispatcher::IsEnqueued(Handle<SharedFunctionInfo> function) const {
return GetJobFor(function) != jobs_.end(); return GetJobFor(function) != jobs_.end();
} }
...@@ -345,16 +302,6 @@ void CompilerDispatcher::WaitForJobIfRunningOnBackground( ...@@ -345,16 +302,6 @@ void CompilerDispatcher::WaitForJobIfRunningOnBackground(
DCHECK(running_background_jobs_.find(job) == running_background_jobs_.end()); DCHECK(running_background_jobs_.find(job) == running_background_jobs_.end());
} }
bool CompilerDispatcher::FinishNow(CompilerDispatcherJob* job) {
WaitForJobIfRunningOnBackground(job);
while (!IsFinished(job)) {
DoNextStepOnMainThread(isolate_, job, ExceptionHandling::kThrow);
}
bool result = job->status() != CompileJobStatus::kFailed;
job->ResetOnMainThread();
return result;
}
bool CompilerDispatcher::FinishNow(Handle<SharedFunctionInfo> function) { bool CompilerDispatcher::FinishNow(Handle<SharedFunctionInfo> function) {
JobMap::const_iterator job = GetJobFor(function); JobMap::const_iterator job = GetJobFor(function);
CHECK(job != jobs_.end()); CHECK(job != jobs_.end());
...@@ -365,7 +312,12 @@ bool CompilerDispatcher::FinishNow(Handle<SharedFunctionInfo> function) { ...@@ -365,7 +312,12 @@ bool CompilerDispatcher::FinishNow(Handle<SharedFunctionInfo> function) {
PrintF(" now\n"); PrintF(" now\n");
} }
bool result = FinishNow(job->second.get()); WaitForJobIfRunningOnBackground(job->second.get());
while (!IsFinished(job->second.get())) {
DoNextStepOnMainThread(isolate_, job->second.get(),
ExceptionHandling::kThrow);
}
bool result = job->second->status() != CompileJobStatus::kFailed;
if (trace_compiler_dispatcher_) { if (trace_compiler_dispatcher_) {
PrintF("CompilerDispatcher: finished working on "); PrintF("CompilerDispatcher: finished working on ");
...@@ -374,6 +326,7 @@ bool CompilerDispatcher::FinishNow(Handle<SharedFunctionInfo> function) { ...@@ -374,6 +326,7 @@ bool CompilerDispatcher::FinishNow(Handle<SharedFunctionInfo> function) {
tracer_->DumpStatistics(); tracer_->DumpStatistics();
} }
job->second->ResetOnMainThread();
jobs_.erase(job); jobs_.erase(job);
if (jobs_.empty()) { if (jobs_.empty()) {
base::LockGuard<base::Mutex> lock(&mutex_); base::LockGuard<base::Mutex> lock(&mutex_);
...@@ -382,30 +335,6 @@ bool CompilerDispatcher::FinishNow(Handle<SharedFunctionInfo> function) { ...@@ -382,30 +335,6 @@ bool CompilerDispatcher::FinishNow(Handle<SharedFunctionInfo> function) {
return result; return result;
} }
bool CompilerDispatcher::FinishAllNow() {
if (trace_compiler_dispatcher_) {
PrintF("CompilerDispatcher: finishing all jobs now\n");
}
bool result = true;
for (auto& it : jobs_) {
result &= FinishNow(it.second.get());
}
if (trace_compiler_dispatcher_) {
PrintF("CompilerDispatcher: finished all jobs\n");
}
jobs_.clear();
{
base::LockGuard<base::Mutex> lock(&mutex_);
DCHECK(pending_background_jobs_.empty());
DCHECK(running_background_jobs_.empty());
abort_ = false;
}
return result;
}
void CompilerDispatcher::AbortAll(BlockingBehavior blocking) { void CompilerDispatcher::AbortAll(BlockingBehavior blocking) {
bool background_tasks_running = bool background_tasks_running =
task_manager_->TryAbortAll() == CancelableTaskManager::kTaskRunning; task_manager_->TryAbortAll() == CancelableTaskManager::kTaskRunning;
......
...@@ -28,7 +28,6 @@ namespace internal { ...@@ -28,7 +28,6 @@ namespace internal {
class CancelableTaskManager; class CancelableTaskManager;
class CompilerDispatcherJob; class CompilerDispatcherJob;
class CompilerDispatcherTracer; class CompilerDispatcherTracer;
class FunctionLiteral;
class Isolate; class Isolate;
class SharedFunctionInfo; class SharedFunctionInfo;
...@@ -69,10 +68,7 @@ class V8_EXPORT_PRIVATE CompilerDispatcher { ...@@ -69,10 +68,7 @@ class V8_EXPORT_PRIVATE CompilerDispatcher {
size_t max_stack_size); size_t max_stack_size);
~CompilerDispatcher(); ~CompilerDispatcher();
// Returns true if the compiler dispatcher is enabled. // Returns true if a job was enqueued.
bool IsEnabled() const;
// Enqueue a job for parse and compile. Returns true if a job was enqueued.
bool Enqueue(Handle<SharedFunctionInfo> function); bool Enqueue(Handle<SharedFunctionInfo> function);
// Like Enqueue, but also advances the job so that it can potentially // Like Enqueue, but also advances the job so that it can potentially
...@@ -80,27 +76,13 @@ class V8_EXPORT_PRIVATE CompilerDispatcher { ...@@ -80,27 +76,13 @@ class V8_EXPORT_PRIVATE CompilerDispatcher {
// true if the job was enqueued. // true if the job was enqueued.
bool EnqueueAndStep(Handle<SharedFunctionInfo> function); bool EnqueueAndStep(Handle<SharedFunctionInfo> function);
// Enqueue a job for compilation. Function must have already been parsed and
// analyzed and be ready for compilation. Returns true if a job was enqueued.
bool Enqueue(Handle<SharedFunctionInfo> function, FunctionLiteral* literal);
// Like Enqueue, but also advances the job so that it can potentially
// continue running on a background thread (if at all possible). Returns
// true if the job was enqueued.
bool EnqueueAndStep(Handle<SharedFunctionInfo> function,
FunctionLiteral* literal);
// Returns true if there is a pending job for the given function. // Returns true if there is a pending job for the given function.
bool IsEnqueued(Handle<SharedFunctionInfo> function) const; bool IsEnqueued(Handle<SharedFunctionInfo> function) const;
// Blocks until the given function is compiled (and does so as fast as // Blocks until the given function is compiled (and does so as fast as
// possible). Returns true if the compile job was successful. // possible). Returns true if the compile job was succesful.
bool FinishNow(Handle<SharedFunctionInfo> function); bool FinishNow(Handle<SharedFunctionInfo> function);
// Blocks until all enqueued jobs have finished. Returns true if all the
// compile jobs were successful.
bool FinishAllNow();
// Aborts a given job. Blocks if requested. // Aborts a given job. Blocks if requested.
void Abort(Handle<SharedFunctionInfo> function, BlockingBehavior blocking); void Abort(Handle<SharedFunctionInfo> function, BlockingBehavior blocking);
...@@ -113,8 +95,6 @@ class V8_EXPORT_PRIVATE CompilerDispatcher { ...@@ -113,8 +95,6 @@ class V8_EXPORT_PRIVATE CompilerDispatcher {
private: private:
FRIEND_TEST(CompilerDispatcherTest, EnqueueAndStep); FRIEND_TEST(CompilerDispatcherTest, EnqueueAndStep);
FRIEND_TEST(CompilerDispatcherTest, EnqueueParsed);
FRIEND_TEST(CompilerDispatcherTest, EnqueueAndStepParsed);
FRIEND_TEST(CompilerDispatcherTest, IdleTaskSmallIdleTime); FRIEND_TEST(CompilerDispatcherTest, IdleTaskSmallIdleTime);
FRIEND_TEST(CompilerDispatcherTest, CompileOnBackgroundThread); FRIEND_TEST(CompilerDispatcherTest, CompileOnBackgroundThread);
FRIEND_TEST(CompilerDispatcherTest, FinishNowWithBackgroundTask); FRIEND_TEST(CompilerDispatcherTest, FinishNowWithBackgroundTask);
...@@ -130,10 +110,9 @@ class V8_EXPORT_PRIVATE CompilerDispatcher { ...@@ -130,10 +110,9 @@ class V8_EXPORT_PRIVATE CompilerDispatcher {
class IdleTask; class IdleTask;
void WaitForJobIfRunningOnBackground(CompilerDispatcherJob* job); void WaitForJobIfRunningOnBackground(CompilerDispatcherJob* job);
bool IsEnabled() const;
void AbortInactiveJobs(); void AbortInactiveJobs();
bool CanEnqueue(Handle<SharedFunctionInfo> function);
JobMap::const_iterator GetJobFor(Handle<SharedFunctionInfo> shared) const; JobMap::const_iterator GetJobFor(Handle<SharedFunctionInfo> shared) const;
bool FinishNow(CompilerDispatcherJob* job);
void ConsiderJobForBackgroundProcessing(CompilerDispatcherJob* job); void ConsiderJobForBackgroundProcessing(CompilerDispatcherJob* job);
void ScheduleMoreBackgroundTasksIfNeeded(); void ScheduleMoreBackgroundTasksIfNeeded();
void ScheduleIdleTaskFromAnyThread(); void ScheduleIdleTaskFromAnyThread();
......
...@@ -15,7 +15,6 @@ ...@@ -15,7 +15,6 @@
#include "src/bootstrapper.h" #include "src/bootstrapper.h"
#include "src/codegen.h" #include "src/codegen.h"
#include "src/compilation-cache.h" #include "src/compilation-cache.h"
#include "src/compiler-dispatcher/compiler-dispatcher.h"
#include "src/compiler-dispatcher/optimizing-compile-dispatcher.h" #include "src/compiler-dispatcher/optimizing-compile-dispatcher.h"
#include "src/compiler/pipeline.h" #include "src/compiler/pipeline.h"
#include "src/crankshaft/hydrogen.h" #include "src/crankshaft/hydrogen.h"
...@@ -376,20 +375,6 @@ bool ShouldUseIgnition(CompilationInfo* info) { ...@@ -376,20 +375,6 @@ bool ShouldUseIgnition(CompilationInfo* info) {
return shared->PassesFilter(FLAG_ignition_filter); return shared->PassesFilter(FLAG_ignition_filter);
} }
bool UseAsmWasm(DeclarationScope* scope, Handle<SharedFunctionInfo> shared_info,
bool is_debug) {
return FLAG_validate_asm && scope->asm_module() &&
!shared_info->is_asm_wasm_broken() && !is_debug;
}
bool UseCompilerDispatcher(CompilerDispatcher* dispatcher,
DeclarationScope* scope,
Handle<SharedFunctionInfo> shared_info,
bool is_debug, bool will_serialize) {
return dispatcher->IsEnabled() && !is_debug && !will_serialize &&
!UseAsmWasm(scope, shared_info, is_debug);
}
CompilationJob* GetUnoptimizedCompilationJob(CompilationInfo* info) { CompilationJob* GetUnoptimizedCompilationJob(CompilationInfo* info) {
// Function should have been parsed and analyzed before creating a compilation // Function should have been parsed and analyzed before creating a compilation
// job. // job.
...@@ -442,34 +427,30 @@ void InstallUnoptimizedCode(CompilationInfo* info) { ...@@ -442,34 +427,30 @@ void InstallUnoptimizedCode(CompilationInfo* info) {
CompilationJob::Status FinalizeUnoptimizedCompilationJob(CompilationJob* job) { CompilationJob::Status FinalizeUnoptimizedCompilationJob(CompilationJob* job) {
CompilationJob::Status status = job->FinalizeJob(); CompilationJob::Status status = job->FinalizeJob();
if (status == CompilationJob::SUCCEEDED) { if (status == CompilationJob::SUCCEEDED) {
CompilationInfo* info = job->info(); EnsureFeedbackMetadata(job->info());
EnsureFeedbackMetadata(info); InstallUnoptimizedCode(job->info());
DCHECK(!info->code().is_null());
if (info->parse_info()->literal()->should_be_used_once_hint()) {
info->code()->MarkToBeExecutedOnce(info->isolate());
}
InstallUnoptimizedCode(info);
RecordFunctionCompilation(CodeEventListener::FUNCTION_TAG, info);
job->RecordUnoptimizedCompilationStats(); job->RecordUnoptimizedCompilationStats();
} }
return status; return status;
} }
bool Renumber(Isolate* isolate, Zone* zone, FunctionLiteral* literal, bool Renumber(ParseInfo* parse_info,
Handle<SharedFunctionInfo> shared_info,
Compiler::EagerInnerFunctionLiterals* eager_literals) { Compiler::EagerInnerFunctionLiterals* eager_literals) {
RuntimeCallTimerScope runtimeTimer(isolate, RuntimeCallTimerScope runtimeTimer(parse_info->isolate(),
&RuntimeCallStats::CompileRenumber); &RuntimeCallStats::CompileRenumber);
if (!AstNumbering::Renumber(isolate->stack_guard()->real_climit(), zone, if (!AstNumbering::Renumber(
literal, eager_literals)) { parse_info->isolate()->stack_guard()->real_climit(),
parse_info->zone(), parse_info->literal(), eager_literals)) {
return false; return false;
} }
Handle<SharedFunctionInfo> shared_info = parse_info->shared_info();
if (!shared_info.is_null()) { if (!shared_info.is_null()) {
shared_info->set_ast_node_count(literal->ast_node_count()); FunctionLiteral* lit = parse_info->literal();
if (literal->dont_optimize_reason() != kNoReason) { shared_info->set_ast_node_count(lit->ast_node_count());
shared_info->DisableOptimization(literal->dont_optimize_reason()); if (lit->dont_optimize_reason() != kNoReason) {
shared_info->DisableOptimization(lit->dont_optimize_reason());
} }
if (literal->flags() & AstProperties::kMustUseIgnitionTurbo) { if (lit->flags() & AstProperties::kMustUseIgnitionTurbo) {
shared_info->set_must_use_ignition_turbo(true); shared_info->set_must_use_ignition_turbo(true);
} }
} }
...@@ -477,7 +458,8 @@ bool Renumber(Isolate* isolate, Zone* zone, FunctionLiteral* literal, ...@@ -477,7 +458,8 @@ bool Renumber(Isolate* isolate, Zone* zone, FunctionLiteral* literal,
} }
bool GenerateUnoptimizedCode(CompilationInfo* info) { bool GenerateUnoptimizedCode(CompilationInfo* info) {
if (UseAsmWasm(info->scope(), info->shared_info(), info->is_debug())) { if (FLAG_validate_asm && info->scope()->asm_module() &&
!info->shared_info()->is_asm_wasm_broken() && !info->is_debug()) {
EnsureFeedbackMetadata(info); EnsureFeedbackMetadata(info);
MaybeHandle<FixedArray> wasm_data; MaybeHandle<FixedArray> wasm_data;
wasm_data = AsmJs::CompileAsmViaWasm(info); wasm_data = AsmJs::CompileAsmViaWasm(info);
...@@ -504,39 +486,29 @@ bool CompileUnoptimizedInnerFunctionsRecursively( ...@@ -504,39 +486,29 @@ bool CompileUnoptimizedInnerFunctionsRecursively(
CompilationInfo* outer_info) { CompilationInfo* outer_info) {
Isolate* isolate = outer_info->isolate(); Isolate* isolate = outer_info->isolate();
Handle<Script> script = outer_info->script(); Handle<Script> script = outer_info->script();
bool is_debug = outer_info->is_debug();
bool will_serialize = outer_info->will_serialize();
RuntimeCallTimerScope runtimeTimer(isolate, RuntimeCallTimerScope runtimeTimer(isolate,
&RuntimeCallStats::CompileInnerFunction); &RuntimeCallStats::CompileInnerFunction);
for (auto it : *literals) { for (auto it : *literals) {
FunctionLiteral* literal = it->value(); FunctionLiteral* literal = it->value();
Handle<SharedFunctionInfo> shared =
Compiler::GetSharedFunctionInfo(literal, script, outer_info); // Find any previously allocated shared function info for the given literal.
Handle<SharedFunctionInfo> shared;
MaybeHandle<SharedFunctionInfo> maybe_existing =
script->FindSharedFunctionInfo(isolate, literal);
if (maybe_existing.ToHandle(&shared)) {
DCHECK(!shared->is_toplevel());
// If we found an existing shared function info with compiled code,
// we are done.
if (shared->is_compiled()) continue; if (shared->is_compiled()) continue;
Compiler::EagerInnerFunctionLiterals inner_literals; } else {
if (!Renumber(isolate, outer_info->zone(), literal, shared, shared =
&inner_literals) || isolate->factory()->NewSharedFunctionInfoForLiteral(literal, script);
!CompileUnoptimizedInnerFunctionsRecursively(&inner_literals, shared->set_is_toplevel(false);
outer_info)) {
if (!isolate->has_pending_exception()) isolate->StackOverflow();
return false;
} }
// Try to enqueue the eager function on the compiler dispatcher.
CompilerDispatcher* dispatcher = isolate->compiler_dispatcher();
if (UseCompilerDispatcher(dispatcher, literal->scope(), shared, is_debug,
will_serialize) &&
dispatcher->EnqueueAndStep(shared, literal)) {
// If we have successfully queued up the function for compilation on the
// compiler dispatcher then we are done.
continue;
} else {
// Otherwise generate unoptimized code now.
Zone zone(isolate->allocator(), ZONE_NAME); Zone zone(isolate->allocator(), ZONE_NAME);
ParseInfo parse_info(&zone, script); ParseInfo parse_info(&zone, script);
CompilationInfo info(&parse_info, Handle<JSFunction>::null());
parse_info.set_literal(literal); parse_info.set_literal(literal);
parse_info.set_shared_info(shared); parse_info.set_shared_info(shared);
parse_info.set_function_literal_id(shared->function_literal_id()); parse_info.set_function_literal_id(shared->function_literal_id());
...@@ -545,13 +517,23 @@ bool CompileUnoptimizedInnerFunctionsRecursively( ...@@ -545,13 +517,23 @@ bool CompileUnoptimizedInnerFunctionsRecursively(
outer_info->parse_info()->ast_value_factory()); outer_info->parse_info()->ast_value_factory());
parse_info.set_ast_value_factory_owned(false); parse_info.set_ast_value_factory_owned(false);
if (will_serialize) info.PrepareForSerializing(); CompilationInfo info(&parse_info, Handle<JSFunction>::null());
if (is_debug) info.MarkAsDebug(); if (outer_info->will_serialize()) info.PrepareForSerializing();
if (outer_info->is_debug()) info.MarkAsDebug();
if (!GenerateUnoptimizedCode(&info)) { Compiler::EagerInnerFunctionLiterals inner_literals;
if (!Renumber(&parse_info, &inner_literals) ||
!CompileUnoptimizedInnerFunctionsRecursively(&inner_literals,
outer_info) ||
!GenerateUnoptimizedCode(&info)) {
if (!isolate->has_pending_exception()) isolate->StackOverflow(); if (!isolate->has_pending_exception()) isolate->StackOverflow();
return false; return false;
} }
DCHECK(!info.code().is_null());
RecordFunctionCompilation(CodeEventListener::FUNCTION_TAG, &info);
if (literal->should_be_used_once_hint()) {
info.code()->MarkToBeExecutedOnce(isolate);
} }
} }
return true; return true;
...@@ -569,15 +551,6 @@ bool CompileUnoptimizedCode(CompilationInfo* info) { ...@@ -569,15 +551,6 @@ bool CompileUnoptimizedCode(CompilationInfo* info) {
return false; return false;
} }
// TODO(rmcilroy): Remove this once the enqueued tasks can keep the parsed
// zone and handles alive and replace with a check in CompileLazy to finish
// the task itself.
if (isolate->compiler_dispatcher()->IsEnabled() &&
!isolate->compiler_dispatcher()->FinishAllNow()) {
if (!isolate->has_pending_exception()) isolate->StackOverflow();
return false;
}
return true; return true;
} }
...@@ -1153,10 +1126,7 @@ bool Compiler::Analyze(ParseInfo* info, ...@@ -1153,10 +1126,7 @@ bool Compiler::Analyze(ParseInfo* info,
&RuntimeCallStats::CompileAnalyse); &RuntimeCallStats::CompileAnalyse);
if (!Rewriter::Rewrite(info)) return false; if (!Rewriter::Rewrite(info)) return false;
DeclarationScope::Analyze(info, AnalyzeMode::kRegular); DeclarationScope::Analyze(info, AnalyzeMode::kRegular);
if (!Renumber(info->isolate(), info->zone(), info->literal(), if (!Renumber(info, eager_literals)) return false;
info->shared_info(), eager_literals)) {
return false;
}
DCHECK_NOT_NULL(info->scope()); DCHECK_NOT_NULL(info->scope());
return true; return true;
} }
...@@ -1763,8 +1733,13 @@ bool Compiler::FinalizeCompilationJob(CompilationJob* raw_job) { ...@@ -1763,8 +1733,13 @@ bool Compiler::FinalizeCompilationJob(CompilationJob* raw_job) {
return FinalizeOptimizedCompilationJob(job.get()) == return FinalizeOptimizedCompilationJob(job.get()) ==
CompilationJob::SUCCEEDED; CompilationJob::SUCCEEDED;
} else { } else {
return FinalizeUnoptimizedCompilationJob(job.get()) == if (FinalizeUnoptimizedCompilationJob(job.get()) ==
CompilationJob::SUCCEEDED; CompilationJob::SUCCEEDED) {
RecordFunctionCompilation(CodeEventListener::LAZY_COMPILE_TAG,
job->info());
return true;
}
return false;
} }
} }
......
...@@ -37,7 +37,7 @@ class ThreadedListZoneEntry; ...@@ -37,7 +37,7 @@ class ThreadedListZoneEntry;
// parameters which then can be executed. If the source code contains other // parameters which then can be executed. If the source code contains other
// functions, they might be compiled and allocated as part of the compilation // functions, they might be compiled and allocated as part of the compilation
// of the source code or deferred for lazy compilation at a later point. // of the source code or deferred for lazy compilation at a later point.
class V8_EXPORT_PRIVATE Compiler : public AllStatic { class Compiler : public AllStatic {
public: public:
enum ClearExceptionFlag { KEEP_EXCEPTION, CLEAR_EXCEPTION }; enum ClearExceptionFlag { KEEP_EXCEPTION, CLEAR_EXCEPTION };
enum ConcurrencyMode { NOT_CONCURRENT, CONCURRENT }; enum ConcurrencyMode { NOT_CONCURRENT, CONCURRENT };
......
...@@ -255,17 +255,11 @@ HARMONY_STAGED(FLAG_STAGED_FEATURES) ...@@ -255,17 +255,11 @@ HARMONY_STAGED(FLAG_STAGED_FEATURES)
HARMONY_SHIPPING(FLAG_SHIPPING_FEATURES) HARMONY_SHIPPING(FLAG_SHIPPING_FEATURES)
#undef FLAG_SHIPPING_FEATURES #undef FLAG_SHIPPING_FEATURES
// Flags for future configurations.
DEFINE_BOOL(future, false, DEFINE_BOOL(future, false,
"Implies all staged features that we want to ship in the " "Implies all staged features that we want to ship in the "
"not-too-far future") "not-too-far future")
DEFINE_IMPLICATION(future, ignition_staging) DEFINE_IMPLICATION(future, ignition_staging)
DEFINE_BOOL(ignition_staging, false, "use ignition with all staged features")
DEFINE_IMPLICATION(ignition_staging, ignition)
DEFINE_IMPLICATION(ignition_staging, compiler_dispatcher)
DEFINE_IMPLICATION(ignition_staging, validate_asm)
// Flags for experimental implementation features. // Flags for experimental implementation features.
DEFINE_BOOL(allocation_site_pretenuring, true, DEFINE_BOOL(allocation_site_pretenuring, true,
"pretenure with allocation sites") "pretenure with allocation sites")
...@@ -306,6 +300,9 @@ DEFINE_BOOL(string_slices, true, "use string slices") ...@@ -306,6 +300,9 @@ DEFINE_BOOL(string_slices, true, "use string slices")
// Flags for Ignition. // Flags for Ignition.
DEFINE_BOOL(ignition, false, "use ignition interpreter") DEFINE_BOOL(ignition, false, "use ignition interpreter")
DEFINE_BOOL(ignition_staging, false, "use ignition with all staged features")
DEFINE_IMPLICATION(ignition_staging, ignition)
DEFINE_IMPLICATION(ignition_staging, compiler_dispatcher)
DEFINE_STRING(ignition_filter, "*", "filter for ignition interpreter") DEFINE_STRING(ignition_filter, "*", "filter for ignition interpreter")
DEFINE_BOOL(ignition_deadcode, true, DEFINE_BOOL(ignition_deadcode, true,
"use ignition dead code elimination optimizer") "use ignition dead code elimination optimizer")
...@@ -523,6 +520,7 @@ DEFINE_BOOL(wasm_loop_assignment_analysis, true, ...@@ -523,6 +520,7 @@ DEFINE_BOOL(wasm_loop_assignment_analysis, true,
"perform loop assignment analysis for WASM") "perform loop assignment analysis for WASM")
DEFINE_BOOL(validate_asm, true, "validate asm.js modules before compiling") DEFINE_BOOL(validate_asm, true, "validate asm.js modules before compiling")
DEFINE_IMPLICATION(ignition_staging, validate_asm)
DEFINE_BOOL(suppress_asm_messages, false, DEFINE_BOOL(suppress_asm_messages, false,
"don't emit asm.js related messages (for golden file testing)") "don't emit asm.js related messages (for golden file testing)")
DEFINE_BOOL(trace_asm_time, false, "log asm.js timing info to the console") DEFINE_BOOL(trace_asm_time, false, "log asm.js timing info to the console")
......
...@@ -25,6 +25,8 @@ ...@@ -25,6 +25,8 @@
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
// Flags: --ignition-filter=f
// This test tests that full code compiled without debug break slots // This test tests that full code compiled without debug break slots
// is recompiled with debug break slots when debugging is started. // is recompiled with debug break slots when debugging is started.
......
...@@ -2,6 +2,8 @@ ...@@ -2,6 +2,8 @@
// Use of this source code is governed by a BSD-style license that can be // Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file. // found in the LICENSE file.
// Flags: --ignition-filter=f
var Debug = debug.Debug; var Debug = debug.Debug;
var break_count = 0; var break_count = 0;
......
...@@ -2,6 +2,7 @@ ...@@ -2,6 +2,7 @@
// Use of this source code is governed by a BSD-style license that can be // Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file. // found in the LICENSE file.
// Flags: --ignition-filter=f
// Flags: --no-turbo // Flags: --no-turbo
// TODO(yangguo): fix for turbofan // TODO(yangguo): fix for turbofan
...@@ -15,6 +16,6 @@ function f(x) { ...@@ -15,6 +16,6 @@ function f(x) {
var stack_lines = f(2).split("\n"); var stack_lines = f(2).split("\n");
assertTrue(/at f \(.*?:11:12\)/.test(stack_lines[1])); assertTrue(/at f \(.*?:12:12\)/.test(stack_lines[1]));
assertTrue(/at f \(.*?:13:10\)/.test(stack_lines[2])); assertTrue(/at f \(.*?:14:10\)/.test(stack_lines[2]));
assertTrue(/at f \(.*?:13:10\)/.test(stack_lines[3])); assertTrue(/at f \(.*?:14:10\)/.test(stack_lines[3]));
...@@ -2,7 +2,7 @@ ...@@ -2,7 +2,7 @@
// Use of this source code is governed by a BSD-style license that can be // Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file. // found in the LICENSE file.
// Flags: --ignition // Flags: --ignition --ignition-filter=-foo
function* foo() { yield 42 } function* foo() { yield 42 }
function* goo() { yield 42 } function* goo() { yield 42 }
......
...@@ -112,9 +112,7 @@ TEST_F(CompilerDispatcherJobTest, StateTransitions) { ...@@ -112,9 +112,7 @@ TEST_F(CompilerDispatcherJobTest, StateTransitions) {
job->Parse(); job->Parse();
ASSERT_TRUE(job->status() == CompileJobStatus::kParsed); ASSERT_TRUE(job->status() == CompileJobStatus::kParsed);
ASSERT_TRUE(job->FinalizeParsingOnMainThread()); ASSERT_TRUE(job->FinalizeParsingOnMainThread());
ASSERT_TRUE(job->status() == CompileJobStatus::kReadyToAnalyze); ASSERT_TRUE(job->status() == CompileJobStatus::kReadyToAnalyse);
ASSERT_TRUE(job->AnalyzeOnMainThread());
ASSERT_TRUE(job->status() == CompileJobStatus::kAnalyzed);
ASSERT_TRUE(job->PrepareToCompileOnMainThread()); ASSERT_TRUE(job->PrepareToCompileOnMainThread());
ASSERT_TRUE(job->status() == CompileJobStatus::kReadyToCompile); ASSERT_TRUE(job->status() == CompileJobStatus::kReadyToCompile);
job->Compile(); job->Compile();
...@@ -155,7 +153,6 @@ TEST_F(CompilerDispatcherJobTest, ScopeChain) { ...@@ -155,7 +153,6 @@ TEST_F(CompilerDispatcherJobTest, ScopeChain) {
job->PrepareToParseOnMainThread(); job->PrepareToParseOnMainThread();
job->Parse(); job->Parse();
ASSERT_TRUE(job->FinalizeParsingOnMainThread()); ASSERT_TRUE(job->FinalizeParsingOnMainThread());
ASSERT_TRUE(job->AnalyzeOnMainThread());
ASSERT_TRUE(job->PrepareToCompileOnMainThread()); ASSERT_TRUE(job->PrepareToCompileOnMainThread());
ASSERT_TRUE(job->status() == CompileJobStatus::kReadyToCompile); ASSERT_TRUE(job->status() == CompileJobStatus::kReadyToCompile);
...@@ -192,7 +189,6 @@ TEST_F(CompilerDispatcherJobTest, CompileAndRun) { ...@@ -192,7 +189,6 @@ TEST_F(CompilerDispatcherJobTest, CompileAndRun) {
job->PrepareToParseOnMainThread(); job->PrepareToParseOnMainThread();
job->Parse(); job->Parse();
job->FinalizeParsingOnMainThread(); job->FinalizeParsingOnMainThread();
job->AnalyzeOnMainThread();
job->PrepareToCompileOnMainThread(); job->PrepareToCompileOnMainThread();
job->Compile(); job->Compile();
ASSERT_TRUE(job->FinalizeCompilingOnMainThread()); ASSERT_TRUE(job->FinalizeCompilingOnMainThread());
...@@ -205,7 +201,7 @@ TEST_F(CompilerDispatcherJobTest, CompileAndRun) { ...@@ -205,7 +201,7 @@ TEST_F(CompilerDispatcherJobTest, CompileAndRun) {
ASSERT_TRUE(job->status() == CompileJobStatus::kInitial); ASSERT_TRUE(job->status() == CompileJobStatus::kInitial);
} }
TEST_F(CompilerDispatcherJobTest, CompileFailureToAnalyse) { TEST_F(CompilerDispatcherJobTest, CompileFailureToPrepare) {
std::string raw_script("() { var a = "); std::string raw_script("() { var a = ");
for (int i = 0; i < 100000; i++) { for (int i = 0; i < 100000; i++) {
raw_script += "'x' + "; raw_script += "'x' + ";
...@@ -219,7 +215,7 @@ TEST_F(CompilerDispatcherJobTest, CompileFailureToAnalyse) { ...@@ -219,7 +215,7 @@ TEST_F(CompilerDispatcherJobTest, CompileFailureToAnalyse) {
job->PrepareToParseOnMainThread(); job->PrepareToParseOnMainThread();
job->Parse(); job->Parse();
job->FinalizeParsingOnMainThread(); job->FinalizeParsingOnMainThread();
ASSERT_FALSE(job->AnalyzeOnMainThread()); ASSERT_FALSE(job->PrepareToCompileOnMainThread());
ASSERT_TRUE(job->status() == CompileJobStatus::kFailed); ASSERT_TRUE(job->status() == CompileJobStatus::kFailed);
ASSERT_TRUE(i_isolate()->has_pending_exception()); ASSERT_TRUE(i_isolate()->has_pending_exception());
...@@ -242,7 +238,6 @@ TEST_F(CompilerDispatcherJobTest, CompileFailureToFinalize) { ...@@ -242,7 +238,6 @@ TEST_F(CompilerDispatcherJobTest, CompileFailureToFinalize) {
job->PrepareToParseOnMainThread(); job->PrepareToParseOnMainThread();
job->Parse(); job->Parse();
job->FinalizeParsingOnMainThread(); job->FinalizeParsingOnMainThread();
job->AnalyzeOnMainThread();
job->PrepareToCompileOnMainThread(); job->PrepareToCompileOnMainThread();
job->Compile(); job->Compile();
ASSERT_FALSE(job->FinalizeCompilingOnMainThread()); ASSERT_FALSE(job->FinalizeCompilingOnMainThread());
...@@ -287,7 +282,6 @@ TEST_F(CompilerDispatcherJobTest, CompileOnBackgroundThread) { ...@@ -287,7 +282,6 @@ TEST_F(CompilerDispatcherJobTest, CompileOnBackgroundThread) {
job->PrepareToParseOnMainThread(); job->PrepareToParseOnMainThread();
job->Parse(); job->Parse();
job->FinalizeParsingOnMainThread(); job->FinalizeParsingOnMainThread();
job->AnalyzeOnMainThread();
job->PrepareToCompileOnMainThread(); job->PrepareToCompileOnMainThread();
base::Semaphore semaphore(0); base::Semaphore semaphore(0);
...@@ -320,7 +314,6 @@ TEST_F(CompilerDispatcherJobTest, LazyInnerFunctions) { ...@@ -320,7 +314,6 @@ TEST_F(CompilerDispatcherJobTest, LazyInnerFunctions) {
job->PrepareToParseOnMainThread(); job->PrepareToParseOnMainThread();
job->Parse(); job->Parse();
ASSERT_TRUE(job->FinalizeParsingOnMainThread()); ASSERT_TRUE(job->FinalizeParsingOnMainThread());
ASSERT_TRUE(job->AnalyzeOnMainThread());
ASSERT_TRUE(job->PrepareToCompileOnMainThread()); ASSERT_TRUE(job->PrepareToCompileOnMainThread());
job->Compile(); job->Compile();
ASSERT_TRUE(job->FinalizeCompilingOnMainThread()); ASSERT_TRUE(job->FinalizeCompilingOnMainThread());
......
...@@ -8,13 +8,10 @@ ...@@ -8,13 +8,10 @@
#include "src/base/platform/semaphore.h" #include "src/base/platform/semaphore.h"
#include "src/compiler-dispatcher/compiler-dispatcher-job.h" #include "src/compiler-dispatcher/compiler-dispatcher-job.h"
#include "src/compiler-dispatcher/compiler-dispatcher-tracer.h" #include "src/compiler-dispatcher/compiler-dispatcher-tracer.h"
#include "src/compiler.h"
#include "src/flags.h" #include "src/flags.h"
#include "src/handles.h" #include "src/handles.h"
#include "src/objects-inl.h" #include "src/objects-inl.h"
#include "src/parsing/parse-info.h"
#include "src/v8.h" #include "src/v8.h"
#include "src/zone/zone.h"
#include "test/unittests/compiler-dispatcher/compiler-dispatcher-helper.h" #include "test/unittests/compiler-dispatcher/compiler-dispatcher-helper.h"
#include "test/unittests/test-utils.h" #include "test/unittests/test-utils.h"
#include "testing/gtest/include/gtest/gtest.h" #include "testing/gtest/include/gtest/gtest.h"
...@@ -805,97 +802,5 @@ TEST_F(CompilerDispatcherTest, EnqueueAndStep) { ...@@ -805,97 +802,5 @@ TEST_F(CompilerDispatcherTest, EnqueueAndStep) {
platform.ClearBackgroundTasks(); platform.ClearBackgroundTasks();
} }
TEST_F(CompilerDispatcherTest, EnqueueParsed) {
MockPlatform platform;
CompilerDispatcher dispatcher(i_isolate(), &platform, FLAG_stack_size);
const char script[] =
"function g() { var y = 1; function f17(x) { return x * y }; return f17; "
"} g();";
Handle<JSFunction> f = Handle<JSFunction>::cast(RunJS(isolate(), script));
Handle<SharedFunctionInfo> shared(f->shared(), i_isolate());
Zone zone(i_isolate()->allocator(), ZONE_NAME);
ParseInfo parse_info(&zone, shared);
ASSERT_TRUE(Compiler::ParseAndAnalyze(&parse_info));
ASSERT_FALSE(dispatcher.IsEnqueued(shared));
ASSERT_TRUE(dispatcher.Enqueue(shared, parse_info.literal()));
ASSERT_TRUE(dispatcher.IsEnqueued(shared));
ASSERT_TRUE(dispatcher.jobs_.begin()->second->status() ==
CompileJobStatus::kAnalyzed);
ASSERT_TRUE(platform.IdleTaskPending());
platform.ClearIdleTask();
ASSERT_FALSE(platform.BackgroundTasksPending());
}
TEST_F(CompilerDispatcherTest, EnqueueAndStepParsed) {
MockPlatform platform;
CompilerDispatcher dispatcher(i_isolate(), &platform, FLAG_stack_size);
const char script[] =
"function g() { var y = 1; function f18(x) { return x * y }; return f18; "
"} g();";
Handle<JSFunction> f = Handle<JSFunction>::cast(RunJS(isolate(), script));
Handle<SharedFunctionInfo> shared(f->shared(), i_isolate());
Zone zone(i_isolate()->allocator(), ZONE_NAME);
ParseInfo parse_info(&zone, shared);
ASSERT_TRUE(Compiler::ParseAndAnalyze(&parse_info));
ASSERT_FALSE(dispatcher.IsEnqueued(shared));
ASSERT_TRUE(dispatcher.EnqueueAndStep(shared, parse_info.literal()));
ASSERT_TRUE(dispatcher.IsEnqueued(shared));
ASSERT_TRUE(dispatcher.jobs_.begin()->second->status() ==
CompileJobStatus::kReadyToCompile);
ASSERT_TRUE(platform.IdleTaskPending());
ASSERT_TRUE(platform.BackgroundTasksPending());
platform.ClearIdleTask();
platform.ClearBackgroundTasks();
}
TEST_F(CompilerDispatcherTest, FinishAllNow) {
MockPlatform platform;
CompilerDispatcher dispatcher(i_isolate(), &platform, FLAG_stack_size);
const char script1[] =
"function g() { var y = 1; function f19(x) { return x + y }; return f19; "
"} g();";
Handle<JSFunction> f1 = Handle<JSFunction>::cast(RunJS(isolate(), script1));
Handle<SharedFunctionInfo> shared1(f1->shared(), i_isolate());
const char script2[] =
"function g() { var y = 1; function f20(x) { return x * y }; return f20; "
"} g();";
Handle<JSFunction> f2 = Handle<JSFunction>::cast(RunJS(isolate(), script2));
Handle<SharedFunctionInfo> shared2(f2->shared(), i_isolate());
ASSERT_FALSE(shared1->is_compiled());
ASSERT_FALSE(shared2->is_compiled());
// Enqueue shared1 as already parsed.
Zone zone(i_isolate()->allocator(), ZONE_NAME);
ParseInfo parse_info(&zone, shared1);
ASSERT_TRUE(Compiler::ParseAndAnalyze(&parse_info));
ASSERT_TRUE(dispatcher.Enqueue(shared1, parse_info.literal()));
// Enqueue shared2 for parsing and compiling
ASSERT_TRUE(dispatcher.Enqueue(shared2));
ASSERT_TRUE(dispatcher.FinishAllNow());
// Finishing removes the SFI from the queue.
ASSERT_FALSE(dispatcher.IsEnqueued(shared1));
ASSERT_FALSE(dispatcher.IsEnqueued(shared2));
ASSERT_TRUE(shared1->is_compiled());
ASSERT_TRUE(shared2->is_compiled());
ASSERT_TRUE(platform.IdleTaskPending());
platform.ClearIdleTask();
}
} // namespace internal } // namespace internal
} // namespace v8 } // namespace v8
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