| OLD | NEW |
| 1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
| 2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
| 3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
| 4 // met: | 4 // met: |
| 5 // | 5 // |
| 6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
| 7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
| 8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
| 9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
| 10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
| (...skipping 960 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 971 ASSERT(closure->IsMarkedForParallelRecompilation()); | 971 ASSERT(closure->IsMarkedForParallelRecompilation()); |
| 972 | 972 |
| 973 Isolate* isolate = closure->GetIsolate(); | 973 Isolate* isolate = closure->GetIsolate(); |
| 974 // Here we prepare compile data for the parallel recompilation thread, but | 974 // Here we prepare compile data for the parallel recompilation thread, but |
| 975 // this still happens synchronously and interrupts execution. | 975 // this still happens synchronously and interrupts execution. |
| 976 Logger::TimerEventScope timer( | 976 Logger::TimerEventScope timer( |
| 977 isolate, Logger::TimerEventScope::v8_recompile_synchronous); | 977 isolate, Logger::TimerEventScope::v8_recompile_synchronous); |
| 978 | 978 |
| 979 if (!isolate->optimizing_compiler_thread()->IsQueueAvailable()) { | 979 if (!isolate->optimizing_compiler_thread()->IsQueueAvailable()) { |
| 980 if (FLAG_trace_parallel_recompilation) { | 980 if (FLAG_trace_parallel_recompilation) { |
| 981 PrintF(" ** Compilation queue, will retry opting on next run.\n"); | 981 PrintF(" ** Compilation queue full, will retry optimizing "); |
| 982 closure->PrintName(); |
| 983 PrintF(" on next run.\n"); |
| 982 } | 984 } |
| 983 return; | 985 return; |
| 984 } | 986 } |
| 985 | 987 |
| 986 SmartPointer<CompilationInfo> info(new CompilationInfoWithZone(closure)); | 988 SmartPointer<CompilationInfo> info(new CompilationInfoWithZone(closure)); |
| 987 VMState<COMPILER> state(isolate); | 989 VMState<COMPILER> state(isolate); |
| 988 PostponeInterruptsScope postpone(isolate); | 990 PostponeInterruptsScope postpone(isolate); |
| 989 | 991 |
| 990 Handle<SharedFunctionInfo> shared = info->shared_info(); | 992 Handle<SharedFunctionInfo> shared = info->shared_info(); |
| 991 int compiled_size = shared->end_position() - shared->start_position(); | 993 int compiled_size = shared->end_position() - shared->start_position(); |
| (...skipping 257 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 1249 if (FLAG_hydrogen_stats) { | 1251 if (FLAG_hydrogen_stats) { |
| 1250 unsigned size = zone()->allocation_size(); | 1252 unsigned size = zone()->allocation_size(); |
| 1251 size += info_->zone()->allocation_size() - info_zone_start_allocation_size_; | 1253 size += info_->zone()->allocation_size() - info_zone_start_allocation_size_; |
| 1252 int64_t ticks = OS::Ticks() - start_ticks_; | 1254 int64_t ticks = OS::Ticks() - start_ticks_; |
| 1253 isolate()->GetHStatistics()->SaveTiming(name_, ticks, size); | 1255 isolate()->GetHStatistics()->SaveTiming(name_, ticks, size); |
| 1254 } | 1256 } |
| 1255 } | 1257 } |
| 1256 | 1258 |
| 1257 | 1259 |
| 1258 bool CompilationPhase::ShouldProduceTraceOutput() const { | 1260 bool CompilationPhase::ShouldProduceTraceOutput() const { |
| 1259 // Produce trace output if flag is set so that the first letter of the | 1261 // Trace if the appropriate trace flag is set and the phase name's first |
| 1260 // phase name matches the command line parameter FLAG_trace_phase. | 1262 // character is in the FLAG_trace_phase command line parameter. |
| 1261 return (FLAG_trace_hydrogen && | 1263 bool tracing_on = info()->IsStub() ? |
| 1262 OS::StrChr(const_cast<char*>(FLAG_trace_phase), name_[0]) != NULL); | 1264 FLAG_trace_hydrogen_stubs : |
| 1265 FLAG_trace_hydrogen; |
| 1266 return (tracing_on && |
| 1267 OS::StrChr(const_cast<char*>(FLAG_trace_phase), name_[0]) != NULL); |
| 1263 } | 1268 } |
| 1264 | 1269 |
| 1265 } } // namespace v8::internal | 1270 } } // namespace v8::internal |
| OLD | NEW |