From 130eb5602f8e4b9d5ecf91091607ca47f2a4eea6 Mon Sep 17 00:00:00 2001 From: Joshua Colp <jcolp@digium.com> Date: Fri, 5 Jan 2007 23:51:43 +0000 Subject: [PATCH] It is possible for framein to get called and no channel be available, so do a check before we increment the count. git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@49716 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- codecs/codec_zap.c | 8 ++++++++ 1 file changed, 8 insertions(+) diff --git a/codecs/codec_zap.c b/codecs/codec_zap.c index b07d3e586f..8cd4862a50 100644 --- a/codecs/codec_zap.c +++ b/codecs/codec_zap.c @@ -142,10 +142,18 @@ static int zap_framein(struct ast_trans_pvt *pvt, struct ast_frame *f) if(!ztp->inuse) { ast_mutex_lock(&channelcount); if(pvt->t->dstfmt == 8 || pvt->t->dstfmt == 0 ) { + if (complexinuse == totalchannels) { + ast_mutex_unlock(&channelcount); + return -1; + } complexinuse++; if(complexinuse == totalchannels) deactivate_translator(0); } else { + if (simpleinuse == totalchannels) { + ast_mutex_unlock(&channelcount); + return -1; + } simpleinuse++; if(simpleinuse == totalchannels) deactivate_translator(1); -- GitLab