[asterisk-commits] irroot: branch irroot/distrotech-customers-1.8 r338025 - in /team/irroot/dist...
SVN commits to the Asterisk project
asterisk-commits at lists.digium.com
Tue Sep 27 03:23:26 CDT 2011
Author: irroot
Date: Tue Sep 27 03:23:21 2011
New Revision: 338025
URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=338025
Log:
Update dialog_initialize_rtp to respect the rtp timeout/holdtimeout/keepalive
Modified:
team/irroot/distrotech-customers-1.8/channels/chan_sip.c
team/irroot/distrotech-customers-1.8/channels/sip/include/sip.h
Modified: team/irroot/distrotech-customers-1.8/channels/chan_sip.c
URL: http://svnview.digium.com/svn/asterisk/team/irroot/distrotech-customers-1.8/channels/chan_sip.c?view=diff&rev=338025&r1=338024&r2=338025
==============================================================================
--- team/irroot/distrotech-customers-1.8/channels/chan_sip.c (original)
+++ team/irroot/distrotech-customers-1.8/channels/chan_sip.c Tue Sep 27 03:23:21 2011
@@ -5051,9 +5051,9 @@
if (!(dialog->vrtp = ast_rtp_instance_new(dialog->engine, sched, &bindaddr_tmp, NULL))) {
return -1;
}
- ast_rtp_instance_set_timeout(dialog->vrtp, global_rtptimeout);
- ast_rtp_instance_set_hold_timeout(dialog->vrtp, global_rtpholdtimeout);
- ast_rtp_instance_set_keepalive(dialog->vrtp, global_rtpholdtimeout);
+ ast_rtp_instance_set_timeout(dialog->vrtp, dialog->rtptimeout);
+ ast_rtp_instance_set_hold_timeout(dialog->vrtp, dialog->rtpholdtimeout);
+ ast_rtp_instance_set_keepalive(dialog->vrtp, dialog->rtpkeepalive);
ast_rtp_instance_set_prop(dialog->vrtp, AST_RTP_PROPERTY_RTCP, 1);
}
@@ -5062,16 +5062,16 @@
if (!(dialog->trtp = ast_rtp_instance_new(dialog->engine, sched, &bindaddr_tmp, NULL))) {
return -1;
}
- ast_rtp_instance_set_timeout(dialog->trtp, global_rtptimeout);
- ast_rtp_instance_set_hold_timeout(dialog->trtp, global_rtpholdtimeout);
- ast_rtp_instance_set_keepalive(dialog->trtp, global_rtpholdtimeout);
+ ast_rtp_instance_set_timeout(dialog->trtp, dialog->rtptimeout);
+ ast_rtp_instance_set_hold_timeout(dialog->trtp, dialog->rtpholdtimeout);
+ ast_rtp_instance_set_keepalive(dialog->trtp, dialog->rtpkeepalive);
ast_rtp_instance_set_prop(dialog->trtp, AST_RTP_PROPERTY_RTCP, 1);
}
- ast_rtp_instance_set_timeout(dialog->rtp, global_rtptimeout);
- ast_rtp_instance_set_hold_timeout(dialog->rtp, global_rtpholdtimeout);
- ast_rtp_instance_set_keepalive(dialog->rtp, global_rtpkeepalive);
+ ast_rtp_instance_set_timeout(dialog->rtp, dialog->rtptimeout);
+ ast_rtp_instance_set_hold_timeout(dialog->rtp, dialog->rtpholdtimeout);
+ ast_rtp_instance_set_keepalive(dialog->rtp, dialog->rtpkeepalive);
ast_rtp_instance_set_prop(dialog->rtp, AST_RTP_PROPERTY_RTCP, 1);
ast_rtp_instance_set_prop(dialog->rtp, AST_RTP_PROPERTY_DTMF, ast_test_flag(&dialog->flags[0], SIP_DTMF) == SIP_DTMF_RFC2833);
@@ -5132,6 +5132,9 @@
ast_string_field_set(dialog, engine, peer->engine);
+ dialog->rtptimeout = peer->rtptimeout;
+ dialog->rtpholdtimeout = peer->rtpholdtimeout;
+ dialog->rtpkeepalive = peer->rtpkeepalive;
if (dialog_initialize_rtp(dialog)) {
return -1;
}
@@ -5139,22 +5142,9 @@
if (dialog->rtp) { /* Audio */
ast_rtp_instance_set_prop(dialog->rtp, AST_RTP_PROPERTY_DTMF, ast_test_flag(&dialog->flags[0], SIP_DTMF) == SIP_DTMF_RFC2833);
ast_rtp_instance_set_prop(dialog->rtp, AST_RTP_PROPERTY_DTMF_COMPENSATE, ast_test_flag(&dialog->flags[1], SIP_PAGE2_RFC2833_COMPENSATE));
- ast_rtp_instance_set_timeout(dialog->rtp, peer->rtptimeout);
- ast_rtp_instance_set_hold_timeout(dialog->rtp, peer->rtpholdtimeout);
- ast_rtp_instance_set_keepalive(dialog->rtp, peer->rtpkeepalive);
/* Set Frame packetization */
ast_rtp_codecs_packetization_set(ast_rtp_instance_get_codecs(dialog->rtp), dialog->rtp, &dialog->prefs);
dialog->autoframing = peer->autoframing;
- }
- if (dialog->vrtp) { /* Video */
- ast_rtp_instance_set_timeout(dialog->vrtp, peer->rtptimeout);
- ast_rtp_instance_set_hold_timeout(dialog->vrtp, peer->rtpholdtimeout);
- ast_rtp_instance_set_keepalive(dialog->vrtp, peer->rtpkeepalive);
- }
- if (dialog->trtp) { /* Realtime text */
- ast_rtp_instance_set_timeout(dialog->trtp, peer->rtptimeout);
- ast_rtp_instance_set_hold_timeout(dialog->trtp, peer->rtpholdtimeout);
- ast_rtp_instance_set_keepalive(dialog->trtp, peer->rtpkeepalive);
}
/* XXX TODO: get fields directly from peer only as they are needed using dialog->relatedpeer */
@@ -5182,7 +5172,6 @@
dialog->pickupgroup = peer->pickupgroup;
dialog->allowtransfer = peer->allowtransfer;
dialog->jointnoncodeccapability = dialog->noncodeccapability;
- dialog->rtptimeout = peer->rtptimeout;
/* Update dialog authorization credentials */
ao2_lock(peer);
@@ -5295,10 +5284,13 @@
dialog->relatedpeer = ref_peer(peer, "create_addr: setting dialog's relatedpeer pointer");
unref_peer(peer, "create_addr: unref peer from find_peer hashtab lookup");
return res;
- }
-
- if (dialog_initialize_rtp(dialog)) {
- return -1;
+ } else {
+ dialog->rtptimeout = global_rtptimeout;
+ dialog->rtpholdtimeout = global_rtpholdtimeout;
+ dialog->rtpkeepalive = global_rtpkeepalive;
+ if (dialog_initialize_rtp(dialog)) {
+ return -1;
+ }
}
ast_string_field_set(dialog, tohost, hostport.host);
@@ -15598,6 +15590,9 @@
else
p->noncodeccapability &= ~AST_RTP_DTMF;
p->jointnoncodeccapability = p->noncodeccapability;
+ p->rtptimeout = peer->rtptimeout;
+ p->rtpholdtimeout = peer->rtpholdtimeout;
+ p->rtpkeepalive = peer->rtpkeepalive;
if (!dialog_initialize_rtp(p)) {
if (p->rtp) {
ast_rtp_codecs_packetization_set(ast_rtp_instance_get_codecs(p->rtp), p->rtp, &peer->prefs);
@@ -15719,6 +15714,9 @@
/* Finally, apply the guest policy */
if (sip_cfg.allowguest) {
get_rpid(p, req);
+ p->rtptimeout = global_rtptimeout;
+ p->rtpholdtimeout = global_rtpholdtimeout;
+ p->rtpkeepalive = global_rtpkeepalive;
if (!dialog_initialize_rtp(p)) {
res = AUTH_SUCCESSFUL;
} else {
Modified: team/irroot/distrotech-customers-1.8/channels/sip/include/sip.h
URL: http://svnview.digium.com/svn/asterisk/team/irroot/distrotech-customers-1.8/channels/sip/include/sip.h?view=diff&rev=338025&r1=338024&r2=338025
==============================================================================
--- team/irroot/distrotech-customers-1.8/channels/sip/include/sip.h (original)
+++ team/irroot/distrotech-customers-1.8/channels/sip/include/sip.h Tue Sep 27 03:23:21 2011
@@ -1041,6 +1041,8 @@
time_t lastrtprx; /*!< Last RTP received */
time_t lastrtptx; /*!< Last RTP sent */
int rtptimeout; /*!< RTP timeout time */
+ int rtpholdtimeout; /*!< RTP timeout time on hold*/
+ int rtpkeepalive; /*!< RTP send packets for keepalive */
struct ast_ha *directmediaha; /*!< Which IPs are allowed to interchange direct media with this peer - copied from sip_peer */
struct ast_sockaddr recv; /*!< Received as */
struct ast_sockaddr ourip; /*!< Our IP (as seen from the outside) */
More information about the asterisk-commits
mailing list