| 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 14 matching lines...) Expand all Loading... |
| 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 |
| OLD | NEW |