Skip to content
项目
群组
代码片段
帮助
正在加载...
登录
切换导航
F
freeswitch
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
张华
freeswitch
Commits
fa5767eb
提交
fa5767eb
authored
9月 22, 2006
作者:
Anthony Minessale
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fixes
git-svn-id:
http://svn.freeswitch.org/svn/freeswitch/trunk@2781
d0543943-73ff-0310-b7d9-9358b9ac24b2
上级
464eada6
显示空白字符变更
内嵌
并排
正在显示
4 个修改的文件
包含
100 行增加
和
63 行删除
+100
-63
switch_core.h
src/include/switch_core.h
+1
-1
mod_dingaling.c
src/mod/endpoints/mod_dingaling/mod_dingaling.c
+97
-60
switch_core.c
src/switch_core.c
+1
-1
switch_ivr.c
src/switch_ivr.c
+1
-1
没有找到文件。
src/include/switch_core.h
浏览文件 @
fa5767eb
...
...
@@ -283,7 +283,7 @@ SWITCH_DECLARE(void) switch_core_session_run(switch_core_session_t *session);
\brief determine if the session's state machine is running
\param session the session on which to check
*/
SWITCH_DECLARE
(
unsigned
int
)
switch_core_session_runing
(
switch_core_session_t
*
session
);
SWITCH_DECLARE
(
unsigned
int
)
switch_core_session_run
n
ing
(
switch_core_session_t
*
session
);
/*!
\brief Allocate memory from the main pool with no intention of returning it
...
...
src/mod/endpoints/mod_dingaling/mod_dingaling.c
浏览文件 @
fa5767eb
...
...
@@ -177,38 +177,49 @@ static ldl_status handle_response(ldl_handle_t *handle, char *id);
static
switch_status_t
load_config
(
void
);
static
void
terminate_session
(
switch_core_session_t
**
session
,
switch_call_cause_t
cause
)
static
void
terminate_session
(
switch_core_session_t
**
session
,
int
line
,
switch_call_cause_t
cause
)
{
if
(
*
session
)
{
switch_channel_t
*
channel
=
switch_core_session_get_channel
(
*
session
);
switch_channel_state_t
state
=
switch_channel_get_state
(
channel
);
struct
private_object
*
tech_pvt
=
NULL
;
switch_log_printf
(
SWITCH_CHANNEL_LOG
,
SWITCH_LOG_DEBUG
,
"Terminate called from line %d state=%s
\n
"
,
line
,
switch_channel_state_name
(
state
));
tech_pvt
=
switch_core_session_get_private
(
*
session
);
if
(
state
<
CS_INIT
||
!
switch_core_session_running
(
*
session
))
{
if
(
state
>
CS_INIT
&&
state
<
CS_HANGUP
)
{
channel_on_hangup
(
*
session
);
}
if
(
tech_pvt
&&
tech_pvt
->
dlsession
)
{
ldl_session_set_private
(
tech_pvt
->
dlsession
,
NULL
);
}
switch_core_session_destroy
(
session
);
}
else
if
(
tech_pvt
){
if
(
switch_test_flag
(
tech_pvt
,
TFLAG_TERM
))
{
/*once is enough*/
return
;
}
if
(
tech_pvt
->
dlsession
)
{
if
(
!
switch_test_flag
(
tech_pvt
,
TFLAG_TERM
))
{
ldl_session_terminate
(
tech_pvt
->
dlsession
);
switch_set_flag_locked
(
tech_pvt
,
TFLAG_TERM
);
}
ldl_session_destroy
(
&
tech_pvt
->
dlsession
);
}
switch_set_flag_locked
(
tech_pvt
,
TFLAG_TERM
);
}
if
(
state
>
CS_INIT
&&
state
<
CS_HANGUP
)
{
if
(
state
<
CS_HANGUP
)
{
switch_channel_hangup
(
channel
,
cause
);
}
if
(
!
switch_core_session_runing
(
*
session
))
{
if
(
state
>
CS_INIT
&&
state
<
CS_HANGUP
)
{
channel_on_hangup
(
*
session
);
*
session
=
NULL
;
}
if
(
tech_pvt
&&
tech_pvt
->
dlsession
)
{
ldl_session_set_private
(
tech_pvt
->
dlsession
,
NULL
);
}
switch_core_session_destroy
(
session
);
}
}
}
static
void
dl_logger
(
char
*
file
,
const
char
*
func
,
int
line
,
int
level
,
char
*
fmt
,
...)
...
...
@@ -474,7 +485,7 @@ static int do_describe(struct private_object *tech_pvt, int force)
memset
(
payloads
,
0
,
sizeof
(
payloads
));
switch_set_flag_locked
(
tech_pvt
,
TFLAG_DO_CAND
);
if
(
!
get_codecs
(
tech_pvt
))
{
terminate_session
(
&
tech_pvt
->
session
,
SWITCH_CAUSE_INCOMPATIBLE_DESTINATION
);
terminate_session
(
&
tech_pvt
->
session
,
__LINE__
,
SWITCH_CAUSE_INCOMPATIBLE_DESTINATION
);
switch_set_flag_locked
(
tech_pvt
,
TFLAG_BYE
);
switch_clear_flag_locked
(
tech_pvt
,
TFLAG_IO
);
return
0
;
...
...
@@ -522,6 +533,12 @@ static void *SWITCH_THREAD_FUNC negotiate_thread_run(switch_thread_t *thread, vo
switch_time_t
now
;
unsigned
int
elapsed
;
if
(
switch_core_session_read_lock
(
session
)
!=
SWITCH_STATUS_SUCCESS
)
{
/* too late */
return
NULL
;
}
tech_pvt
=
switch_core_session_get_private
(
session
);
assert
(
tech_pvt
!=
NULL
);
...
...
@@ -564,13 +581,13 @@ static void *SWITCH_THREAD_FUNC negotiate_thread_run(switch_thread_t *thread, vo
}
}
if
(
elapsed
>
60000
)
{
terminate_session
(
&
tech_pvt
->
session
,
SWITCH_CAUSE_NORMAL_CLEARING
);
terminate_session
(
&
tech_pvt
->
session
,
__LINE__
,
SWITCH_CAUSE_NORMAL_CLEARING
);
switch_set_flag_locked
(
tech_pvt
,
TFLAG_BYE
);
switch_clear_flag_locked
(
tech_pvt
,
TFLAG_IO
);
return
NULL
;
goto
done
;
}
if
(
switch_test_flag
(
tech_pvt
,
TFLAG_BYE
)
||
!
switch_test_flag
(
tech_pvt
,
TFLAG_IO
))
{
return
NULL
;
goto
done
;
}
switch_yield
(
1000
);
//printf("WAIT %s %d %d %d %d\n", switch_channel_get_name(channel), switch_test_flag(tech_pvt, TFLAG_TRANSPORT), switch_test_flag(tech_pvt, TFLAG_CODEC_READY), switch_test_flag(tech_pvt, TFLAG_RTP_READY), switch_test_flag(tech_pvt, TFLAG_ANSWER));
...
...
@@ -594,10 +611,14 @@ static void *SWITCH_THREAD_FUNC negotiate_thread_run(switch_thread_t *thread, vo
switch_core_session_thread_launch
(
session
);
}
switch_channel_set_state
(
channel
,
CS_INIT
);
return
NULL
;
goto
done
;
out:
terminate_session
(
&
session
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
terminate_session
(
&
session
,
__LINE__
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
done:
if
(
session
)
{
switch_core_session_rwunlock
(
session
);
}
return
NULL
;
}
...
...
@@ -875,7 +896,7 @@ static switch_status_t channel_read_frame(switch_core_session_t *session, switch
switch_clear_flag_locked
(
tech_pvt
,
TFLAG_READING
);
if
(
switch_test_flag
(
tech_pvt
,
TFLAG_BYE
))
{
terminate_session
(
&
session
,
SWITCH_CAUSE_NORMAL_CLEARING
);
terminate_session
(
&
session
,
__LINE__
,
SWITCH_CAUSE_NORMAL_CLEARING
);
return
SWITCH_STATUS_FALSE
;
}
...
...
@@ -908,7 +929,7 @@ static switch_status_t channel_write_frame(switch_core_session_t *session, switc
if
(
switch_test_flag
(
tech_pvt
,
TFLAG_BYE
))
{
terminate_session
(
&
session
,
SWITCH_CAUSE_NORMAL_CLEARING
);
terminate_session
(
&
session
,
__LINE__
,
SWITCH_CAUSE_NORMAL_CLEARING
);
return
SWITCH_STATUS_FALSE
;
}
...
...
@@ -1099,7 +1120,7 @@ static switch_status_t channel_outgoing_channel(switch_core_session_t *session,
*
callto
++
=
'\0'
;
}
else
{
switch_log_printf
(
SWITCH_CHANNEL_LOG
,
SWITCH_LOG_DEBUG
,
"Invalid URL!
\n
"
);
terminate_session
(
new_session
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
terminate_session
(
new_session
,
__LINE__
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
return
SWITCH_STATUS_GENERR
;
}
...
...
@@ -1110,17 +1131,17 @@ static switch_status_t channel_outgoing_channel(switch_core_session_t *session,
if
((
mdl_profile
=
switch_core_hash_find
(
globals
.
profile_hash
,
profile_name
)))
{
if
(
!
ldl_handle_ready
(
mdl_profile
->
handle
))
{
switch_log_printf
(
SWITCH_CHANNEL_LOG
,
SWITCH_LOG_DEBUG
,
"Doh! we are not logged in yet!
\n
"
);
terminate_session
(
new_session
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
terminate_session
(
new_session
,
__LINE__
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
return
SWITCH_STATUS_GENERR
;
}
if
(
!
(
full_id
=
ldl_handle_probe
(
mdl_profile
->
handle
,
callto
,
idbuf
,
sizeof
(
idbuf
))))
{
switch_log_printf
(
SWITCH_CHANNEL_LOG
,
SWITCH_LOG_DEBUG
,
"Unknown Recipient!
\n
"
);
terminate_session
(
new_session
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
terminate_session
(
new_session
,
__LINE__
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
return
SWITCH_STATUS_GENERR
;
}
}
else
{
switch_log_printf
(
SWITCH_CHANNEL_LOG
,
SWITCH_LOG_DEBUG
,
"Unknown Profile!
\n
"
);
terminate_session
(
new_session
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
terminate_session
(
new_session
,
__LINE__
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
return
SWITCH_STATUS_GENERR
;
}
...
...
@@ -1140,7 +1161,7 @@ static switch_status_t channel_outgoing_channel(switch_core_session_t *session,
tech_pvt
->
dnis
=
switch_core_session_strdup
(
*
new_session
,
dnis
);
}
else
{
switch_log_printf
(
SWITCH_CHANNEL_LOG
,
SWITCH_LOG_CRIT
,
"Hey where is my memory pool?
\n
"
);
terminate_session
(
new_session
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
terminate_session
(
new_session
,
__LINE__
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
return
SWITCH_STATUS_GENERR
;
}
...
...
@@ -1155,7 +1176,7 @@ static switch_status_t channel_outgoing_channel(switch_core_session_t *session,
tech_pvt
->
caller_profile
=
caller_profile
;
}
else
{
switch_log_printf
(
SWITCH_CHANNEL_LOG
,
SWITCH_LOG_DEBUG
,
"Doh! no caller profile
\n
"
);
terminate_session
(
new_session
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
terminate_session
(
new_session
,
__LINE__
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
return
SWITCH_STATUS_GENERR
;
}
...
...
@@ -1172,7 +1193,7 @@ static switch_status_t channel_outgoing_channel(switch_core_session_t *session,
ldl_session_set_value
(
dlsession
,
"caller_id_number"
,
outbound_profile
->
caller_id_number
);
tech_pvt
->
dlsession
=
dlsession
;
if
(
!
get_codecs
(
tech_pvt
))
{
terminate_session
(
new_session
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
terminate_session
(
new_session
,
__LINE__
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
return
SWITCH_STATUS_GENERR
;
}
//tech_pvt->desc_id = ldl_session_describe(dlsession, NULL, 0, LDL_DESCRIPTION_INITIATE);
...
...
@@ -1535,12 +1556,14 @@ static ldl_status handle_signalling(ldl_handle_t *handle, ldl_session_t *dlsessi
switch_channel_t
*
channel
=
NULL
;
struct
private_object
*
tech_pvt
=
NULL
;
switch_event_t
*
event
;
ldl_status
status
=
LDL_STATUS_SUCCESS
;
assert
(
handle
!=
NULL
);
if
(
!
(
profile
=
ldl_handle_get_private
(
handle
)))
{
switch_log_printf
(
SWITCH_CHANNEL_LOG
,
SWITCH_LOG_ERROR
,
"ERROR NO PROFILE!
\n
"
);
return
LDL_STATUS_FALSE
;
status
=
LDL_STATUS_FALSE
;
goto
done
;
}
if
(
!
dlsession
)
{
...
...
@@ -1577,7 +1600,8 @@ static ldl_status handle_signalling(ldl_handle_t *handle, ldl_session_t *dlsessi
break
;
}
return
LDL_STATUS_SUCCESS
;
status
=
LDL_STATUS_SUCCESS
;
goto
done
;
}
...
...
@@ -1592,16 +1616,19 @@ static ldl_status handle_signalling(ldl_handle_t *handle, ldl_session_t *dlsessi
if
(
switch_channel_get_state
(
channel
)
>=
CS_HANGUP
)
{
switch_log_printf
(
SWITCH_CHANNEL_LOG
,
SWITCH_LOG_DEBUG
,
"Call %s is already over
\n
"
,
switch_channel_get_name
(
channel
));
return
LDL_STATUS_FALSE
;
status
=
LDL_STATUS_FALSE
;
goto
done
;
}
}
else
{
if
(
signal
!=
LDL_SIGNAL_INITIATE
)
{
switch_log_printf
(
SWITCH_CHANNEL_LOG
,
SWITCH_LOG_DEBUG
,
"Session is already dead
\n
"
);
return
LDL_STATUS_FALSE
;
status
=
LDL_STATUS_FALSE
;
goto
done
;
}
if
((
session
=
switch_core_session_request
(
&
channel_endpoint_interface
,
NULL
))
!=
0
)
{
switch_core_session_add_stream
(
session
,
NULL
);
if
((
tech_pvt
=
(
struct
private_object
*
)
switch_core_session_alloc
(
session
,
sizeof
(
struct
private_object
)))
!=
0
)
{
memset
(
tech_pvt
,
0
,
sizeof
(
*
tech_pvt
));
switch_mutex_init
(
&
tech_pvt
->
flag_mutex
,
SWITCH_MUTEX_NESTED
,
switch_core_session_get_pool
(
session
));
...
...
@@ -1618,8 +1645,9 @@ static ldl_status handle_signalling(ldl_handle_t *handle, ldl_session_t *dlsessi
switch_set_flag_locked
(
tech_pvt
,
TFLAG_TRANSPORT_ACCEPT
);
}
else
{
switch_log_printf
(
SWITCH_CHANNEL_LOG
,
SWITCH_LOG_DEBUG
,
"Hey where is my memory pool?
\n
"
);
terminate_session
(
&
session
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
return
LDL_STATUS_FALSE
;
terminate_session
(
&
session
,
__LINE__
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
status
=
LDL_STATUS_FALSE
;
goto
done
;
}
...
...
@@ -1627,7 +1655,11 @@ static ldl_status handle_signalling(ldl_handle_t *handle, ldl_session_t *dlsessi
ldl_session_set_private
(
dlsession
,
session
);
tech_pvt
->
dlsession
=
dlsession
;
negotiate_thread_launch
(
session
);
}
else
{
status
=
LDL_STATUS_FALSE
;
goto
done
;
}
}
switch
(
signal
)
{
...
...
@@ -1669,7 +1701,9 @@ static ldl_status handle_signalling(ldl_handle_t *handle, ldl_session_t *dlsessi
if
(
!
strcasecmp
(
msg
,
"accept"
))
{
switch_set_flag_locked
(
tech_pvt
,
TFLAG_ANSWER
);
if
(
!
do_candidates
(
tech_pvt
,
0
))
{
terminate_session
(
&
session
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
terminate_session
(
&
session
,
__LINE__
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
status
=
LDL_STATUS_FALSE
;
goto
done
;
}
}
}
...
...
@@ -1681,8 +1715,9 @@ static ldl_status handle_signalling(ldl_handle_t *handle, ldl_session_t *dlsessi
if
(
!
get_codecs
(
tech_pvt
))
{
terminate_session
(
&
session
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
return
LDL_STATUS_FALSE
;
terminate_session
(
&
session
,
__LINE__
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
status
=
LDL_STATUS_FALSE
;
goto
done
;
}
...
...
@@ -1713,18 +1748,21 @@ static ldl_status handle_signalling(ldl_handle_t *handle, ldl_session_t *dlsessi
tech_pvt
->
codec_rate
=
payloads
[
x
].
rate
;
if
(
!
switch_test_flag
(
tech_pvt
,
TFLAG_OUTBOUND
))
{
if
(
!
do_describe
(
tech_pvt
,
0
))
{
terminate_session
(
&
session
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
return
LDL_STATUS_FALSE
;
terminate_session
(
&
session
,
__LINE__
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
status
=
LDL_STATUS_FALSE
;
goto
done
;
}
}
return
LDL_STATUS_SUCCESS
;
status
=
LDL_STATUS_SUCCESS
;
goto
done
;
}
}
}
if
(
!
match
&&
!
switch_test_flag
(
tech_pvt
,
TFLAG_OUTBOUND
))
{
if
(
!
do_describe
(
tech_pvt
,
0
))
{
terminate_session
(
&
session
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
return
LDL_STATUS_FALSE
;
terminate_session
(
&
session
,
__LINE__
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
status
=
LDL_STATUS_FALSE
;
goto
done
;
}
}
}
...
...
@@ -1829,8 +1867,9 @@ static ldl_status handle_signalling(ldl_handle_t *handle, ldl_session_t *dlsessi
}
if
(
!
get_codecs
(
tech_pvt
))
{
terminate_session
(
&
session
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
return
LDL_STATUS_FALSE
;
terminate_session
(
&
session
,
__LINE__
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
status
=
LDL_STATUS_FALSE
;
goto
done
;
}
...
...
@@ -1842,15 +1881,17 @@ static ldl_status handle_signalling(ldl_handle_t *handle, ldl_session_t *dlsessi
if
(
!
switch_test_flag
(
tech_pvt
,
TFLAG_OUTBOUND
))
{
if
(
!
do_candidates
(
tech_pvt
,
0
))
{
terminate_session
(
&
session
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
return
LDL_STATUS_FALSE
;
terminate_session
(
&
session
,
__LINE__
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
status
=
LDL_STATUS_FALSE
;
goto
done
;
}
}
switch_set_flag_locked
(
tech_pvt
,
TFLAG_TRANSPORT
);
return
LDL_STATUS_SUCCESS
;
status
=
LDL_STATUS_SUCCESS
;
goto
done
;
}
}
}
...
...
@@ -1866,15 +1907,9 @@ static ldl_status handle_signalling(ldl_handle_t *handle, ldl_session_t *dlsessi
switch_set_flag
(
tech_pvt
,
TFLAG_BYE
);
switch_clear_flag
(
tech_pvt
,
TFLAG_IO
);
switch_mutex_unlock
(
tech_pvt
->
flag_mutex
);
terminate_session
(
&
session
,
SWITCH_CAUSE_NORMAL_CLEARING
);
if
(
state
<=
CS_INIT
&&
!
switch_test_flag
(
tech_pvt
,
TFLAG_OUTBOUND
))
{
switch_log_printf
(
SWITCH_CHANNEL_LOG
,
SWITCH_LOG_DEBUG
,
"Destroy unused Session
\n
"
);
terminate_session
(
&
session
,
SWITCH_CAUSE_DESTINATION_OUT_OF_ORDER
);
}
else
{
terminate_session
(
&
session
,
__LINE__
,
SWITCH_CAUSE_NORMAL_CLEARING
);
switch_log_printf
(
SWITCH_CHANNEL_LOG
,
SWITCH_LOG_DEBUG
,
"End Call
\n
"
);
}
goto
done
;
}
break
;
...
...
@@ -1883,7 +1918,9 @@ static ldl_status handle_signalling(ldl_handle_t *handle, ldl_session_t *dlsessi
break
;
}
return
LDL_STATUS_SUCCESS
;
done
:
return
status
;
}
static
ldl_status
handle_response
(
ldl_handle_t
*
handle
,
char
*
id
)
...
...
src/switch_core.c
浏览文件 @
fa5767eb
...
...
@@ -2508,7 +2508,7 @@ SWITCH_DECLARE(void) switch_core_session_signal_state_change(switch_core_session
}
SWITCH_DECLARE
(
unsigned
int
)
switch_core_session_runing
(
switch_core_session_t
*
session
)
SWITCH_DECLARE
(
unsigned
int
)
switch_core_session_run
n
ing
(
switch_core_session_t
*
session
)
{
return
session
->
thread_running
;
}
...
...
src/switch_ivr.c
浏览文件 @
fa5767eb
...
...
@@ -1829,7 +1829,7 @@ SWITCH_DECLARE(switch_status_t) switch_ivr_originate(switch_core_session_t *sess
switch_channel_add_state_handler
(
peer_channels
[
i
],
table
);
}
if
(
switch_core_session_runing
(
peer_sessions
[
i
]))
{
if
(
switch_core_session_run
n
ing
(
peer_sessions
[
i
]))
{
switch_channel_set_state
(
peer_channels
[
i
],
CS_RING
);
}
else
{
switch_core_session_thread_launch
(
peer_sessions
[
i
]);
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论