Skip to content
项目
群组
代码片段
帮助
正在加载...
登录
切换导航
F
freeswitch
项目
项目
详情
活动
周期分析
仓库
仓库
文件
提交
分支
标签
贡献者
分枝图
比较
统计图
议题
0
议题
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
CI / CD
CI / CD
流水线
作业
日程
统计图
Wiki
Wiki
代码片段
代码片段
成员
成员
折叠边栏
关闭边栏
活动
分枝图
统计图
创建新议题
作业
提交
议题看板
打开侧边栏
张华
freeswitch
Commits
df76709e
提交
df76709e
authored
5月 17, 2012
作者:
kapil
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Adding code to bring up MEGACO stack
上级
32c5100e
全部展开
隐藏空白字符变更
内嵌
并排
正在显示
7 个修改的文件
包含
1031 行增加
和
13 行删除
+1031
-13
Makefile
src/mod/endpoints/mod_megaco/Makefile
+9
-1
megaco.c
src/mod/endpoints/mod_megaco/megaco.c
+12
-1
megaco_stack.c
src/mod/endpoints/mod_megaco/megaco_stack.c
+964
-0
megaco_stack.h
src/mod/endpoints/mod_megaco/megaco_stack.h
+38
-1
megaco_xml.c
src/mod/endpoints/mod_megaco/megaco_xml.c
+1
-0
mod_megaco.c
src/mod/endpoints/mod_megaco/mod_megaco.c
+6
-9
mod_megaco.h
src/mod/endpoints/mod_megaco/mod_megaco.h
+1
-1
没有找到文件。
src/mod/endpoints/mod_megaco/Makefile
浏览文件 @
df76709e
ifndef
ARCH
ARCH
=
$(
shell
uname
-m
)
endif
ifeq
($(ARCH),x86_64)
LOCAL_CFLAGS
+=
-DBIT_64
-DALIGN_64BIT
endif
BASE
=
../../../..
LOCAL_OBJS
=
megaco.o megaco_
cfg
.o
LOCAL_OBJS
=
megaco.o megaco_
stack.o megaco_xml
.o
LOCAL_LDFLAGS
=
-lsng_megaco
include
$(BASE)/build/modmake.rules
src/mod/endpoints/mod_megaco/megaco.c
浏览文件 @
df76709e
...
...
@@ -96,7 +96,12 @@ static switch_status_t config_profile(megaco_profile_t *profile, switch_bool_t r
}
}
status
=
SWITCH_STATUS_SUCCESS
;
/* configure the MEGACO stack */
status
=
sng_mgco_cfg
(
profile
->
name
);
/* we should break from here , profile name should be unique */
break
;
}
done:
...
...
@@ -131,6 +136,12 @@ switch_status_t megaco_profile_start(const char *profilename)
goto
fail
;
}
/* start MEGACP stack */
if
(
SWITCH_STATUS_FALSE
==
sng_mgco_start
(
profilename
))
{
switch_log_printf
(
SWITCH_CHANNEL_LOG
,
SWITCH_LOG_ERROR
,
"Error starting MEGACO Stack for profile %s
\n
"
,
profile
->
name
);
goto
fail
;
}
switch_core_hash_insert_wrlock
(
megaco_globals
.
profile_hash
,
profile
->
name
,
profile
,
megaco_globals
.
profile_rwlock
);
switch_log_printf
(
SWITCH_CHANNEL_LOG
,
SWITCH_LOG_INFO
,
"Started profile: %s
\n
"
,
profile
->
name
);
...
...
src/mod/endpoints/mod_megaco/megaco_stack.c
0 → 100644
浏览文件 @
df76709e
差异被折叠。
点击展开。
src/mod/endpoints/mod_megaco/megaco_
cfg
.h
→
src/mod/endpoints/mod_megaco/megaco_
stack
.h
浏览文件 @
df76709e
...
...
@@ -51,12 +51,21 @@ typedef enum{
SNG_MG_MEGACO
,
}
sng_mg_protocol_types_e
;
#define PRNT_PROTOCOL_TYPE(_val)\
((_val == SNG_MG_MGCP)?"SNG_MG_MGCP":\
(_val == SNG_MG_MEGACO)?"SNG_MG_MEGACO":\
"SNG_MG_NONE")
typedef
enum
{
SNG_MG_ENCODING_NONE
,
SNG_MG_ENCODING_TEXT
,
SNG_MG_ENCODING_BINARY
,
SNG_MG_ENCODING_TEXT
,
}
sng_mg_encoding_types_e
;
#define PRNT_ENCODING_TYPE(_val)\
((_val == SNG_MG_ENCODING_TEXT)?"SNG_MG_ENCODING_TEXT":\
(_val == SNG_MG_ENCODING_BINARY)?"SNG_MG_ENCODING_BINARY":\
"SNG_MG_ENCODING_NONE")
/* each profile is corresponds to each MG Instance */
...
...
@@ -95,4 +104,32 @@ void handle_mgco_audit_cfm(Pst *pst, SuId suId, MgMgtAudit* audit, Reason reason
void
handle_mg_alarm
(
Pst
*
pst
,
MgMngmt
*
sta
);
void
handle_tucl_alarm
(
Pst
*
pst
,
HiMngmt
*
sta
);
switch_status_t
sng_mgco_init
(
sng_isup_event_interface_t
*
event
);
switch_status_t
sng_mgco_cfg
(
const
char
*
profilename
);
switch_status_t
sng_mgco_start
(
const
char
*
profilename
);
switch_status_t
sng_mgco_stack_shutdown
(
void
);
/*****************************************************************************************************/
#define GET_MG_CFG_IDX(_profilename, _idx){\
for(idx=0; idx < MAX_MG_PROFILES; idx++){\
/* id zero is not acceptable */
\
if(megaco_globals.g_mg_cfg.mgCfg[idx].id){\
if (strcmp(megaco_globals.g_mg_cfg.mgCfg[idx].name, profilename)) {\
continue;\
} else{\
break;\
}\
}\
}\
}
#define GET_TPT_ID(_id) megaco_globals.g_mg_cfg.mgTptProf[megaco_globals.g_mg_cfg.mgCfg[_id].transport_prof_id].id
#define GET_MU_SAP_ID(_id) megaco_globals.g_mg_cfg.mgCfg[_id].id
#define GET_TPT_TYPE(_id) megaco_globals.g_mg_cfg.mgTptProf[megaco_globals.g_mg_cfg.mgCfg[_id].transport_prof_id].transport_type
#define GET_ENCODING_TYPE(_id) megaco_globals.g_mg_cfg.mgPeer.peers[megaco_globals.g_mg_cfg.mgCfg[_id].peer_id].encoding_type
#endif
/* _MEGACO_CFG_H_ */
src/mod/endpoints/mod_megaco/megaco_xml.c
浏览文件 @
df76709e
...
...
@@ -214,6 +214,7 @@ switch_status_t sng_parse_mg_peer_profile(switch_xml_t mg_peer_profile)
}
}
megaco_globals
.
g_mg_cfg
.
mgPeer
.
total_peer
++
;
return
SWITCH_STATUS_SUCCESS
;
}
/***********************************************************************************************************/
src/mod/endpoints/mod_megaco/mod_megaco.c
浏览文件 @
df76709e
...
...
@@ -123,25 +123,22 @@ SWITCH_MODULE_LOAD_FUNCTION(mod_megaco_load)
sng_event
.
mg
.
sng_mgco_cmd_ind
=
handle_mgco_cmd_ind
;
sng_event
.
mg
.
sng_mgco_txn_sta_ind
=
handle_mgco_txn_sta_ind
;
sng_event
.
mg
.
sng_mgco_sta_ind
=
handle_mgco_sta_ind
;
sng_event
.
mg
.
sng_mgco_cntrl_cfm
=
handle_mgco_cntrl_cfm
;
sng_event
.
mg
.
sng_mgco_audit_cfm
=
handle_mgco_audit_cfm
;
sng_event
.
mg
.
sng_mgco_cntrl_cfm
=
handle_mgco_cntrl_cfm
;
sng_event
.
mg
.
sng_mgco_audit_cfm
=
handle_mgco_audit_cfm
;
/* Alarm CB */
sng_event
.
sm
.
sng_mg_alarm
=
handle_mg_alarm
;
sng_event
.
sm
.
sng_tucl_alarm
=
handle_tucl_alarm
;
/* Log */
sng_event
.
sm
.
sng_log
=
handle_sng_log
;
/* initalize sng_mg library */
sng_isup_init_gen
(
&
sng_event
);
return
SWITCH_STATUS_SUCCESS
;
/* initualize MEGACO stack */
return
sng_mgco_init
(
&
sng_event
);
}
SWITCH_MODULE_SHUTDOWN_FUNCTION
(
mod_megaco_shutdown
)
{
/* TODO: Kapil: Insert stack global shutdown code here */
sng_mgco_stack_shutdown
();
return
SWITCH_STATUS_SUCCESS
;
}
...
...
src/mod/endpoints/mod_megaco/mod_megaco.h
浏览文件 @
df76709e
...
...
@@ -11,7 +11,7 @@
#define MOD_MEGACO_H
#include <switch.h>
#include "megaco_
cfg
.h"
#include "megaco_
stack
.h"
struct
megaco_globals
{
switch_memory_pool_t
*
pool
;
...
...
编写
预览
Markdown
格式
0%
重试
或
添加新文件
添加附件
取消
您添加了
0
人
到此讨论。请谨慎行事。
请先完成此评论的编辑!
取消
请
注册
或者
登录
后发表评论