Shared Libraries: In the FLAT build mode, kernel modules may be used to provide minimal shared library functionality.
This commit is contained in:
parent
1b9f2795f6
commit
8d52ad9dd6
@ -7,7 +7,8 @@ config LIBC_DLLFCN
|
|||||||
bool "Shared library support"
|
bool "Shared library support"
|
||||||
default n
|
default n
|
||||||
select LIBC_ARCH_ELF
|
select LIBC_ARCH_ELF
|
||||||
depends on EXPERIMENTAL
|
select MODULE if BUILD_FLAT
|
||||||
|
depends on EXPERIMENTAL || BUILD_FLAT
|
||||||
---help---
|
---help---
|
||||||
Enabled support for user-space shared libraries.
|
Enabled support for user-space shared libraries.
|
||||||
|
|
||||||
|
@ -41,6 +41,8 @@
|
|||||||
|
|
||||||
#include <dllfcn.h>
|
#include <dllfcn.h>
|
||||||
|
|
||||||
|
#include <nuttx/module.h>
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Public Functions
|
* Public Functions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
@ -88,6 +90,37 @@
|
|||||||
|
|
||||||
int dlclose(FAR void *handle)
|
int dlclose(FAR void *handle)
|
||||||
{
|
{
|
||||||
|
#if defined(CONFIG_BUILD_FLAT)
|
||||||
|
/* In the FLAT build, a shared library is essentially the same as a kernel
|
||||||
|
* module.
|
||||||
|
*/
|
||||||
|
|
||||||
|
return rmmod(handle);
|
||||||
|
|
||||||
|
#elif defined(CONFIG_BUILD_PROTECTED)
|
||||||
|
/* The PROTECTED build is equivalent to the FLAT build EXCEPT that there
|
||||||
|
* must be two copies of the the module logic: One residing in kernel
|
||||||
|
* space and using the kernel symbol table and one residing in user space
|
||||||
|
* using the user space symbol table.
|
||||||
|
*
|
||||||
|
* The brute force way to accomplish this is by just copying the kernel
|
||||||
|
* module code into libc/module.
|
||||||
|
*/
|
||||||
|
|
||||||
#warning Missing logic
|
#warning Missing logic
|
||||||
return 1;
|
return -ENOSYS;
|
||||||
|
|
||||||
|
#else /* if defined(CONFIG_BUILD_KERNEL) */
|
||||||
|
/* The KERNEL build is considerably more complex: In order to be shared,
|
||||||
|
* the .text portion of the module must be (1) build for PIC/PID operation
|
||||||
|
* and (2) must like in a shared memory region accessible from all
|
||||||
|
* processes. The .data/.bss portion of the module must be allocated in
|
||||||
|
* the user space of each process, but must lie at the same virtual address
|
||||||
|
* so that it can be referenced from the one copy of the text in the shared
|
||||||
|
* memory region.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#warning Missing logic
|
||||||
|
return -ENOSYS;
|
||||||
|
#endif
|
||||||
}
|
}
|
@ -41,6 +41,8 @@
|
|||||||
|
|
||||||
#include <dllfcn.h>
|
#include <dllfcn.h>
|
||||||
|
|
||||||
|
#include <nuttx/module.h>
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Public Functions
|
* Public Functions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
@ -147,6 +149,42 @@
|
|||||||
|
|
||||||
FAR void *dlopen(FAR const char *file, int mode)
|
FAR void *dlopen(FAR const char *file, int mode)
|
||||||
{
|
{
|
||||||
|
#if defined(CONFIG_BUILD_FLAT)
|
||||||
|
/* In the FLAT build, a shared library is essentially the same as a kernel
|
||||||
|
* module.
|
||||||
|
*
|
||||||
|
* REVIST: Missing functionality:
|
||||||
|
* - No automatic binding of symbols
|
||||||
|
* - No dependencies
|
||||||
|
* - mode is ignored.
|
||||||
|
*/
|
||||||
|
|
||||||
|
return insmod(file, file);
|
||||||
|
|
||||||
|
#elif defined(CONFIG_BUILD_PROTECTED)
|
||||||
|
/* The PROTECTED build is equivalent to the FLAT build EXCEPT that there
|
||||||
|
* must be two copies of the the module logic: One residing in kernel
|
||||||
|
* space and using the kernel symbol table and one residing in user space
|
||||||
|
* using the user space symbol table.
|
||||||
|
*
|
||||||
|
* The brute force way to accomplish this is by just copying the kernel
|
||||||
|
* module code into libc/module.
|
||||||
|
*/
|
||||||
|
|
||||||
#warning Missing logic
|
#warning Missing logic
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
#else /* if defined(CONFIG_BUILD_KERNEL) */
|
||||||
|
/* The KERNEL build is considerably more complex: In order to be shared,
|
||||||
|
* the .text portion of the module must be (1) build for PIC/PID operation
|
||||||
|
* and (2) must like in a shared memory region accessible from all
|
||||||
|
* processes. The .data/.bss portion of the module must be allocated in
|
||||||
|
* the user space of each process, but must lie at the same virtual address
|
||||||
|
* so that it can be referenced from the one copy of the text in the shared
|
||||||
|
* memory region.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#warning Missing logic
|
||||||
|
return NULL;
|
||||||
|
#endif
|
||||||
}
|
}
|
@ -41,6 +41,8 @@
|
|||||||
|
|
||||||
#include <dllfcn.h>
|
#include <dllfcn.h>
|
||||||
|
|
||||||
|
#include <nuttx/module.h>
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Public Functions
|
* Public Functions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
@ -78,6 +80,37 @@
|
|||||||
|
|
||||||
FAR void *dlsym(FAR void *handle, FAR const char *name)
|
FAR void *dlsym(FAR void *handle, FAR const char *name)
|
||||||
{
|
{
|
||||||
|
#if defined(CONFIG_BUILD_FLAT)
|
||||||
|
/* In the FLAT build, a shared library is essentially the same as a kernel
|
||||||
|
* module.
|
||||||
|
*/
|
||||||
|
|
||||||
|
return (FAR void *)modsym(handle, name);
|
||||||
|
|
||||||
|
#elif defined(CONFIG_BUILD_PROTECTED)
|
||||||
|
/* The PROTECTED build is equivalent to the FLAT build EXCEPT that there
|
||||||
|
* must be two copies of the the module logic: One residing in kernel
|
||||||
|
* space and using the kernel symbol table and one residing in user space
|
||||||
|
* using the user space symbol table.
|
||||||
|
*
|
||||||
|
* The brute force way to accomplish this is by just copying the kernel
|
||||||
|
* module code into libc/module.
|
||||||
|
*/
|
||||||
|
|
||||||
#warning Missing logic
|
#warning Missing logic
|
||||||
return NULL;
|
return NULL;
|
||||||
|
|
||||||
|
#else /* if defined(CONFIG_BUILD_KERNEL) */
|
||||||
|
/* The KERNEL build is considerably more complex: In order to be shared,
|
||||||
|
* the .text portion of the module must be (1) build for PIC/PID operation
|
||||||
|
* and (2) must like in a shared memory region accessible from all
|
||||||
|
* processes. The .data/.bss portion of the module must be allocated in
|
||||||
|
* the user space of each process, but must lie at the same virtual address
|
||||||
|
* so that it can be referenced from the one copy of the text in the shared
|
||||||
|
* memory region.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#warning Missing logic
|
||||||
|
return NULL;
|
||||||
|
#endif
|
||||||
}
|
}
|
Loading…
Reference in New Issue
Block a user