OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 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 #ifndef V8_COMPILER_H_ | 5 #ifndef V8_COMPILER_H_ |
6 #define V8_COMPILER_H_ | 6 #define V8_COMPILER_H_ |
7 | 7 |
8 #include "src/allocation.h" | 8 #include "src/allocation.h" |
9 #include "src/ast/ast.h" | 9 #include "src/ast/ast.h" |
10 #include "src/bailout-reason.h" | 10 #include "src/bailout-reason.h" |
11 #include "src/compilation-dependencies.h" | 11 #include "src/compilation-dependencies.h" |
12 #include "src/source-position.h" | 12 #include "src/source-position.h" |
13 #include "src/zone.h" | 13 #include "src/zone.h" |
14 | 14 |
15 namespace v8 { | 15 namespace v8 { |
16 namespace internal { | 16 namespace internal { |
17 | 17 |
18 // Forward declarations. | 18 // Forward declarations. |
19 class CompilationInfo; | 19 class CompilationInfo; |
| 20 class CompilationJob; |
20 class JavaScriptFrame; | 21 class JavaScriptFrame; |
21 class OptimizedCompileJob; | |
22 class ParseInfo; | 22 class ParseInfo; |
23 class ScriptData; | 23 class ScriptData; |
24 | 24 |
25 // The V8 compiler API. | 25 // The V8 compiler API. |
26 // | 26 // |
27 // This is the central hub for dispatching to the various compilers within V8. | 27 // This is the central hub for dispatching to the various compilers within V8. |
28 // Logic for which compiler to choose and how to wire compilation results into | 28 // Logic for which compiler to choose and how to wire compilation results into |
29 // the object heap should be kept inside this class. | 29 // the object heap should be kept inside this class. |
30 // | 30 // |
31 // General strategy: Scripts are translated into anonymous functions w/o | 31 // General strategy: Scripts are translated into anonymous functions w/o |
(...skipping 11 matching lines...) Expand all Loading... |
43 // whereas successful compilation ensures the {is_compiled} predicate on the | 43 // whereas successful compilation ensures the {is_compiled} predicate on the |
44 // given function holds (except for live-edit, which compiles the world). | 44 // given function holds (except for live-edit, which compiles the world). |
45 | 45 |
46 static bool Compile(Handle<JSFunction> function, ClearExceptionFlag flag); | 46 static bool Compile(Handle<JSFunction> function, ClearExceptionFlag flag); |
47 static bool CompileBaseline(Handle<JSFunction> function); | 47 static bool CompileBaseline(Handle<JSFunction> function); |
48 static bool CompileOptimized(Handle<JSFunction> function, ConcurrencyMode); | 48 static bool CompileOptimized(Handle<JSFunction> function, ConcurrencyMode); |
49 static bool CompileDebugCode(Handle<JSFunction> function); | 49 static bool CompileDebugCode(Handle<JSFunction> function); |
50 static bool CompileDebugCode(Handle<SharedFunctionInfo> shared); | 50 static bool CompileDebugCode(Handle<SharedFunctionInfo> shared); |
51 static bool CompileForLiveEdit(Handle<Script> script); | 51 static bool CompileForLiveEdit(Handle<Script> script); |
52 | 52 |
53 // Generate and install code from previously queued optimization job. | 53 // Generate and install code from previously queued compilation job. |
54 static void FinalizeOptimizedCompileJob(OptimizedCompileJob* job); | 54 static void FinalizeCompilationJob(CompilationJob* job); |
55 | 55 |
56 // Give the compiler a chance to perform low-latency initialization tasks of | 56 // Give the compiler a chance to perform low-latency initialization tasks of |
57 // the given {function} on its instantiation. Note that only the runtime will | 57 // the given {function} on its instantiation. Note that only the runtime will |
58 // offer this chance, optimized closure instantiation will not call this. | 58 // offer this chance, optimized closure instantiation will not call this. |
59 static void PostInstantiation(Handle<JSFunction> function, PretenureFlag); | 59 static void PostInstantiation(Handle<JSFunction> function, PretenureFlag); |
60 | 60 |
61 // Parser::Parse, then Compiler::Analyze. | 61 // Parser::Parse, then Compiler::Analyze. |
62 static bool ParseAndAnalyze(ParseInfo* info); | 62 static bool ParseAndAnalyze(ParseInfo* info); |
63 // Rewrite, analyze scopes, and renumber. | 63 // Rewrite, analyze scopes, and renumber. |
64 static bool Analyze(ParseInfo* info); | 64 static bool Analyze(ParseInfo* info); |
(...skipping 500 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
565 // thread. The job is split into three phases which are called in sequence on | 565 // thread. The job is split into three phases which are called in sequence on |
566 // different threads and with different limitations: | 566 // different threads and with different limitations: |
567 // 1) CreateGraph: Runs on main thread. No major limitations. | 567 // 1) CreateGraph: Runs on main thread. No major limitations. |
568 // 2) OptimizeGraph: Runs concurrently. No heap allocation or handle derefs. | 568 // 2) OptimizeGraph: Runs concurrently. No heap allocation or handle derefs. |
569 // 3) GenerateCode: Runs on main thread. No dependency changes. | 569 // 3) GenerateCode: Runs on main thread. No dependency changes. |
570 // | 570 // |
571 // Each of the three phases can either fail, bail-out to full code generator or | 571 // Each of the three phases can either fail, bail-out to full code generator or |
572 // succeed. Apart from their return value, the status of the phase last run can | 572 // succeed. Apart from their return value, the status of the phase last run can |
573 // be checked using {last_status()} as well. | 573 // be checked using {last_status()} as well. |
574 // TODO(mstarzinger): Make CompilationInfo base embedded. | 574 // TODO(mstarzinger): Make CompilationInfo base embedded. |
575 class OptimizedCompileJob { | 575 class CompilationJob { |
576 public: | 576 public: |
577 explicit OptimizedCompileJob(CompilationInfo* info, const char* compiler_name) | 577 explicit CompilationJob(CompilationInfo* info, const char* compiler_name) |
578 : info_(info), compiler_name_(compiler_name), last_status_(SUCCEEDED) {} | 578 : info_(info), compiler_name_(compiler_name), last_status_(SUCCEEDED) {} |
579 virtual ~OptimizedCompileJob() {} | 579 virtual ~CompilationJob() {} |
580 | 580 |
581 enum Status { | 581 enum Status { |
582 FAILED, BAILED_OUT, SUCCEEDED | 582 FAILED, BAILED_OUT, SUCCEEDED |
583 }; | 583 }; |
584 | 584 |
585 MUST_USE_RESULT Status CreateGraph(); | 585 MUST_USE_RESULT Status CreateGraph(); |
586 MUST_USE_RESULT Status OptimizeGraph(); | 586 MUST_USE_RESULT Status OptimizeGraph(); |
587 MUST_USE_RESULT Status GenerateCode(); | 587 MUST_USE_RESULT Status GenerateCode(); |
588 | 588 |
589 Status last_status() const { return last_status_; } | 589 Status last_status() const { return last_status_; } |
(...skipping 31 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
621 MUST_USE_RESULT Status SetLastStatus(Status status) { | 621 MUST_USE_RESULT Status SetLastStatus(Status status) { |
622 last_status_ = status; | 622 last_status_ = status; |
623 return last_status_; | 623 return last_status_; |
624 } | 624 } |
625 }; | 625 }; |
626 | 626 |
627 } // namespace internal | 627 } // namespace internal |
628 } // namespace v8 | 628 } // namespace v8 |
629 | 629 |
630 #endif // V8_COMPILER_H_ | 630 #endif // V8_COMPILER_H_ |
OLD | NEW |