X-Git-Url: http://git.lttng.org/?a=blobdiff_plain;f=usttrace;h=e8ab13c7079ea2ca84eaa048805e2e13ae58bc0c;hb=2a3fba4984dd15c145ba58803c6fa3cf557c34dc;hp=385abc643a00e06f56d1f17975c331239a9f879a;hpb=eb6adb25b8492bcfd0e72153708166563a109015;p=ust.git diff --git a/usttrace b/usttrace index 385abc6..e8ab13c 100755 --- a/usttrace +++ b/usttrace @@ -1,18 +1,49 @@ #!/bin/bash +# usttrace by Pierre-Marc Fournier 2009 +# Distributed under the GPLv2. + USTD="./ustd/ustd" -LIBINTERFORK="./libinterfork/.libs/libinterfork.so" +LIBINTERFORK_PATH="./libinterfork/.libs/libinterfork.so" +LIBMALLOCWRAP_PATH="./libmallocwrap/.libs/libmallocwrap.so" + +STD_LDLIBRARY_UST="./libust/.libs:../liburcu" BASE_TRACE_DIR="$HOME/.usttraces" function usage () { - echo "usage: $0 COMMAND" 2>/dev/stderr + echo "usage: $0 OPTIONS COMMAND" 2>/dev/stderr + echo "" 2>/dev/stderr + echo "Options:" 2>/dev/stderr + echo " -l Runtime link with UST library." 2>/dev/stderr + echo " (Needed only if program was not linked at compile time with libust.)" 2>/dev/stderr + echo " -L Add path to ust libraries to LD_LIBRARY_PATH." 2>/dev/stderr + echo " -m Instrument malloc calls." 2>/dev/stderr + echo " -f Also trace forked processes." 2>/dev/stderr + echo " -s Use system-wide daemon instead of creating one for this session." 2>/dev/stderr } function error() { echo "$0: error: $1" 2>/dev/stderr } +while getopts ":hlLmfs" options; do + case $options in + l) arg_preload_libust=1;; + L) arg_ld_std_ust=1;; + m) arg_preload_malloc=1;; + f) arg_preload_fork=1;; + s) arg_syswide_daemon=1;; + h) usage; + exit 0;; + \?) usage + exit 1;; + *) usage + exit 1;; + esac +done +shift $(($OPTIND - 1)) + # Prepare vars CMD=$1 @@ -37,24 +68,65 @@ mkdir -p "$OUTDIR" # Choose socket path SOCKPATH="/tmp/ust-sock-$$" -# Start daemon -$USTD -s "$SOCKPATH" -o "$OUTDIR" >"$OUTDIR/ustd.log" 2>&1 & -USTDPID=$! +if [ "$arg_syswide_daemon" != "1" ]; +then + # Start daemon + $USTD -s "$SOCKPATH" -o "$OUTDIR" 2>&1 >"$OUTDIR/ustd.log" & + USTDPID="$!" + export UST_DAEMON_SOCKET="$SOCKPATH" +fi + +# Wait for the daemon to settle +# If we don't, the process may try to connect to its socket before +# it's ready. +# FIXME: is there a way to make sure this works every time? +sleep 0.5 # Establish the environment for the command export UST_TRACE=1 export UST_AUTOPROBE=1 -export UST_DAEMON_SOCKET="$SOCKPATH" + +if [ "$arg_preload_libust" = "1" ]; +then + export LD_LIBRARY_PATH="$LD_LIBRARY_PATH:./libust/.libs" + export LD_PRELOAD="$LD_PRELOAD:./libust/.libs/libust.so" +fi + +if [ "$arg_ld_std_ust" = "1" ]; +then + export LD_LIBRARY_PATH="$LD_LIBRARY_PATH:$STD_LDLIBRARY_UST" +fi + +if [ "$arg_preload_malloc" = "1" ]; +then + export LD_PRELOAD="$LD_PRELOAD:./libmallocwrap/.libs/libmallocwrap.so" +fi + +if [ "$arg_preload_fork" = "1" ]; +then + export LD_PRELOAD="$LD_PRELOAD:$LIBINTERFORK_PATH" +fi + +# Install a handler for SIGIO. This is the signal that will be sent by ustd to +# the traced program to trigger the creation of its listener thread. However, +# it is possible that the SIGIO will be sent after the shell fork, but before +# the exec of the command. If this handler isn't there, bash might terminate +# because of a unhandled signal. # Execute the command -bash -c "$CMD" +bash -c "$CMD" 2>&1 | tee "$OUTDIR/app.log" ## Because of the keepalive mechanism, we're sure that by the time ## we get here, the daemon is connected to all the buffers that still exist. ## Therefore we can politely ask it to die when it's done. -kill -SIGTERM "$USTDPID" +if [ "$arg_syswide_daemon" != "1" ]; +then + # Tell the daemon to die + kill -SIGTERM "$USTDPID" + + echo "Waiting for ustd to shutdown..." + wait "$USTDPID" +fi -# Tell the daemon to die -echo "Waiting for ustd to shutdown..." -wait "$USTDPID" +echo "Trace was output in: " $OUTDIR