mirror of
https://github.com/AFLplusplus/AFLplusplus.git
synced 2025-06-12 18:18:07 +00:00
better afl startup detection in afl-whatsup
This commit is contained in:
359
afl-whatsup
359
afl-whatsup
@ -46,7 +46,7 @@ unset RESET
|
|||||||
if [ -z "$TERM" ]; then export TERM=vt220; fi
|
if [ -z "$TERM" ]; then export TERM=vt220; fi
|
||||||
|
|
||||||
while [ "$1" = "-d" -o "$1" = "-m" -o "$1" = "-n" -o "$1" = "-s" ]; do
|
while [ "$1" = "-d" -o "$1" = "-m" -o "$1" = "-n" -o "$1" = "-s" ]; do
|
||||||
|
|
||||||
if [ "$1" = "-d" ]; then
|
if [ "$1" = "-d" ]; then
|
||||||
PROCESS_DEAD=1
|
PROCESS_DEAD=1
|
||||||
fi
|
fi
|
||||||
@ -62,15 +62,15 @@ while [ "$1" = "-d" -o "$1" = "-m" -o "$1" = "-n" -o "$1" = "-s" ]; do
|
|||||||
if [ "$1" = "-s" ]; then
|
if [ "$1" = "-s" ]; then
|
||||||
SUMMARY_ONLY=1
|
SUMMARY_ONLY=1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
shift
|
shift
|
||||||
|
|
||||||
done
|
done
|
||||||
|
|
||||||
DIR="$1"
|
DIR="$1"
|
||||||
|
|
||||||
if [ "$DIR" = "" -o "$DIR" = "-h" -o "$DIR" = "--help" ]; then
|
if [ "$DIR" = "" -o "$DIR" = "-h" -o "$DIR" = "--help" ]; then
|
||||||
|
|
||||||
echo "$0 status check tool for afl-fuzz by Michal Zalewski" 1>&2
|
echo "$0 status check tool for afl-fuzz by Michal Zalewski" 1>&2
|
||||||
echo 1>&2
|
echo 1>&2
|
||||||
echo "Usage: $0 [-d] [-m] [-n] [-s] afl_output_directory" 1>&2
|
echo "Usage: $0 [-d] [-m] [-n] [-s] afl_output_directory" 1>&2
|
||||||
@ -82,7 +82,7 @@ if [ "$DIR" = "" -o "$DIR" = "-h" -o "$DIR" = "--help" ]; then
|
|||||||
echo " -s - skip details and output summary results only" 1>&2
|
echo " -s - skip details and output summary results only" 1>&2
|
||||||
echo 1>&2
|
echo 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ -z "$MINIMAL_ONLY" ]; then
|
if [ -z "$MINIMAL_ONLY" ]; then
|
||||||
@ -93,10 +93,10 @@ fi
|
|||||||
cd "$DIR" || exit 1
|
cd "$DIR" || exit 1
|
||||||
|
|
||||||
if [ -d queue ]; then
|
if [ -d queue ]; then
|
||||||
|
|
||||||
echo "[-] Error: parameter is an individual output directory, not a sync dir." 1>&2
|
echo "[-] Error: parameter is an individual output directory, not a sync dir." 1>&2
|
||||||
exit 1
|
exit 1
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
BC=`which bc 2>/dev/null`
|
BC=`which bc 2>/dev/null`
|
||||||
@ -135,11 +135,11 @@ FMT_CRASH="none seen yet"
|
|||||||
FMT_HANG="none seen yet"
|
FMT_HANG="none seen yet"
|
||||||
|
|
||||||
if [ "$SUMMARY_ONLY" = "" ]; then
|
if [ "$SUMMARY_ONLY" = "" ]; then
|
||||||
|
|
||||||
echo "Individual fuzzers"
|
echo "Individual fuzzers"
|
||||||
echo "=================="
|
echo "=================="
|
||||||
echo
|
echo
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
fmt_duration()
|
fmt_duration()
|
||||||
@ -148,22 +148,22 @@ fmt_duration()
|
|||||||
if [ $1 -le 0 ]; then
|
if [ $1 -le 0 ]; then
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
|
|
||||||
local duration=$((CUR_TIME - $1))
|
local duration=$((CUR_TIME - $1))
|
||||||
local days=$((duration / 60 / 60 / 24))
|
local days=$((duration / 60 / 60 / 24))
|
||||||
local hours=$(((duration / 60 / 60) % 24))
|
local hours=$(((duration / 60 / 60) % 24))
|
||||||
local minutes=$(((duration / 60) % 60))
|
local minutes=$(((duration / 60) % 60))
|
||||||
local seconds=$((duration % 60))
|
local seconds=$((duration % 60))
|
||||||
|
|
||||||
if [ $duration -le 0 ]; then
|
if [ $duration -le 0 ]; then
|
||||||
DUR_STRING="0 seconds"
|
DUR_STRING="0 seconds"
|
||||||
elif [ $duration -eq 1 ]; then
|
elif [ $duration -eq 1 ]; then
|
||||||
DUR_STRING="1 second"
|
DUR_STRING="1 second"
|
||||||
elif [ $days -gt 0 ]; then
|
elif [ $days -gt 0 ]; then
|
||||||
DUR_STRING="$days days, $hours hours"
|
DUR_STRING="$days days, $hours hours"
|
||||||
elif [ $hours -gt 0 ]; then
|
elif [ $hours -gt 0 ]; then
|
||||||
DUR_STRING="$hours hours, $minutes minutes"
|
DUR_STRING="$hours hours, $minutes minutes"
|
||||||
elif [ $minutes -gt 0 ]; then
|
elif [ $minutes -gt 0 ]; then
|
||||||
DUR_STRING="$minutes minutes, $seconds seconds"
|
DUR_STRING="$minutes minutes, $seconds seconds"
|
||||||
else
|
else
|
||||||
DUR_STRING="$seconds seconds"
|
DUR_STRING="$seconds seconds"
|
||||||
@ -174,168 +174,185 @@ FIRST=true
|
|||||||
TOTAL_WCOP=
|
TOTAL_WCOP=
|
||||||
TOTAL_LAST_FIND=0
|
TOTAL_LAST_FIND=0
|
||||||
|
|
||||||
for i in `find . -maxdepth 2 -iname fuzzer_stats | sort`; do
|
for j in `find . -maxdepth 2 -iname fuzzer_setup | sort`; do
|
||||||
|
|
||||||
sed 's/^command_line.*$/_skip:1/;s/[ ]*:[ ]*/="/;s/$/"/' "$i" >"$TMP"
|
DIR=$(dirname "$j")
|
||||||
. "$TMP"
|
i=$DIR/fuzzer_stats
|
||||||
DIR=$(dirname "$i")
|
|
||||||
DIRECTORY=$DIR
|
if [ -f "$i" ]; then
|
||||||
DIR=${DIR##*/}
|
|
||||||
RUN_UNIX=$run_time
|
sed 's/^command_line.*$/_skip:1/;s/[ ]*:[ ]*/="/;s/$/"/' "$i" >"$TMP"
|
||||||
RUN_DAYS=$((RUN_UNIX / 60 / 60 / 24))
|
. "$TMP"
|
||||||
RUN_HRS=$(((RUN_UNIX / 60 / 60) % 24))
|
DIRECTORY=$DIR
|
||||||
COVERAGE=$(echo $bitmap_cvg|tr -d %)
|
DIR=${DIR##*/}
|
||||||
if [ -n "$TOTAL_COVERAGE" -a -n "$COVERAGE" -a -n "$BC" ]; then
|
RUN_UNIX=$run_time
|
||||||
if [ "$(echo "$TOTAL_COVERAGE < $COVERAGE" | bc)" -eq 1 ]; then
|
RUN_DAYS=$((RUN_UNIX / 60 / 60 / 24))
|
||||||
TOTAL_COVERAGE=$COVERAGE
|
RUN_HRS=$(((RUN_UNIX / 60 / 60) % 24))
|
||||||
fi
|
COVERAGE=$(echo $bitmap_cvg|tr -d %)
|
||||||
fi
|
if [ -n "$TOTAL_COVERAGE" -a -n "$COVERAGE" -a -n "$BC" ]; then
|
||||||
if [ -z "$TOTAL_COVERAGE" ]; then TOTAL_COVERAGE=$COVERAGE ; fi
|
if [ "$(echo "$TOTAL_COVERAGE < $COVERAGE" | bc)" -eq 1 ]; then
|
||||||
|
TOTAL_COVERAGE=$COVERAGE
|
||||||
test -n "$cycles_wo_finds" && {
|
|
||||||
test -z "$FIRST" && TOTAL_WCOP="${TOTAL_WCOP}/"
|
|
||||||
TOTAL_WCOP="${TOTAL_WCOP}${cycles_wo_finds}"
|
|
||||||
FIRST=
|
|
||||||
}
|
|
||||||
|
|
||||||
if [ "$SUMMARY_ONLY" = "" ]; then
|
|
||||||
|
|
||||||
echo ">>> $afl_banner instance: $DIR ($RUN_DAYS days, $RUN_HRS hrs) fuzzer PID: $fuzzer_pid <<<"
|
|
||||||
echo
|
|
||||||
|
|
||||||
fi
|
|
||||||
|
|
||||||
if ! kill -0 "$fuzzer_pid" 2>/dev/null; then
|
|
||||||
|
|
||||||
IS_STARTING=
|
|
||||||
IS_DEAD=
|
|
||||||
|
|
||||||
if [ -e "$i" ] && [ -e "$DIRECTORY/fuzzer_setup" ] && [ -n "$FUSER" ]; then
|
|
||||||
|
|
||||||
if [ "$i" -ot "$DIRECTORY/fuzzer_setup" ]; then
|
|
||||||
|
|
||||||
# fuzzer_setup is newer than fuzzer_stats, maybe the instance is starting?
|
|
||||||
TMP_PID=`fuser -v "$DIRECTORY" 2>&1 | grep afl-fuzz`
|
|
||||||
|
|
||||||
if [ -n "$TMP_PID" ]; then
|
|
||||||
|
|
||||||
if [ "$SUMMARY_ONLY" = "" ]; then
|
|
||||||
|
|
||||||
echo " Instance is still starting up, skipping."
|
|
||||||
echo
|
|
||||||
|
|
||||||
fi
|
|
||||||
|
|
||||||
START_CNT=$((START_CNT + 1))
|
|
||||||
last_find=0
|
|
||||||
IS_STARTING=1
|
|
||||||
|
|
||||||
if [ "$PROCESS_DEAD" = "" ]; then
|
|
||||||
|
|
||||||
continue
|
|
||||||
|
|
||||||
fi
|
|
||||||
|
|
||||||
fi
|
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
if [ -z "$TOTAL_COVERAGE" ]; then TOTAL_COVERAGE=$COVERAGE ; fi
|
||||||
if [ -z "$IS_STARTING" ]; then
|
|
||||||
|
|
||||||
if [ "$SUMMARY_ONLY" = "" ]; then
|
|
||||||
|
|
||||||
echo " Instance is dead or running remotely, skipping."
|
|
||||||
echo
|
|
||||||
|
|
||||||
fi
|
|
||||||
|
|
||||||
DEAD_CNT=$((DEAD_CNT + 1))
|
|
||||||
IS_DEAD=1
|
|
||||||
last_find=0
|
|
||||||
|
|
||||||
if [ "$PROCESS_DEAD" = "" ]; then
|
|
||||||
|
|
||||||
continue
|
|
||||||
|
|
||||||
fi
|
|
||||||
|
|
||||||
fi
|
|
||||||
|
|
||||||
fi
|
|
||||||
|
|
||||||
ALIVE_CNT=$((ALIVE_CNT + 1))
|
|
||||||
|
|
||||||
EXEC_SEC=0
|
|
||||||
test -z "$RUN_UNIX" -o "$RUN_UNIX" = 0 || EXEC_SEC=$((execs_done / RUN_UNIX))
|
|
||||||
PATH_PERC=$((cur_item * 100 / corpus_count))
|
|
||||||
|
|
||||||
TOTAL_TIME=$((TOTAL_TIME + RUN_UNIX))
|
|
||||||
TOTAL_EPS=$((TOTAL_EPS + EXEC_SEC))
|
|
||||||
TOTAL_EXECS=$((TOTAL_EXECS + execs_done))
|
|
||||||
TOTAL_CRASHES=$((TOTAL_CRASHES + saved_crashes))
|
|
||||||
TOTAL_HANGS=$((TOTAL_HANGS + saved_hangs))
|
|
||||||
TOTAL_PENDING=$((TOTAL_PENDING + pending_total))
|
|
||||||
TOTAL_PFAV=$((TOTAL_PFAV + pending_favs))
|
|
||||||
|
|
||||||
if [ "$last_find" -gt "$TOTAL_LAST_FIND" ]; then
|
|
||||||
TOTAL_LAST_FIND=$last_find
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ "$SUMMARY_ONLY" = "" ]; then
|
|
||||||
|
|
||||||
# Warnings in red
|
|
||||||
TIMEOUT_PERC=$((exec_timeout * 100 / execs_done))
|
|
||||||
if [ $TIMEOUT_PERC -ge 10 ]; then
|
|
||||||
echo " ${RED}timeout_ratio $TIMEOUT_PERC%${NC}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
if [ $EXEC_SEC -eq 0 ]; then
|
|
||||||
echo " ${YELLOW}no data yet, 0 execs/sec${NC}"
|
|
||||||
elif [ $EXEC_SEC -lt 100 ]; then
|
|
||||||
echo " ${RED}slow execution, $EXEC_SEC execs/sec${NC}"
|
|
||||||
fi
|
|
||||||
|
|
||||||
fmt_duration $last_find && FMT_FIND=$DUR_STRING
|
|
||||||
fmt_duration $last_crash && FMT_CRASH=$DUR_STRING
|
|
||||||
fmt_duration $last_hang && FMT_HANG=$DUR_STRING
|
|
||||||
FMT_CWOP="not available"
|
|
||||||
test -n "$cycles_wo_finds" && {
|
test -n "$cycles_wo_finds" && {
|
||||||
test "$cycles_wo_finds" = 0 && FMT_CWOP="$cycles_wo_finds"
|
test -z "$FIRST" && TOTAL_WCOP="${TOTAL_WCOP}/"
|
||||||
test "$cycles_wo_finds" -gt 10 && FMT_CWOP="${YELLOW}$cycles_wo_finds${NC}"
|
TOTAL_WCOP="${TOTAL_WCOP}${cycles_wo_finds}"
|
||||||
test "$cycles_wo_finds" -gt 50 && FMT_CWOP="${RED}$cycles_wo_finds${NC}"
|
FIRST=
|
||||||
}
|
}
|
||||||
|
|
||||||
echo " last_find : $FMT_FIND"
|
if [ "$SUMMARY_ONLY" = "" ]; then
|
||||||
echo " last_crash : $FMT_CRASH"
|
|
||||||
if [ -z "$MINIMAL_ONLY" ]; then
|
echo ">>> $afl_banner instance: $DIR ($RUN_DAYS days, $RUN_HRS hrs) fuzzer PID: $fuzzer_pid <<<"
|
||||||
echo " last_hang : $FMT_HANG"
|
echo
|
||||||
echo " cycles_wo_finds : $FMT_CWOP"
|
|
||||||
fi
|
fi
|
||||||
echo " coverage : $COVERAGE%"
|
|
||||||
|
if ! kill -0 "$fuzzer_pid" 2>/dev/null; then
|
||||||
if [ -z "$MINIMAL_ONLY" ]; then
|
|
||||||
|
IS_STARTING=
|
||||||
CPU_USAGE=$(ps aux | grep $fuzzer_pid | grep -v grep | awk '{print $3}')
|
IS_DEAD=
|
||||||
MEM_USAGE=$(ps aux | grep $fuzzer_pid | grep -v grep | awk '{print $4}')
|
|
||||||
|
if [ -e "$i" ] && [ -e "$j" ] && [ -n "$FUSER" ]; then
|
||||||
echo " cpu usage $CPU_USAGE%, memory usage $MEM_USAGE%"
|
|
||||||
|
if [ "$i" -ot "$j" ]; then
|
||||||
|
|
||||||
|
# fuzzer_setup is newer than fuzzer_stats, maybe the instance is starting?
|
||||||
|
TMP_PID=`fuser -v "$DIRECTORY" 2>&1 | grep afl-fuzz`
|
||||||
|
|
||||||
|
if [ -n "$TMP_PID" ]; then
|
||||||
|
|
||||||
|
if [ "$SUMMARY_ONLY" = "" ]; then
|
||||||
|
|
||||||
|
echo " Instance is still starting up, skipping."
|
||||||
|
echo
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
START_CNT=$((START_CNT + 1))
|
||||||
|
last_find=0
|
||||||
|
IS_STARTING=1
|
||||||
|
|
||||||
|
if [ "$PROCESS_DEAD" = "" ]; then
|
||||||
|
|
||||||
|
continue
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ -z "$IS_STARTING" ]; then
|
||||||
|
|
||||||
|
if [ "$SUMMARY_ONLY" = "" ]; then
|
||||||
|
|
||||||
|
echo " Instance is dead or running remotely, skipping."
|
||||||
|
echo
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
DEAD_CNT=$((DEAD_CNT + 1))
|
||||||
|
IS_DEAD=1
|
||||||
|
last_find=0
|
||||||
|
|
||||||
|
if [ "$PROCESS_DEAD" = "" ]; then
|
||||||
|
|
||||||
|
continue
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
ALIVE_CNT=$((ALIVE_CNT + 1))
|
||||||
|
|
||||||
|
EXEC_SEC=0
|
||||||
|
test -z "$RUN_UNIX" -o "$RUN_UNIX" = 0 || EXEC_SEC=$((execs_done / RUN_UNIX))
|
||||||
|
PATH_PERC=$((cur_item * 100 / corpus_count))
|
||||||
|
|
||||||
|
TOTAL_TIME=$((TOTAL_TIME + RUN_UNIX))
|
||||||
|
TOTAL_EPS=$((TOTAL_EPS + EXEC_SEC))
|
||||||
|
TOTAL_EXECS=$((TOTAL_EXECS + execs_done))
|
||||||
|
TOTAL_CRASHES=$((TOTAL_CRASHES + saved_crashes))
|
||||||
|
TOTAL_HANGS=$((TOTAL_HANGS + saved_hangs))
|
||||||
|
TOTAL_PENDING=$((TOTAL_PENDING + pending_total))
|
||||||
|
TOTAL_PFAV=$((TOTAL_PFAV + pending_favs))
|
||||||
|
|
||||||
|
if [ "$last_find" -gt "$TOTAL_LAST_FIND" ]; then
|
||||||
|
TOTAL_LAST_FIND=$last_find
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ "$SUMMARY_ONLY" = "" ]; then
|
||||||
|
|
||||||
|
# Warnings in red
|
||||||
|
TIMEOUT_PERC=$((exec_timeout * 100 / execs_done))
|
||||||
|
if [ $TIMEOUT_PERC -ge 10 ]; then
|
||||||
|
echo " ${RED}timeout_ratio $TIMEOUT_PERC%${NC}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
if [ $EXEC_SEC -eq 0 ]; then
|
||||||
|
echo " ${YELLOW}no data yet, 0 execs/sec${NC}"
|
||||||
|
elif [ $EXEC_SEC -lt 100 ]; then
|
||||||
|
echo " ${RED}slow execution, $EXEC_SEC execs/sec${NC}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
fmt_duration $last_find && FMT_FIND=$DUR_STRING
|
||||||
|
fmt_duration $last_crash && FMT_CRASH=$DUR_STRING
|
||||||
|
fmt_duration $last_hang && FMT_HANG=$DUR_STRING
|
||||||
|
FMT_CWOP="not available"
|
||||||
|
test -n "$cycles_wo_finds" && {
|
||||||
|
test "$cycles_wo_finds" = 0 && FMT_CWOP="$cycles_wo_finds"
|
||||||
|
test "$cycles_wo_finds" -gt 10 && FMT_CWOP="${YELLOW}$cycles_wo_finds${NC}"
|
||||||
|
test "$cycles_wo_finds" -gt 50 && FMT_CWOP="${RED}$cycles_wo_finds${NC}"
|
||||||
|
}
|
||||||
|
|
||||||
|
echo " last_find : $FMT_FIND"
|
||||||
|
echo " last_crash : $FMT_CRASH"
|
||||||
|
if [ -z "$MINIMAL_ONLY" ]; then
|
||||||
|
echo " last_hang : $FMT_HANG"
|
||||||
|
echo " cycles_wo_finds : $FMT_CWOP"
|
||||||
|
fi
|
||||||
|
echo " coverage : $COVERAGE%"
|
||||||
|
|
||||||
|
if [ -z "$MINIMAL_ONLY" ]; then
|
||||||
|
|
||||||
|
CPU_USAGE=$(ps aux | grep $fuzzer_pid | grep -v grep | awk '{print $3}')
|
||||||
|
MEM_USAGE=$(ps aux | grep $fuzzer_pid | grep -v grep | awk '{print $4}')
|
||||||
|
|
||||||
|
echo " cpu usage $CPU_USAGE%, memory usage $MEM_USAGE%"
|
||||||
|
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo " cycles $((cycles_done + 1)), lifetime speed $EXEC_SEC execs/sec, items $cur_item/$corpus_count (${PATH_PERC}%)"
|
||||||
|
|
||||||
|
if [ "$saved_crashes" = "0" ]; then
|
||||||
|
echo " pending $pending_favs/$pending_total, coverage $bitmap_cvg, no crashes yet"
|
||||||
|
else
|
||||||
|
echo " pending $pending_favs/$pending_total, coverage $bitmap_cvg, crashes saved $saved_crashes (!)"
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo " cycles $((cycles_done + 1)), lifetime speed $EXEC_SEC execs/sec, items $cur_item/$corpus_count (${PATH_PERC}%)"
|
else
|
||||||
|
|
||||||
if [ "$saved_crashes" = "0" ]; then
|
if [ ! -e "$i" -a -e "$j" ]; then
|
||||||
echo " pending $pending_favs/$pending_total, coverage $bitmap_cvg, no crashes yet"
|
|
||||||
else
|
ALIVE_CNT=$((ALIVE_CNT + 1))
|
||||||
echo " pending $pending_favs/$pending_total, coverage $bitmap_cvg, crashes saved $saved_crashes (!)"
|
START_CNT=$((START_CNT + 1))
|
||||||
|
last_find=0
|
||||||
|
IS_STARTING=1
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo
|
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
done
|
done
|
||||||
|
|
||||||
# Formatting for total time, time since last find, crash, and hang
|
# Formatting for total time, time since last find, crash, and hang
|
||||||
@ -346,7 +363,7 @@ EXECS_MILLION=$((TOTAL_EXECS / 1000 / 1000))
|
|||||||
EXECS_THOUSAND=$((TOTAL_EXECS / 1000 % 1000))
|
EXECS_THOUSAND=$((TOTAL_EXECS / 1000 % 1000))
|
||||||
if [ $EXECS_MILLION -gt 9 ]; then
|
if [ $EXECS_MILLION -gt 9 ]; then
|
||||||
FMT_EXECS="$EXECS_MILLION millions"
|
FMT_EXECS="$EXECS_MILLION millions"
|
||||||
elif [ $EXECS_MILLION -gt 0 ]; then
|
elif [ $EXECS_MILLION -gt 0 ]; then
|
||||||
FMT_EXECS="$EXECS_MILLION millions, $EXECS_THOUSAND thousands"
|
FMT_EXECS="$EXECS_MILLION millions, $EXECS_THOUSAND thousands"
|
||||||
else
|
else
|
||||||
FMT_EXECS="$EXECS_THOUSAND thousands"
|
FMT_EXECS="$EXECS_THOUSAND thousands"
|
||||||
@ -363,14 +380,14 @@ fmt_duration $TOTAL_LAST_FIND && TOTAL_LAST_FIND=$DUR_STRING
|
|||||||
test "$TOTAL_TIME" = "0" && TOTAL_TIME=1
|
test "$TOTAL_TIME" = "0" && TOTAL_TIME=1
|
||||||
|
|
||||||
if [ "$PROCESS_DEAD" = "" ]; then
|
if [ "$PROCESS_DEAD" = "" ]; then
|
||||||
|
|
||||||
TXT="excluded from stats"
|
TXT="excluded from stats"
|
||||||
|
|
||||||
else
|
else
|
||||||
|
|
||||||
TXT="included in stats"
|
TXT="included in stats"
|
||||||
ALIVE_CNT=$(($ALIVE_CNT - $DEAD_CNT - $START_CNT))
|
ALIVE_CNT=$(($ALIVE_CNT - $DEAD_CNT - $START_CNT))
|
||||||
|
|
||||||
fi
|
fi
|
||||||
|
|
||||||
echo "Summary stats"
|
echo "Summary stats"
|
||||||
|
Reference in New Issue
Block a user