#!/bin/sh
# This function just re-writes the timestamp of the strace entries to be
# seconds.usecs since boot. To match the timestamping of ftrace (so we can
# merge them later).
process_strace()
{
strace=$1
# parse in data/system/vendor and parse out /sys/devices/system/...
egrep '\/system\/|\/data\/|\/vendor\/' $strace | egrep -v '\/sys\/devices\/system\/' > bar
fgrep -v '= -1' bar > foo
mv foo bar
# begin_time is seconds since epoch
begin_time=`cat trace.begin`
# replace seconds since epoch with SECONDS SINCE BOOT in the
# strace files
awk -v begin="$begin_time" '{ printf "%f strace ", $1 - begin; $1=""; print $0}' bar > $2
rm bar
}
#
# This function processes the ftrace file, removing the fields that we don't care
# about, breaks up the ftrace file into one file per pid.
# Input : One single fstrace file.
# Output : Multiple fstrace.pid files.
prep_fstrace()
{
# Remove leading junk
fgrep android_fs_data $1 | sed 's/^.* \[.*\] //' | sed s/://g | sed s/,//g > foo
sed 's/android_fs_dataread_start/read/' foo > bar1
mv bar1 bar
# First column is timestamp SECONDS SINCE BOOT
awk '{ print $2, "ftrace", $3, $5, $7, $9, $13 }' bar > foo
rm bar
# Get all the uniq pids
awk '{print $7}' foo | sort | uniq > pidlist
for i in `cat pidlist`
do
awk -v pid=$i '{ if (pid == $7) print $0}' foo > fstrace.$i
done
rm pidlist
rm foo
}
# Merge straces and ftraces.
# The goal here is to catch mmap'ed IO (reads) that won't be in the
# strace file. The algorithm is to look for mmaps in the strace file,
# use the files tha are mmap'ed to search in the ftraces to pick up
# tracepoints from there, and merge those with the straces.
# The output of this function is a set of parsed_input_trace.<pid>
# files, that can then be compiled into .wl files
merge_compile()
{
for stracefile in trace.*
do
if [ $stracefile == trace.begin ] || [ $stracefile == trace.tar ];
then
continue
fi
# Get the pid from the strace filename (pid is the extension)
pid=${stracefile##*.}
process_strace $stracefile foo.$pid
if ! [ -s foo.$pid ]; then
rm foo.$pid
continue
fi
#
# If we have matching strace and ftrace files, then look for mmaps in
# the strace pluck the corresponding entries for the mmap (mmaped IO)
# from the ftrace and merge them into the strace
#
if [ -f fstrace.$pid ]; then
fgrep mmap foo.$pid > bar
if [ -s bar ]; then
# Get all the unique mmap'ed filenames from the strace
awk '{ print $7 }' bar | sed 's/^[^<]*<//g' | sed 's/>,//g' > mapped_files
# Pluck all the lines from the ftrace corresponding to the mmaps
cat /dev/null > footemp
for j in `sort mapped_files | uniq`
do
# Merge the readpage(s) traces from the ftrace into strace
# for this mmaped file.
grep -w $j fstrace.$pid > foobar
if [ $? == 0 ]; then
sort foo.$pid foobar >> footemp
fi
rm foobar
done
rm mapped_files
if [ -s footemp ]; then
mv footemp parsed_input_trace.$pid
else
mv foo.$pid parsed_input_trace.$pid
fi
else
mv foo.$pid parsed_input_trace.$pid
fi
rm bar
else
mv foo.$pid parsed_input_trace.$pid
fi
echo compiling parsed_input_trace.$pid
compile_ioshark parsed_input_trace.$pid $pid.wl
rm parsed_input_trace.$pid
rm -f foo.$pid
done
}
# main() starts here
rm -f *.wl
rm -f parsed*
rm ioshark_filenames
# Pre-process the ftrace file
prep_fstrace fstrace
# Merge the ftrace file(s) with the strace files
merge_compile
# tar up the .wl files just created
tar cf wl-test.tar ioshark_filenames *.wl