summaryrefslogtreecommitdiff
path: root/channels/chan_h323.c
diff options
context:
space:
mode:
Diffstat (limited to 'channels/chan_h323.c')
-rwxr-xr-xchannels/chan_h323.c6
1 files changed, 3 insertions, 3 deletions
diff --git a/channels/chan_h323.c b/channels/chan_h323.c
index e306131d4..8d4373d9c 100755
--- a/channels/chan_h323.c
+++ b/channels/chan_h323.c
@@ -782,7 +782,7 @@ static struct oh323_pvt *oh323_alloc(int callid)
return NULL;
}
memset(pvt, 0, sizeof(struct oh323_pvt));
- pvt->rtp = ast_rtp_new(sched, io, 1, 0);
+ pvt->rtp = ast_rtp_new_with_bindaddr(sched, io, 1, 0,bindaddr.sin_addr);
if (!pvt->rtp) {
ast_log(LOG_WARNING, "Unable to create RTP session: %s\n", strerror(errno));
free(pvt);
@@ -1108,8 +1108,8 @@ struct rtp_info *external_rtp_create(unsigned call_reference, const char * token
/* figure out our local RTP port and tell the H.323 stack about it */
ast_rtp_get_us(pvt->rtp, &us);
ast_mutex_unlock(&pvt->lock);
- /* evil hack, until I (or someone?) figures out a better way */
- ast_inet_ntoa(info->addr, sizeof(info->addr), bindaddr.sin_addr);
+
+ ast_inet_ntoa(info->addr, sizeof(info->addr), us.sin_addr);
info->port = ntohs(us.sin_port);
if (h323debug)
ast_log(LOG_DEBUG, "Sending RTP 'US' %s:%d\n", info->addr, info->port);