Skip to content
项目
群组
代码片段
帮助
正在加载...
登录
切换导航
F
freeswitch
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
张华
freeswitch
Commits
432e9cdf
提交
432e9cdf
authored
9月 01, 2010
作者:
David Yat Sin
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Added passthrough for bearer capability
上级
e15d52bd
隐藏空白字符变更
内嵌
并排
正在显示
10 个修改的文件
包含
184 行增加
和
48 行删除
+184
-48
mod_freetdm.c
libs/freetdm/mod_freetdm/mod_freetdm.c
+4
-0
ftdm_call_utils.c
libs/freetdm/src/ftdm_call_utils.c
+31
-0
ftdm_io.c
libs/freetdm/src/ftdm_io.c
+8
-0
ftmod_sangoma_isdn.h
...freetdm/src/ftmod/ftmod_sangoma_isdn/ftmod_sangoma_isdn.h
+5
-0
ftmod_sangoma_isdn_cfg.c
...tdm/src/ftmod/ftmod_sangoma_isdn/ftmod_sangoma_isdn_cfg.c
+17
-0
ftmod_sangoma_isdn_stack_hndl.c
.../ftmod/ftmod_sangoma_isdn/ftmod_sangoma_isdn_stack_hndl.c
+12
-12
ftmod_sangoma_isdn_stack_out.c
...c/ftmod/ftmod_sangoma_isdn/ftmod_sangoma_isdn_stack_out.c
+20
-14
ftmod_sangoma_isdn_support.c
...src/ftmod/ftmod_sangoma_isdn/ftmod_sangoma_isdn_support.c
+82
-22
freetdm.h
libs/freetdm/src/include/freetdm.h
+3
-0
ftdm_call_utils.h
libs/freetdm/src/include/private/ftdm_call_utils.h
+2
-0
没有找到文件。
libs/freetdm/mod_freetdm/mod_freetdm.c
浏览文件 @
432e9cdf
...
@@ -1230,10 +1230,14 @@ static switch_call_cause_t channel_outgoing_channel(switch_core_session_t *sessi
...
@@ -1230,10 +1230,14 @@ static switch_call_cause_t channel_outgoing_channel(switch_core_session_t *sessi
freetdmvar
=
switch_channel_get_variable
(
channel
,
"freetdm_bearer_capability"
);
freetdmvar
=
switch_channel_get_variable
(
channel
,
"freetdm_bearer_capability"
);
if
(
freetdmvar
)
{
if
(
freetdmvar
)
{
caller_data
.
bearer_capability
=
(
uint8_t
)
atoi
(
freetdmvar
);
caller_data
.
bearer_capability
=
(
uint8_t
)
atoi
(
freetdmvar
);
}
else
{
caller_data
.
bearer_capability
=
FTDM_INVALID_INT_PARM
;
}
}
freetdmvar
=
switch_channel_get_variable
(
channel
,
"freetdm_bearer_layer1"
);
freetdmvar
=
switch_channel_get_variable
(
channel
,
"freetdm_bearer_layer1"
);
if
(
freetdmvar
)
{
if
(
freetdmvar
)
{
caller_data
.
bearer_layer1
=
(
uint8_t
)
atoi
(
freetdmvar
);
caller_data
.
bearer_layer1
=
(
uint8_t
)
atoi
(
freetdmvar
);
}
else
{
caller_data
.
bearer_layer1
=
FTDM_INVALID_INT_PARM
;
}
}
}
}
...
...
libs/freetdm/src/ftdm_call_utils.c
浏览文件 @
432e9cdf
...
@@ -78,6 +78,37 @@ FT_DECLARE(ftdm_status_t) ftdm_span_set_ton(const char *ton_string, uint8_t *tar
...
@@ -78,6 +78,37 @@ FT_DECLARE(ftdm_status_t) ftdm_span_set_ton(const char *ton_string, uint8_t *tar
return
FTDM_SUCCESS
;
return
FTDM_SUCCESS
;
}
}
FT_DECLARE
(
ftdm_status_t
)
ftdm_span_set_bearer_capability
(
const
char
*
bc_string
,
ftdm_bearer_cap_t
*
target
)
{
if
(
!
strcasecmp
(
bc_string
,
"speech"
))
{
*
target
=
FTDM_BEARER_CAP_SPEECH
;
}
else
if
(
!
strcasecmp
(
bc_string
,
"unrestricted-digital"
))
{
*
target
=
FTDM_BEARER_CAP_64K_UNRESTRICTED
;
}
else
if
(
!
strcasecmp
(
bc_string
,
"3.1Khz"
))
{
*
target
=
FTDM_BEARER_CAP_3_1KHZ_AUDIO
;
}
else
{
ftdm_log
(
FTDM_LOG_WARNING
,
"Unsupported Bearer Capability value (%s)
\n
"
,
bc_string
);
return
FTDM_FAIL
;
}
return
FTDM_SUCCESS
;
}
FT_DECLARE
(
ftdm_status_t
)
ftdm_span_set_bearer_layer1
(
const
char
*
bc_string
,
ftdm_user_layer1_prot_t
*
target
)
{
if
(
!
strcasecmp
(
bc_string
,
"v110"
))
{
*
target
=
FTDM_USER_LAYER1_PROT_V110
;
}
else
if
(
!
strcasecmp
(
bc_string
,
"ulaw"
))
{
*
target
=
FTDM_USER_LAYER1_PROT_ULAW
;
}
else
if
(
!
strcasecmp
(
bc_string
,
"alaw"
))
{
*
target
=
FTDM_USER_LAYER1_PROT_ALAW
;
}
else
{
ftdm_log
(
FTDM_LOG_WARNING
,
"Unsupported Bearer Layer1 Prot value (%s)
\n
"
,
bc_string
);
return
FTDM_FAIL
;
}
return
FTDM_SUCCESS
;
}
FT_DECLARE
(
ftdm_status_t
)
ftdm_is_number
(
char
*
number
)
FT_DECLARE
(
ftdm_status_t
)
ftdm_is_number
(
char
*
number
)
{
{
if
(
!
number
)
{
if
(
!
number
)
{
...
...
libs/freetdm/src/ftdm_io.c
浏览文件 @
432e9cdf
...
@@ -293,6 +293,14 @@ static ftdm_status_t ftdm_set_caller_data(ftdm_span_t *span, ftdm_caller_data_t
...
@@ -293,6 +293,14 @@ static ftdm_status_t ftdm_set_caller_data(ftdm_span_t *span, ftdm_caller_data_t
caller_data
->
rdnis
.
type
=
span
->
default_caller_data
.
rdnis
.
type
;
caller_data
->
rdnis
.
type
=
span
->
default_caller_data
.
rdnis
.
type
;
}
}
if
(
caller_data
->
bearer_capability
==
FTDM_INVALID_INT_PARM
)
{
caller_data
->
bearer_capability
=
span
->
default_caller_data
.
bearer_capability
;
}
if
(
caller_data
->
bearer_layer1
==
FTDM_INVALID_INT_PARM
)
{
caller_data
->
bearer_layer1
=
span
->
default_caller_data
.
bearer_layer1
;
}
if
(
FTDM_FAIL
==
ftdm_is_number
(
caller_data
->
cid_num
.
digits
))
{
if
(
FTDM_FAIL
==
ftdm_is_number
(
caller_data
->
cid_num
.
digits
))
{
ftdm_log
(
FTDM_LOG_DEBUG
,
"dropping caller id number %s since we only accept digits
\n
"
,
caller_data
->
cid_num
.
digits
);
ftdm_log
(
FTDM_LOG_DEBUG
,
"dropping caller id number %s since we only accept digits
\n
"
,
caller_data
->
cid_num
.
digits
);
caller_data
->
cid_num
.
digits
[
0
]
=
'\0'
;
caller_data
->
cid_num
.
digits
[
0
]
=
'\0'
;
...
...
libs/freetdm/src/ftmod/ftmod_sangoma_isdn/ftmod_sangoma_isdn.h
浏览文件 @
432e9cdf
...
@@ -320,6 +320,11 @@ void sngisdn_rcv_cc_ind(CcMngmt *status);
...
@@ -320,6 +320,11 @@ void sngisdn_rcv_cc_ind(CcMngmt *status);
void
sngisdn_rcv_sng_log
(
uint8_t
level
,
char
*
fmt
,...);
void
sngisdn_rcv_sng_log
(
uint8_t
level
,
char
*
fmt
,...);
void
sngisdn_rcv_sng_assert
(
char
*
message
);
void
sngisdn_rcv_sng_assert
(
char
*
message
);
uint8_t
sngisdn_get_infoTranCap_from_stack
(
ftdm_bearer_cap_t
bearer_capability
);
uint8_t
sngisdn_get_usrInfoLyr1Prot_from_stack
(
ftdm_user_layer1_prot_t
layer1_prot
);
ftdm_bearer_cap_t
sngisdn_get_infoTranCap_from_user
(
uint8_t
bearer_capability
);
ftdm_user_layer1_prot_t
sngisdn_get_usrInfoLyr1Prot_from_user
(
uint8_t
layer1_prot
);
static
__inline__
uint32_t
sngisdn_test_flag
(
sngisdn_chan_data_t
*
sngisdn_info
,
sngisdn_flag_t
flag
)
static
__inline__
uint32_t
sngisdn_test_flag
(
sngisdn_chan_data_t
*
sngisdn_info
,
sngisdn_flag_t
flag
)
{
{
return
(
uint32_t
)
sngisdn_info
->
flags
&
flag
;
return
(
uint32_t
)
sngisdn_info
->
flags
&
flag
;
...
...
libs/freetdm/src/ftmod/ftmod_sangoma_isdn/ftmod_sangoma_isdn_cfg.c
浏览文件 @
432e9cdf
...
@@ -163,6 +163,11 @@ ftdm_status_t ftmod_isdn_parse_cfg(ftdm_conf_parameter_t *ftdm_parameters, ftdm_
...
@@ -163,6 +163,11 @@ ftdm_status_t ftmod_isdn_parse_cfg(ftdm_conf_parameter_t *ftdm_parameters, ftdm_
signal_data
->
overlap_dial
=
SNGISDN_OPT_DEFAULT
;
signal_data
->
overlap_dial
=
SNGISDN_OPT_DEFAULT
;
signal_data
->
setup_arb
=
SNGISDN_OPT_DEFAULT
;
signal_data
->
setup_arb
=
SNGISDN_OPT_DEFAULT
;
span
->
default_caller_data
.
bearer_capability
=
IN_ITC_SPEECH
;
/* Cannot set default bearer_layer1 yet, as we do not know the switchtype */
span
->
default_caller_data
.
bearer_layer1
=
FTDM_INVALID_INT_PARM
;
if
(
span
->
trunk_type
==
FTDM_TRUNK_BRI
||
if
(
span
->
trunk_type
==
FTDM_TRUNK_BRI
||
span
->
trunk_type
==
FTDM_TRUNK_BRI_PTMP
)
{
span
->
trunk_type
==
FTDM_TRUNK_BRI_PTMP
)
{
...
@@ -240,6 +245,10 @@ ftdm_status_t ftmod_isdn_parse_cfg(ftdm_conf_parameter_t *ftdm_parameters, ftdm_
...
@@ -240,6 +245,10 @@ ftdm_status_t ftmod_isdn_parse_cfg(ftdm_conf_parameter_t *ftdm_parameters, ftdm_
ftdm_span_set_ton
(
val
,
&
span
->
default_caller_data
.
rdnis
.
type
);
ftdm_span_set_ton
(
val
,
&
span
->
default_caller_data
.
rdnis
.
type
);
}
else
if
(
!
strcasecmp
(
var
,
"outbound-rdnis-npi"
))
{
}
else
if
(
!
strcasecmp
(
var
,
"outbound-rdnis-npi"
))
{
ftdm_span_set_npi
(
val
,
&
span
->
default_caller_data
.
rdnis
.
plan
);
ftdm_span_set_npi
(
val
,
&
span
->
default_caller_data
.
rdnis
.
plan
);
}
else
if
(
!
strcasecmp
(
var
,
"outbound-bearer_cap"
))
{
ftdm_span_set_bearer_capability
(
val
,
&
span
->
default_caller_data
.
bearer_capability
);
}
else
if
(
!
strcasecmp
(
var
,
"outbound-bearer_layer1"
))
{
ftdm_span_set_bearer_layer1
(
val
,
&
span
->
default_caller_data
.
bearer_layer1
);
}
else
{
}
else
{
ftdm_log
(
FTDM_LOG_WARNING
,
"Ignoring unknown parameter %s
\n
"
,
ftdm_parameters
[
paramindex
].
var
);
ftdm_log
(
FTDM_LOG_WARNING
,
"Ignoring unknown parameter %s
\n
"
,
ftdm_parameters
[
paramindex
].
var
);
}
}
...
@@ -253,6 +262,14 @@ ftdm_status_t ftmod_isdn_parse_cfg(ftdm_conf_parameter_t *ftdm_parameters, ftdm_
...
@@ -253,6 +262,14 @@ ftdm_status_t ftmod_isdn_parse_cfg(ftdm_conf_parameter_t *ftdm_parameters, ftdm_
ftdm_log
(
FTDM_LOG_ERROR
,
"%s: signalling not specified"
,
span
->
name
);
ftdm_log
(
FTDM_LOG_ERROR
,
"%s: signalling not specified"
,
span
->
name
);
return
FTDM_FAIL
;
return
FTDM_FAIL
;
}
}
if
(
span
->
default_caller_data
.
bearer_layer1
==
FTDM_INVALID_INT_PARM
)
{
if
(
signal_data
->
switchtype
==
SNGISDN_SWITCH_EUROISDN
)
{
span
->
default_caller_data
.
bearer_layer1
=
IN_UIL1_G711ULAW
;
}
else
{
span
->
default_caller_data
.
bearer_layer1
=
IN_UIL1_G711ALAW
;
}
}
return
FTDM_SUCCESS
;
return
FTDM_SUCCESS
;
}
}
...
...
libs/freetdm/src/ftmod/ftmod_sangoma_isdn/ftmod_sangoma_isdn_stack_hndl.c
浏览文件 @
432e9cdf
...
@@ -34,10 +34,10 @@
...
@@ -34,10 +34,10 @@
#include "ftmod_sangoma_isdn.h"
#include "ftmod_sangoma_isdn.h"
extern
ftdm_status_t
cpy_calling_num_from_s
ngisdn
(
ftdm_caller_data_t
*
ftdm
,
CgPtyNmb
*
cgPtyNmb
);
extern
ftdm_status_t
cpy_calling_num_from_s
tack
(
ftdm_caller_data_t
*
ftdm
,
CgPtyNmb
*
cgPtyNmb
);
extern
ftdm_status_t
cpy_called_num_from_s
ngisdn
(
ftdm_caller_data_t
*
ftdm
,
CdPtyNmb
*
cdPtyNmb
);
extern
ftdm_status_t
cpy_called_num_from_s
tack
(
ftdm_caller_data_t
*
ftdm
,
CdPtyNmb
*
cdPtyNmb
);
extern
ftdm_status_t
cpy_redir_num_from_s
ngisdn
(
ftdm_caller_data_t
*
ftdm
,
RedirNmb
*
redirNmb
);
extern
ftdm_status_t
cpy_redir_num_from_s
tack
(
ftdm_caller_data_t
*
ftdm
,
RedirNmb
*
redirNmb
);
extern
ftdm_status_t
cpy_calling_name_from_s
ngisdn
(
ftdm_caller_data_t
*
ftdm
,
Display
*
display
);
extern
ftdm_status_t
cpy_calling_name_from_s
tack
(
ftdm_caller_data_t
*
ftdm
,
Display
*
display
);
/* Remote side transmit a SETUP */
/* Remote side transmit a SETUP */
void
sngisdn_process_con_ind
(
sngisdn_event_data_t
*
sngisdn_event
)
void
sngisdn_process_con_ind
(
sngisdn_event_data_t
*
sngisdn_event
)
...
@@ -110,10 +110,14 @@ void sngisdn_process_con_ind (sngisdn_event_data_t *sngisdn_event)
...
@@ -110,10 +110,14 @@ void sngisdn_process_con_ind (sngisdn_event_data_t *sngisdn_event)
break
;
break
;
}
}
/* Fill in call information */
/* Fill in call information */
cpy_calling_num_from_s
ngisdn
(
&
ftdmchan
->
caller_data
,
&
conEvnt
->
cgPtyNmb
);
cpy_calling_num_from_s
tack
(
&
ftdmchan
->
caller_data
,
&
conEvnt
->
cgPtyNmb
);
cpy_called_num_from_s
ngisdn
(
&
ftdmchan
->
caller_data
,
&
conEvnt
->
cdPtyNmb
);
cpy_called_num_from_s
tack
(
&
ftdmchan
->
caller_data
,
&
conEvnt
->
cdPtyNmb
);
cpy_calling_name_from_s
ngisdn
(
&
ftdmchan
->
caller_data
,
&
conEvnt
->
display
);
cpy_calling_name_from_s
tack
(
&
ftdmchan
->
caller_data
,
&
conEvnt
->
display
);
if
(
conEvnt
->
bearCap
[
0
].
eh
.
pres
)
{
ftdmchan
->
caller_data
.
bearer_layer1
=
sngisdn_get_infoTranCap_from_stack
(
conEvnt
->
bearCap
[
0
].
usrInfoLyr1Prot
.
val
);
ftdmchan
->
caller_data
.
bearer_capability
=
sngisdn_get_infoTranCap_from_stack
(
conEvnt
->
bearCap
[
0
].
infoTranCap
.
val
);
}
if
(
signal_data
->
switchtype
==
SNGISDN_SWITCH_NI2
)
{
if
(
signal_data
->
switchtype
==
SNGISDN_SWITCH_NI2
)
{
if
(
conEvnt
->
shift11
.
eh
.
pres
&&
conEvnt
->
ni2OctStr
.
eh
.
pres
)
{
if
(
conEvnt
->
shift11
.
eh
.
pres
&&
conEvnt
->
ni2OctStr
.
eh
.
pres
)
{
...
@@ -370,7 +374,7 @@ void sngisdn_process_cnst_ind (sngisdn_event_data_t *sngisdn_event)
...
@@ -370,7 +374,7 @@ void sngisdn_process_cnst_ind (sngisdn_event_data_t *sngisdn_event)
ftdm_size_t
min_digits
=
((
sngisdn_span_data_t
*
)
ftdmchan
->
span
->
signal_data
)
->
min_digits
;
ftdm_size_t
min_digits
=
((
sngisdn_span_data_t
*
)
ftdmchan
->
span
->
signal_data
)
->
min_digits
;
ftdm_size_t
num_digits
;
ftdm_size_t
num_digits
;
cpy_called_num_from_s
ngisdn
(
&
ftdmchan
->
caller_data
,
&
cnStEvnt
->
cdPtyNmb
);
cpy_called_num_from_s
tack
(
&
ftdmchan
->
caller_data
,
&
cnStEvnt
->
cdPtyNmb
);
num_digits
=
strlen
(
ftdmchan
->
caller_data
.
dnis
.
digits
);
num_digits
=
strlen
(
ftdmchan
->
caller_data
.
dnis
.
digits
);
if
(
cnStEvnt
->
sndCmplt
.
eh
.
pres
||
num_digits
>=
min_digits
)
{
if
(
cnStEvnt
->
sndCmplt
.
eh
.
pres
||
num_digits
>=
min_digits
)
{
...
@@ -686,7 +690,6 @@ void sngisdn_process_fac_ind (sngisdn_event_data_t *sngisdn_event)
...
@@ -686,7 +690,6 @@ void sngisdn_process_fac_ind (sngisdn_event_data_t *sngisdn_event)
switch
(
ftdmchan
->
state
)
{
switch
(
ftdmchan
->
state
)
{
case
FTDM_CHANNEL_STATE_GET_CALLERID
:
case
FTDM_CHANNEL_STATE_GET_CALLERID
:
/* Update the caller ID Name */
/* Update the caller ID Name */
#if 1
if
(
facEvnt
->
facElmt
.
facStr
.
pres
)
{
if
(
facEvnt
->
facElmt
.
facStr
.
pres
)
{
uint8_t
facility_str
[
255
];
uint8_t
facility_str
[
255
];
memcpy
(
facility_str
,
(
uint8_t
*
)
&
facEvnt
->
facElmt
.
facStr
.
val
,
facEvnt
->
facElmt
.
facStr
.
len
);
memcpy
(
facility_str
,
(
uint8_t
*
)
&
facEvnt
->
facElmt
.
facStr
.
val
,
facEvnt
->
facElmt
.
facStr
.
len
);
...
@@ -694,10 +697,7 @@ void sngisdn_process_fac_ind (sngisdn_event_data_t *sngisdn_event)
...
@@ -694,10 +697,7 @@ void sngisdn_process_fac_ind (sngisdn_event_data_t *sngisdn_event)
if
(
sng_isdn_retrieve_facility_caller_name
(
facility_str
,
facEvnt
->
facElmt
.
facStr
.
len
,
retrieved_str
)
!=
FTDM_SUCCESS
)
{
if
(
sng_isdn_retrieve_facility_caller_name
(
facility_str
,
facEvnt
->
facElmt
.
facStr
.
len
,
retrieved_str
)
!=
FTDM_SUCCESS
)
{
ftdm_log_chan_msg
(
ftdmchan
,
FTDM_LOG_WARNING
,
"Failed to retrieve Caller Name from Facility IE
\n
"
);
ftdm_log_chan_msg
(
ftdmchan
,
FTDM_LOG_WARNING
,
"Failed to retrieve Caller Name from Facility IE
\n
"
);
}
}
ftdm_log_chan
(
ftdmchan
,
FTDM_LOG_WARNING
,
"DYDBG Name is:%s
\n
"
,
retrieved_str
);
}
}
#endif
ftdm_set_state
(
ftdmchan
,
FTDM_CHANNEL_STATE_RING
);
ftdm_set_state
(
ftdmchan
,
FTDM_CHANNEL_STATE_RING
);
break
;
break
;
default:
default:
...
...
libs/freetdm/src/ftmod/ftmod_sangoma_isdn/ftmod_sangoma_isdn_stack_out.c
浏览文件 @
432e9cdf
...
@@ -34,9 +34,9 @@
...
@@ -34,9 +34,9 @@
#include "ftmod_sangoma_isdn.h"
#include "ftmod_sangoma_isdn.h"
extern
ftdm_status_t
cpy_calling_num_
to_sngisdn
(
CgPtyNmb
*
cgPtyNmb
,
ftdm_caller_data_t
*
ftdm
);
extern
ftdm_status_t
cpy_calling_num_
from_user
(
CgPtyNmb
*
cgPtyNmb
,
ftdm_caller_data_t
*
ftdm
);
extern
ftdm_status_t
cpy_called_num_
to_sngisdn
(
CdPtyNmb
*
cdPtyNmb
,
ftdm_caller_data_t
*
ftdm
);
extern
ftdm_status_t
cpy_called_num_
from_user
(
CdPtyNmb
*
cdPtyNmb
,
ftdm_caller_data_t
*
ftdm
);
extern
ftdm_status_t
cpy_calling_name_
to_sngisdn
(
ConEvnt
*
conEvnt
,
ftdm_channel_t
*
ftdmchan
);
extern
ftdm_status_t
cpy_calling_name_
from_user
(
ConEvnt
*
conEvnt
,
ftdm_channel_t
*
ftdmchan
);
void
sngisdn_snd_setup
(
ftdm_channel_t
*
ftdmchan
);
void
sngisdn_snd_setup
(
ftdm_channel_t
*
ftdmchan
);
void
sngisdn_snd_proceed
(
ftdm_channel_t
*
ftdmchan
);
void
sngisdn_snd_proceed
(
ftdm_channel_t
*
ftdmchan
);
...
@@ -62,11 +62,10 @@ void sngisdn_snd_setup(ftdm_channel_t *ftdmchan)
...
@@ -62,11 +62,10 @@ void sngisdn_snd_setup(ftdm_channel_t *ftdmchan)
ftdm_mutex_unlock
(
g_sngisdn_data
.
ccs
[
signal_data
->
cc_id
].
mutex
);
ftdm_mutex_unlock
(
g_sngisdn_data
.
ccs
[
signal_data
->
cc_id
].
mutex
);
memset
(
&
conEvnt
,
0
,
sizeof
(
conEvnt
));
memset
(
&
conEvnt
,
0
,
sizeof
(
conEvnt
));
conEvnt
.
bearCap
[
0
].
eh
.
pres
=
PRSNT_NODEF
;
conEvnt
.
bearCap
[
0
].
eh
.
pres
=
PRSNT_NODEF
;
conEvnt
.
bearCap
[
0
].
infoTranCap
.
pres
=
PRSNT_NODEF
;
conEvnt
.
bearCap
[
0
].
infoTranCap
.
pres
=
PRSNT_NODEF
;
conEvnt
.
bearCap
[
0
].
infoTranCap
.
val
=
sngisdn_get_infoTranCap_from_user
(
ftdmchan
->
caller_data
.
bearer_capability
);
conEvnt
.
bearCap
[
0
].
infoTranCap
.
val
=
IN_ITC_SPEECH
;
conEvnt
.
bearCap
[
0
].
codeStand0
.
pres
=
PRSNT_NODEF
;
conEvnt
.
bearCap
[
0
].
codeStand0
.
pres
=
PRSNT_NODEF
;
conEvnt
.
bearCap
[
0
].
codeStand0
.
val
=
IN_CSTD_CCITT
;
conEvnt
.
bearCap
[
0
].
codeStand0
.
val
=
IN_CSTD_CCITT
;
...
@@ -96,14 +95,21 @@ void sngisdn_snd_setup(ftdm_channel_t *ftdmchan)
...
@@ -96,14 +95,21 @@ void sngisdn_snd_setup(ftdm_channel_t *ftdmchan)
conEvnt
.
chanId
.
infoChanSel
.
val
=
ftdmchan
->
physical_chan_id
;
conEvnt
.
chanId
.
infoChanSel
.
val
=
ftdmchan
->
physical_chan_id
;
}
else
{
}
else
{
/* PRI only params */
/* PRI only params */
conEvnt
.
bearCap
[
0
].
usrInfoLyr1Prot
.
pres
=
PRSNT_NODEF
;
if
(
signal_data
->
switchtype
==
SNGISDN_SWITCH_EUROISDN
)
{
conEvnt
.
bearCap
[
0
].
usrInfoLyr1Prot
.
val
=
sngisdn_get_usrInfoLyr1Prot_from_user
(
ftdmchan
->
caller_data
.
bearer_layer1
);
conEvnt
.
bearCap
[
0
].
usrInfoLyr1Prot
.
pres
=
PRSNT_NODEF
;
if
(
signal_data
->
switchtype
==
SNGISDN_SWITCH_EUROISDN
&&
conEvnt
.
bearCap
[
0
].
usrInfoLyr1Prot
.
val
==
IN_UIL1_G711ULAW
)
{
/* We are bridging a call from T1 */
conEvnt
.
bearCap
[
0
].
usrInfoLyr1Prot
.
val
=
IN_UIL1_G711ALAW
;
conEvnt
.
bearCap
[
0
].
usrInfoLyr1Prot
.
val
=
IN_UIL1_G711ALAW
;
}
else
{
conEvnt
.
bearCap
[
0
].
usrInfoLyr1Prot
.
pres
=
PRSNT_NODEF
;
}
else
if
(
conEvnt
.
bearCap
[
0
].
usrInfoLyr1Prot
.
val
==
IN_UIL1_G711ALAW
)
{
/* We are bridging a call from E1 */
conEvnt
.
bearCap
[
0
].
usrInfoLyr1Prot
.
val
=
IN_UIL1_G711ULAW
;
conEvnt
.
bearCap
[
0
].
usrInfoLyr1Prot
.
val
=
IN_UIL1_G711ULAW
;
}
}
conEvnt
.
bearCap
[
0
].
lyr1Ident
.
pres
=
PRSNT_NODEF
;
conEvnt
.
bearCap
[
0
].
lyr1Ident
.
pres
=
PRSNT_NODEF
;
conEvnt
.
bearCap
[
0
].
lyr1Ident
.
val
=
IN_L1_IDENT
;
conEvnt
.
bearCap
[
0
].
lyr1Ident
.
val
=
IN_L1_IDENT
;
...
@@ -138,9 +144,9 @@ void sngisdn_snd_setup(ftdm_channel_t *ftdmchan)
...
@@ -138,9 +144,9 @@ void sngisdn_snd_setup(ftdm_channel_t *ftdmchan)
sngisdn_info
->
ces
=
CES_MNGMNT
;
sngisdn_info
->
ces
=
CES_MNGMNT
;
}
}
cpy_called_num_
to_sngisdn
(
&
conEvnt
.
cdPtyNmb
,
&
ftdmchan
->
caller_data
);
cpy_called_num_
from_user
(
&
conEvnt
.
cdPtyNmb
,
&
ftdmchan
->
caller_data
);
cpy_calling_num_
to_sngisdn
(
&
conEvnt
.
cgPtyNmb
,
&
ftdmchan
->
caller_data
);
cpy_calling_num_
from_user
(
&
conEvnt
.
cgPtyNmb
,
&
ftdmchan
->
caller_data
);
cpy_calling_name_
to_sngisdn
(
&
conEvnt
,
ftdmchan
);
cpy_calling_name_
from_user
(
&
conEvnt
,
ftdmchan
);
ftdm_log_chan
(
ftdmchan
,
FTDM_LOG_INFO
,
"Sending SETUP (suId:%d suInstId:%u spInstId:%u dchan:%d ces:%d)
\n
"
,
signal_data
->
cc_id
,
sngisdn_info
->
suInstId
,
sngisdn_info
->
spInstId
,
signal_data
->
dchan_id
,
sngisdn_info
->
ces
);
ftdm_log_chan
(
ftdmchan
,
FTDM_LOG_INFO
,
"Sending SETUP (suId:%d suInstId:%u spInstId:%u dchan:%d ces:%d)
\n
"
,
signal_data
->
cc_id
,
sngisdn_info
->
suInstId
,
sngisdn_info
->
spInstId
,
signal_data
->
dchan_id
,
sngisdn_info
->
ces
);
...
...
libs/freetdm/src/ftmod/ftmod_sangoma_isdn/ftmod_sangoma_isdn_support.c
浏览文件 @
432e9cdf
...
@@ -34,15 +34,15 @@
...
@@ -34,15 +34,15 @@
#include "ftmod_sangoma_isdn.h"
#include "ftmod_sangoma_isdn.h"
ftdm_status_t
cpy_calling_num_from_s
ngisdn
(
ftdm_caller_data_t
*
ftdm
,
CgPtyNmb
*
cgPtyNmb
);
ftdm_status_t
cpy_calling_num_from_s
tack
(
ftdm_caller_data_t
*
ftdm
,
CgPtyNmb
*
cgPtyNmb
);
ftdm_status_t
cpy_called_num_from_s
ngisdn
(
ftdm_caller_data_t
*
ftdm
,
CdPtyNmb
*
cdPtyNmb
);
ftdm_status_t
cpy_called_num_from_s
tack
(
ftdm_caller_data_t
*
ftdm
,
CdPtyNmb
*
cdPtyNmb
);
ftdm_status_t
cpy_redir_num_from_s
ngisdn
(
ftdm_caller_data_t
*
ftdm
,
RedirNmb
*
redirNmb
);
ftdm_status_t
cpy_redir_num_from_s
tack
(
ftdm_caller_data_t
*
ftdm
,
RedirNmb
*
redirNmb
);
ftdm_status_t
cpy_calling_name_from_s
ngisdn
(
ftdm_caller_data_t
*
ftdm
,
Display
*
display
);
ftdm_status_t
cpy_calling_name_from_s
tack
(
ftdm_caller_data_t
*
ftdm
,
Display
*
display
);
ftdm_status_t
cpy_calling_num_
to_sngisdn
(
CgPtyNmb
*
cgPtyNmb
,
ftdm_caller_data_t
*
ftdm
);
ftdm_status_t
cpy_calling_num_
from_user
(
CgPtyNmb
*
cgPtyNmb
,
ftdm_caller_data_t
*
ftdm
);
ftdm_status_t
cpy_called_num_
to_sngisdn
(
CdPtyNmb
*
cdPtyNmb
,
ftdm_caller_data_t
*
ftdm
);
ftdm_status_t
cpy_called_num_
from_user
(
CdPtyNmb
*
cdPtyNmb
,
ftdm_caller_data_t
*
ftdm
);
ftdm_status_t
cpy_redir_num_
to_sngisdn
(
RedirNmb
*
redirNmb
,
ftdm_caller_data_t
*
ftdm
);
ftdm_status_t
cpy_redir_num_
from_user
(
RedirNmb
*
redirNmb
,
ftdm_caller_data_t
*
ftdm
);
ftdm_status_t
cpy_calling_name_
to_sngisdn
(
ConEvnt
*
conEvnt
,
ftdm_channel_t
*
ftdmchan
);
ftdm_status_t
cpy_calling_name_
from_user
(
ConEvnt
*
conEvnt
,
ftdm_channel_t
*
ftdmchan
);
ftdm_status_t
sngisdn_check_free_ids
(
void
);
ftdm_status_t
sngisdn_check_free_ids
(
void
);
...
@@ -146,7 +146,7 @@ ftdm_status_t sng_isdn_set_avail_rate(ftdm_span_t *ftdmspan, sngisdn_avail_t ava
...
@@ -146,7 +146,7 @@ ftdm_status_t sng_isdn_set_avail_rate(ftdm_span_t *ftdmspan, sngisdn_avail_t ava
return
FTDM_SUCCESS
;
return
FTDM_SUCCESS
;
}
}
ftdm_status_t
cpy_calling_num_from_s
ngisdn
(
ftdm_caller_data_t
*
ftdm
,
CgPtyNmb
*
cgPtyNmb
)
ftdm_status_t
cpy_calling_num_from_s
tack
(
ftdm_caller_data_t
*
ftdm
,
CgPtyNmb
*
cgPtyNmb
)
{
{
if
(
cgPtyNmb
->
eh
.
pres
!=
PRSNT_NODEF
)
{
if
(
cgPtyNmb
->
eh
.
pres
!=
PRSNT_NODEF
)
{
return
FTDM_FAIL
;
return
FTDM_FAIL
;
...
@@ -173,7 +173,7 @@ ftdm_status_t cpy_calling_num_from_sngisdn(ftdm_caller_data_t *ftdm, CgPtyNmb *c
...
@@ -173,7 +173,7 @@ ftdm_status_t cpy_calling_num_from_sngisdn(ftdm_caller_data_t *ftdm, CgPtyNmb *c
return
FTDM_SUCCESS
;
return
FTDM_SUCCESS
;
}
}
ftdm_status_t
cpy_called_num_from_s
ngisdn
(
ftdm_caller_data_t
*
ftdm
,
CdPtyNmb
*
cdPtyNmb
)
ftdm_status_t
cpy_called_num_from_s
tack
(
ftdm_caller_data_t
*
ftdm
,
CdPtyNmb
*
cdPtyNmb
)
{
{
if
(
cdPtyNmb
->
eh
.
pres
!=
PRSNT_NODEF
)
{
if
(
cdPtyNmb
->
eh
.
pres
!=
PRSNT_NODEF
)
{
return
FTDM_FAIL
;
return
FTDM_FAIL
;
...
@@ -195,7 +195,7 @@ ftdm_status_t cpy_called_num_from_sngisdn(ftdm_caller_data_t *ftdm, CdPtyNmb *cd
...
@@ -195,7 +195,7 @@ ftdm_status_t cpy_called_num_from_sngisdn(ftdm_caller_data_t *ftdm, CdPtyNmb *cd
return
FTDM_SUCCESS
;
return
FTDM_SUCCESS
;
}
}
ftdm_status_t
cpy_redir_num_from_s
ngisdn
(
ftdm_caller_data_t
*
ftdm
,
RedirNmb
*
redirNmb
)
ftdm_status_t
cpy_redir_num_from_s
tack
(
ftdm_caller_data_t
*
ftdm
,
RedirNmb
*
redirNmb
)
{
{
if
(
redirNmb
->
eh
.
pres
!=
PRSNT_NODEF
)
{
if
(
redirNmb
->
eh
.
pres
!=
PRSNT_NODEF
)
{
return
FTDM_FAIL
;
return
FTDM_FAIL
;
...
@@ -215,7 +215,7 @@ ftdm_status_t cpy_redir_num_from_sngisdn(ftdm_caller_data_t *ftdm, RedirNmb *red
...
@@ -215,7 +215,7 @@ ftdm_status_t cpy_redir_num_from_sngisdn(ftdm_caller_data_t *ftdm, RedirNmb *red
return
FTDM_SUCCESS
;
return
FTDM_SUCCESS
;
}
}
ftdm_status_t
cpy_calling_name_from_s
ngisdn
(
ftdm_caller_data_t
*
ftdm
,
Display
*
display
)
ftdm_status_t
cpy_calling_name_from_s
tack
(
ftdm_caller_data_t
*
ftdm
,
Display
*
display
)
{
{
if
(
display
->
eh
.
pres
!=
PRSNT_NODEF
)
{
if
(
display
->
eh
.
pres
!=
PRSNT_NODEF
)
{
return
FTDM_FAIL
;
return
FTDM_FAIL
;
...
@@ -228,7 +228,7 @@ ftdm_status_t cpy_calling_name_from_sngisdn(ftdm_caller_data_t *ftdm, Display *d
...
@@ -228,7 +228,7 @@ ftdm_status_t cpy_calling_name_from_sngisdn(ftdm_caller_data_t *ftdm, Display *d
return
FTDM_SUCCESS
;
return
FTDM_SUCCESS
;
}
}
ftdm_status_t
cpy_calling_num_
to_sngisdn
(
CgPtyNmb
*
cgPtyNmb
,
ftdm_caller_data_t
*
ftdm
)
ftdm_status_t
cpy_calling_num_
from_user
(
CgPtyNmb
*
cgPtyNmb
,
ftdm_caller_data_t
*
ftdm
)
{
{
uint8_t
len
=
strlen
(
ftdm
->
cid_num
.
digits
);
uint8_t
len
=
strlen
(
ftdm
->
cid_num
.
digits
);
if
(
!
len
)
{
if
(
!
len
)
{
...
@@ -256,7 +256,7 @@ ftdm_status_t cpy_calling_num_to_sngisdn(CgPtyNmb *cgPtyNmb, ftdm_caller_data_t
...
@@ -256,7 +256,7 @@ ftdm_status_t cpy_calling_num_to_sngisdn(CgPtyNmb *cgPtyNmb, ftdm_caller_data_t
return
FTDM_SUCCESS
;
return
FTDM_SUCCESS
;
}
}
ftdm_status_t
cpy_called_num_
to_sngisdn
(
CdPtyNmb
*
cdPtyNmb
,
ftdm_caller_data_t
*
ftdm
)
ftdm_status_t
cpy_called_num_
from_user
(
CdPtyNmb
*
cdPtyNmb
,
ftdm_caller_data_t
*
ftdm
)
{
{
uint8_t
len
=
strlen
(
ftdm
->
dnis
.
digits
);
uint8_t
len
=
strlen
(
ftdm
->
dnis
.
digits
);
if
(
!
len
)
{
if
(
!
len
)
{
...
@@ -286,7 +286,7 @@ ftdm_status_t cpy_called_num_to_sngisdn(CdPtyNmb *cdPtyNmb, ftdm_caller_data_t *
...
@@ -286,7 +286,7 @@ ftdm_status_t cpy_called_num_to_sngisdn(CdPtyNmb *cdPtyNmb, ftdm_caller_data_t *
return
FTDM_SUCCESS
;
return
FTDM_SUCCESS
;
}
}
ftdm_status_t
cpy_redir_num_
to_sngisdn
(
RedirNmb
*
redirNmb
,
ftdm_caller_data_t
*
ftdm
)
ftdm_status_t
cpy_redir_num_
from_user
(
RedirNmb
*
redirNmb
,
ftdm_caller_data_t
*
ftdm
)
{
{
uint8_t
len
=
strlen
(
ftdm
->
rdnis
.
digits
);
uint8_t
len
=
strlen
(
ftdm
->
rdnis
.
digits
);
if
(
!
len
)
{
if
(
!
len
)
{
...
@@ -318,7 +318,7 @@ ftdm_status_t cpy_redir_num_to_sngisdn(RedirNmb *redirNmb, ftdm_caller_data_t *f
...
@@ -318,7 +318,7 @@ ftdm_status_t cpy_redir_num_to_sngisdn(RedirNmb *redirNmb, ftdm_caller_data_t *f
}
}
ftdm_status_t
cpy_calling_name_
to_sngisdn
(
ConEvnt
*
conEvnt
,
ftdm_channel_t
*
ftdmchan
)
ftdm_status_t
cpy_calling_name_
from_user
(
ConEvnt
*
conEvnt
,
ftdm_channel_t
*
ftdmchan
)
{
{
uint8_t
len
;
uint8_t
len
;
ftdm_caller_data_t
*
ftdm
=
&
ftdmchan
->
caller_data
;
ftdm_caller_data_t
*
ftdm
=
&
ftdmchan
->
caller_data
;
...
@@ -385,13 +385,7 @@ void sngisdn_delayed_release(void* p_sngisdn_info)
...
@@ -385,13 +385,7 @@ void sngisdn_delayed_release(void* p_sngisdn_info)
signal_data
->
cc_id
,
sngisdn_info
->
glare
.
spInstId
,
sngisdn_info
->
glare
.
suInstId
);
signal_data
->
cc_id
,
sngisdn_info
->
glare
.
spInstId
,
sngisdn_info
->
glare
.
suInstId
);
sngisdn_snd_release
(
ftdmchan
,
1
);
sngisdn_snd_release
(
ftdmchan
,
1
);
#if 1
/* TODO: Confirm this */
clear_call_glare_data
(
sngisdn_info
);
clear_call_glare_data
(
sngisdn_info
);
#else
g_sngisdn_data
.
ccs
[
signal_data
->
cc_id
].
active_spInstIds
[
sngisdn_info
->
glare
.
spInstId
]
=
NULL
;
g_sngisdn_data
.
ccs
[
signal_data
->
cc_id
].
active_suInstIds
[
sngisdn_info
->
glare
.
suInstId
]
=
NULL
;
#endif
}
else
{
}
else
{
ftdm_log_chan
(
ftdmchan
,
FTDM_LOG_DEBUG
,
"Call was already released (suId:%d suInstId:%u spInstId:%u)
\n
"
,
ftdm_log_chan
(
ftdmchan
,
FTDM_LOG_DEBUG
,
"Call was already released (suId:%d suInstId:%u spInstId:%u)
\n
"
,
signal_data
->
cc_id
,
sngisdn_info
->
glare
.
spInstId
,
sngisdn_info
->
glare
.
suInstId
);
signal_data
->
cc_id
,
sngisdn_info
->
glare
.
spInstId
,
sngisdn_info
->
glare
.
suInstId
);
...
@@ -473,6 +467,72 @@ void get_memory_info(void)
...
@@ -473,6 +467,72 @@ void get_memory_info(void)
return
;
return
;
}
}
uint8_t
sngisdn_get_infoTranCap_from_stack
(
ftdm_bearer_cap_t
bearer_capability
)
{
switch
(
bearer_capability
)
{
case
FTDM_BEARER_CAP_SPEECH
:
return
IN_ITC_SPEECH
;
case
FTDM_BEARER_CAP_64K_UNRESTRICTED
:
return
IN_ITC_UNRDIG
;
case
FTDM_BEARER_CAP_3_1KHZ_AUDIO
:
return
IN_ITC_A31KHZ
;
/* Do not put a default case here, so we can see compile warnings if we have unhandled cases */
}
return
FTDM_BEARER_CAP_SPEECH
;
}
uint8_t
sngisdn_get_usrInfoLyr1Prot_from_stack
(
ftdm_user_layer1_prot_t
layer1_prot
)
{
switch
(
layer1_prot
)
{
case
FTDM_USER_LAYER1_PROT_V110
:
return
IN_UIL1_CCITTV110
;
case
FTDM_USER_LAYER1_PROT_ULAW
:
return
IN_UIL1_G711ULAW
;
case
FTDM_USER_LAYER1_PROT_ALAW
:
return
IN_UIL1_G711ALAW
;
/* Do not put a default case here, so we can see compile warnings if we have unhandled cases */
}
return
IN_UIL1_G711ULAW
;
}
ftdm_bearer_cap_t
sngisdn_get_infoTranCap_from_user
(
uint8_t
bearer_capability
)
{
switch
(
bearer_capability
)
{
case
IN_ITC_SPEECH
:
return
FTDM_BEARER_CAP_SPEECH
;
case
IN_ITC_UNRDIG
:
return
FTDM_BEARER_CAP_64K_UNRESTRICTED
;
case
IN_ITC_A31KHZ
:
return
FTDM_BEARER_CAP_3_1KHZ_AUDIO
;
default:
return
FTDM_BEARER_CAP_SPEECH
;
}
return
FTDM_BEARER_CAP_SPEECH
;
}
ftdm_user_layer1_prot_t
sngisdn_get_usrInfoLyr1Prot_from_user
(
uint8_t
layer1_prot
)
{
switch
(
layer1_prot
)
{
case
IN_UIL1_CCITTV110
:
return
FTDM_USER_LAYER1_PROT_V110
;
case
IN_UIL1_G711ULAW
:
return
FTDM_USER_LAYER1_PROT_ULAW
;
case
IN_UIL1_G711ALAW
:
return
IN_UIL1_G711ALAW
;
default:
return
FTDM_USER_LAYER1_PROT_ULAW
;
}
return
FTDM_USER_LAYER1_PROT_ULAW
;
}
/* For Emacs:
/* For Emacs:
* Local Variables:
* Local Variables:
...
...
libs/freetdm/src/include/freetdm.h
浏览文件 @
432e9cdf
...
@@ -60,6 +60,8 @@
...
@@ -60,6 +60,8 @@
/*! \brief Max number of groups */
/*! \brief Max number of groups */
#define FTDM_MAX_GROUPS_INTERFACE FTDM_MAX_SPANS_INTERFACE
#define FTDM_MAX_GROUPS_INTERFACE FTDM_MAX_SPANS_INTERFACE
#define FTDM_INVALID_INT_PARM 0xFF
/*! \brief FreeTDM APIs possible return codes */
/*! \brief FreeTDM APIs possible return codes */
typedef
enum
{
typedef
enum
{
FTDM_SUCCESS
,
/*!< Success */
FTDM_SUCCESS
,
/*!< Success */
...
@@ -208,6 +210,7 @@ typedef struct ftdm_queue_handler {
...
@@ -208,6 +210,7 @@ typedef struct ftdm_queue_handler {
ftdm_queue_destroy_func_t
destroy
;
ftdm_queue_destroy_func_t
destroy
;
}
ftdm_queue_handler_t
;
}
ftdm_queue_handler_t
;
/*! \brief Type Of Number (TON) */
/*! \brief Type Of Number (TON) */
typedef
enum
{
typedef
enum
{
FTDM_TON_UNKNOWN
=
0
,
FTDM_TON_UNKNOWN
=
0
,
...
...
libs/freetdm/src/include/private/ftdm_call_utils.h
浏览文件 @
432e9cdf
...
@@ -39,6 +39,8 @@
...
@@ -39,6 +39,8 @@
FT_DECLARE
(
ftdm_status_t
)
ftdm_span_set_npi
(
const
char
*
npi_string
,
uint8_t
*
target
);
FT_DECLARE
(
ftdm_status_t
)
ftdm_span_set_npi
(
const
char
*
npi_string
,
uint8_t
*
target
);
FT_DECLARE
(
ftdm_status_t
)
ftdm_span_set_ton
(
const
char
*
ton_string
,
uint8_t
*
target
);
FT_DECLARE
(
ftdm_status_t
)
ftdm_span_set_ton
(
const
char
*
ton_string
,
uint8_t
*
target
);
FT_DECLARE
(
ftdm_status_t
)
ftdm_span_set_bearer_capability
(
const
char
*
bc_string
,
ftdm_bearer_cap_t
*
target
);
FT_DECLARE
(
ftdm_status_t
)
ftdm_span_set_bearer_layer1
(
const
char
*
bc_string
,
ftdm_user_layer1_prot_t
*
target
);
FT_DECLARE
(
ftdm_status_t
)
ftdm_is_number
(
char
*
number
);
FT_DECLARE
(
ftdm_status_t
)
ftdm_is_number
(
char
*
number
);
#endif
/* __FTDM_CALL_UTILS_H__ */
#endif
/* __FTDM_CALL_UTILS_H__ */
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论