Skip to content
项目
群组
代码片段
帮助
正在加载...
登录
切换导航
F
freeswitch
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
张华
freeswitch
Commits
7433a1e5
提交
7433a1e5
authored
11月 25, 2010
作者:
David Yat Sin
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Fix for caller ID not received properly on BRI
上级
b814dc17
全部展开
隐藏空白字符变更
内嵌
并排
正在显示
5 个修改的文件
包含
116 行增加
和
89 行删除
+116
-89
ftmod_sangoma_isdn.h
...freetdm/src/ftmod/ftmod_sangoma_isdn/ftmod_sangoma_isdn.h
+12
-10
ftmod_sangoma_isdn_stack_hndl.c
.../ftmod/ftmod_sangoma_isdn/ftmod_sangoma_isdn_stack_hndl.c
+13
-9
ftmod_sangoma_isdn_stack_out.c
...c/ftmod/ftmod_sangoma_isdn/ftmod_sangoma_isdn_stack_out.c
+8
-22
ftmod_sangoma_isdn_support.c
...src/ftmod/ftmod_sangoma_isdn/ftmod_sangoma_isdn_support.c
+80
-45
freetdm.h
libs/freetdm/src/include/freetdm.h
+3
-3
没有找到文件。
libs/freetdm/src/ftmod/ftmod_sangoma_isdn/ftmod_sangoma_isdn.h
浏览文件 @
7433a1e5
...
...
@@ -376,16 +376,18 @@ void sngisdn_rcv_cc_ind(CcMngmt *status);
void
sngisdn_rcv_sng_log
(
uint8_t
level
,
char
*
fmt
,...);
void
sngisdn_rcv_sng_assert
(
char
*
message
);
ftdm_status_t
cpy_calling_num_from_stack
(
ftdm_caller_data_t
*
ftdm
,
CgPtyNmb
*
cgPtyNmb
);
ftdm_status_t
cpy_called_num_from_stack
(
ftdm_caller_data_t
*
ftdm
,
CdPtyNmb
*
cdPtyNmb
);
ftdm_status_t
cpy_redir_num_from_stack
(
ftdm_caller_data_t
*
ftdm
,
RedirNmb
*
redirNmb
);
ftdm_status_t
cpy_calling_name_from_stack
(
ftdm_caller_data_t
*
ftdm
,
Display
*
display
);
ftdm_status_t
cpy_facility_ie_from_stack
(
ftdm_caller_data_t
*
ftdm
,
uint8_t
*
data
,
uint32_t
data_len
);
ftdm_status_t
cpy_calling_num_from_user
(
CgPtyNmb
*
cgPtyNmb
,
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_from_user
(
RedirNmb
*
redirNmb
,
ftdm_caller_data_t
*
ftdm
);
ftdm_status_t
cpy_calling_name_from_user
(
ConEvnt
*
conEvnt
,
ftdm_channel_t
*
ftdmchan
);
ftdm_status_t
get_calling_num
(
ftdm_caller_data_t
*
ftdm
,
CgPtyNmb
*
cgPtyNmb
);
ftdm_status_t
get_called_num
(
ftdm_caller_data_t
*
ftdm
,
CdPtyNmb
*
cdPtyNmb
);
ftdm_status_t
get_redir_num
(
ftdm_caller_data_t
*
ftdm
,
RedirNmb
*
redirNmb
);
ftdm_status_t
get_calling_name_from_display
(
ftdm_caller_data_t
*
ftdm
,
Display
*
display
);
ftdm_status_t
get_calling_name_from_usr_usr
(
ftdm_caller_data_t
*
ftdm
,
UsrUsr
*
usrUsr
);
ftdm_status_t
get_facility_ie
(
ftdm_caller_data_t
*
ftdm
,
uint8_t
*
data
,
uint32_t
data_len
);
ftdm_status_t
set_calling_num
(
CgPtyNmb
*
cgPtyNmb
,
ftdm_caller_data_t
*
ftdm
);
ftdm_status_t
set_called_num
(
CdPtyNmb
*
cdPtyNmb
,
ftdm_caller_data_t
*
ftdm
);
ftdm_status_t
set_redir_num
(
RedirNmb
*
redirNmb
,
ftdm_caller_data_t
*
ftdm
);
ftdm_status_t
set_calling_name
(
ConEvnt
*
conEvnt
,
ftdm_channel_t
*
ftdmchan
);
ftdm_status_t
set_facility_ie
(
ftdm_channel_t
*
ftdmchan
,
FacilityStr
*
facilityStr
);
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
);
...
...
libs/freetdm/src/ftmod/ftmod_sangoma_isdn/ftmod_sangoma_isdn_stack_hndl.c
浏览文件 @
7433a1e5
...
...
@@ -127,10 +127,14 @@ void sngisdn_process_con_ind (sngisdn_event_data_t *sngisdn_event)
ftdm_channel_add_var(ftdmchan, "isdn_specific_var", "1");
#endif
/* Fill in call information */
cpy_calling_num_from_stack
(
&
ftdmchan
->
caller_data
,
&
conEvnt
->
cgPtyNmb
);
cpy_called_num_from_stack
(
&
ftdmchan
->
caller_data
,
&
conEvnt
->
cdPtyNmb
);
cpy_calling_name_from_stack
(
&
ftdmchan
->
caller_data
,
&
conEvnt
->
display
);
cpy_redir_num_from_stack
(
&
ftdmchan
->
caller_data
,
&
conEvnt
->
redirNmb
);
get_calling_num
(
&
ftdmchan
->
caller_data
,
&
conEvnt
->
cgPtyNmb
);
get_called_num
(
&
ftdmchan
->
caller_data
,
&
conEvnt
->
cdPtyNmb
);
get_redir_num
(
&
ftdmchan
->
caller_data
,
&
conEvnt
->
redirNmb
);
if
(
get_calling_name_from_display
(
&
ftdmchan
->
caller_data
,
&
conEvnt
->
display
)
!=
FTDM_SUCCESS
)
{
get_calling_name_from_usr_usr
(
&
ftdmchan
->
caller_data
,
&
conEvnt
->
usrUsr
);
}
ftdm_log_chan
(
sngisdn_info
->
ftdmchan
,
FTDM_LOG_INFO
,
"Incoming call: Called No:[%s] Calling No:[%s]
\n
"
,
ftdmchan
->
caller_data
.
dnis
.
digits
,
ftdmchan
->
caller_data
.
cid_num
.
digits
);
if
(
conEvnt
->
bearCap
[
0
].
eh
.
pres
)
{
...
...
@@ -147,7 +151,7 @@ void sngisdn_process_con_ind (sngisdn_event_data_t *sngisdn_event)
if
(
conEvnt
->
facilityStr
.
eh
.
pres
)
{
if
(
signal_data
->
facility_ie_decode
==
SNGISDN_OPT_FALSE
)
{
cpy_facility_ie_from_stack
(
&
ftdmchan
->
caller_data
,
conEvnt
->
facilityStr
.
facilityStr
.
val
,
conEvnt
->
facilityStr
.
facilityStr
.
len
);
get_facility_ie
(
&
ftdmchan
->
caller_data
,
conEvnt
->
facilityStr
.
facilityStr
.
val
,
conEvnt
->
facilityStr
.
facilityStr
.
len
);
}
else
if
(
signal_data
->
facility
==
SNGISDN_OPT_TRUE
)
{
/* Verify whether the Caller Name will come in a subsequent FACILITY message */
uint16_t
ret_val
;
...
...
@@ -413,7 +417,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
num_digits
;
cpy_called_num_from_stack
(
&
ftdmchan
->
caller_data
,
&
cnStEvnt
->
cdPtyNmb
);
get_called_num
(
&
ftdmchan
->
caller_data
,
&
cnStEvnt
->
cdPtyNmb
);
num_digits
=
strlen
(
ftdmchan
->
caller_data
.
dnis
.
digits
);
if
(
cnStEvnt
->
sndCmplt
.
eh
.
pres
||
num_digits
>=
min_digits
)
{
...
...
@@ -472,7 +476,7 @@ void sngisdn_process_disc_ind (sngisdn_event_data_t *sngisdn_event)
case
FTDM_CHANNEL_STATE_UP
:
if
(
discEvnt
->
facilityStr
.
eh
.
pres
)
{
if
(
signal_data
->
facility_ie_decode
==
SNGISDN_OPT_FALSE
)
{
cpy_facility_ie_from_stack
(
&
ftdmchan
->
caller_data
,
discEvnt
->
facilityStr
.
facilityStr
.
val
,
discEvnt
->
facilityStr
.
facilityStr
.
len
);
get_facility_ie
(
&
ftdmchan
->
caller_data
,
discEvnt
->
facilityStr
.
facilityStr
.
val
,
discEvnt
->
facilityStr
.
facilityStr
.
len
);
}
else
{
/* Call libsng_isdn facility decode function and copy variables here */
}
...
...
@@ -569,7 +573,7 @@ void sngisdn_process_rel_ind (sngisdn_event_data_t *sngisdn_event)
if
(
relEvnt
->
facilityStr
.
eh
.
pres
)
{
if
(
signal_data
->
facility_ie_decode
==
SNGISDN_OPT_FALSE
)
{
cpy_facility_ie_from_stack
(
&
ftdmchan
->
caller_data
,
relEvnt
->
facilityStr
.
facilityStr
.
val
,
relEvnt
->
facilityStr
.
facilityStr
.
len
);
get_facility_ie
(
&
ftdmchan
->
caller_data
,
relEvnt
->
facilityStr
.
facilityStr
.
val
,
relEvnt
->
facilityStr
.
facilityStr
.
len
);
}
else
{
/* Call libsng_isdn facility decode function and copy variables here */
}
...
...
@@ -785,7 +789,7 @@ void sngisdn_process_fac_ind (sngisdn_event_data_t *sngisdn_event)
ftdm_sigmsg_t
sigev
;
if
(
facEvnt
->
facElmt
.
facStr
.
pres
)
{
if
(
signal_data
->
facility_ie_decode
==
SNGISDN_OPT_FALSE
)
{
cpy_facility_ie_from_stack
(
&
ftdmchan
->
caller_data
,
&
facEvnt
->
facElmt
.
facStr
.
val
[
2
],
facEvnt
->
facElmt
.
facStr
.
len
);
get_facility_ie
(
&
ftdmchan
->
caller_data
,
&
facEvnt
->
facElmt
.
facStr
.
val
[
2
],
facEvnt
->
facElmt
.
facStr
.
len
);
}
else
{
/* Call libsng_isdn facility decode function and copy variables here */
}
...
...
libs/freetdm/src/ftmod/ftmod_sangoma_isdn/ftmod_sangoma_isdn_stack_out.c
浏览文件 @
7433a1e5
...
...
@@ -35,7 +35,6 @@
#include "ftmod_sangoma_isdn.h"
static
void
sngisdn_set_prog_desc
(
ProgInd
*
progInd
,
ftdm_sngisdn_progind_t
prod_ind
);
static
void
sngisdn_set_facilityStr
(
ftdm_channel_t
*
ftdmchan
,
FacilityStr
*
facilityStr
);
void
sngisdn_snd_setup
(
ftdm_channel_t
*
ftdmchan
)
{
...
...
@@ -136,12 +135,11 @@ void sngisdn_snd_setup(ftdm_channel_t *ftdmchan)
}
ftdm_log_chan
(
sngisdn_info
->
ftdmchan
,
FTDM_LOG_INFO
,
"Outgoing call: Called No:[%s] Calling No:[%s]
\n
"
,
ftdmchan
->
caller_data
.
dnis
.
digits
,
ftdmchan
->
caller_data
.
cid_num
.
digits
);
cpy_called_num_from_user
(
&
conEvnt
.
cdPtyNmb
,
&
ftdmchan
->
caller_data
);
cpy_calling_num_from_user
(
&
conEvnt
.
cgPtyNmb
,
&
ftdmchan
->
caller_data
);
cpy_redir_num_from_user
(
&
conEvnt
.
redirNmb
,
&
ftdmchan
->
caller_data
);
cpy_calling_name_from_user
(
&
conEvnt
,
ftdmchan
);
sngisdn_set_facilityStr
(
ftdmchan
,
&
conEvnt
.
facilityStr
);
set_called_num
(
&
conEvnt
.
cdPtyNmb
,
&
ftdmchan
->
caller_data
);
set_calling_num
(
&
conEvnt
.
cgPtyNmb
,
&
ftdmchan
->
caller_data
);
set_redir_num
(
&
conEvnt
.
redirNmb
,
&
ftdmchan
->
caller_data
);
set_calling_name
(
&
conEvnt
,
ftdmchan
);
set_facility_ie
(
ftdmchan
,
&
conEvnt
.
facilityStr
);
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
);
...
...
@@ -558,7 +556,8 @@ void sngisdn_snd_disconnect(ftdm_channel_t *ftdmchan)
discEvnt
.
causeDgn
[
0
].
recommend
.
pres
=
NOTPRSNT
;
discEvnt
.
causeDgn
[
0
].
dgnVal
.
pres
=
NOTPRSNT
;
sngisdn_set_facilityStr
(
ftdmchan
,
&
discEvnt
.
facilityStr
);
set_facility_ie
(
ftdmchan
,
&
discEvnt
.
facilityStr
);
ftdm_log_chan
(
ftdmchan
,
FTDM_LOG_INFO
,
"Sending DISCONNECT (suId:%d suInstId:%u spInstId:%u)
\n
"
,
signal_data
->
cc_id
,
sngisdn_info
->
suInstId
,
sngisdn_info
->
spInstId
);
if
(
sng_isdn_disc_request
(
signal_data
->
cc_id
,
sngisdn_info
->
suInstId
,
sngisdn_info
->
spInstId
,
&
discEvnt
))
{
...
...
@@ -604,7 +603,7 @@ void sngisdn_snd_release(ftdm_channel_t *ftdmchan, uint8_t glare)
spInstId
=
sngisdn_info
->
spInstId
;
}
s
ngisdn_set_facilityStr
(
ftdmchan
,
&
relEvnt
.
facilityStr
);
s
et_facility_ie
(
ftdmchan
,
&
relEvnt
.
facilityStr
);
ftdm_log_chan
(
ftdmchan
,
FTDM_LOG_INFO
,
"Sending RELEASE/RELEASE COMPLETE (suId:%d suInstId:%u spInstId:%u)
\n
"
,
signal_data
->
cc_id
,
suInstId
,
spInstId
);
...
...
@@ -647,19 +646,6 @@ static void sngisdn_set_prog_desc(ProgInd *progInd, ftdm_sngisdn_progind_t prog_
return
;
}
static
void
sngisdn_set_facilityStr
(
ftdm_channel_t
*
ftdmchan
,
FacilityStr
*
facilityStr
)
{
const
char
*
facility_str
=
NULL
;
facility_str
=
ftdm_channel_get_var
(
ftdmchan
,
"isdn.facility.val"
);
if
(
facility_str
)
{
facilityStr
->
eh
.
pres
=
PRSNT_NODEF
;
facilityStr
->
facilityStr
.
len
=
strlen
(
facility_str
);
memcpy
(
facilityStr
->
facilityStr
.
val
,
facility_str
,
facilityStr
->
facilityStr
.
len
);
}
return
;
}
/* We received an incoming frame on the d-channel, send data to the stack */
void
sngisdn_snd_data
(
ftdm_channel_t
*
dchan
,
uint8_t
*
data
,
ftdm_size_t
len
)
{
...
...
libs/freetdm/src/ftmod/ftmod_sangoma_isdn/ftmod_sangoma_isdn_support.c
浏览文件 @
7433a1e5
差异被折叠。
点击展开。
libs/freetdm/src/include/freetdm.h
浏览文件 @
7433a1e5
...
...
@@ -285,7 +285,7 @@ typedef enum {
/*! \brief Signaling messages sent by the stacks */
typedef
enum
{
FTDM_SIGEVENT_START
,
/*!< Incoming call (ie: incoming SETUP msg or Ring) */
FTDM_SIGEVENT_START
,
/*!< Incoming call (ie: incoming SETUP msg or Ring) */
FTDM_SIGEVENT_STOP
,
/*!< Hangup */
FTDM_SIGEVENT_RELEASED
,
/*!< Channel is completely released and available */
FTDM_SIGEVENT_UP
,
/*!< Outgoing call has been answered */
...
...
@@ -300,12 +300,12 @@ typedef enum {
FTDM_SIGEVENT_RESTART
,
/*!< Restart has been requested. Typically you hangup your call resources here */
FTDM_SIGEVENT_SIGSTATUS_CHANGED
,
/*!< Signaling protocol status changed (ie: D-chan up), see new status in raw_data ftdm_sigmsg_t member */
FTDM_SIGEVENT_COLLISION
,
/*!< Outgoing call was dropped because an incoming call arrived at the same time */
FTDM_SIGEVENT_MSG
,
/*
!< We received an in-call msg */
FTDM_SIGEVENT_MSG
,
/*!< We received an in-call msg */
FTDM_SIGEVENT_INVALID
}
ftdm_signal_event_t
;
#define SIGNAL_STRINGS "START", "STOP", "RELEASED", "UP", "FLASH", "PROCEED", "PROGRESS", \
"PROGRESS_MEDIA", "ALARM_TRAP", "ALARM_CLEAR", \
"COLLECTED_DIGIT", "ADD_CALL", "RESTART", "SIGSTATUS_CHANGED", "COLLISION", "INVALID"
"COLLECTED_DIGIT", "ADD_CALL", "RESTART", "SIGSTATUS_CHANGED", "COLLISION", "
MSG", "
INVALID"
/*! \brief Move from string to ftdm_signal_event_t and viceversa */
FTDM_STR2ENUM_P
(
ftdm_str2ftdm_signal_event
,
ftdm_signal_event2str
,
ftdm_signal_event_t
)
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论