module Loadable Module
This example builds a small loadable module test case. This includes a character
driver under examples/module/drivers. This driver is built using the
relocatable ELF format and installed in a ROMFS file system. At run time, the
driver module is loaded and exercised. Requires CONFIG_MODULE. Other
configuration options:
- CONFIG_EXAMPLES_ELF_DEVMINOR– The minor device number of the ROMFS block driver. For example, the- Nin- /dev/ramN. Used for registering the RAM block driver that will hold the ROMFS file system containing the ELF executables to be tested. Default:- 0.
- CONFIG_EXAMPLES_ELF_DEVPATH– The path to the ROMFS block driver device. This must match- EXAMPLES_ELF_DEVMINOR. Used for registering the RAM block driver that will hold the ROMFS file system containing the ELF executables to be tested. Default:- /dev/ram0.
Notes:
- CFLAGSshould be provided in- CMODULEFLAGS. RAM and FLASH memory regions may require long allcs. For ARM, this might be:- CMODULEFLAGS = $(CFLAGS) -mlong-calls - Similarly for C++ flags which must be provided in - CXXMODULEFLAGS.
- Your top-level - nuttx/Make.defsfile must also include an appropriate definition, LDMODULEFLAGS, to generate a relocatable ELF object. With GNU LD, this should include- -rand- -e <entry point>.:- LDMODULEFLAGS = -r -e module_initialize - If you use GCC to link, you make also need to include - -nostdlib.
- This example also requires - genromfs.- genromfscan be build as part of the nuttx toolchain. Or can built from the- genromfssources that can be found in the NuttX tools repository (- genromfs-0.5.2.tar.gz). In any event, the PATH variable must include the path to the- genromfsexecutable.
- ELF size: The ELF files in this example are, be default, quite large because they include a lot of build garbage. You can greatly reduce the size of the ELF binaries are using the - objcopy --strip-unneededcommand to remove un-necessary information from the ELF files.
- Simulator. You cannot use this example with the NuttX simulator on Cygwin. That is because the Cygwin GCC does not generate ELF file but rather some Windows-native binary format. - If you really want to do this, you can create a NuttX x86 - buildroottoolchain and use that be build the ELF executables for the ROMFS file system.
- Linker scripts. You might also want to use a linker scripts to combine sections better. An example linker script is at - nuttx/libc/modlib/gnu-elf.ld. That example might have to be tuned for your particular linker output to position additional sections correctly. The GNU LD- LDMODULEFLAGSthen might be:- LDMODULEFLAGS = -r -e module_initialize -T$(TOPDIR)/libc/modlib/gnu-elf.ld