aboutsummaryrefslogtreecommitdiffstats
path: root/channels/chan_local.c
diff options
context:
space:
mode:
authormarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2003-08-11 20:47:48 +0000
committermarkster <markster@f38db490-d61c-443f-a65b-d21fe96a405b>2003-08-11 20:47:48 +0000
commit86f23150f5242dc5583ebd10ff581549e4dbf402 (patch)
treefa943562a3b2383c45e76ae93483fcca0041c27d /channels/chan_local.c
parent40d959f5783f0ce0b4c694c1316c2593bd0f917a (diff)
Lock everything that might need to be locked
git-svn-id: http://svn.digium.com/svn/asterisk/trunk@1292 f38db490-d61c-443f-a65b-d21fe96a405b
Diffstat (limited to 'channels/chan_local.c')
-rwxr-xr-xchannels/chan_local.c4
1 files changed, 4 insertions, 0 deletions
diff --git a/channels/chan_local.c b/channels/chan_local.c
index 221b01135..3d4511d95 100755
--- a/channels/chan_local.c
+++ b/channels/chan_local.c
@@ -131,13 +131,17 @@ static void check_bridge(struct local_pvt *p, int isoutbound)
/* Masquerade bridged channel into owner */
/* Lock other side first */
ast_pthread_mutex_lock(&p->chan->bridge->lock);
+ ast_pthread_mutex_lock(&p->owner->lock);
ast_channel_masquerade(p->owner, p->chan->bridge);
+ ast_pthread_mutex_unlock(&p->owner->lock);
ast_pthread_mutex_unlock(&p->chan->bridge->lock);
p->alreadymasqed = 1;
} else if (!isoutbound && p->owner && p->owner->bridge && p->chan) {
/* Masquerade bridged channel into chan */
ast_pthread_mutex_lock(&p->owner->bridge->lock);
+ ast_pthread_mutex_lock(&p->chan->lock);
ast_channel_masquerade(p->chan, p->owner->bridge);
+ ast_pthread_mutex_unlock(&p->chan->lock);
ast_pthread_mutex_unlock(&p->owner->bridge->lock);
p->alreadymasqed = 1;
}