Commit 9e8fc0e8 authored by yangguo@chromium.org's avatar yangguo@chromium.org

Find plot range with only sampling ticks (profiling with only --prof).

R=jkummerow@chromium.org
BUG=

Review URL: https://chromiumcodereview.appspot.com/11543019

git-svn-id: http://v8.googlecode.com/svn/branches/bleeding_edge@13207 ce2b1a6d-e550-0410-aec6-3dcde31c8c00
parent e318155c
...@@ -94,8 +94,8 @@ var CodeKinds = { ...@@ -94,8 +94,8 @@ var CodeKinds = {
} }
var xrange_start = Infinity; var xrange_start;
var xrange_end = 0; var xrange_end;
var obj_index = 0; var obj_index = 0;
var execution_pauses = []; var execution_pauses = [];
var code_map = new CodeMap(); var code_map = new CodeMap();
...@@ -268,6 +268,38 @@ function Undistort() { ...@@ -268,6 +268,38 @@ function Undistort() {
} }
function FindPlotRange() {
var start_found = (xrange_start_override || xrange_start_override == 0);
var end_found = (xrange_end_override || xrange_end_override == 0);
xrange_start = start_found ? xrange_start_override : Infinity;
xrange_end = end_found ? xrange_end_override : -Infinity;
if (start_found && end_found) return;
var execution_ranges = kExecutionEvent.ranges;
for (var i = 0; i < execution_ranges.length; i++) {
if (execution_ranges[i].start < xrange_start && !start_found) {
xrange_start = execution_ranges[i].start;
}
if (execution_ranges[i].end > xrange_end && !end_found) {
xrange_end = execution_ranges[i].end;
}
}
for (codekind in CodeKinds) {
var ticks = CodeKinds[codekind].in_execution;
for (var i = 0; i < ticks.length; i++) {
if (ticks[i].tick < xrange_start && !start_found) {
xrange_start = ticks[i].tick;
}
if (ticks[i].tick > xrange_end && !end_found) {
xrange_end = ticks[i].tick;
}
}
}
}
function CollectData() { function CollectData() {
// Collect data from log. // Collect data from log.
var logreader = new LogReader( var logreader = new LogReader(
...@@ -297,17 +329,6 @@ function CollectData() { ...@@ -297,17 +329,6 @@ function CollectData() {
Undistort(); Undistort();
// Figure out plot range.
var execution_ranges = kExecutionEvent.ranges;
for (var i = 0; i < execution_ranges.length; i++) {
if (execution_ranges[i].start < xrange_start) {
xrange_start = execution_ranges[i].start;
}
if (execution_ranges[i].end > xrange_end) {
xrange_end = execution_ranges[i].end;
}
}
// Collect execution pauses. // Collect execution pauses.
for (name in TimerEvents) { for (name in TimerEvents) {
var event = TimerEvents[name]; var event = TimerEvents[name];
...@@ -466,10 +487,8 @@ function ExcludeRanges(include, exclude) { ...@@ -466,10 +487,8 @@ function ExcludeRanges(include, exclude) {
function GnuplotOutput() { function GnuplotOutput() {
xrange_start = (xrange_start_override || xrange_start_override == 0) FindPlotRange();
? xrange_start_override : xrange_start;
xrange_end = (xrange_end_override || xrange_end_override == 0)
? xrange_end_override : xrange_end;
print("set terminal pngcairo size " + kResX + "," + kResY + print("set terminal pngcairo size " + kResX + "," + kResY +
" enhanced font 'Helvetica,10'"); " enhanced font 'Helvetica,10'");
print("set yrange [0:" + (num_timer_event + 1) + "]"); print("set yrange [0:" + (num_timer_event + 1) + "]");
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment