-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathparse_ftrace.sh
More file actions
executable file
·67 lines (56 loc) · 1.83 KB
/
parse_ftrace.sh
File metadata and controls
executable file
·67 lines (56 loc) · 1.83 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
#!/bin/bash
# common
OP_TYPE=""
HP_TYPE=""
MFRG_TYPE=""
DIR_CUR=$(pwd)
function usage()
{
echo ""
echo " usage : # ./parse_ftrace.sh -p data_analytics -h thp -f ftrace_v1"
echo " : # ./parse_ftrace.sh -p graph_analytics -h thp -f ftrace_v2"
echo ""
exit
}
while getopts p:h:f: opt
do
case $opt in
p)
if [ $OPTARG == "data_analytics" ] || [ $OPTARG == "data_caching" ] || [ $OPTARG == "data_serving" ] || [ $OPTARG == "graph_analytics" ] || [ $OPTARG == "inmemory_analytics" ] || [ $OPTARG == "media_streaming" ] || [ $OPTARG == "web_search" ] || [ $OPTARG == "web_serving" ]
then
OP_TYPE=$OPTARG
else
echo " error : benchmark type missing"
usage
exit 0
fi
;;
h)
HP_TYPE=$OPTARG
;;
f)
MFRG_TYPE=$OPTARG
;;
*)
usage
exit 0
;;
esac
done
if [ $# -eq 0 ]
then
usage
exit
fi
DIR_LOG=${DIR_CUR}/ftrace/${OP_TYPE}/${HP_TYPE}
LOG_INPUT=${DIR_LOG}/ftrace_${OP_TYPE}_${HP_TYPE}_${MFRG_TYPE}.txt
LOG_RESULT=${DIR_LOG}/ftrace_${OP_TYPE}_${HP_TYPE}_${MFRG_TYPE}_result.txt
LOG_RAW=${DIR_LOG}/ftrace_${OP_TYPE}_${HP_TYPE}_${MFRG_TYPE}_raw.txt
rm -rf ${LOG_RESULT} ${LOG_RAW}
#cat ${LOG_INPUT} | sed -e '1,4d' | awk '{ n=split($0,arr,"us"); printf("%s\n",arr[1]);}' > a.txt
cat ${LOG_INPUT} | awk '{ n=split($0,arr,"us"); printf("%s\n",arr[1]);}' > a.txt
cat a.txt | awk '{ n=split($0,arr,")"); printf("%s\n",arr[2]);}' | sed "s/ + / /g" > ${LOG_RAW}
cat ${LOG_RAW} | awk 'BEGIN {sum=0} {for(i=1; i<=NF; i++) sum+=$i } END {print sum}' >> ${LOG_RESULT}
rm -rf a.txt
#cat b.txt | awk '{ n=split($0,arr," "); for(i=1; i < n; i++) printf("%s\n",arr[1]);}'
#echo ${ARRAY}