2021-09-06 22:23:24 -05:00
|
|
|
#!/bin/bash
|
|
|
|
|
|
2025-09-12 23:47:58 +05:30
|
|
|
# Copyright (c) Advanced Micro Devices, Inc.
|
|
|
|
|
# SPDX-License-Identifier: MIT
|
|
|
|
|
|
2021-09-06 22:23:24 -05:00
|
|
|
EXE=$(basename ${1})
|
2022-07-17 21:52:09 -05:00
|
|
|
DIR=gperftools-output
|
2021-09-06 22:23:24 -05:00
|
|
|
mkdir -p ${DIR}
|
|
|
|
|
|
2022-07-17 21:52:09 -05:00
|
|
|
# gperftools settings
|
2021-09-06 22:23:24 -05:00
|
|
|
: ${N:=0}
|
2022-07-17 21:52:09 -05:00
|
|
|
: ${GPERFTOOLS_PROFILE:=""}
|
|
|
|
|
: ${GPERFTOOLS_PROFILE_BASE:=${DIR}/prof.${EXE}}
|
2021-09-06 22:23:24 -05:00
|
|
|
: ${MALLOCSTATS:=1}
|
|
|
|
|
: ${CPUPROFILE_FREQUENCY:=250}
|
|
|
|
|
: ${CPUPROFILE_REALTIME:=1}
|
2022-07-17 21:52:09 -05:00
|
|
|
: ${PPROF:=$(which google-pprof)}
|
|
|
|
|
: ${PPROF:=$(which pprof)}
|
2021-09-06 22:23:24 -05:00
|
|
|
|
|
|
|
|
# rendering settings
|
|
|
|
|
: ${INTERACTIVE:=0}
|
|
|
|
|
: ${IMG_FORMAT:="png"}
|
|
|
|
|
#: ${DOT_ARGS:='-Gsize=24,24\! -Gdpi=200'}
|
|
|
|
|
: ${DOT_ARGS:=""}
|
|
|
|
|
: ${PPROF_ARGS:="--no_strip_temp --functions"}
|
|
|
|
|
|
|
|
|
|
if [ "$(uname)" = "Darwin" ]; then
|
|
|
|
|
if [ "${IMG_FORMAT}" = "jpeg" ]; then
|
|
|
|
|
IMG_FORMAT="jpg"
|
|
|
|
|
fi
|
|
|
|
|
fi
|
2022-07-17 21:52:09 -05:00
|
|
|
|
2021-09-06 22:23:24 -05:00
|
|
|
run-verbose()
|
|
|
|
|
{
|
2022-07-17 21:52:09 -05:00
|
|
|
echo "### ${@} ###" 1>&2
|
2021-09-06 22:23:24 -05:00
|
|
|
eval ${@}
|
|
|
|
|
}
|
|
|
|
|
|
2022-07-17 21:52:09 -05:00
|
|
|
while [ -z "${GPERFTOOLS_PROFILE}" ]
|
2021-09-06 22:23:24 -05:00
|
|
|
do
|
2022-07-17 21:52:09 -05:00
|
|
|
TEST_FILE=${GPERFTOOLS_PROFILE_BASE}.${N}
|
2021-09-06 22:23:24 -05:00
|
|
|
if [ ! -f "${TEST_FILE}" ]; then
|
2022-07-17 21:52:09 -05:00
|
|
|
GPERFTOOLS_PROFILE=${TEST_FILE}
|
2021-09-06 22:23:24 -05:00
|
|
|
fi
|
|
|
|
|
N=$((${N}+1))
|
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
export MALLOCSTATS
|
|
|
|
|
export CPUPROFILE_FREQUENCY
|
|
|
|
|
export CPUPROFILE_REALTIME
|
|
|
|
|
|
2022-07-17 21:52:09 -05:00
|
|
|
echo -e "\n\t--> Outputting profile to '${GPERFTOOLS_PROFILE}'...\n"
|
2021-09-06 22:23:24 -05:00
|
|
|
|
|
|
|
|
# remove profile file if unsucessful execution
|
2022-07-17 21:52:09 -05:00
|
|
|
cleanup-failure() { set +v ; echo "failure"; rm -f ${GPERFTOOLS_PROFILE}; exit 1; }
|
2021-09-06 22:23:24 -05:00
|
|
|
trap cleanup-failure SIGHUP SIGINT SIGQUIT SIGILL SIGABRT SIGKILL
|
|
|
|
|
|
|
|
|
|
ADD_LIBS()
|
|
|
|
|
{
|
|
|
|
|
for i in $@
|
|
|
|
|
do
|
|
|
|
|
if [ -z "${ADD_LIB_LIST}" ]; then
|
|
|
|
|
ADD_LIB_LIST="--add_lib=${i}"
|
|
|
|
|
else
|
|
|
|
|
ADD_LIB_LIST="${ADD_LIB_LIST} --add_lib=${i}"
|
|
|
|
|
fi
|
|
|
|
|
done
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
ADD_PRELOAD()
|
|
|
|
|
{
|
|
|
|
|
for i in $@
|
|
|
|
|
do
|
|
|
|
|
if [ -z "${LIBS}" ]; then
|
|
|
|
|
LIBS=${i}
|
|
|
|
|
else
|
|
|
|
|
LIBS="${LIBS}:${i}"
|
|
|
|
|
fi
|
|
|
|
|
done
|
|
|
|
|
}
|
|
|
|
|
|
2022-07-17 21:52:09 -05:00
|
|
|
run-pprof()
|
|
|
|
|
{
|
|
|
|
|
if [ -n "${PPROF}" ]; then
|
|
|
|
|
run-verbose ${PPROF} ${ADD_LIB_LIST} ${PPROF_ARGS} "${@}"
|
|
|
|
|
else
|
|
|
|
|
echo -e "neither google-pprof nor pprof were found!"
|
|
|
|
|
exit 1
|
2021-09-06 22:23:24 -05:00
|
|
|
fi
|
2022-07-17 21:52:09 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# configure pre-loading of profiler library
|
2024-10-15 11:20:40 -04:00
|
|
|
for i in $(find ${PWD} -type f | egrep 'librocprof-sys' | egrep -v '\.a$' | egrep '\.so$') $(ldd ${1} | awk '{print $(NF-1)}')
|
2022-07-17 21:52:09 -05:00
|
|
|
do
|
|
|
|
|
if [ -f "${i}" ]; then run-verbose ADD_LIBS "${i}"; fi
|
|
|
|
|
done
|
|
|
|
|
run-verbose ADD_PRELOAD $(ldd ${1} | egrep 'profiler' | awk '{print $(NF-1)}') /usr/lib/$(uname -m)-linux-gnu/libprofiler.so
|
|
|
|
|
LIBS=$(echo ${LIBS} | sed 's/^://g')
|
2021-09-06 22:23:24 -05:00
|
|
|
|
|
|
|
|
set -e
|
|
|
|
|
# run the application
|
2022-07-17 21:52:09 -05:00
|
|
|
LD_PRELOAD=${LIBS} CPUPROFILE_FREQUENCY=${CPUPROFILE_FREQUENCY} CPUPROFILE=${GPERFTOOLS_PROFILE} ${@} | tee ${GPERFTOOLS_PROFILE}.log
|
2021-09-06 22:23:24 -05:00
|
|
|
set +e
|
|
|
|
|
|
|
|
|
|
# generate the results
|
|
|
|
|
EXT=so
|
2022-07-17 21:52:09 -05:00
|
|
|
if [ -f "${GPERFTOOLS_PROFILE}" ]; then
|
|
|
|
|
run-pprof --text ${1} ${GPERFTOOLS_PROFILE} | c++filt -n -t 1> ${GPERFTOOLS_PROFILE}.txt
|
|
|
|
|
run-pprof ${PPROF} --text --cum ${1} ${GPERFTOOLS_PROFILE} | c++filt -n -t 1> ${GPERFTOOLS_PROFILE}.cum.txt
|
|
|
|
|
# if dot is available
|
|
|
|
|
if [ -n "$(which dot)" ]; then
|
|
|
|
|
run-pprof ${PPROF} --dot ${1} ${GPERFTOOLS_PROFILE} 1> ${GPERFTOOLS_PROFILE}.dot
|
|
|
|
|
run-verbose $(which dot) ${DOT_ARGS} -T${IMG_FORMAT} ${GPERFTOOLS_PROFILE}.dot -o ${GPERFTOOLS_PROFILE}.${IMG_FORMAT}
|
|
|
|
|
fi
|
|
|
|
|
if [ "${INTERACTIVE}" -gt 0 ]; then
|
|
|
|
|
run-pprof ${PPROF} ${1} ${GPERFTOOLS_PROFILE}
|
2021-09-06 22:23:24 -05:00
|
|
|
fi
|
|
|
|
|
else
|
2022-07-17 21:52:09 -05:00
|
|
|
echo -e "profile file \"${GPERFTOOLS_PROFILE}\" not found!"
|
2021-09-06 22:23:24 -05:00
|
|
|
ls -la
|
2022-07-17 21:52:09 -05:00
|
|
|
exit 1
|
2021-09-06 22:23:24 -05:00
|
|
|
fi
|