X-Git-Url: http://www.aleph1.co.uk/gitweb/?p=yaffs2.git;a=blobdiff_plain;f=linux-tests%2Fplot_data.sh;h=6713f722aa5a972dd238021fa6f7b71b8bbe2f06;hp=23a22024c15ff90408fab6b7483b37e88014374a;hb=6c7131b1d7c221125851a7c0bd183dd05a02d583;hpb=1f4323687427e7b156a7391bea3f1f4e55d90838 diff --git a/linux-tests/plot_data.sh b/linux-tests/plot_data.sh index 23a2202..6713f72 100755 --- a/linux-tests/plot_data.sh +++ b/linux-tests/plot_data.sh @@ -1,5 +1,60 @@ #!/bin/sh -# plot_data.sh runs the plot, updating it in realtime +# Script that gathers data erased vs free data from /proc/yaffs_stats and simultaneously \ +# plots it using gnuplot. -./drive_gnuplot.sh | gnuplot + +#Gather settings +log_file=data +gather_delay=1 + +# Plot settings +trunc_file=trunc_data +plot_samples=1000 +plot_delay=2 + + + +# Gathering task + +gather_data() { +i=0; +rm -f $log_file + +while true; do +str=$(cat /proc/yaffs_debug) +echo "$i, $str" +echo "$i, $str" >> $log_file +let i=$i+1 +sleep $gather_delay +done +} + + +# Plotting task +# Periodically creates a truncated version of the log file and +# outputs commands into gnuplot, thus driving gnuplot + +drive_gnuplot(){ +sleep 5 +tail -$plot_samples $log_file > $trunc_file + +plot_str=" plot '$trunc_file' using 1:3 with linespoints title 'free', '' using 1:4 with linespoints title 'erased'" + +echo "set title 'yaffs free space and erased space'" + +echo $plot_str + +while true; do +sleep $plot_delay +tail -$plot_samples $log_file > $trunc_file +echo replot +done +} + + + +echo "Start gathering task in background" +gather_data & +echo "Run plotting task" +drive_gnuplot | gnuplot