Chromium Code Reviews| 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 344 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 355 } | 355 } |
| 356 | 356 |
| 357 const int locals_limit = LUnallocated::kMaxFixedSlotIndex; | 357 const int locals_limit = LUnallocated::kMaxFixedSlotIndex; |
| 358 if (!info()->osr_ast_id().IsNone() && | 358 if (!info()->osr_ast_id().IsNone() && |
| 359 scope->num_parameters() + 1 + scope->num_stack_slots() > locals_limit) { | 359 scope->num_parameters() + 1 + scope->num_stack_slots() > locals_limit) { |
| 360 info()->set_bailout_reason(kTooManyParametersLocals); | 360 info()->set_bailout_reason(kTooManyParametersLocals); |
| 361 return AbortOptimization(); | 361 return AbortOptimization(); |
| 362 } | 362 } |
| 363 | 363 |
| 364 // Take --hydrogen-filter into account. | 364 // Take --hydrogen-filter into account. |
| 365 if (!info()->closure()->PassesHydrogenFilter()) { | 365 if (!info()->closure()->PassesFilter(FLAG_hydrogen_filter)) { |
| 366 info()->AbortOptimization(); | 366 info()->AbortOptimization(); |
| 367 return SetLastStatus(BAILED_OUT); | 367 return SetLastStatus(BAILED_OUT); |
| 368 } | 368 } |
| 369 | 369 |
| 370 // Recompile the unoptimized version of the code if the current version | 370 // Recompile the unoptimized version of the code if the current version |
| 371 // doesn't have deoptimization support. Alternatively, we may decide to | 371 // doesn't have deoptimization support. Alternatively, we may decide to |
| 372 // run the full code generator to get a baseline for the compile-time | 372 // run the full code generator to get a baseline for the compile-time |
| 373 // performance of the hydrogen-based compiler. | 373 // performance of the hydrogen-based compiler. |
| 374 bool should_recompile = !info()->shared_info()->has_deoptimization_support(); | 374 bool should_recompile = !info()->shared_info()->has_deoptimization_support(); |
| 375 if (should_recompile || FLAG_hydrogen_stats) { | 375 if (should_recompile || FLAG_hydrogen_stats) { |
| (...skipping 875 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 1251 size += info_->zone()->allocation_size() - info_zone_start_allocation_size_; | 1251 size += info_->zone()->allocation_size() - info_zone_start_allocation_size_; |
| 1252 int64_t ticks = OS::Ticks() - start_ticks_; | 1252 int64_t ticks = OS::Ticks() - start_ticks_; |
| 1253 isolate()->GetHStatistics()->SaveTiming(name_, ticks, size); | 1253 isolate()->GetHStatistics()->SaveTiming(name_, ticks, size); |
| 1254 } | 1254 } |
| 1255 } | 1255 } |
| 1256 | 1256 |
| 1257 | 1257 |
| 1258 bool CompilationPhase::ShouldProduceTraceOutput() const { | 1258 bool CompilationPhase::ShouldProduceTraceOutput() const { |
| 1259 // Trace if the appropriate trace flag is set and the phase name's first | 1259 // Trace if the appropriate trace flag is set and the phase name's first |
| 1260 // character is in the FLAG_trace_phase command line parameter. | 1260 // character is in the FLAG_trace_phase command line parameter. |
| 1261 bool tracing_on = info()->IsStub() ? | 1261 bool tracing_on = info()->IsStub() |
| 1262 FLAG_trace_hydrogen_stubs : | 1262 ? FLAG_trace_hydrogen_stubs |
| 1263 FLAG_trace_hydrogen; | 1263 : (FLAG_trace_hydrogen && |
| 1264 info()->closure()->PassesFilter(FLAG_trace_hydrogen_filter)); | |
|
Michael Starzinger
2013/08/26 18:00:00
This breaks --trace-hydrogen in debug mode with --
| |
| 1264 return (tracing_on && | 1265 return (tracing_on && |
| 1265 OS::StrChr(const_cast<char*>(FLAG_trace_phase), name_[0]) != NULL); | 1266 OS::StrChr(const_cast<char*>(FLAG_trace_phase), name_[0]) != NULL); |
| 1266 } | 1267 } |
| 1267 | 1268 |
| 1268 } } // namespace v8::internal | 1269 } } // namespace v8::internal |
| OLD | NEW |