OLD | NEW |
---|---|
1 // Copyright 2014 the V8 project authors. All rights reserved. | 1 // Copyright 2014 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/background-parsing-task.h" | 5 #include "src/background-parsing-task.h" |
6 | 6 |
7 namespace v8 { | 7 namespace v8 { |
8 namespace internal { | 8 namespace internal { |
9 | 9 |
10 BackgroundParsingTask::BackgroundParsingTask( | 10 BackgroundParsingTask::BackgroundParsingTask( |
11 StreamedSource* source, ScriptCompiler::CompileOptions options, | 11 StreamedSource* source, ScriptCompiler::CompileOptions options, |
12 int stack_size, Isolate* isolate) | 12 int stack_size, Isolate* isolate) |
13 : source_(source), options_(options), stack_size_(stack_size) { | 13 : source_(source), stack_size_(stack_size) { |
14 // Prepare the data for the internalization phase and compilation phase, which | |
15 // will happen in the main thread after parsing. | |
16 source->info.Reset(new i::CompilationInfoWithZone(source->source_stream.get(), | |
17 source->encoding, isolate)); | |
18 source->info->MarkAsGlobal(); | |
19 | |
20 // We don't set the context to the CompilationInfo yet, because the background | |
marja
2015/03/09 09:18:07
This comment is probably still relevant; why was i
titzer
2015/03/09 13:03:09
Done.
| |
21 // thread cannot do anything with it anyway. We set it just before compilation | |
22 // on the foreground thread. | |
23 DCHECK(options == ScriptCompiler::kProduceParserCache || | 14 DCHECK(options == ScriptCompiler::kProduceParserCache || |
24 options == ScriptCompiler::kProduceCodeCache || | 15 options == ScriptCompiler::kProduceCodeCache || |
25 options == ScriptCompiler::kNoCompileOptions); | 16 options == ScriptCompiler::kNoCompileOptions); |
26 source->allow_lazy = | |
27 !i::Compiler::DebuggerWantsEagerCompilation(source->info.get()); | |
28 | 17 |
29 if (!source->allow_lazy && options_ == ScriptCompiler::kProduceParserCache) { | 18 // Prepare the data for the internalization phase and compilation phase, which |
19 // will happen in the main thread after parsing. | |
20 Zone* zone = new Zone(); | |
marja
2015/03/09 09:18:07
Who deletes Zone? ParseInfo doesn't own it afaics.
titzer
2015/03/09 13:03:09
I've changed it back to a SmartPointer in Backgrou
| |
21 ParseInfo* info = new ParseInfo(zone); | |
22 source->info.Reset(info); | |
23 info->set_isolate(isolate); | |
24 info->set_source_stream(source->source_stream.get()); | |
25 info->set_source_stream_encoding(source->encoding); | |
26 info->set_hash_seed(isolate->heap()->HashSeed()); | |
27 info->set_global(); | |
28 info->set_unicode_cache(&source_->unicode_cache); | |
29 | |
30 bool disable_lazy = Compiler::DebuggerWantsEagerCompilation(isolate); | |
31 if (disable_lazy && options == ScriptCompiler::kProduceParserCache) { | |
30 // Producing cached data while parsing eagerly is not supported. | 32 // Producing cached data while parsing eagerly is not supported. |
31 options_ = ScriptCompiler::kNoCompileOptions; | 33 options = ScriptCompiler::kNoCompileOptions; |
32 } | 34 } |
33 source->hash_seed = isolate->heap()->HashSeed(); | 35 |
36 info->set_compile_options(options); | |
37 info->set_allow_lazy_parsing(!disable_lazy); | |
34 } | 38 } |
35 | 39 |
36 | 40 |
37 void BackgroundParsingTask::Run() { | 41 void BackgroundParsingTask::Run() { |
38 DisallowHeapAllocation no_allocation; | 42 DisallowHeapAllocation no_allocation; |
39 DisallowHandleAllocation no_handles; | 43 DisallowHandleAllocation no_handles; |
40 DisallowHandleDereference no_deref; | 44 DisallowHandleDereference no_deref; |
41 | 45 |
42 ScriptData* script_data = NULL; | 46 ScriptData* script_data = NULL; |
43 if (options_ == ScriptCompiler::kProduceParserCache || | 47 ScriptCompiler::CompileOptions options = source_->info->compile_options(); |
44 options_ == ScriptCompiler::kProduceCodeCache) { | 48 if (options == ScriptCompiler::kProduceParserCache || |
45 source_->info->SetCachedData(&script_data, options_); | 49 options == ScriptCompiler::kProduceCodeCache) { |
50 source_->info->set_cached_data(&script_data); | |
46 } | 51 } |
47 | 52 |
48 uintptr_t stack_limit = | 53 uintptr_t stack_limit = |
49 reinterpret_cast<uintptr_t>(&stack_limit) - stack_size_ * KB; | 54 reinterpret_cast<uintptr_t>(&stack_limit) - stack_size_ * KB; |
50 | 55 |
56 source_->info->set_stack_limit(stack_limit); | |
51 // Parser needs to stay alive for finalizing the parsing on the main | 57 // Parser needs to stay alive for finalizing the parsing on the main |
52 // thread. Passing &parse_info is OK because Parser doesn't store it. | 58 // thread. Passing &parse_info is OK because Parser doesn't store it. |
53 source_->parser.Reset(new Parser(source_->info.get(), stack_limit, | 59 source_->parser.Reset(new Parser(source_->info.get())); |
54 source_->hash_seed, | |
55 &source_->unicode_cache)); | |
56 source_->parser->set_allow_lazy(source_->allow_lazy); | |
57 source_->parser->ParseOnBackground(source_->info.get()); | 60 source_->parser->ParseOnBackground(source_->info.get()); |
58 | 61 |
59 if (script_data != NULL) { | 62 if (script_data != NULL) { |
60 source_->cached_data.Reset(new ScriptCompiler::CachedData( | 63 source_->cached_data.Reset(new ScriptCompiler::CachedData( |
61 script_data->data(), script_data->length(), | 64 script_data->data(), script_data->length(), |
62 ScriptCompiler::CachedData::BufferOwned)); | 65 ScriptCompiler::CachedData::BufferOwned)); |
63 script_data->ReleaseDataOwnership(); | 66 script_data->ReleaseDataOwnership(); |
64 delete script_data; | 67 delete script_data; |
65 } | 68 } |
66 } | 69 } |
67 } | 70 } |
68 } // namespace v8::internal | 71 } // namespace v8::internal |
OLD | NEW |