From 12ab2fcadfc997c5ea2a18a29b545f0550ce212f Mon Sep 17 00:00:00 2001 From: Mark Spencer Date: Fri, 21 Mar 2003 04:33:36 +0000 Subject: [PATCH] Select proper trunk mode on incoming calls based upon peer git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@673 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- channels/chan_iax2.c | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/channels/chan_iax2.c b/channels/chan_iax2.c index ab5f991fe4..ce575380a5 100755 --- a/channels/chan_iax2.c +++ b/channels/chan_iax2.c @@ -1941,6 +1941,24 @@ static int iax2_getpeername(struct sockaddr_in sin, char *host, int len) return res; } +static int iax2_getpeertrunk(struct sockaddr_in sin) +{ + struct iax2_peer *peer; + int res = 0; + ast_pthread_mutex_lock(&peerl.lock); + peer = peerl.peers; + while(peer) { + if ((peer->addr.sin_addr.s_addr == sin.sin_addr.s_addr) && + (peer->addr.sin_port == sin.sin_port)) { + res = peer->trunk; + break; + } + peer = peer->next; + } + ast_pthread_mutex_unlock(&peerl.lock); + return res; +} + static struct ast_channel *ast_iax2_new(struct chan_iax2_pvt *i, int state, int capability) { char host[256]; @@ -2628,6 +2646,7 @@ static int check_access(int callno, struct sockaddr_in *sin, struct iax_ies *ies user = user->next; } ast_pthread_mutex_unlock(&userl.lock); + iaxs[callno]->trunk = iax2_getpeertrunk(*sin); return res; }