diff options
author | Mark Spencer <markster@digium.com> | 2005-12-20 09:56:55 +0000 |
---|---|---|
committer | Mark Spencer <markster@digium.com> | 2005-12-20 09:56:55 +0000 |
commit | a965978a25dad0ffa9665b7e2d2ab0d751389a4b (patch) | |
tree | c63db32285cf58b7d52ffec7b9dea34c57056dde /apps/app_directed_pickup.c | |
parent | 6322aaad68ba0ee7d1f805d6fa184f28f9a599fa (diff) |
Fix segfault on directed pickup when no CDR is available (bug #5998)
git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@7541 65c4cc65-6c06-0410-ace0-fbb531ad65f3
Diffstat (limited to 'apps/app_directed_pickup.c')
-rw-r--r-- | apps/app_directed_pickup.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/apps/app_directed_pickup.c b/apps/app_directed_pickup.c index 7008ff083..9e7d3cc84 100644 --- a/apps/app_directed_pickup.c +++ b/apps/app_directed_pickup.c @@ -77,7 +77,7 @@ static int pickup_exec(struct ast_channel *chan, void *data) /* Find a channel to pickup */ origin = ast_get_channel_by_exten_locked(exten, context); - if (origin) { + if (origin && origin->cdr) { ast_cdr_getvar(origin->cdr, "dstchannel", &tmp, workspace, sizeof(workspace), 0); if (tmp) { @@ -89,6 +89,8 @@ static int pickup_exec(struct ast_channel *chan, void *data) } ast_mutex_unlock(&origin->lock); } else { + if (origin) + ast_mutex_unlock(&origin->lock); ast_log(LOG_DEBUG, "No originating channel found.\n"); } |