PerKins Zhu

Le vent se lève,il faut tenter de vivre.

导航

freeswitch模块开发【问题排查】—load模块时提示 127错误

Posted on 2025-02-19 10:28  PerKins.Zhu  阅读(106)  评论(0)    收藏  举报

在控制台load模块时提示 127错误:

2025-02-14 13:41:53.340827 96.36% [CRIT] switch_loadable_module.c:1754 Error Loading module D:/myproject/visualCode/freeswitch/x64/Debug/mod/mod_soundtouch.dll **dll sym error [127l] **

 

1、启动debug模式,在 switch_loadable_module.c文件中,找到 SWITCH_DECLARE(switch_status_t) switch_loadable_module_init(switch_bool_t autoload) 函数,在其中打断点,然后执行load命令,逐步跟进查找错误原因。可以通过监视变量获取执行中变量值。

2、 static switch_status_t switch_loadable_module_load_file(char *path, char *filename, switch_bool_t global, switch_loadable_module_t **new_module) 函数也可以作为监控点。

3、module加载逻辑见下图:

 

 

 

对于.CPP 代码加载时发生127错误,如果代码是从.c文件中复制到.cpp文件中,则注意需要在声明宏的时候加入如下导出函数命令:

SWITCH_BEGIN_EXTERN_C
SWITCH_MODULE_SHUTDOWN_FUNCTION(mod_soundtouch_shutdown);
SWITCH_MODULE_RUNTIME_FUNCTION(mod_soundtouch_runtime);
SWITCH_MODULE_LOAD_FUNCTION(mod_soundtouch_load);
SWITCH_MODULE_DEFINITION(mod_soundtouch, mod_soundtouch_load, mod_soundtouch_shutdown, NULL);
SWITCH_END_EXTERN_C

否则无法导出   SWITCH_MOD_DECLARE_DATA switch_loadable_module_function_table_t name##_module_interface  函数,加载模块时便找不到   mod_xxxx_module_interface 函数,导致提示127错误。

 

可用 Dependencies 软件打开 mod_xxxx.dll查看生成的dll文件是否有导出该函数: