[svn-commits] branch oej/t38passthrough r11816 - in
/team/oej/t38passthrough: ./ channels/ ...
svn-commits at lists.digium.com
svn-commits at lists.digium.com
Sat Mar 4 08:18:13 MST 2006
Author: oej
Date: Sat Mar 4 09:18:09 2006
New Revision: 11816
URL: http://svn.digium.com/view/asterisk?rev=11816&view=rev
Log:
- Adding options to sip.conf, need explanation
- Adding a README file
- Changing variable names to reflect that they're global settings
- Small formatting changes
Added:
team/oej/t38passthrough/doc/sipt38support.txt (with props)
Modified:
team/oej/t38passthrough/Makefile
team/oej/t38passthrough/channels/chan_sip.c
team/oej/t38passthrough/configs/sip.conf.sample
Modified: team/oej/t38passthrough/Makefile
URL: http://svn.digium.com/view/asterisk/team/oej/t38passthrough/Makefile?rev=11816&r1=11815&r2=11816&view=diff
==============================================================================
--- team/oej/t38passthrough/Makefile (original)
+++ team/oej/t38passthrough/Makefile Sat Mar 4 09:18:09 2006
@@ -431,6 +431,7 @@
INSTALL=install
+#Add T38_SUPPORT by default. Disable by commenting out next line
CFLAGS+=-DT38_SUPPORT
_all: all
Modified: team/oej/t38passthrough/channels/chan_sip.c
URL: http://svn.digium.com/view/asterisk/team/oej/t38passthrough/channels/chan_sip.c?rev=11816&r1=11815&r2=11816&view=diff
==============================================================================
--- team/oej/t38passthrough/channels/chan_sip.c (original)
+++ team/oej/t38passthrough/channels/chan_sip.c Sat Mar 4 09:18:09 2006
@@ -36,7 +36,6 @@
* \ingroup channel_drivers
*
*/
-
#include <stdio.h>
#include <ctype.h>
@@ -481,9 +480,9 @@
#endif
#if defined(T38_SUPPORT)
-static int t38udptlsupport = 0;
-static int t38rtpsupport = 0;
-static int t38tcpsupport = 0;
+static int global_t38udptl_support = 0;
+static int global_t38rtp_support = 0;
+static int global_t38tcp_support = 0;
#endif
#define DEC_CALL_LIMIT 0
@@ -2967,11 +2966,11 @@
t38 support is enabled - not good, but working.
XXX: It would be better to have user/peer configuration flag for t38support. :XXX
*/
- if (!t38udptlsupport) {
- return ast_rtp_bridge(c0,c1,flags,fo,rc,timeoutms);
- } else {
- ast_log(LOG_NOTICE, "T38 UDPTL support enabled native RTP bridging disabled\n");
- return AST_BRIDGE_FAILED_NOWARN;
+ if (!global_t38udptl_support) {
+ return ast_rtp_bridge(c0,c1,flags,fo,rc,timeoutms);
+ } else {
+ ast_log(LOG_NOTICE, "T38 UDPTL support enabled, native RTP bridging disabled\n");
+ return AST_BRIDGE_FAILED_NOWARN;
}
}
#endif
@@ -3255,7 +3254,7 @@
f = ast_dsp_process(p->owner, p->vad, f);
if (f && (f->frametype == AST_FRAME_DTMF)) {
#if defined(T38_SUPPORT)
- if (t38udptlsupport && f->subclass == 'f') {
+ if (global_t38udptl_support && f->subclass == 'f') {
/* Fax tone */
if (option_debug)
ast_log(LOG_DEBUG, "Fax CNG detected on %s\n", ast->name);
@@ -3291,7 +3290,7 @@
#if defined(T38_SUPPORT)
/* If we are NOT bridged to another channel, and we have detected fax tone we issue T38 re-invite to a peer */
/* If we are bridged than it is responsibility of the SIP device to issue T38 re-invite if it detects CNG or fax preabmle */
- if (faxdetected && t38udptlsupport && (p->t38state == 0) && !(ast_bridged_channel(ast))) {
+ if (faxdetected && global_t38udptl_support && (p->t38state == 0) && !(ast_bridged_channel(ast))) {
if (!ast_test_flag(p, SIP_GOTREFER)) {
if (!p->pendinginvite) {
if (option_debug > 2)
@@ -3400,7 +3399,7 @@
if (global_videosupport)
p->vrtp = ast_rtp_new_with_bindaddr(sched, io, 1, 0, bindaddr.sin_addr);
#if defined(T38_SUPPORT)
- if (t38udptlsupport)
+ if (global_t38udptl_support)
p->udptl = ast_udptl_new_with_bindaddr(sched, io, 0, bindaddr.sin_addr);
#endif
if (!p->rtp || (global_videosupport && !p->vrtp)) {
@@ -3833,7 +3832,7 @@
}
}
#if defined(T38_SUPPORT)
- if (p->udptl && t38udptlsupport && (sscanf(m, "image %d udptl t38 %n", &x, &len) == 1)) {
+ if (p->udptl && global_t38udptl_support && (sscanf(m, "image %d udptl t38 %n", &x, &len) == 1)) {
if (debug)
ast_verbose("Got T.38 offer in SDP\n");
found = 1;
@@ -3932,7 +3931,7 @@
#if defined(T38_SUPPORT)
/* Setup UDPTL port number */
sin.sin_port = htons(udptlportno);
- if (p->udptl && t38udptlsupport && sin.sin_port) {
+ if (p->udptl && global_t38udptl_support && sin.sin_port) {
ast_udptl_set_peer(p->udptl, &sin);
if (debug) {
ast_verbose("Peer T.38 UDPTL is at port %s:%d\n", ast_inet_ntoa(iabuf,sizeof(iabuf), sin.sin_addr), ntohs(sin.sin_port));
@@ -5053,7 +5052,7 @@
alreadysent |= p->prefcodec;
}
#if defined(T38_SUPPORT)
- if (t38rtpsupport) {
+ if (global_t38rtp_support) {
/* TODO: Improve this */
len = snprintf(a_audio_next, a_audio_left, " %d", 191);
a_audio_next += len;
@@ -13094,9 +13093,9 @@
ast_copy_string(global_realm, DEFAULT_REALM, sizeof(global_realm));
ast_copy_string(default_callerid, DEFAULT_CALLERID, sizeof(default_callerid));
#if defined(T38_SUPPORT)
- t38udptlsupport = 0;
- t38rtpsupport = 0;
- t38tcpsupport = 0;
+ global_t38udptl_support = 0;
+ global_t38rtp_support = 0;
+ global_t38tcp_support = 0;
#endif
global_videosupport = DEFAULT_VIDEOSUPPORT;
compactheaders = DEFAULT_COMPACTHEADERS;
@@ -13190,12 +13189,12 @@
} else if (!strcasecmp(v->name, "videosupport")) {
global_videosupport = ast_true(v->value);
#if defined(T38_SUPPORT)
- } else if (!strcasecmp(v->name, "t38udptlsupport")) {
- t38udptlsupport = ast_true(v->value);
- } else if (!strcasecmp(v->name, "t38rtpsupport")) {
- t38rtpsupport = ast_true(v->value);
- } else if (!strcasecmp(v->name, "t38tcpsupport")) {
- t38tcpsupport = ast_true(v->value);
+ } else if (!strcasecmp(v->name, "global_t38udptl_support")) {
+ global_t38udptl_support = ast_true(v->value);
+ } else if (!strcasecmp(v->name, "global_t38rtp_support")) {
+ global_t38rtp_support = ast_true(v->value);
+ } else if (!strcasecmp(v->name, "global_t38tcp_support")) {
+ global_t38tcp_support = ast_true(v->value);
#endif
} else if (!strcasecmp(v->name, "compactheaders")) {
compactheaders = ast_true(v->value);
@@ -14068,6 +14067,11 @@
ast_unregister_application(app_dtmfmode);
ast_unregister_application(app_sipaddheader);
+#if defined(T38_SUPPORT)
+ /* Tell the UDPTL subdriver that we're gone */
+ ast_udptl_proto_unregister(&sip_udptl);
+#endif
+
ast_cli_unregister_multiple(my_clis, sizeof(my_clis) / sizeof(my_clis[0]));
ast_rtp_proto_unregister(&sip_rtp);
Modified: team/oej/t38passthrough/configs/sip.conf.sample
URL: http://svn.digium.com/view/asterisk/team/oej/t38passthrough/configs/sip.conf.sample?rev=11816&r1=11815&r2=11816&view=diff
==============================================================================
--- team/oej/t38passthrough/configs/sip.conf.sample (original)
+++ team/oej/t38passthrough/configs/sip.conf.sample Sat Mar 4 09:18:09 2006
@@ -120,6 +120,10 @@
;
;regcontext=sipregistrations
;
+;---------------------------- T.38 FAX PASSTHROUGH SUPPORT ------------------------------------
+; t38udptlsupport = yes ; Default false
+; t38rtpsupport = yes ; Default false
+; t38tcpsupport = yes ; Default false
;----------------------------------------- OUTBOUND SIP REGISTRATIONS ------------------------
; Asterisk can register as a SIP user agent to a SIP proxy (provider)
; Format for the register statement is:
Added: team/oej/t38passthrough/doc/sipt38support.txt
URL: http://svn.digium.com/view/asterisk/team/oej/t38passthrough/doc/sipt38support.txt?rev=11816&view=auto
==============================================================================
--- team/oej/t38passthrough/doc/sipt38support.txt (added)
+++ team/oej/t38passthrough/doc/sipt38support.txt Sat Mar 4 09:18:09 2006
@@ -1,0 +1,10 @@
+T38 Fax passthrough support in SIP
+----------------------------------
+
+By default there is now T.38 Fax over IP support for fax passthrough
+in the SIP channel. There are a number of devices in the market that
+supports T.38 faxing.
+
+Contributors
+-------------
+The T.38 support in Asterisk was developed by Steve Underwood
Propchange: team/oej/t38passthrough/doc/sipt38support.txt
------------------------------------------------------------------------------
svn:eol-style = native
Propchange: team/oej/t38passthrough/doc/sipt38support.txt
------------------------------------------------------------------------------
svn:keywords = Author Date Id Revision
Propchange: team/oej/t38passthrough/doc/sipt38support.txt
------------------------------------------------------------------------------
svn:mime-type = text/plain
More information about the svn-commits
mailing list