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/runtime/runtime-utils.h" | 5 #include "src/runtime/runtime-utils.h" |
6 | 6 |
7 #include "src/arguments.h" | 7 #include "src/arguments.h" |
8 #include "src/compiler.h" | 8 #include "src/compiler.h" |
9 #include "src/deoptimizer.h" | 9 #include "src/deoptimizer.h" |
10 #include "src/frames-inl.h" | 10 #include "src/frames-inl.h" |
11 #include "src/full-codegen/full-codegen.h" | 11 #include "src/full-codegen/full-codegen.h" |
12 #include "src/isolate-inl.h" | 12 #include "src/isolate-inl.h" |
13 #include "src/messages.h" | 13 #include "src/messages.h" |
14 #include "src/v8threads.h" | 14 #include "src/v8threads.h" |
15 #include "src/vm-state-inl.h" | 15 #include "src/vm-state-inl.h" |
16 | 16 |
17 namespace v8 { | 17 namespace v8 { |
18 namespace internal { | 18 namespace internal { |
19 | 19 |
20 RUNTIME_FUNCTION(Runtime_CompileLazy) { | 20 RUNTIME_FUNCTION(Runtime_CompileLazy) { |
21 HandleScope scope(isolate); | 21 HandleScope scope(isolate); |
22 DCHECK(args.length() == 1); | 22 DCHECK(args.length() == 1); |
23 CONVERT_ARG_HANDLE_CHECKED(JSFunction, function, 0); | 23 CONVERT_ARG_HANDLE_CHECKED(JSFunction, function, 0); |
| 24 |
24 #ifdef DEBUG | 25 #ifdef DEBUG |
25 if (FLAG_trace_lazy && !function->shared()->is_compiled()) { | 26 if (FLAG_trace_lazy && !function->shared()->is_compiled()) { |
26 PrintF("[unoptimized: "); | 27 PrintF("[unoptimized: "); |
27 function->PrintName(); | 28 function->PrintName(); |
28 PrintF("]\n"); | 29 PrintF("]\n"); |
29 } | 30 } |
30 #endif | 31 #endif |
| 32 |
31 StackLimitCheck check(isolate); | 33 StackLimitCheck check(isolate); |
32 if (check.JsHasOverflowed(1 * KB)) return isolate->StackOverflow(); | 34 if (check.JsHasOverflowed(1 * KB)) return isolate->StackOverflow(); |
33 | 35 if (!Compiler::Compile(function, KEEP_EXCEPTION)) { |
34 // Compile the target function. | 36 return isolate->heap()->exception(); |
35 DCHECK(function->shared()->allows_lazy_compilation()); | |
36 | |
37 Handle<Code> code; | |
38 ASSIGN_RETURN_FAILURE_ON_EXCEPTION(isolate, code, | |
39 Compiler::GetLazyCode(function)); | |
40 DCHECK(code->IsJavaScriptCode()); | |
41 | |
42 function->ReplaceCode(*code); | |
43 return *code; | |
44 } | |
45 | |
46 | |
47 namespace { | |
48 | |
49 Object* CompileOptimized(Isolate* isolate, Handle<JSFunction> function, | |
50 Compiler::ConcurrencyMode mode) { | |
51 StackLimitCheck check(isolate); | |
52 if (check.JsHasOverflowed(1 * KB)) return isolate->StackOverflow(); | |
53 | |
54 Handle<Code> code; | |
55 if (Compiler::GetOptimizedCode(function, mode).ToHandle(&code)) { | |
56 // Optimization succeeded, return optimized code. | |
57 function->ReplaceCode(*code); | |
58 } else { | |
59 // Optimization failed, get unoptimized code. | |
60 if (isolate->has_pending_exception()) { // Possible stack overflow. | |
61 return isolate->heap()->exception(); | |
62 } | |
63 code = Handle<Code>(function->shared()->code(), isolate); | |
64 if (code->kind() != Code::FUNCTION && | |
65 code->kind() != Code::OPTIMIZED_FUNCTION) { | |
66 ASSIGN_RETURN_FAILURE_ON_EXCEPTION( | |
67 isolate, code, Compiler::GetUnoptimizedCode(function)); | |
68 } | |
69 function->ReplaceCode(*code); | |
70 } | 37 } |
71 | 38 DCHECK(function->is_compiled()); |
72 DCHECK(function->code()->kind() == Code::FUNCTION || | |
73 function->code()->kind() == Code::OPTIMIZED_FUNCTION || | |
74 (function->code()->is_interpreter_entry_trampoline() && | |
75 function->shared()->HasBytecodeArray()) || | |
76 function->IsInOptimizationQueue()); | |
77 return function->code(); | 39 return function->code(); |
78 } | 40 } |
79 | 41 |
80 } // namespace | |
81 | |
82 | 42 |
83 RUNTIME_FUNCTION(Runtime_CompileOptimized_Concurrent) { | 43 RUNTIME_FUNCTION(Runtime_CompileOptimized_Concurrent) { |
84 HandleScope scope(isolate); | 44 HandleScope scope(isolate); |
85 DCHECK(args.length() == 1); | 45 DCHECK(args.length() == 1); |
86 CONVERT_ARG_HANDLE_CHECKED(JSFunction, function, 0); | 46 CONVERT_ARG_HANDLE_CHECKED(JSFunction, function, 0); |
87 return CompileOptimized(isolate, function, Compiler::CONCURRENT); | 47 StackLimitCheck check(isolate); |
| 48 if (check.JsHasOverflowed(1 * KB)) return isolate->StackOverflow(); |
| 49 if (!Compiler::CompileOptimized(function, Compiler::CONCURRENT)) { |
| 50 return isolate->heap()->exception(); |
| 51 } |
| 52 DCHECK(function->is_compiled()); |
| 53 return function->code(); |
88 } | 54 } |
89 | 55 |
90 | 56 |
91 RUNTIME_FUNCTION(Runtime_CompileOptimized_NotConcurrent) { | 57 RUNTIME_FUNCTION(Runtime_CompileOptimized_NotConcurrent) { |
92 HandleScope scope(isolate); | 58 HandleScope scope(isolate); |
93 DCHECK(args.length() == 1); | 59 DCHECK(args.length() == 1); |
94 CONVERT_ARG_HANDLE_CHECKED(JSFunction, function, 0); | 60 CONVERT_ARG_HANDLE_CHECKED(JSFunction, function, 0); |
95 return CompileOptimized(isolate, function, Compiler::NOT_CONCURRENT); | 61 StackLimitCheck check(isolate); |
| 62 if (check.JsHasOverflowed(1 * KB)) return isolate->StackOverflow(); |
| 63 if (!Compiler::CompileOptimized(function, Compiler::NOT_CONCURRENT)) { |
| 64 return isolate->heap()->exception(); |
| 65 } |
| 66 DCHECK(function->is_compiled()); |
| 67 return function->code(); |
96 } | 68 } |
97 | 69 |
98 | 70 |
99 RUNTIME_FUNCTION(Runtime_NotifyStubFailure) { | 71 RUNTIME_FUNCTION(Runtime_NotifyStubFailure) { |
100 HandleScope scope(isolate); | 72 HandleScope scope(isolate); |
101 DCHECK(args.length() == 0); | 73 DCHECK(args.length() == 0); |
102 Deoptimizer* deoptimizer = Deoptimizer::Grab(isolate); | 74 Deoptimizer* deoptimizer = Deoptimizer::Grab(isolate); |
103 DCHECK(AllowHeapAllocation::IsAllowed()); | 75 DCHECK(AllowHeapAllocation::IsAllowed()); |
104 delete deoptimizer; | 76 delete deoptimizer; |
105 return isolate->heap()->undefined_value(); | 77 return isolate->heap()->undefined_value(); |
(...skipping 324 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
430 DCHECK(is_valid_language_mode(args.smi_at(3))); | 402 DCHECK(is_valid_language_mode(args.smi_at(3))); |
431 LanguageMode language_mode = static_cast<LanguageMode>(args.smi_at(3)); | 403 LanguageMode language_mode = static_cast<LanguageMode>(args.smi_at(3)); |
432 DCHECK(args[4]->IsSmi()); | 404 DCHECK(args[4]->IsSmi()); |
433 Handle<SharedFunctionInfo> outer_info(args.at<JSFunction>(2)->shared(), | 405 Handle<SharedFunctionInfo> outer_info(args.at<JSFunction>(2)->shared(), |
434 isolate); | 406 isolate); |
435 return CompileGlobalEval(isolate, args.at<String>(1), outer_info, | 407 return CompileGlobalEval(isolate, args.at<String>(1), outer_info, |
436 language_mode, args.smi_at(4)); | 408 language_mode, args.smi_at(4)); |
437 } | 409 } |
438 } // namespace internal | 410 } // namespace internal |
439 } // namespace v8 | 411 } // namespace v8 |
OLD | NEW |