summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMark Spencer <markster@digium.com>2005-01-18 11:37:08 +0000
committerMark Spencer <markster@digium.com>2005-01-18 11:37:08 +0000
commit8b0d0923b4a980fdce4c569808e2c05ee5db73bc (patch)
tree3db96a5af81d7900428623f12174f39331515983
parent5914c791bb36aba1a3e1be019883946a69f00804 (diff)
Fix recently introduced zap crash from HOLD/UNHOLD patch (bug #3365)
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@4831 65c4cc65-6c06-0410-ace0-fbb531ad65f3
-rwxr-xr-xchannels/chan_zap.c21
1 files changed, 16 insertions, 5 deletions
diff --git a/channels/chan_zap.c b/channels/chan_zap.c
index 36efc2176..c32149cb6 100755
--- a/channels/chan_zap.c
+++ b/channels/chan_zap.c
@@ -4392,12 +4392,11 @@ static int zt_indicate(struct ast_channel *chan, int condition)
chan->_softhangup |= AST_SOFTHANGUP_DEV;
res = 0;
} else if (!p->proceeding && p->sig==SIG_PRI && p->pri && !p->outgoing) {
- if (p->pri->pri) {
+ if (p->pri) {
if (!pri_grab(p, p->pri)) {
pri_progress(p->pri->pri,p->call, PVT_TO_CHANNEL(p), 1);
pri_rel(p->pri);
- }
- else
+ } else
ast_log(LOG_WARNING, "Unable to grab PRI on span %d\n", p->span);
}
p->proceeding=1;
@@ -4408,10 +4407,22 @@ static int zt_indicate(struct ast_channel *chan, int condition)
break;
#ifdef ZAPATA_PRI
case AST_CONTROL_HOLD:
- res = pri_notify(p->pri->pri, p->call, p->prioffset, PRI_NOTIFY_REMOTE_HOLD);
+ if (p->pri) {
+ if (!pri_grab(p, p->pri)) {
+ res = pri_notify(p->pri->pri, p->call, p->prioffset, PRI_NOTIFY_REMOTE_HOLD);
+ pri_rel(p->pri);
+ } else
+ ast_log(LOG_WARNING, "Unable to grab PRI on span %d\n", p->span);
+ }
break;
case AST_CONTROL_UNHOLD:
- res = pri_notify(p->pri->pri, p->call, p->prioffset, PRI_NOTIFY_REMOTE_RETRIEVAL);
+ if (p->pri) {
+ if (!pri_grab(p, p->pri)) {
+ res = pri_notify(p->pri->pri, p->call, p->prioffset, PRI_NOTIFY_REMOTE_RETRIEVAL);
+ pri_rel(p->pri);
+ } else
+ ast_log(LOG_WARNING, "Unable to grab PRI on span %d\n", p->span);
+ }
break;
#endif
case AST_CONTROL_RADIO_KEY: