[svn-commits] file: branch group/vldtmf r39836 -
/team/group/vldtmf/rtp.c
svn-commits at lists.digium.com
svn-commits at lists.digium.com
Tue Aug 15 10:57:44 MST 2006
Author: file
Date: Tue Aug 15 12:57:44 2006
New Revision: 39836
URL: http://svn.digium.com/view/asterisk?rev=39836&view=rev
Log:
Add latest round of fixes. This totally works (inbound/outbound/compensation) but is currently subject to change after lunch.
Modified:
team/group/vldtmf/rtp.c
Modified: team/group/vldtmf/rtp.c
URL: http://svn.digium.com/view/asterisk/team/group/vldtmf/rtp.c?rev=39836&r1=39835&r2=39836&view=diff
==============================================================================
--- team/group/vldtmf/rtp.c (original)
+++ team/group/vldtmf/rtp.c Tue Aug 15 12:57:44 2006
@@ -133,6 +133,7 @@
unsigned int lasteventendseqn;
int dtmfcount;
unsigned int dtmfduration;
+ int receive_compensate;
/* DTMF Transmission Variables */
unsigned int lastdigitts;
char send_digit;
@@ -168,6 +169,8 @@
static int ast_rtcp_write_sr(void *data);
static int ast_rtcp_write_rr(void *data);
static unsigned int ast_rtcp_calc_interval(struct ast_rtp *rtp);
+static int ast_rtp_senddigit_continuation(struct ast_rtp *rtp);
+int ast_rtp_senddigit_end(struct ast_rtp *rtp, char digit);
#define FLAG_3389_WARNING (1 << 0)
#define FLAG_NAT_ACTIVE (3 << 1)
@@ -663,14 +666,18 @@
resp = 'X';
}
- if ((!(rtp->resp) && (!(event_end & 0x80))) || (rtp->resp && rtp->resp != resp)) {
+ if (((!(rtp->resp) && (!(event_end & 0x80))) || (rtp->resp && rtp->resp != resp)) && !ast_test_flag(rtp, FLAG_DTMF_COMPENSATE)) {
rtp->resp = resp;
f = send_dtmf(rtp, AST_FRAME_DTMF_BEGIN);
- } else if ((event_end & 0x80) && rtp->resp && rtp->lasteventendseqn != seqno && !ast_test_flag(rtp, FLAG_DTMF_COMPENSATE)) {
- /* If we are compensating then our AST_FRAME_DTMF_END will come from elsewhere */
- rtp->lasteventendseqn = seqno;
- f = send_dtmf(rtp, AST_FRAME_DTMF_END);
- rtp->resp = 0;
+ } else if (event_end & 0x80) {
+ if (!rtp->resp && ast_test_flag(rtp, FLAG_DTMF_COMPENSATE)) {
+ rtp->resp = resp;
+ f = send_dtmf(rtp, AST_FRAME_DTMF_BEGIN);
+ } else if (rtp->resp && rtp->lasteventendseqn != seqno && !ast_test_flag(rtp, FLAG_DTMF_COMPENSATE)) {
+ rtp->lasteventendseqn = seqno;
+ f = send_dtmf(rtp, AST_FRAME_DTMF_END);
+ rtp->resp = 0;
+ }
}
rtp->dtmfcount = dtmftimeout;
@@ -954,6 +961,15 @@
struct rtpPayloadType rtpPT;
struct ast_frame *fr = NULL;
+ /* If time is up, kill it */
+ if (rtp->send_compensate >= 1) {
+ if (rtp->send_compensate == 7)
+ ast_rtp_senddigit_end(rtp, rtp->send_digit);
+ else
+ rtp->send_compensate++;
+ } else if (rtp->send_digit)
+ ast_rtp_senddigit_continuation(rtp);
+
len = sizeof(sin);
/* Cache where the header will go */
@@ -1119,11 +1135,15 @@
rtp->rxseqno = seqno;
/* If we are compensating for lack of VLDTMF, then check to see if we need to send an AST_FRAME_DTMF_END */
- if (rtp->resp && ast_test_flag(rtp, FLAG_DTMF_COMPENSATE) && (timestamp - rtp->lastrxts) >= rtp->dtmfduration) {
- fr = send_dtmf(rtp, AST_FRAME_DTMF_END);
- rtp->lastrxts = timestamp;
- rtp->resp = 0;
- return fr;
+ if (rtp->resp && ast_test_flag(rtp, FLAG_DTMF_COMPENSATE)) {
+ /* We wait for 6 regular frames to come in before queueing the AST_FRAME_DTMF_END */
+ if (rtp->receive_compensate >= 6) {
+ fr = send_dtmf(rtp, AST_FRAME_DTMF_END);
+ rtp->lastrxts = timestamp;
+ rtp->resp = 0;
+ return fr;
+ } else
+ rtp->receive_compensate++;
}
/* Record received timestamp as last received now */
@@ -1893,11 +1913,11 @@
if (digit_convert(digit))
return -1;
- payload = ast_rtp_lookup_code(rtp, 0, AST_RTP_DTMF);
-
/* If we have no peer, return immediately */
if (!rtp->them.sin_addr.s_addr)
return 0;
+
+ payload = ast_rtp_lookup_code(rtp, 0, AST_RTP_DTMF);
rtp->dtmfmute = ast_tvadd(ast_tvnow(), ast_tv(0, 500000));
@@ -2412,10 +2432,6 @@
ast_log(LOG_WARNING, "RTP can only send voice and video\n");
return -1;
}
-
- /* If a digit is currently active then send a continuation frame */
- if (rtp->send_digit)
- ast_rtp_senddigit_continuation(rtp);
subclass = _f->subclass;
if (_f->frametype == AST_FRAME_VIDEO)
More information about the svn-commits
mailing list