4
0
mirror of https://github.com/RT-Thread/rt-thread.git synced 2025-02-02 07:40:30 +08:00

78 lines
2.2 KiB
C
Raw Normal View History

2013-01-08 22:40:58 +08:00
/*
2024-11-12 15:38:28 +08:00
* Copyright (c) 2006-2024 RT-Thread Development Team
2013-01-08 22:40:58 +08:00
*
2018-08-30 20:27:45 +08:00
* SPDX-License-Identifier: Apache-2.0
2013-01-08 22:40:58 +08:00
*
* Change Logs:
2018-04-25 23:26:20 +08:00
* Date Author Notes
* 2010-11-17 yi.qiu first version
2013-01-08 22:40:58 +08:00
*/
2018-04-25 23:26:20 +08:00
2013-01-08 22:40:58 +08:00
#include <rtthread.h>
#include <rtm.h>
#include <string.h>
2018-08-30 20:27:45 +08:00
#include "dlmodule.h"
2018-04-25 23:26:20 +08:00
#define MODULE_ROOT_DIR "/modules"
2013-01-08 22:40:58 +08:00
2024-11-12 15:38:28 +08:00
/**
* @brief dynamically load a shared library at runtime.
*
* @param filename the path to the shared library to load, which shouldn't be set to NULL.
* @param flags options for loading the shared library.
* @return void* on success, it returns a handle (a pointer) to the opened shared library, otherwise it returns NULL.
*
* @note This function is an API of POSIX standard, which is used for dynamically loading shared libraries at runtime.
* the function first tries to check if the module is already loaded, by finding module in module list.
* If module is found in memory (RT_NULL check fails), the reference count (nref) is incremented.
* Otherwise, dlmodule_load() will be called to load the module into memory.
* A handle (a pointer to the module) is returned at last, which can be used with other functions like dlsym().
*/
2013-01-08 22:40:58 +08:00
void* dlopen(const char *filename, int flags)
{
2018-08-30 20:27:45 +08:00
struct rt_dlmodule *module;
2018-04-25 23:26:20 +08:00
char *fullpath;
const char*def_path = MODULE_ROOT_DIR;
/* check parameters */
RT_ASSERT(filename != RT_NULL);
if (filename[0] != '/') /* it's a relative path, prefix with MODULE_ROOT_DIR */
{
fullpath = rt_malloc(strlen(def_path) + strlen(filename) + 2);
/* join path and file name */
rt_snprintf(fullpath, strlen(def_path) + strlen(filename) + 2,
"%s/%s", def_path, filename);
}
else
{
fullpath = (char*)filename; /* absolute path, use it directly */
}
2018-08-30 20:27:45 +08:00
rt_enter_critical();
2018-04-25 23:26:20 +08:00
/* find in module list */
2018-08-30 20:27:45 +08:00
module = dlmodule_find(fullpath);
2018-04-25 23:26:20 +08:00
2021-03-08 18:19:04 +08:00
if(module != RT_NULL)
2018-08-30 20:27:45 +08:00
{
rt_exit_critical();
module->nref++;
}
2021-03-08 18:19:04 +08:00
else
2018-08-30 20:27:45 +08:00
{
rt_exit_critical();
module = dlmodule_load(fullpath);
}
2018-04-25 23:26:20 +08:00
if(fullpath != filename)
{
rt_free(fullpath);
}
return (void*)module;
2013-01-08 22:40:58 +08:00
}
2018-04-25 23:26:20 +08:00
RTM_EXPORT(dlopen);