OLD | NEW |
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 23 matching lines...) Expand all Loading... |
34 | 34 |
35 if [ -n "$DISTORTION" ]; then | 35 if [ -n "$DISTORTION" ]; then |
36 distortion=$DISTORTION | 36 distortion=$DISTORTION |
37 else | 37 else |
38 # Try to find out how much the instrumentation overhead is. | 38 # Try to find out how much the instrumentation overhead is. |
39 calibration_log=calibration.log | 39 calibration_log=calibration.log |
40 calibration_script="for (var i = 0; i < 1000000; i++) print();" | 40 calibration_script="for (var i = 0; i < 1000000; i++) print();" |
41 | 41 |
42 $d8_exec --nocrankshaft --prof --logfile $calibration_log \ | 42 $d8_exec --nocrankshaft --prof --logfile $calibration_log \ |
43 --log-timer-events -e "$calibration_script" > /dev/null | 43 --log-timer-events -e "$calibration_script" > /dev/null |
44 t_1=`grep "V8.Execute" $calibration_log | tail -n1 | awk -F, '{print $4}'` | 44 t_1_start=`grep "timer-event-start,\"V8.Execute\"" $calibration_log \ |
45 n_1=`grep "timer-event" $calibration_log | wc -l` | 45 | tail -n1 | awk -F, '{print $3}'` |
| 46 t_1_end=`grep "timer-event-end,\"V8.Execute\"" $calibration_log \ |
| 47 | tail -n1 | awk -F, '{print $3}'` |
| 48 n_1=`grep "timer-event\|tick" $calibration_log | wc -l` |
46 | 49 |
47 $d8_exec --nocrankshaft --prof --logfile $calibration_log \ | 50 $d8_exec --nocrankshaft --prof --logfile $calibration_log \ |
48 --log-internal-timer-events -e "$calibration_script" > /dev/null | 51 --log-internal-timer-events -e "$calibration_script" > /dev/null |
49 t_2=`grep "V8.Execute" $calibration_log | tail -n1 | awk -F, '{print $4}'` | 52 t_2_start=`grep "timer-event-start,\"V8.Execute\"" $calibration_log \ |
50 n_2=`grep "timer-event" $calibration_log | wc -l` | 53 | tail -n1 | awk -F, '{print $3}'` |
| 54 t_2_end=`grep "timer-event-end,\"V8.Execute\"" $calibration_log \ |
| 55 | tail -n1 | awk -F, '{print $3}'` |
| 56 n_2=`grep "timer-event\|tick" $calibration_log | wc -l` |
51 | 57 |
52 rm $calibration_log | 58 rm $calibration_log |
53 | 59 |
54 # Overhead in picoseconds. | 60 # Overhead in picoseconds. |
55 distortion=`echo "1000*($t_1 - $t_2)/($n_1 - $n_2)" | bc` | 61 distortion=`echo "1000*(($t_1_end - $t_1_start) - ($t_2_end - $t_2_start)) \ |
| 62 / ($n_1 - $n_2)" | bc` |
56 fi | 63 fi |
57 | 64 |
58 if [ -n "$PLOT_RANGE" ]; then | 65 if [ -n "$PLOT_RANGE" ]; then |
59 plot_range=$PLOT_RANGE | 66 plot_range=$PLOT_RANGE |
60 else | 67 else |
61 plot_range=auto,auto | 68 plot_range=auto,auto |
62 fi | 69 fi |
63 | 70 |
64 echo "DISTORTION=$distortion" | 71 echo "DISTORTION=$distortion" |
65 echo "PLOT_RANGE=$plot_range" | 72 echo "PLOT_RANGE=$plot_range" |
66 | 73 |
67 echo -e "plot-range,$plot_range\ndistortion,$distortion" | cat - $log_file | | 74 echo -e "plot-range,$plot_range\ndistortion,$distortion" | cat - $log_file | |
68 $d8_exec $tools_path/csvparser.js \ | 75 $d8_exec $tools_path/csvparser.js \ |
69 $tools_path/splaytree.js $tools_path/codemap.js \ | 76 $tools_path/splaytree.js $tools_path/codemap.js \ |
70 $tools_path/logreader.js $tools_path/plot-timer-events.js \ | 77 $tools_path/logreader.js $tools_path/plot-timer-events.js \ |
71 2>/dev/null | gnuplot > timer-events.png | 78 2>/dev/null | gnuplot > timer-events.png |
OLD | NEW |