linux下加载动态链接库的方法:以下以触摸屏为例:介绍是如何加载一下共享库的。
首先让我们看看以下几个函数:
dlopen()
功能:打开一个动态链接库
包含头文件:
#include <dlfcn.h>
函数定义:
void * dlopen( const char * pathname, int mode );
函数描述:
在dlopen的()函数以指定模式打开指定的动态连接库文件,并返回一个句柄给调用进程。使用dlclose()来卸载打开的库。
dlclose(handle);
功能:关闭一个动态链接库
dlsym()
函数原型: void* dlsym(void* handle,const char* symbol)
该函数在<dlfcn.h>文件中。
handle是由dlopen打开动态链接库后返回的指针,symbol就是要求获取的函数的名称,函数返回值是void*,指向函数的地址,供调用使用
getenv()
功 能: 从环境中取字符串,获取环境变量的值
头文件: stdlib.h
用 法:char *getenv(char *envvar);
函数说明:getenv()用来取得参数enwar环境变量的内容。参数enwar为环境变量的名称,如果该变量存在则会返回指向该内容的指针。环境变量的格式为enwar=value
返回值: 执行成功则返回指向该内容的指针,找不到符合的环境变量名称则返回NULL
alloca()
包含在头文件malloc.h中. 在某些系统中会宏定义成_alloca使用.
int load_module(struct tsdev *ts, const char *module, const char *params, int raw)
{
struct tslib_module_info * (*init)(struct tsdev *, const char *);
struct tslib_module_info *info;
char fn[1024];
void *handle;
int ret;
char *plugin_directory=NULL;
if( (plugin_directory = getenv("TSLIB_PLUGINDIR")) != NULL ) {
//fn = alloca(sizeof(plugin_directory) + strlen(module) + 4);
strcpy(fn,plugin_directory);
} else {
//fn = alloca(sizeof(PLUGIN_DIR) + strlen(module) + 4);
strcpy(fn, PLUGIN_DIR);
}
/*构造共享库路径*/
strcat(fn, "/");
strcat(fn, module);
strcat(fn, ".so");
#ifdef DEBUG
printf ("Loading module %s\n", fn);
#endif
handle = dlopen(fn, RTLD_NOW);
if (!handle)
return -1;
init = dlsym(handle, "mod_init");
if (!init) {
dlclose(handle);
return -1;
}
info = init(ts, params);
if (!info) {
dlclose(handle);
return -1;
}
info->handle = handle;
if (raw) {
ret = __ts_attach_raw(ts, info);
} else {
ret = __ts_attach(ts, info);
}
if (ret) {
info->ops->fini(info);
dlclose(handle);
}
return ret;
}