2009-12-22 20:06:10 +00:00
|
|
|
#!/bin/sh
|
2009-10-12 22:22:52 +00:00
|
|
|
|
|
|
|
arg=$1
|
|
|
|
shift
|
|
|
|
|
2010-02-01 15:29:40 +00:00
|
|
|
if [ -f "config.status" ] ; then
|
|
|
|
prefix=$(cat config.status | grep @prefix@ | awk -F, '{print $3}')
|
|
|
|
fi
|
|
|
|
if [ -f "config.status" -a -z "$prefix" ] ; then
|
2009-11-12 03:46:43 +00:00
|
|
|
prefix=$(cat config.status | grep '"prefix"' | awk -F\" '{print $4}')
|
|
|
|
fi
|
2009-10-12 22:22:52 +00:00
|
|
|
|
2010-02-01 15:29:40 +00:00
|
|
|
if [ -z "$prefix" -a -d "/usr/local/freeswitch" ] ; then
|
2009-11-12 03:46:43 +00:00
|
|
|
prefix="/usr/local/freeswitch"
|
2009-10-12 22:22:52 +00:00
|
|
|
fi
|
2010-02-01 15:29:40 +00:00
|
|
|
if [ -z "$prefix" -a -d "/opt/freeswitch" ] ; then
|
|
|
|
prefix="/opt/freeswitch"
|
|
|
|
fi
|
|
|
|
if [ -z "$prefix" ] ; then
|
|
|
|
echo "Unable to locate freeswitch prefix directory."
|
|
|
|
exit 255
|
|
|
|
fi
|
2009-10-12 22:22:52 +00:00
|
|
|
|
|
|
|
if [ "$arg" = "gcore" ] ; then
|
|
|
|
user=$1
|
|
|
|
shift
|
2010-01-22 00:31:19 +00:00
|
|
|
fspid=`cat $prefix/run/freeswitch.pid`
|
2009-10-12 22:22:52 +00:00
|
|
|
echo "pulling gcore $fspid"
|
|
|
|
gcore -o core $fspid
|
|
|
|
else
|
|
|
|
user=$arg
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
core=`ls -1t core.* | head -1 2> /dev/null`
|
2009-09-17 18:48:01 +00:00
|
|
|
|
2009-09-22 23:09:14 +00:00
|
|
|
if [ -z "$core" ] ; then
|
2009-10-12 22:22:52 +00:00
|
|
|
core=`ls -1 core 2> /dev/null`
|
2009-09-22 23:09:14 +00:00
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -z "$core" ] ; then
|
2009-10-12 22:22:52 +00:00
|
|
|
core=`ls -1 freeswitch.core 2> /dev/null`
|
2009-09-22 23:09:14 +00:00
|
|
|
fi
|
|
|
|
|
2009-09-17 18:48:01 +00:00
|
|
|
if [ -z "$core" ] ; then
|
|
|
|
echo "You must be in the current directory with a core file from FreeSWITCH!"
|
|
|
|
exit 255
|
|
|
|
fi
|
|
|
|
|
2010-02-01 15:29:40 +00:00
|
|
|
if [ -x `which gdb` ] ; then
|
|
|
|
echo "Found gdb"
|
|
|
|
else
|
2009-09-23 15:33:05 +00:00
|
|
|
echo "Unable to locate gdb, is it installed?"
|
|
|
|
exit 255
|
|
|
|
fi
|
|
|
|
|
2009-10-12 22:22:52 +00:00
|
|
|
echo "core is $core"
|
2009-09-23 15:33:05 +00:00
|
|
|
|
2009-09-17 18:48:01 +00:00
|
|
|
line="--------------------------------------------------------------------------------"
|
|
|
|
|
|
|
|
mypwd=`pwd`
|
|
|
|
tmpdir=/tmp/fscore_pb.tmp
|
2009-10-31 18:15:29 +00:00
|
|
|
post_file=$mypwd/fscore_pb.post
|
2009-10-12 22:22:52 +00:00
|
|
|
|
2009-09-17 18:48:01 +00:00
|
|
|
|
|
|
|
if [ -z $user ] ; then
|
|
|
|
user=$SUDO_USER
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -z $user ] ; then
|
|
|
|
user=$USER
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -z $user ] ; then
|
|
|
|
user="anon"
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
|
|
echo "Gathering Data Please Wait........."
|
|
|
|
|
2010-04-27 22:27:10 +00:00
|
|
|
echo -n "paste=Send&remember=0&poster=$user&format=none&expiry=f&code2=" > $post_file
|
2009-09-17 18:48:01 +00:00
|
|
|
|
|
|
|
echo "LSB RELEASE:" >> $post_file
|
|
|
|
echo $line >> $post_file
|
2011-03-17 19:18:08 +00:00
|
|
|
if [ -f /etc/redhat-release ] ; then
|
|
|
|
cat /etc/redhat-release >> $post_file
|
|
|
|
else
|
|
|
|
lsb_release -a >> $post_file
|
|
|
|
fi
|
2009-09-17 18:48:01 +00:00
|
|
|
|
|
|
|
echo "CPU INFO:" >> $post_file
|
|
|
|
echo $line >> $post_file
|
|
|
|
cat /proc/cpuinfo >> $post_file
|
|
|
|
|
2011-03-17 19:18:08 +00:00
|
|
|
echo "GIT INFO:" >> $post_file
|
2009-09-17 18:48:01 +00:00
|
|
|
echo $line >> $post_file
|
|
|
|
echo -n "Revision: " >> $post_file
|
2011-03-17 19:18:08 +00:00
|
|
|
if [ -d ".git" ] ; then
|
|
|
|
git log -1 | cat >> $post_file
|
|
|
|
printf "\n\n\n" >> $post_file
|
|
|
|
git status >> $post_file
|
2010-02-01 15:29:40 +00:00
|
|
|
else
|
2011-03-17 19:18:08 +00:00
|
|
|
echo "Not run from an git managed directory." >> $post_file
|
2010-02-01 15:29:40 +00:00
|
|
|
fi
|
2009-09-17 18:48:01 +00:00
|
|
|
|
|
|
|
echo "GDB BACKTRACE:" >> $post_file
|
|
|
|
echo $line >> $post_file
|
|
|
|
|
2009-10-12 22:22:52 +00:00
|
|
|
gdb $prefix/bin/freeswitch `echo $core | tail -n1` \
|
2009-09-17 20:05:40 +00:00
|
|
|
--eval-command="echo \n\n" \
|
|
|
|
--eval-command="set pagination off" \
|
2011-08-24 20:00:01 +00:00
|
|
|
--eval-command="echo Thread Info\n" \
|
|
|
|
--eval-command="echo $line\n" \
|
|
|
|
--eval-command="info threads" \
|
2009-09-17 20:05:40 +00:00
|
|
|
--eval-command="echo Stack Trace\n" \
|
|
|
|
--eval-command="echo $line\n" \
|
|
|
|
--eval-command="bt" \
|
|
|
|
--eval-command="echo \n\n\n\n Stack Trace (full)\n" \
|
|
|
|
--eval-command="echo $line\n" \
|
|
|
|
--eval-command="bt full" \
|
|
|
|
--eval-command="echo \n\n\n\n Stack Trace (all threads)\n" \
|
|
|
|
--eval-command="echo $line\n" \
|
|
|
|
--eval-command="thread apply all bt" \
|
|
|
|
--eval-command="echo \n\n\n\n Stack Trace (all threads) (full)\n" \
|
|
|
|
--eval-command="echo $line\n" \
|
|
|
|
--eval-command="thread apply all bt full" \
|
|
|
|
--eval-command="quit" 1>> $post_file 2>/dev/null
|
2009-09-17 18:48:01 +00:00
|
|
|
|
|
|
|
rm -fr $tmpdir
|
|
|
|
mkdir -p $tmpdir
|
|
|
|
cd $tmpdir
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
wget --output-file=/dev/null --http-user=pastebin --http-password=freeswitch http://pastebin.freeswitch.org --post-file=$post_file
|
|
|
|
|
|
|
|
pb=`ls [0-9]*`
|
|
|
|
|
2009-09-18 15:42:54 +00:00
|
|
|
mv $post_file $tmpdir
|
2009-09-17 18:48:01 +00:00
|
|
|
echo "Finished."
|
|
|
|
echo "Please report http://pastebin.freeswitch.org/$pb to the developers."
|