OLD | NEW |
1 // Copyright (c) 2012, the Dart project authors. Please see the AUTHORS file | 1 // Copyright (c) 2012, 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 #include "vm/code_generator.h" | 5 #include "vm/code_generator.h" |
6 | 6 |
7 #include "vm/assembler_macros.h" | 7 #include "vm/assembler_macros.h" |
8 #include "vm/ast.h" | 8 #include "vm/ast.h" |
9 #include "vm/bigint_operations.h" | 9 #include "vm/bigint_operations.h" |
10 #include "vm/code_patcher.h" | 10 #include "vm/code_patcher.h" |
(...skipping 1321 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1332 ic_data.raw(), | 1332 ic_data.raw(), |
1333 function.usage_counter(), | 1333 function.usage_counter(), |
1334 ic_data.NumberOfChecks(), | 1334 ic_data.NumberOfChecks(), |
1335 ic_data.is_closure_call() ? "closure" : "", | 1335 ic_data.is_closure_call() ? "closure" : "", |
1336 function.ToFullyQualifiedCString()); | 1336 function.ToFullyQualifiedCString()); |
1337 } | 1337 } |
1338 | 1338 |
1339 | 1339 |
1340 // This is called from function that needs to be optimized. | 1340 // This is called from function that needs to be optimized. |
1341 // The requesting function can be already optimized (reoptimization). | 1341 // The requesting function can be already optimized (reoptimization). |
| 1342 // Returns the Code object where to continue execution. |
1342 DEFINE_RUNTIME_ENTRY(OptimizeInvokedFunction, 1) { | 1343 DEFINE_RUNTIME_ENTRY(OptimizeInvokedFunction, 1) { |
1343 ASSERT(arguments.ArgCount() == | 1344 ASSERT(arguments.ArgCount() == |
1344 kOptimizeInvokedFunctionRuntimeEntry.argument_count()); | 1345 kOptimizeInvokedFunctionRuntimeEntry.argument_count()); |
1345 const intptr_t kLowInvocationCount = -100000000; | 1346 const intptr_t kLowInvocationCount = -100000000; |
1346 const Function& function = Function::CheckedHandle(arguments.ArgAt(0)); | 1347 const Function& function = Function::CheckedHandle(arguments.ArgAt(0)); |
| 1348 ASSERT(!function.IsNull()); |
1347 if (isolate->debugger()->HasBreakpoint(function)) { | 1349 if (isolate->debugger()->HasBreakpoint(function)) { |
1348 // We cannot set breakpoints in optimized code, so do not optimize | 1350 // We cannot set breakpoints in optimized code, so do not optimize |
1349 // the function. | 1351 // the function. |
1350 function.set_usage_counter(0); | 1352 function.set_usage_counter(0); |
| 1353 arguments.SetReturn(Code::Handle(function.CurrentCode())); |
1351 return; | 1354 return; |
1352 } | 1355 } |
1353 if (function.deoptimization_counter() >= | 1356 if (function.deoptimization_counter() >= |
1354 FLAG_deoptimization_counter_threshold) { | 1357 FLAG_deoptimization_counter_threshold) { |
1355 if (FLAG_trace_failed_optimization_attempts) { | 1358 if (FLAG_trace_failed_optimization_attempts) { |
1356 PrintCaller("Too Many Deoptimizations"); | 1359 PrintCaller("Too Many Deoptimizations"); |
1357 } | 1360 } |
1358 // TODO(srdjan): Investigate excessive deoptimization. | 1361 // TODO(srdjan): Investigate excessive deoptimization. |
1359 function.set_usage_counter(kLowInvocationCount); | 1362 function.set_usage_counter(kLowInvocationCount); |
| 1363 arguments.SetReturn(Code::Handle(function.CurrentCode())); |
1360 return; | 1364 return; |
1361 } | 1365 } |
1362 if ((FLAG_optimization_filter != NULL) && | 1366 if ((FLAG_optimization_filter != NULL) && |
1363 (strstr(function.ToFullyQualifiedCString(), | 1367 (strstr(function.ToFullyQualifiedCString(), |
1364 FLAG_optimization_filter) == NULL)) { | 1368 FLAG_optimization_filter) == NULL)) { |
1365 function.set_usage_counter(kLowInvocationCount); | 1369 function.set_usage_counter(kLowInvocationCount); |
| 1370 arguments.SetReturn(Code::Handle(function.CurrentCode())); |
1366 return; | 1371 return; |
1367 } | 1372 } |
1368 if (function.is_optimizable()) { | 1373 if (function.is_optimizable()) { |
1369 const Error& error = | 1374 const Error& error = |
1370 Error::Handle(Compiler::CompileOptimizedFunction(function)); | 1375 Error::Handle(Compiler::CompileOptimizedFunction(function)); |
1371 if (!error.IsNull()) { | 1376 if (!error.IsNull()) { |
1372 Exceptions::PropagateError(error); | 1377 Exceptions::PropagateError(error); |
1373 } | 1378 } |
1374 const Code& optimized_code = Code::Handle(function.CurrentCode()); | 1379 const Code& optimized_code = Code::Handle(function.CurrentCode()); |
1375 ASSERT(!optimized_code.IsNull()); | 1380 ASSERT(!optimized_code.IsNull()); |
1376 // Set usage counter for reoptimization. | 1381 // Set usage counter for reoptimization. |
1377 function.set_usage_counter( | 1382 function.set_usage_counter( |
1378 function.usage_counter() - FLAG_reoptimization_counter_threshold); | 1383 function.usage_counter() - FLAG_reoptimization_counter_threshold); |
1379 } else { | 1384 } else { |
1380 if (FLAG_trace_failed_optimization_attempts) { | 1385 if (FLAG_trace_failed_optimization_attempts) { |
1381 PrintCaller("Not Optimizable"); | 1386 PrintCaller("Not Optimizable"); |
1382 } | 1387 } |
1383 // TODO(5442338): Abort as this should not happen. | 1388 // TODO(5442338): Abort as this should not happen. |
1384 function.set_usage_counter(kLowInvocationCount); | 1389 function.set_usage_counter(kLowInvocationCount); |
1385 } | 1390 } |
| 1391 arguments.SetReturn(Code::Handle(function.CurrentCode())); |
1386 } | 1392 } |
1387 | 1393 |
1388 | 1394 |
1389 // The caller must be a static call in a Dart frame, or an entry frame. | 1395 // The caller must be a static call in a Dart frame, or an entry frame. |
1390 // Patch static call to point to valid code's entry point. | 1396 // Patch static call to point to valid code's entry point. |
1391 DEFINE_RUNTIME_ENTRY(FixCallersTarget, 0) { | 1397 DEFINE_RUNTIME_ENTRY(FixCallersTarget, 0) { |
1392 ASSERT(arguments.ArgCount() == | 1398 ASSERT(arguments.ArgCount() == |
1393 kFixCallersTargetRuntimeEntry.argument_count()); | 1399 kFixCallersTargetRuntimeEntry.argument_count()); |
1394 | 1400 |
1395 StackFrameIterator iterator(StackFrameIterator::kDontValidateFrames); | 1401 StackFrameIterator iterator(StackFrameIterator::kDontValidateFrames); |
(...skipping 392 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
1788 return; | 1794 return; |
1789 } | 1795 } |
1790 HeapTrace* heap_trace = Isolate::Current()->heap()->trace(); | 1796 HeapTrace* heap_trace = Isolate::Current()->heap()->trace(); |
1791 heap_trace->TraceStoreIntoObject(RawObject::ToAddr(object), | 1797 heap_trace->TraceStoreIntoObject(RawObject::ToAddr(object), |
1792 field_addr, | 1798 field_addr, |
1793 RawObject::ToAddr(value)); | 1799 RawObject::ToAddr(value)); |
1794 } | 1800 } |
1795 END_LEAF_RUNTIME_ENTRY | 1801 END_LEAF_RUNTIME_ENTRY |
1796 | 1802 |
1797 } // namespace dart | 1803 } // namespace dart |
OLD | NEW |