OLD | NEW |
1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2013, the Dart project authors. Please see the AUTHORS file |
2 // for details. All rights reserved. Use of this source code is governed by a | 2 // for details. All rights reserved. Use of this source code is governed by a |
3 // BSD-style license that can be found in the LICENSE file. | 3 // BSD-style license that can be found in the LICENSE file. |
4 | 4 |
5 #if !defined(DART_PRECOMPILED_RUNTIME) | 5 #if !defined(DART_PRECOMPILED_RUNTIME) |
6 | 6 |
7 #include "vm/flow_graph_inliner.h" | 7 #include "vm/flow_graph_inliner.h" |
8 | 8 |
9 #include "vm/aot_optimizer.h" | 9 #include "vm/aot_optimizer.h" |
10 #include "vm/block_scheduler.h" | 10 #include "vm/block_scheduler.h" |
(...skipping 1253 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1264 const GrowableArray<CallSites::StaticCallInfo>& call_info = | 1264 const GrowableArray<CallSites::StaticCallInfo>& call_info = |
1265 inlining_call_sites_->static_calls(); | 1265 inlining_call_sites_->static_calls(); |
1266 TRACE_INLINING(THR_Print(" Static Calls (%" Pd ")\n", call_info.length())); | 1266 TRACE_INLINING(THR_Print(" Static Calls (%" Pd ")\n", call_info.length())); |
1267 for (intptr_t call_idx = 0; call_idx < call_info.length(); ++call_idx) { | 1267 for (intptr_t call_idx = 0; call_idx < call_info.length(); ++call_idx) { |
1268 StaticCallInstr* call = call_info[call_idx].call; | 1268 StaticCallInstr* call = call_info[call_idx].call; |
1269 const Function& target = call->function(); | 1269 const Function& target = call->function(); |
1270 if (!inliner_->AlwaysInline(target) && | 1270 if (!inliner_->AlwaysInline(target) && |
1271 (call_info[call_idx].ratio * 100) < FLAG_inlining_hotness) { | 1271 (call_info[call_idx].ratio * 100) < FLAG_inlining_hotness) { |
1272 if (trace_inlining()) { | 1272 if (trace_inlining()) { |
1273 String& name = String::Handle(target.QualifiedUserVisibleName()); | 1273 String& name = String::Handle(target.QualifiedUserVisibleName()); |
1274 THR_Print(" => %s (deopt count %d)\n Bailout: cold %f\n", | 1274 THR_Print(" => %s (deopt count %d, optimized instructions %" Pd |
| 1275 ")\n Bailout: cold %f\n", |
1275 name.ToCString(), target.deoptimization_counter(), | 1276 name.ToCString(), target.deoptimization_counter(), |
| 1277 target.optimized_instruction_count(), |
1276 call_info[call_idx].ratio); | 1278 call_info[call_idx].ratio); |
1277 } | 1279 } |
1278 PRINT_INLINING_TREE("Too cold", &call_info[call_idx].caller(), | 1280 PRINT_INLINING_TREE("Too cold", &call_info[call_idx].caller(), |
1279 &call->function(), call); | 1281 &call->function(), call); |
1280 continue; | 1282 continue; |
1281 } | 1283 } |
1282 GrowableArray<Value*> arguments(call->ArgumentCount()); | 1284 GrowableArray<Value*> arguments(call->ArgumentCount()); |
1283 for (int i = 0; i < call->ArgumentCount(); ++i) { | 1285 for (int i = 0; i < call->ArgumentCount(); ++i) { |
1284 arguments.Add(call->PushArgumentAt(i)->value()); | 1286 arguments.Add(call->PushArgumentAt(i)->value()); |
1285 } | 1287 } |
(...skipping 2451 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
3737 } | 3739 } |
3738 | 3740 |
3739 default: | 3741 default: |
3740 return false; | 3742 return false; |
3741 } | 3743 } |
3742 } | 3744 } |
3743 | 3745 |
3744 } // namespace dart | 3746 } // namespace dart |
3745 | 3747 |
3746 #endif // !defined(DART_PRECOMPILED_RUNTIME) | 3748 #endif // !defined(DART_PRECOMPILED_RUNTIME) |
OLD | NEW |