mirror of
https://github.com/apache/nuttx.git
synced 2026-05-28 03:45:50 +08:00
Extend canned symbol table logic to work in protected build mode
This commit is contained in:
+1
-1
Submodule configs updated: ba78f31764...de62dbc734
@@ -64,6 +64,18 @@
|
|||||||
* fixed size arrays completely defined at compilation or link time.
|
* fixed size arrays completely defined at compilation or link time.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
/* In order to full describe a symbol table, a vector containing the address
|
||||||
|
* of the symbol table and the number of elements in the symbol table is
|
||||||
|
* required.
|
||||||
|
*/
|
||||||
|
|
||||||
|
struct symtab_s; /* Forward reference */
|
||||||
|
struct symtab_desc_s
|
||||||
|
{
|
||||||
|
FAR struct symtab_s *symtab;
|
||||||
|
int nsymbols;
|
||||||
|
}
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Public Functions
|
* Public Functions
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
@@ -81,7 +93,9 @@ extern "C"
|
|||||||
* Name: canned_symtab_initialize
|
* Name: canned_symtab_initialize
|
||||||
*
|
*
|
||||||
* Description:
|
* Description:
|
||||||
* Setup system provided canned symbol table.
|
* Setup system provided canned symbol table. NOTE that this a user-space
|
||||||
|
* interface only. It is not generally available to to kernel mode code
|
||||||
|
* in protected or kernel builds.
|
||||||
*
|
*
|
||||||
* Input Parameters:
|
* Input Parameters:
|
||||||
* None
|
* None
|
||||||
@@ -91,7 +105,36 @@ extern "C"
|
|||||||
*
|
*
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
|
#if defined(CONFIG_BUILD_FLAT) || !defined(__KERNEL__)
|
||||||
void canned_symtab_initialize(void);
|
void canned_symtab_initialize(void);
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: canned_symtab_select
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Setup system provided canned symbol table. This function only exists
|
||||||
|
* the kernel portion of a protected or kernel build. It is called only
|
||||||
|
* by boardctl(). I this case:
|
||||||
|
*
|
||||||
|
* - canned_symbtab_initialize() and g_symtab() lie in the user space.
|
||||||
|
* - boardctl(), canned_symtabl_select(), and exec_setsymtab() reside in
|
||||||
|
* kernel space.
|
||||||
|
*
|
||||||
|
* Access to boardctl() is provided in user space through a call gate.
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* symtab - The symbol table to be used
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* Zero (OK) on success; a negated errno value on failure.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#if (defined(CONFIG_BUILD_PROTECTED) || defined(CONFIG_BUILD_KERNEL)) && \
|
||||||
|
defined(__KERNEL__)
|
||||||
|
int canned_symtab_select(FAR const struct symtab_desc_s *symdesc);
|
||||||
|
#endif
|
||||||
|
|
||||||
#undef EXTERN
|
#undef EXTERN
|
||||||
#if defined(__cplusplus)
|
#if defined(__cplusplus)
|
||||||
|
|||||||
+15
-7
@@ -70,6 +70,13 @@
|
|||||||
* CONFIGURATION: CONFIG_BOARDCTL_RESET
|
* CONFIGURATION: CONFIG_BOARDCTL_RESET
|
||||||
* DEPENDENCIES: Board logic must provide board_reset
|
* DEPENDENCIES: Board logic must provide board_reset
|
||||||
*
|
*
|
||||||
|
* CMD: BOARDIOC_SYMTAB
|
||||||
|
* DESCRIPTION: Select a symbol table
|
||||||
|
* ARG: A pointer to an instance of struct symtab_desc_s
|
||||||
|
* (See include/nuttx/binfmt/canned_symtab.h).
|
||||||
|
* CONFIGURATION: CONFIG_LIBC_SYMTAB
|
||||||
|
* DEPENDENCIES: None
|
||||||
|
*
|
||||||
* CMD: BOARDIOC_TSCTEST_SETUP
|
* CMD: BOARDIOC_TSCTEST_SETUP
|
||||||
* DESCRIPTION: Touchscreen controller test configuration
|
* DESCRIPTION: Touchscreen controller test configuration
|
||||||
* ARG: Touch controller device minor number
|
* ARG: Touch controller device minor number
|
||||||
@@ -111,12 +118,13 @@
|
|||||||
#define BOARDIOC_INIT _BOARDIOC(0x0001)
|
#define BOARDIOC_INIT _BOARDIOC(0x0001)
|
||||||
#define BOARDIOC_POWEROFF _BOARDIOC(0x0002)
|
#define BOARDIOC_POWEROFF _BOARDIOC(0x0002)
|
||||||
#define BOARDIOC_RESET _BOARDIOC(0x0003)
|
#define BOARDIOC_RESET _BOARDIOC(0x0003)
|
||||||
#define BOARDIOC_TSCTEST_SETUP _BOARDIOC(0x0004)
|
#define BOARDIOC_SYMTAB _BOARDIOC(0x0004)
|
||||||
#define BOARDIOC_TSCTEST_TEARDOWN _BOARDIOC(0x0005)
|
#define BOARDIOC_TSCTEST_SETUP _BOARDIOC(0x0005)
|
||||||
#define BOARDIOC_ADCTEST_SETUP _BOARDIOC(0x0006)
|
#define BOARDIOC_TSCTEST_TEARDOWN _BOARDIOC(0x0006)
|
||||||
#define BOARDIOC_PWMTEST_SETUP _BOARDIOC(0x0007)
|
#define BOARDIOC_ADCTEST_SETUP _BOARDIOC(0x0007)
|
||||||
#define BOARDIOC_CAN_INITIALIZE _BOARDIOC(0x0008)
|
#define BOARDIOC_PWMTEST_SETUP _BOARDIOC(0x0008)
|
||||||
#define BOARDIOC_GRAPHICS_SETUP _BOARDIOC(0x0009)
|
#define BOARDIOC_CAN_INITIALIZE _BOARDIOC(0x0009)
|
||||||
|
#define BOARDIOC_GRAPHICS_SETUP _BOARDIOC(0x000a)
|
||||||
|
|
||||||
/* If CONFIG_BOARDCTL_IOCTL=y, then boad-specific commands will be support.
|
/* If CONFIG_BOARDCTL_IOCTL=y, then boad-specific commands will be support.
|
||||||
* In this case, all commands not recognized by boardctl() will be forwarded
|
* In this case, all commands not recognized by boardctl() will be forwarded
|
||||||
@@ -125,7 +133,7 @@
|
|||||||
* User defined board commands may begin with this value:
|
* User defined board commands may begin with this value:
|
||||||
*/
|
*/
|
||||||
|
|
||||||
#define BOARDIOC_USER _BOARDIOC(0x000a)
|
#define BOARDIOC_USER _BOARDIOC(0x000b)
|
||||||
|
|
||||||
/****************************************************************************
|
/****************************************************************************
|
||||||
* Public Type Definitions
|
* Public Type Definitions
|
||||||
|
|||||||
+2
-1
@@ -6,7 +6,8 @@
|
|||||||
config LIBC_SYMTAB
|
config LIBC_SYMTAB
|
||||||
bool "Include canned symtab for applications and shell"
|
bool "Include canned symtab for applications and shell"
|
||||||
default n
|
default n
|
||||||
depends on EXECFUNCS_HAVE_SYMTAB
|
depends on EXECFUNCS_HAVE_SYMTAB && !BUILD_KERNEL
|
||||||
|
select LIB_BOARDCTL if !BUILD_FLAT
|
||||||
---help---
|
---help---
|
||||||
Build and include default symbol table in the NuttX library.
|
Build and include default symbol table in the NuttX library.
|
||||||
The symbol table is selected by call canned_symtab_initialize().
|
The symbol table is selected by call canned_symtab_initialize().
|
||||||
|
|||||||
+30
-5
@@ -1,23 +1,48 @@
|
|||||||
symtab
|
symtab
|
||||||
======
|
======
|
||||||
|
|
||||||
This directory provide support for canned symbol table which provides
|
Symbol Tables and Build Modes
|
||||||
|
-----------------------------
|
||||||
|
This directory provide support for a canned symbol table which provides
|
||||||
all/most of system and libc services/functions to the application and NSH.
|
all/most of system and libc services/functions to the application and NSH.
|
||||||
|
|
||||||
The support is selected by CONFIG_LIBC_SYMTAB option and table has to be
|
Symbol tables have differing usefulness in different NuttX build modes:
|
||||||
prepared in advance manually.
|
|
||||||
|
|
||||||
It can be prepared from NuttX top level directory by next commands
|
1. In the FLAT build (CONFIG_BUILD_FLAT), symbol tables are used to bind
|
||||||
|
addresses in loaded ELF or NxFLAT modules to base code that usually
|
||||||
|
resides in FLASH memory. Both OS interfaces and user/application
|
||||||
|
libraries are made available to the loaded module via symbol tables.
|
||||||
|
|
||||||
|
2. Symbol tables may be of value in a protected build
|
||||||
|
(CONFIG_BUILD_PROTECTED) where the newly started user task must
|
||||||
|
share resources with other user code (but should use system calls to
|
||||||
|
interact with the OS).
|
||||||
|
|
||||||
|
3. But in the kernel build mode (CONFIG_BUILD_KERNEL), only fully linked
|
||||||
|
executables loadable via execl(), execv(), or posix_spawan() can used.
|
||||||
|
There is no use for a symbol table with the kernel build since all
|
||||||
|
memory resources are separate; nothing is share-able with the newly
|
||||||
|
started process.
|
||||||
|
|
||||||
|
Creating the Canned Symbol Table
|
||||||
|
--------------------------------
|
||||||
|
The support is selected by CONFIG_LIBC_SYMTAB option and table has to be
|
||||||
|
prepared in advance manually. It can be prepared from NuttX top level
|
||||||
|
directory by using the following commands:
|
||||||
|
|
||||||
cat syscall/syscall.csv libc/libc.csv | sort >libc/symtab/canned_symtab.csv
|
cat syscall/syscall.csv libc/libc.csv | sort >libc/symtab/canned_symtab.csv
|
||||||
tools/mksymtab libc/symtab/canned_symtab.csv libc/symtab/canned_symtab.inc
|
tools/mksymtab libc/symtab/canned_symtab.csv libc/symtab/canned_symtab.inc
|
||||||
|
|
||||||
Next code selectes canned symtab from application:
|
Your board-level start up code code then needs to select the canned symbol
|
||||||
|
table by calling the OS internal function canned_symtab_initialize() in the
|
||||||
|
board-specfic board_apps_initialize() logic:
|
||||||
|
|
||||||
#include <nuttx/binfmt/canned_symtab.h>
|
#include <nuttx/binfmt/canned_symtab.h>
|
||||||
...
|
...
|
||||||
canned_symtab_initialize();
|
canned_symtab_initialize();
|
||||||
|
|
||||||
|
Code/Text Size Implications
|
||||||
|
---------------------------
|
||||||
The option can have substantial effect on system image size, mainly
|
The option can have substantial effect on system image size, mainly
|
||||||
code/text. That is because the instructions to generate canned_symtab.inc
|
code/text. That is because the instructions to generate canned_symtab.inc
|
||||||
above will cause EVERY interface in the NuttX RTOS and the C library to be
|
above will cause EVERY interface in the NuttX RTOS and the C library to be
|
||||||
|
|||||||
@@ -49,13 +49,87 @@
|
|||||||
|
|
||||||
#include "canned_symtab.inc"
|
#include "canned_symtab.inc"
|
||||||
|
|
||||||
/************************************************************************
|
/****************************************************************************
|
||||||
* Public Functions
|
* Public Functions
|
||||||
************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: canned_symtab_initialize
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Setup system provided canned symbol table. NOTE that this a user-space
|
||||||
|
* interface only. It is not generally available to to kernel mode code
|
||||||
|
* in protected or kernel builds. That is because exec_setsymtab() and
|
||||||
|
* g_symtab lie in different address spaces.
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* None
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#if defined(CONFIG_BUILD_FLAT) || !defined(__KERNEL__)
|
||||||
void canned_symtab_initialize(void)
|
void canned_symtab_initialize(void)
|
||||||
{
|
{
|
||||||
|
#ifdef CONFIG_BUILD_FLAT
|
||||||
|
/* In the FLAT build, exec_symtab() can be called directly from any logic.
|
||||||
|
* Both the symbol table and the function exec_setsymtabe reside in the same
|
||||||
|
* namespace and address space.
|
||||||
|
*/
|
||||||
|
|
||||||
exec_setsymtab(g_symtab, NSYMBOLS);
|
exec_setsymtab(g_symtab, NSYMBOLS);
|
||||||
|
|
||||||
|
#else
|
||||||
|
/* In the user mode portion of a protected or kernel build, we must set
|
||||||
|
* the symbol table indirectly through the boardctl() call gate that will
|
||||||
|
* proxy the call to canned_symtab_select(). In this case
|
||||||
|
*
|
||||||
|
* - canned_symbtab_initialize() and g_symtab() lie in the user space.
|
||||||
|
* - boardctl(), canned_symtabl_select(), and exec_setsymtab() reside in
|
||||||
|
* kernel space.
|
||||||
|
*
|
||||||
|
* Access to boardctl() is provided in user space throug a call gate.
|
||||||
|
*/
|
||||||
|
|
||||||
|
struct symtab_desc_s symdesc;
|
||||||
|
|
||||||
|
symdesc.symtab = g_symtab;
|
||||||
|
symdesc.nsymbols = NSYMBOLS;
|
||||||
|
(void)boardctl(BOARDIOC_SYMTAB, (uinptr_t)&symdesc);
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/****************************************************************************
|
||||||
|
* Name: canned_symtab_select
|
||||||
|
*
|
||||||
|
* Description:
|
||||||
|
* Setup system provided canned symbol table. This function only exists
|
||||||
|
* the kernel portion of a protected or kernel build. It is called only
|
||||||
|
* by boardctl(). I this case:
|
||||||
|
*
|
||||||
|
* - canned_symbtab_initialize() and g_symtab() lie in the user space.
|
||||||
|
* - boardctl(), canned_symtabl_select(), and exec_setsymtab() reside in
|
||||||
|
* kernel space.
|
||||||
|
*
|
||||||
|
* Access to boardctl() is provided in user space through a call gate.
|
||||||
|
*
|
||||||
|
* Input Parameters:
|
||||||
|
* symtab - The symbol table to be used
|
||||||
|
*
|
||||||
|
* Returned Value:
|
||||||
|
* Zero (OK) on success; a negated errno value on failure.
|
||||||
|
*
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#if (defined(CONFIG_BUILD_PROTECTED) || defined(CONFIG_BUILD_KERNEL)) && \
|
||||||
|
defined(__KERNEL__)
|
||||||
|
int canned_symtab_select(FAR const struct symtab_desc_s *symdesc)
|
||||||
|
{
|
||||||
|
exec_setsymtab(symdesc->symtab, symdesc->nsymbols);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif /* CONFIG_LIBC_SYMTAB */
|
#endif /* CONFIG_LIBC_SYMTAB */
|
||||||
|
|||||||
Reference in New Issue
Block a user