Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(161)

Side by Side Diff: src/isolate.cc

Issue 666223003: Simplify TurboFan's c1visualizer file handling. (Closed) Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
Patch Set: Created 6 years, 2 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
« no previous file with comments | « src/isolate.h ('k') | no next file » | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 // Copyright 2012 the V8 project authors. All rights reserved. 1 // Copyright 2012 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 <stdlib.h> 5 #include <stdlib.h>
6 6
7 #include <fstream> // NOLINT(readability/streams) 7 #include <fstream> // NOLINT(readability/streams)
8 8
9 #include "src/v8.h" 9 #include "src/v8.h"
10 10
(...skipping 1937 matching lines...) Expand 10 before | Expand all | Expand 10 after
1948 clear_scheduled_exception(); 1948 clear_scheduled_exception();
1949 1949
1950 // Deserializing may put strange things in the root array's copy of the 1950 // Deserializing may put strange things in the root array's copy of the
1951 // stack guard. 1951 // stack guard.
1952 heap_.SetStackLimits(); 1952 heap_.SetStackLimits();
1953 1953
1954 // Quiet the heap NaN if needed on target platform. 1954 // Quiet the heap NaN if needed on target platform.
1955 if (!create_heap_objects) Assembler::QuietNaN(heap_.nan_value()); 1955 if (!create_heap_objects) Assembler::QuietNaN(heap_.nan_value());
1956 1956
1957 if (FLAG_trace_turbo) { 1957 if (FLAG_trace_turbo) {
1958 // Erase the file. 1958 // Create an empty file.
1959 char buffer[512]; 1959 std::ofstream(GetTurboCfgFileName(), std::ios_base::trunc);
1960 Vector<char> filename(buffer, sizeof(buffer));
1961 GetTurboCfgFileName(filename);
1962 std::ofstream turbo_cfg_stream(filename.start(),
1963 std::fstream::out | std::fstream::trunc);
1964 } 1960 }
1965 1961
1966 // If we are deserializing, log non-function code objects and compiled 1962 // If we are deserializing, log non-function code objects and compiled
1967 // functions found in the snapshot. 1963 // functions found in the snapshot.
1968 if (!create_heap_objects && 1964 if (!create_heap_objects &&
1969 (FLAG_log_code || 1965 (FLAG_log_code ||
1970 FLAG_ll_prof || 1966 FLAG_ll_prof ||
1971 FLAG_perf_jit_prof || 1967 FLAG_perf_jit_prof ||
1972 FLAG_perf_basic_prof || 1968 FLAG_perf_basic_prof ||
1973 logger_->is_logging_code_events())) { 1969 logger_->is_logging_code_events())) {
(...skipping 395 matching lines...) Expand 10 before | Expand all | Expand 10 after
2369 2365
2370 2366
2371 BasicBlockProfiler* Isolate::GetOrCreateBasicBlockProfiler() { 2367 BasicBlockProfiler* Isolate::GetOrCreateBasicBlockProfiler() {
2372 if (basic_block_profiler_ == NULL) { 2368 if (basic_block_profiler_ == NULL) {
2373 basic_block_profiler_ = new BasicBlockProfiler(); 2369 basic_block_profiler_ = new BasicBlockProfiler();
2374 } 2370 }
2375 return basic_block_profiler_; 2371 return basic_block_profiler_;
2376 } 2372 }
2377 2373
2378 2374
2379 void Isolate::GetTurboCfgFileName(Vector<char> filename) { 2375 std::string Isolate::GetTurboCfgFileName() {
2380 if (FLAG_trace_turbo_cfg_file == NULL) { 2376 return FLAG_trace_turbo_cfg_file == NULL
2381 SNPrintF(filename, "turbo-%d-%d.cfg", base::OS::GetCurrentProcessId(), 2377 ? "turbo-" + std::to_string(base::OS::GetCurrentProcessId()) +
2382 id()); 2378 "-" + std::to_string(id()) + ".cfg"
2383 } else { 2379 : FLAG_trace_turbo_cfg_file;
2384 StrNCpy(filename, FLAG_trace_turbo_cfg_file, filename.length());
2385 }
2386 } 2380 }
2387 2381
2388 2382
2389 bool StackLimitCheck::JsHasOverflowed() const { 2383 bool StackLimitCheck::JsHasOverflowed() const {
2390 StackGuard* stack_guard = isolate_->stack_guard(); 2384 StackGuard* stack_guard = isolate_->stack_guard();
2391 #ifdef USE_SIMULATOR 2385 #ifdef USE_SIMULATOR
2392 // The simulator uses a separate JS stack. 2386 // The simulator uses a separate JS stack.
2393 Address jssp_address = Simulator::current(isolate_)->get_sp(); 2387 Address jssp_address = Simulator::current(isolate_)->get_sp();
2394 uintptr_t jssp = reinterpret_cast<uintptr_t>(jssp_address); 2388 uintptr_t jssp = reinterpret_cast<uintptr_t>(jssp_address);
2395 if (jssp < stack_guard->real_jslimit()) return true; 2389 if (jssp < stack_guard->real_jslimit()) return true;
2396 #endif // USE_SIMULATOR 2390 #endif // USE_SIMULATOR
2397 return GetCurrentStackPosition() < stack_guard->real_climit(); 2391 return GetCurrentStackPosition() < stack_guard->real_climit();
2398 } 2392 }
2399 2393
2400 2394
2401 bool PostponeInterruptsScope::Intercept(StackGuard::InterruptFlag flag) { 2395 bool PostponeInterruptsScope::Intercept(StackGuard::InterruptFlag flag) {
2402 // First check whether the previous scope intercepts. 2396 // First check whether the previous scope intercepts.
2403 if (prev_ && prev_->Intercept(flag)) return true; 2397 if (prev_ && prev_->Intercept(flag)) return true;
2404 // Then check whether this scope intercepts. 2398 // Then check whether this scope intercepts.
2405 if ((flag & intercept_mask_)) { 2399 if ((flag & intercept_mask_)) {
2406 intercepted_flags_ |= flag; 2400 intercepted_flags_ |= flag;
2407 return true; 2401 return true;
2408 } 2402 }
2409 return false; 2403 return false;
2410 } 2404 }
2411 2405
2412 } } // namespace v8::internal 2406 } } // namespace v8::internal
OLDNEW
« no previous file with comments | « src/isolate.h ('k') | no next file » | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698