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

Side by Side Diff: tools/plot-timer-events

Issue 12077043: Add option to limit tick processor to a time range. (Closed) Base URL: https://v8.googlecode.com/svn/branches/bleeding_edge
Patch Set: git cl dcommit Created 7 years, 10 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 | « test/mjsunit/tools/tickprocessor.js ('k') | tools/plot-timer-events.js » ('j') | no next file with comments »
Toggle Intra-line Diffs ('i') | Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
OLDNEW
1 #!/bin/sh 1 #!/bin/sh
2 2
3 # find the name of the log file to process, it must not start with a dash. 3 # find the name of the log file to process, it must not start with a dash.
4 log_file="v8.log" 4 log_file="v8.log"
5 for arg in "$@" 5 for arg in "$@"
6 do 6 do
7 if ! expr "X${arg}" : "^X-" > /dev/null; then 7 if ! expr "X${arg}" : "^X-" > /dev/null; then
8 log_file=${arg} 8 log_file=${arg}
9 fi 9 fi
10 done 10 done
(...skipping 14 matching lines...) Expand all
25 if [ ! -x "$d8_exec" ]; then 25 if [ ! -x "$d8_exec" ]; then
26 d8_exec=`grep -m 1 -o '".*/d8"' $log_file | sed 's/"//g'` 26 d8_exec=`grep -m 1 -o '".*/d8"' $log_file | sed 's/"//g'`
27 fi 27 fi
28 28
29 if [ ! -x "$d8_exec" ]; then 29 if [ ! -x "$d8_exec" ]; then
30 echo "d8 shell not found in $D8_PATH" 30 echo "d8 shell not found in $D8_PATH"
31 echo "To build, execute 'make native' from the V8 directory" 31 echo "To build, execute 'make native' from the V8 directory"
32 exit 1 32 exit 1
33 fi 33 fi
34 34
35 if [ -n "$DISTORTION" ]; then 35 if [[ "$@" != *--distortion* ]]; then
36 distortion=$DISTORTION
37 else
38 # Try to find out how much the instrumentation overhead is. 36 # Try to find out how much the instrumentation overhead is.
39 calibration_log=calibration.log 37 calibration_log=calibration.log
40 calibration_script="for (var i = 0; i < 1000000; i++) print();" 38 calibration_script="for (var i = 0; i < 1000000; i++) print();"
41 39
42 $d8_exec --nocrankshaft --prof --logfile $calibration_log \ 40 $d8_exec --nocrankshaft --prof --logfile $calibration_log \
43 --log-timer-events -e "$calibration_script" > /dev/null 41 --log-timer-events -e "$calibration_script" > /dev/null
44 t_1_start=`grep "timer-event-start,\"V8.Execute\"" $calibration_log \ 42 t_1_start=`grep "timer-event-start,\"V8.Execute\"" $calibration_log \
45 | tail -n1 | awk -F, '{print $3}'` 43 | tail -n1 | awk -F, '{print $3}'`
46 t_1_end=`grep "timer-event-end,\"V8.Execute\"" $calibration_log \ 44 t_1_end=`grep "timer-event-end,\"V8.Execute\"" $calibration_log \
47 | tail -n1 | awk -F, '{print $3}'` 45 | tail -n1 | awk -F, '{print $3}'`
48 n_1=`grep "timer-event\|tick" $calibration_log | wc -l` 46 n_1=`grep "timer-event\|tick" $calibration_log | wc -l`
49 47
50 $d8_exec --nocrankshaft --prof --logfile $calibration_log \ 48 $d8_exec --nocrankshaft --prof --logfile $calibration_log \
51 --log-internal-timer-events -e "$calibration_script" > /dev/null 49 --log-internal-timer-events -e "$calibration_script" > /dev/null
52 t_2_start=`grep "timer-event-start,\"V8.Execute\"" $calibration_log \ 50 t_2_start=`grep "timer-event-start,\"V8.Execute\"" $calibration_log \
53 | tail -n1 | awk -F, '{print $3}'` 51 | tail -n1 | awk -F, '{print $3}'`
54 t_2_end=`grep "timer-event-end,\"V8.Execute\"" $calibration_log \ 52 t_2_end=`grep "timer-event-end,\"V8.Execute\"" $calibration_log \
55 | tail -n1 | awk -F, '{print $3}'` 53 | tail -n1 | awk -F, '{print $3}'`
56 n_2=`grep "timer-event\|tick" $calibration_log | wc -l` 54 n_2=`grep "timer-event\|tick" $calibration_log | wc -l`
57 55
58 rm $calibration_log 56 rm $calibration_log
59 57
60 # Overhead in picoseconds. 58 # Overhead in picoseconds.
61 distortion=`echo "1000*(($t_1_end - $t_1_start) - ($t_2_end - $t_2_start)) \ 59 options=--distortion=
62 / ($n_1 - $n_2)" | bc` 60 options+=`echo "1000*(($t_1_end - $t_1_start) - ($t_2_end - $t_2_start)) \
61 / ($n_1 - $n_2)" | bc`
62 echo $options
63 fi 63 fi
64 64
65 if [ -n "$PLOT_RANGE" ]; then
66 plot_range=$PLOT_RANGE
67 else
68 plot_range=auto,auto
69 fi
70
71 echo "DISTORTION=$distortion"
72 echo "PLOT_RANGE=$plot_range"
73
74 echo -e "plot-range,$plot_range\ndistortion,$distortion" | cat - $log_file | 65 echo -e "plot-range,$plot_range\ndistortion,$distortion" | cat - $log_file |
75 $d8_exec $tools_path/csvparser.js \ 66 $d8_exec $tools_path/csvparser.js $tools_path/splaytree.js \
76 $tools_path/splaytree.js $tools_path/codemap.js \ 67 $tools_path/codemap.js $tools_path/profile.js $tools_path/profile_view.js \
77 $tools_path/logreader.js $tools_path/plot-timer-events.js \ 68 $tools_path/logreader.js $tools_path/tickprocessor.js \
69 $tools_path/plot-timer-events.js -- $options $@ | less \
78 2>/dev/null | gnuplot > timer-events.png 70 2>/dev/null | gnuplot > timer-events.png
OLDNEW
« no previous file with comments | « test/mjsunit/tools/tickprocessor.js ('k') | tools/plot-timer-events.js » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698