Squashed commit of the following:

Merged in masayuki2009/nuttx.apps/loadable_app (pull request #148)

    loadable app support

    * apps: Introduce a build system for loadable apps for nsh.

        This PR consits of following changes. (NOTE: Changes to each
        application will be provided separately)

        apps/nshlib/Kconfig:
        Add 'option modules' to NSH_FILE_APPS so that a user can change
        an application configuration to tristate (y/n/m)

        apps/Make.defs:
        Override COMPILE and COMPILEXX macros to compile loadable apps.
        To make loadable apps, -DLOADABLE_APP is added to the flags.
        Also, introduce ELFLD to link a lodable app.
        Please note that the variable 'LOADABLE' must be defined in
        each application Makefile if you want to make a loadable app.

        apps/Application.mk:
        Add .build target in case of 'LOADABLE=y' which is used to
        link a final loadable application and install the app to
        apps/bin.

        apps/Makefile:
        Add SYMTABSRC and SYMTABOBJ variables for loadable apps which
        will be generated under the apps directory.
        Add make_symbols target which will be called when all applications
        are installed to generate symtab_app.c which is used for
        nsh to inform symbol information to the NuttX kernel.

        Signed-off-by: Masayuki Ishikawa <Masayuki.Ishikawa@jp.sony.com>

    * apps/examples/hello: Apply changes to support a lodable app.

        Kconfig:
        Change the application state from bool to tristate

        Make.defs:
        Change the condition to build. By default, the application is
        not selected (i.e. 'n'), so if other states (i.e. y/m) are
        selected, the application will be compiled.

        Makefile:
        If the application is specified to 'm', the variable 'LOADABLE'
        must be defined here. Also note that other variables (PRIORITY
        and STACKSIZE) can only be used for built-in apps.

        hello_main.c
        Add LOADABLE_APP condition to main().

        Signed-off-by: Masayuki Ishikawa <Masayuki.Ishikawa@jp.sony.com>

    * apps/examples/helloxx: Apply changes to support a lodable app.

        Kconfig:
        Change the application state from bool to tristate

        Make.defs:
        Change the condition to build. By default, the application is
        not selected (i.e. 'n'), so if other states (i.e. y/m) are
        selected, the application will be compiled.

        Makefile:
        If the application is specified to 'm', the variable 'LOADABLE'
        must be defined here. Also note that other variables (PRIORITY
        and STACKSIZE) can only be used for built-in apps.

        helloxx_main.c
        Add LOADABLE_APP condition to main().

        Signed-off-by: Masayuki Ishikawa <Masayuki.Ishikawa@jp.sony.com>

    Approved-by: GregoryN <gnutt@nuttx.org>
This commit is contained in:
Gregory Nutt 2018-08-03 12:05:01 -06:00
parent 3e81973cd5
commit 922283ee5d
12 changed files with 68 additions and 8 deletions

View File

@ -89,9 +89,16 @@ $(MAINOBJ): %$(OBJEXT): %.c
$(call COMPILE, $<, $@) $(call COMPILE, $<, $@)
endif endif
ifeq ($(LOADABLE),y)
.built: $(OBJS)
$(call ELFLD, $(APPNAME)_main, $(OBJS), $(APPNAME))
$(Q) mkdir -p $(BIN_DIR)
$(Q) install $(APPNAME) $(BIN_DIR)$(DELIM)$(APPNAME)
else
.built: $(OBJS) .built: $(OBJS)
$(call ARCHIVE, $(BIN), $(OBJS)) $(call ARCHIVE, $(BIN), $(OBJS))
$(Q) touch $@ $(Q) touch $@
endif
ifeq ($(CONFIG_BUILD_KERNEL),y) ifeq ($(CONFIG_BUILD_KERNEL),y)
$(BIN_DIR)$(DELIM)$(PROGNAME): $(OBJS) $(MAINOBJ) $(BIN_DIR)$(DELIM)$(PROGNAME): $(OBJS) $(MAINOBJ)

View File

@ -56,6 +56,33 @@ define REGISTER
endef endef
endif endif
# COMPILE - a macro to compile a loadable app in C
ifeq ($(LOADABLE),y)
define COMPILE
@echo "CC) $1"
$(Q) $(CC) -c $(CELFFLAGS) -DLOADABLE_APP $1 -o $2
endef
endif
# COMPILEXX - a macro to compile a loadable app in C++
ifeq ($(LOADABLE),y)
define COMPILEXX
@echo "CXX: $1"
$(Q) $(CXX) -c $(CXXELFFLAGS) -DLOADABLE_APP $1 -o $2
endef
endif
# ELFLD - a macro to link loadable app
# Example: $(call ELFLD, entry point, in-file(s), out-file)
define ELFLD
@echo "LD: $3"
$(Q) $(LD) $(LDELFFLAGS) $2 -o $3
$(Q) chmod +x $3
endef
# Tools # Tools
# #
# In a normal build, tools will reside in the nuttx/tools sub-directory and # In a normal build, tools will reside in the nuttx/tools sub-directory and

View File

@ -73,6 +73,11 @@ BIN_DIR = $(APPDIR)$(DELIM)bin
BIN = libapps$(LIBEXT) BIN = libapps$(LIBEXT)
# Symbol table for loadable apps.
SYMTABSRC = $(APPDIR)$(DELIM)symtab_apps.c
SYMTABOBJ = $(APPDIR)$(DELIM)symtab_apps.o
# Build targets # Build targets
all: $(BIN) all: $(BIN)
@ -97,7 +102,15 @@ $(foreach SDIR, $(CONFIGURED_APPS), $(eval $(call SDIR_template,$(SDIR),depend))
$(foreach SDIR, $(CLEANDIRS), $(eval $(call SDIR_template,$(SDIR),clean))) $(foreach SDIR, $(CLEANDIRS), $(eval $(call SDIR_template,$(SDIR),clean)))
$(foreach SDIR, $(CLEANDIRS), $(eval $(call SDIR_template,$(SDIR),distclean))) $(foreach SDIR, $(CLEANDIRS), $(eval $(call SDIR_template,$(SDIR),distclean)))
$(BIN): $(foreach SDIR, $(CONFIGURED_APPS), $(SDIR)_all) make_symbols:
ifeq ($(CONFIG_EXAMPLES_NSH_SYMTAB),y)
mkdir -p $(BIN_DIR)
$(Q) $(APPDIR)$(DELIM)tools$(DELIM)mksymtab.sh $(BIN_DIR) $(SYMTABSRC)
$(call COMPILE, $(SYMTABSRC), $(SYMTABOBJ))
$(call ARCHIVE, $(APPDIR)$(DELIM)$(BIN), $(SYMTABOBJ))
endif
$(BIN): $(foreach SDIR, $(CONFIGURED_APPS), $(SDIR)_all) make_symbols
.install: $(foreach SDIR, $(CONFIGURED_APPS), $(SDIR)_install) .install: $(foreach SDIR, $(CONFIGURED_APPS), $(SDIR)_install)
@ -143,6 +156,7 @@ clean_context:
$(Q) $(MAKE) -C platform clean_context TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)" $(Q) $(MAKE) -C platform clean_context TOPDIR="$(TOPDIR)" APPDIR="$(APPDIR)"
clean: $(foreach SDIR, $(CLEANDIRS), $(SDIR)_clean) clean: $(foreach SDIR, $(CLEANDIRS), $(SDIR)_clean)
$(call DELFILE, $(SYMTABSRC))
$(call DELFILE, $(BIN)) $(call DELFILE, $(BIN))
$(call DELFILE, Kconfig) $(call DELFILE, Kconfig)
$(call DELDIR, $(BIN_DIR)) $(call DELDIR, $(BIN_DIR))
@ -164,6 +178,7 @@ else
) )
endif endif
$(call DELFILE, .depend) $(call DELFILE, .depend)
$(call DELFILE, $(SYMTABSRC))
$(call DELFILE, $(BIN)) $(call DELFILE, $(BIN))
$(call DELFILE, Kconfig) $(call DELFILE, Kconfig)
$(call DELDIR, $(BIN_DIR)) $(call DELDIR, $(BIN_DIR))

View File

@ -4,7 +4,7 @@
# #
config EXAMPLES_HELLO config EXAMPLES_HELLO
bool "\"Hello, World!\" example" tristate "\"Hello, World!\" example"
default n default n
---help--- ---help---
Enable the \"Hello, World!\" example Enable the \"Hello, World!\" example

View File

@ -34,6 +34,6 @@
# #
############################################################################ ############################################################################
ifeq ($(CONFIG_EXAMPLES_HELLO),y) ifneq ($(CONFIG_EXAMPLES_HELLO),)
CONFIGURED_APPS += examples/hello CONFIGURED_APPS += examples/hello
endif endif

View File

@ -41,8 +41,13 @@ CONFIG_EXAMPLES_HELLO_PRIORITY ?= SCHED_PRIORITY_DEFAULT
CONFIG_EXAMPLES_HELLO_STACKSIZE ?= 2048 CONFIG_EXAMPLES_HELLO_STACKSIZE ?= 2048
APPNAME = hello APPNAME = hello
ifeq ($(CONFIG_EXAMPLES_HELLO),m)
LOADABLE = y
else
PRIORITY = $(CONFIG_EXAMPLES_HELLO_PRIORITY) PRIORITY = $(CONFIG_EXAMPLES_HELLO_PRIORITY)
STACKSIZE = $(CONFIG_EXAMPLES_HELLO_STACKSIZE) STACKSIZE = $(CONFIG_EXAMPLES_HELLO_STACKSIZE)
endif
# Hello, World! Example # Hello, World! Example

View File

@ -48,7 +48,7 @@
* hello_main * hello_main
****************************************************************************/ ****************************************************************************/
#ifdef CONFIG_BUILD_KERNEL #if defined (CONFIG_BUILD_KERNEL) || defined (LOADABLE_APP)
int main(int argc, FAR char *argv[]) int main(int argc, FAR char *argv[])
#else #else
int hello_main(int argc, char *argv[]) int hello_main(int argc, char *argv[])

View File

@ -4,7 +4,7 @@
# #
config EXAMPLES_HELLOXX config EXAMPLES_HELLOXX
bool "\"Hello, World!\" C++ example" tristate "\"Hello, World!\" C++ example"
default n default n
depends on HAVE_CXX depends on HAVE_CXX
---help--- ---help---

View File

@ -34,6 +34,6 @@
# #
############################################################################ ############################################################################
ifeq ($(CONFIG_EXAMPLES_HELLOXX),y) ifneq ($(CONFIG_EXAMPLES_HELLOXX),)
CONFIGURED_APPS += examples/helloxx CONFIGURED_APPS += examples/helloxx
endif endif

View File

@ -48,7 +48,12 @@ PROGNAME = $(CONFIG_EXAMPLES_HELLOXX_PROGNAME)
# helloxx built-in application info # helloxx built-in application info
APPNAME = helloxx APPNAME = helloxx
ifeq ($(CONFIG_EXAMPLES_HELLOXX),m)
LOADABLE = y
else
PRIORITY = SCHED_PRIORITY_DEFAULT PRIORITY = SCHED_PRIORITY_DEFAULT
STACKSIZE = 2048 STACKSIZE = 2048
endif
include $(APPDIR)/Application.mk include $(APPDIR)/Application.mk

View File

@ -127,7 +127,7 @@ static CHelloWorld g_HelloWorld;
extern "C" extern "C"
{ {
#ifdef CONFIG_BUILD_KERNEL #if defined (CONFIG_BUILD_KERNEL) || defined (LOADABLE_APP)
int main(int argc, FAR char *argv[]) int main(int argc, FAR char *argv[])
#else #else
int helloxx_main(int argc, char *argv[]) int helloxx_main(int argc, char *argv[])

View File

@ -182,6 +182,7 @@ config NSH_BUILTIN_APPS
config NSH_FILE_APPS config NSH_FILE_APPS
bool "Enable execution of program files" bool "Enable execution of program files"
option modules
default n default n
depends on LIBC_EXECFUNCS depends on LIBC_EXECFUNCS
---help--- ---help---