automerge commit

git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.2-netsec@77937 65c4cc65-6c06-0410-ace0-fbb531ad65f3
1.2-netsec
Automerge Script 18 years ago
parent 220d01134a
commit 09d0b6be60

@ -482,9 +482,9 @@ static int macroif_exec(struct ast_channel *chan, void *data)
label_b++; label_b++;
} }
if (pbx_checkcondition(expr)) if (pbx_checkcondition(expr))
macro_exec(chan, label_a); res = macro_exec(chan, label_a);
else if (label_b) else if (label_b)
macro_exec(chan, label_b); res = macro_exec(chan, label_b);
} else } else
ast_log(LOG_WARNING, "Invalid Syntax.\n"); ast_log(LOG_WARNING, "Invalid Syntax.\n");

@ -3,8 +3,19 @@
# lame quickie script to snarf a core of a hung asterisk process. # lame quickie script to snarf a core of a hung asterisk process.
# bugs to ast_grab_core, blinky-lights.org (derrick daugherty) # bugs to ast_grab_core, blinky-lights.org (derrick daugherty)
# we have found that gcore doesn't yield as useful a core file
# as that yielded by a signal-caused core dump. So we are going to change
# the strategy to sending a SEGV signal to the asterisk process,
# and have it 'burn to the ground', leaving behind a core file.
# the main difference is that you cannot control where the
# core file will end up. We will assume that safe_asterisk was
# used to start asterisk, and the core file should therefore end
# up in /tmp (because safe_asterisk cd's there before starting asterisk).
# if this is not the case, set DUMPDIR to the place where the core
# file can be found.
DATE=`date +%Y%m%d%H%M` DATE=`date +%Y%m%d%H%M`
DUMPDIR=/var/tmp DUMPDIR=/tmp
HOSTNAME=`hostname` HOSTNAME=`hostname`
ADMINEMAIL="root@localhost" ADMINEMAIL="root@localhost"
@ -27,20 +38,16 @@ echo \*\*\* WARNING \*\*\* If the system is not already locked this will cause
echo \*\*\* WARNING \*\*\* process to STOP while memory is dumped to disk. echo \*\*\* WARNING \*\*\* process to STOP while memory is dumped to disk.
echo echo
/usr/bin/gdb > /dev/null << EOF /usr/bin/kill -11 ${PID}
attach ${PID}
gcore ${DUMPDIR}/asterisk_${DATE}.core.${PID}
detach
quit
EOF
echo Snarfed! ${DUMPDIR}/asterisk_${DATE}.core.${PID} echo Snarfed! ${DUMPDIR}/core.${PID}
echo echo
echo Trying for a backtrace of the captured core. echo Trying for a backtrace of the captured core.
/usr/bin/gdb /usr/sbin/asterisk ${DUMPDIR}/asterisk_${DATE}.core.${PID} > /tmp/gdb_dump.${PID} 2> /dev/null << EOF /usr/bin/gdb /usr/sbin/asterisk ${DUMPDIR}/core.${PID} > /tmp/gdb_dump.${PID} 2> /dev/null << EOF
set prompt \n set prompt \n
set print pretty\n
echo --------------------------------------------------------------------------------\n echo --------------------------------------------------------------------------------\n
echo INFO THREAD echo INFO THREAD
info thread info thread
@ -56,7 +63,7 @@ echo Done trying for a bt.
echo Notifying admins of the core. echo Notifying admins of the core.
/usr/bin/mail -s "${HOSTNAME} core dumped at ${DUMPDIR}/asterisk_${DATE}.core.${PID}" ${ADMINEMAIL} < /tmp/gdb_dump.${PID} /usr/bin/mail -s "${HOSTNAME} core dumped at ${DUMPDIR}/core.${PID}" ${ADMINEMAIL} < /tmp/gdb_dump.${PID}
/bin/rm /tmp/gdb_dump.${PID} /bin/rm /tmp/gdb_dump.${PID}
echo Done. echo Done.
echo echo

@ -1103,7 +1103,8 @@ static int handle_exec(struct ast_channel *chan, AGI *agi, int argc, char **argv
} }
fdprintf(agi->fd, "200 result=%d\n", res); fdprintf(agi->fd, "200 result=%d\n", res);
return res >= 0 ? RESULT_SUCCESS : RESULT_FAILURE; /* Even though this is wrong, users are depending upon this result. */
return res;
} }
static int handle_setcallerid(struct ast_channel *chan, AGI *agi, int argc, char **argv) static int handle_setcallerid(struct ast_channel *chan, AGI *agi, int argc, char **argv)

Loading…
Cancel
Save