Masayuki Ishikawa 8660572a3c tools: Fix nuttx-gdbinit 3 年之前
..
ci 817d81d38f tools/ci: Revert workaround for issue with avr-binutils 3 年之前
cxd56 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
esp32 0e76a16545 tools/esp32/backtrace.gdbscript: don't modify registers 3 年之前
esp32c3 e94bf12929 tools/esp32xx/: Always flash with DIO. 3 年之前
esp32s2 2004acdeb1 boards/esp32s2: Remove anything that has to do with QEMU since it's not 3 年之前
licensing 15932fa9ea Lint Python code with flake8 and isort 3 年之前
lwl 15932fa9ea Lint Python code with flake8 and isort 3 年之前
pic32 7e5b0f81e9 build: Replace -I with INCDIR 4 年之前
rp2040 cf72133d3c rp2040: Continue to build even if PICO_SDK_PATH is not set 3 年之前
zds ee875b2a26 boards: Move HOSTCC/HOSTCFLAGS to tools/Config.mk 4 年之前
.gitignore 981734e577 tools/Makefile.host: Add incdir binary to Makefile.host 4 年之前
Config.mk 9097244cb8 build: Makefile should reference CONFIG_HOST_xxx 3 年之前
Directories.mk 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
FlatLibs.mk 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
KernelLibs.mk 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
LibTargets.mk 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
Makefile.export 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
Makefile.host 95c8c99a3f tools/nxstyle: Verify relative path in the file header 3 年之前
Makefile.unix 7f7416278d build: Deprecate NUTTXNAME variable 3 年之前
Makefile.win 7f7416278d build: Deprecate NUTTXNAME variable 3 年之前
ProtectedLibs.mk 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
README.txt 97676a3c06 Remove fork of python xmodem that is an active project 3 年之前
b16.c 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
bdf-converter.c 7c8c6785ca NuttX: NX Engineering, S.A: update licenses to Apache 3 年之前
cfgdefine.c 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
cfgdefine.h 26e1f1f249 tools: Author Gregory Nutt: update licenses to Apache 3 年之前
cfgparser.c 330eff36d7 sourcefiles: Fix relative path in file header 3 年之前
cfgparser.h 330eff36d7 sourcefiles: Fix relative path in file header 3 年之前
checkpatch.sh 6d3269a69d CI: Fix check patch to handle renames / deletes 4 年之前
checkrelease.sh b021375f2c Update checkrelease script for readme.md inread of .txt 3 年之前
cmpconfig.c 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
cnvwindeps.c 26e1f1f249 tools: Author Gregory Nutt: update licenses to Apache 3 年之前
configure.bat 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
configure.c 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
configure.sh 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
configure_completion.bash b5ee9b673c tools: Add a bash completion script for the configure tool 3 年之前
convert-comments.c 367ec2068b tools/convert-comments:Fix breakage from Sytle fixes 3 年之前
copydir.bat 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
copydir.sh 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
csvparser.c 26e1f1f249 tools: Author Gregory Nutt: update licenses to Apache 3 年之前
csvparser.h 6906853f8e Improve proxy/stub parameter passing for variadic OS interfaces. 4 年之前
define.bat 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
define.sh 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
detab.c 26e1f1f249 tools: Author Gregory Nutt: update licenses to Apache 3 年之前
discover.py 15932fa9ea Lint Python code with flake8 and isort 3 年之前
flash_writer.py 15932fa9ea Lint Python code with flake8 and isort 3 年之前
gencromfs.c 579c70a598 tools: Author David Sidrane: update licenses to Apache 3 年之前
ide_exporter.py 15932fa9ea Lint Python code with flake8 and isort 3 年之前
incdir.bat 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
incdir.c 76acb32e29 Fix typos reported by codespell 3 年之前
incdir.sh 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
indent.sh 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
initialconfig.c 26e1f1f249 tools: Author Gregory Nutt: update licenses to Apache 3 年之前
kconfig.bat 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
kconfig2html.c 26fef3f6a1 NuttX: Fix nxtyle errors 3 年之前
link.bat 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
link.sh 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
lowhex.c 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
macar-rcs.sh 76acb32e29 Fix typos reported by codespell 3 年之前
mkconfig.c 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
mkconfigvars.sh 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
mkctags.sh bb6c70bdcc Fix the comment header style in tools folder 4 年之前
mkdeps.c 76acb32e29 Fix typos reported by codespell 3 年之前
mkexport.sh 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
mkfsdata.pl 3b6befcd16 tools/mkfsdata.pl was still generating the old-style apps/include inclusion paths 8 年之前
mknulldeps.sh 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
mkromfsimg.sh 59eb4fa8d6 fs: delete NFILE_DESCRIPTORS for allocating dynamically 3 年之前
mksymtab.c 26e1f1f249 tools: Author Gregory Nutt: update licenses to Apache 3 年之前
mksyscall.c 72d2fc547e tools/mksyscall: Fix build break of syscall instrumentation wrapper 3 年之前
mkversion.c 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
mkwindeps.sh 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
netusb.sh 511e548613 Ethernet Over USB net helper script and docs 4 年之前
noteinfo.c 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
nuttx-gdbinit 8660572a3c tools: Fix nuttx-gdbinit 3 年之前
nxstyle.c f547883747 tools/nxstyle: Extend check to any URI scheme 3 年之前
parsecallstack.py 15932fa9ea Lint Python code with flake8 and isort 3 年之前
refresh.sh 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
rmcr.c 26e1f1f249 tools: Author Gregory Nutt: update licenses to Apache 3 年之前
sethost.sh a49a3eae51 tools: Remove the special handle for Ubuntu under Windows 10 4 年之前
showsize.sh cde107f96b tools: update licenses to Apache 3 年之前
simbridge.sh ae356001cf Change all files come from Xiaomi/Pinecone to Apache License 2.0 4 年之前
simhostroute.sh e5f5f6657d style/script: remove unnecessary trailing whitespace 3 年之前
testbuild.sh 33d5f923b6 tools/testbuild.sh: Quote the parameter expansion pattern by " 3 年之前
uncrustify.cfg bb6c70bdcc Fix the comment header style in tools folder 4 年之前
unlink.bat 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
unlink.sh 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前
version.sh 383b2b7af2 tools/version.sh: Fix version number to get on master branch 3 年之前
xmlrpc_test.py d2f922dc4d xmlrpc_test.py port to py3 and format 3 年之前
zipme.sh 7ff60d7c5b tools: Author Gregory Nutt: update licenses to Apache 3 年之前

README.txt

tools/README.txt
================

This README file addresses the contents of the NuttX tools/ directory.

The tools/ directory contains miscellaneous scripts and host C programs
that are necessary parts of the NuttX build system. These files
include:

cmpconfig.c
-----------

This C file can be used to build a utility for comparing two NuttX
configuration files.

Config.mk
---------

Config.mk contains common definitions used by many configuration files.
This file (along with /.config) must be included at the top of
each configuration-specific Make.defs file like:

include $(TOPDIR)/.config
include $(TOPDIR)/tools/Config.mk

Subsequent logic within the configuration-specific Make.defs file may then
override these default definitions as necessary.

checkpatch.sh
-------------
checkpatch.sh is a bash script that make use of nxstyle and codespell tools
to format patches and files conform to NuttX coding standard. For example,
it has been used in NuttX github action PR check build.

$ tools/checkpatch.sh -h
USAGE: ./tools/checkpatch.sh [options] [list|-]

Options:
-h
-c spell check with codespell(install with: pip install codespell)
-r range check only (coupled with -p or -g)
-p (default)
-g
-f
- read standard input mainly used by git pre-commit hook as below:
git diff --cached | ./tools/checkpatch.sh -
Where a is any syntax supported by git for specifying git revision, see GITREVISIONS(7)
Where a is a space separated list of patch file names or wildcard. or *.patch

configure.sh
configure.bat
configure.c, cfgparser.c, and cfgparser.h
------------

configure.sh is a bash script that is used to configure NuttX for a given
target board in a environment that supports POSIX paths (Linux, Cygwin,
macOS, or similar). See boards/README.txt or Documentation/NuttXPortingGuide.html
for a description of how to configure NuttX with this script.

configure.c, cfgparser.c, and cfgparser.h can be used to build a work-alike
program as a replacement for configure.sh. This work-alike program would be
used in environments that do not support Bash scripting (such as the Windows
native environment).

configure.bat is a small Windows batch file that can be used as a replacement
for configure.sh in a Windows native environment. configure.bat is actually
just a thin layer that executes configure.exe if it is available. If
configure.exe is not available, then configure.bat will attempt to build it
first.

In order to build configure.exe from configure.c in the Windows native
environment, two assumptions are made:

1) You have installed the MinGW GCC toolchain. This toolchain can be
downloaded from http://www.mingw.org/. It is recommended that you not
install the optional MSYS components as there may be conflicts.
2) That path to the bin/ directory containing mingw-gcc.exe must be
included in the PATH variable.

convert-comments.c
------------------

Convert C++-style comments to C89 C-style comments. Usage:

convert-comments

detab.c
-------

Convert tabs to spaces in a file. Usage:

detab [-4]

Default tab size is 8 spaces; -4 selects 4 space tab size.

discover.py
-----------

Example script for discovering devices in the local network.
It is the counter part to apps/netutils/discover

gencromfs.c
-----------

This is a C program that is used to generate CROMFS file system images.
Usage is simple:

gencromfs

Where:

is the path to the directory will be at the root of the
new CROMFS file system image.
the name of the generated, output C file. This file must
be compiled in order to generate the binary CROMFS file system
image.

initialconfig.c
---------------

This is a C file that can be used to create an initial configuration.
This permits creating a new configuration from scratch, without
relying on any existing board configuration in place. This utility
will create a barebones .config file sufficient only for
instantiating the symbolic links necessary to do a real configuration.

kconfig2html.c
--------------

This is a C file that can be used to build a utility for converting the
NuttX configuration in the Kconfig files to an HTML document. This
auto-generated documentation will, eventually, replace the manually
updated configuration documentation that is falling woefully behind.

$ tools/kconfig2html.exe -h
USAGE: tools/kconfig2html [-d] [-a ] {-o ] []
tools/kconfig2html [-h]

Where:

-a : Select relative path to the apps/ directory. This path is relative
to the . Default: ../apps
-o : Send output to . Default: Output goes to stdout
-d : Enable debug output
-h : Prints this message and exits
is the directory containing the root Kconfig file.
Default : .

NOTE: In order to use this tool, some configuration must be in-place with
all necessary symbolic links. You can establish the configured symbolic
links with:

make context

or more quickly with:

make dirlinks

Libraries.mk, FlatLibs.mk, ProtectedLibs.mk, and KernelLib.mk
-------------------------------------------------------------

Libraries.mk has the build rules for all NuttX libraries.

FlatLibs.mk, ProtectedLibs.mk, and KernelLib.mk: These control the
selection of libraries to be built, depending on the selected build mode.

lowhex.c
--------

Convert hexadecimal representation in a file from upper- to lower-case.
Usage:

lowhex

Makefile.[unix|win]
-----------------

Makefile.unix is the Makefile used when building NuttX in Unix-like
systems. It is selected from the top-level Makefile.

Makefile.win is the Makefile used when building natively under
Windows. It is selected from the top-level Makefile.

mkconfig.c, cfgdefine.c, and cfgdefine.h
----------------------------------------

These are C files that are used to build mkconfig program. The mkconfig
program is used during the initial NuttX build.

When you configure NuttX, you will copy a configuration file called .config
in the top level NuttX directory (See boards/README.txt or
Documentation/NuttXPortingGuide.html). The first time you make NuttX,
the top-level makefile will build the mkconfig executable from mkconfig.c
(using Makefile.host). The top-level Makefile will then execute the
mkconfig program to convert the .config file in the top level directory
into include/nuttx/config.h. config.h is a another version of the
NuttX configuration that can be included by C files.

mkconfigvars.sh
---------------

The HTML documentation expects to have a copy of the auto-generated
configuration variable documentation Documentation/NuttXConfigVariables.html.
The script mkconfigvars.sh is a simple script that can be used to
re-generated that file as needed.

$ tools/mkconfigvars.sh -h
tools/mkconfigvars.sh is a tool for generation of configuration variable documentation

USAGE: tools/mkconfigvars.sh [-d|h] [-v ]

Where:
-v
The NuttX version number expressed as a major, minor and patch number separated
by a period
-d
Enable script debug
-h
show this help message and exit

mkexport.sh and Makefile.export
-------------------------------

These implement part of the top-level Makefile's 'export' target. That
target will bundle up all of the NuttX libraries, header files, and the
startup object into an export-able, binary NuttX distribution. The
Makefile.export is used only by the mkexport.sh script to parse out
options from the top-level Make.defs file.

USAGE: tools/mkexport.sh [-d] [-z] [-u] -t [-x ] -l "lib1 [lib2 [lib3 ...]]"

This script also depends on the environment variable MAKE which is set
in the top-level Makefile before starting mkexport.sh. If MAKE is not
defined, the script will set it to `which make`.

mkfsdata.pl
-----------

This perl script is used to build the "fake" file system and CGI support
as needed for the apps/netutils/webserver. It is currently used only
by the Makefile at apps/examples/uip. That example serves as an example
of how to configure the uIP webserver "fake" file system.

NOTE: This perl script comes from uIP and was (probably) written
by Adam Dunkels. uIP has a license that is compatible with NuttX.

mkversion.c, cfgdefine.c, and cfgdefine.h
-----------------------------------------

This is C file that is used to build mkversion program. The mkversion
program is used during the initial NuttX build.

When you build NuttX there should be a version file called .version in
the top level NuttX directory (See Documentation/NuttXPortingGuide.html).
The first time you make NuttX, the top-level makefile will build the
mkversion executable from mkversion.c (using Makefile.host). The top-
level Makefile will then execute the mkversion program to convert the
.version file in the top level directory into include/nuttx/version.h.
version.h provides version information that can be included by C files.

mksyscall.c, cvsparser.c, and cvsparser.h
-----------------------------------------

This is a C file that is used to build mksyscall program. The mksyscall
program is used during the initial NuttX build by the logic in the top-
level syscall/ directory.

If you build NuttX as a separately compiled, monolithic kernel and separate
applications, then there is a syscall layer that is used to get from the
user application space to the NuttX kernel space. In the user application
"proxies" for each of the kernel functions are provided. The proxies have
the same function signature as the kernel function, but only execute a
system call.

Within the kernel, there are "stubs" for each of the system calls. The
stubs receive the marshalled system call data, and perform the actually
kernel function call (in kernel-mode) on behalf of the proxy function.

Information about the stubs and proxies is maintained in a comma separated
value (CSV) file in the syscall/ directory. The mksyscall program will
accept this CVS file as input and generate all of the required proxy or
stub files as output. See syscall/README.txt for additional information.

mksymtab.c, cvsparser.c, and cvsparser.h
----------------------------------------

This is a C file that is used to build symbol tables from comma separated
value (CSV) files. This tool is not used during the NuttX build, but
can be used as needed to generate files.

USAGE: ./mksymtab [-d] [ []]

Where:

: The path to the input CSV file (required)
: The path to the output symbol table file (required)
: Optional name for the symbol table variable
Default: "g_symtab"
: Optional name for the symbol table variable
Default: "g_nsymbols"
-d : Enable debug output

Example:

cd nuttx/tools
cat ../syscall/syscall.csv ../lib/libc.csv | sort >tmp.csv
./mksymtab.exe tmp.csv tmp.c

mkctags.sh
----------

A script for creating ctags from Ken Pettit. See http://en.wikipedia.org/wiki/Ctags
and http://ctags.sourceforge.net/

nxstyle.c
---------

I am embarrassed that this is here. This program is a complete hack
but, unfortunately, it has become so useful to me that I need to keep
it here.

A little background: I have tinkered with pretty printers for some
time and have not been happy with the results. An alternative that
occurred to me would be just a standard checker that examines a C
file that gives warnings for violations of the coding standard.

This turns out to be more difficult that you might think. A pretty
printer understands C syntax: They break the file up into its C
components then reassembles the output in the format. But parsing the
C loses the original file layout and so it not useful in this case.

This program instead, uses a collection of heuristics (i.e., hacks and
bandaids) to examine the C file for obvious violations of the coding
standard. This program is completely ignorant of C syntax; it simply
performs crude pattern matching to check the file.

Prints formatted messages that are classified as info, warn, error,
fatal. In a parsable format that can be used by editors and IDEs.

Usage: nxstyle [-m ] [-v ] [-r ]
nxstyle -h this help
nxstyle -v where level is
0 - no output
1 - PASS/FAIL
2 - output each line (default)

See also indent.sh and uncrustify.cfg

pic32mx
-------

This directory contains build tools used only for PIC32MX/Z platforms

bdf-convert.c
-------------

This C file is used to build the bdf-converter program. The bdf-converter
program can be used to convert fonts in Bitmap Distribution Format (BDF)
into fonts that can be used in the NX graphics system.

Below are general instructions for creating and installing a new font
in the NX graphic system:

1. Locate a font in BDF format,
2. Use the bdf-converter program to convert the BDF font to the NuttX
font format. This will result in a C header file containing
definitions. That header file should be installed at, for example,
libnx/nxfonts/nxfonts_myfont.h.

Create a new NuttX configuration variable. For example, suppose
you define the following variable: CONFIG_NXFONT_MYFONT. Then
you would need to:

3. Define CONFIG_NXFONT_MYFONT=y in your NuttX configuration file.

A font ID number has to be assigned for each new font. The font ID
is defined in the file include/nuttx/nx/nxfonts.h. Those definitions
have to be extended to support your new font. Look at how the font ID
enabled by CONFIG_NXFONT_SANS23X27 is defined and add an ID for your
new font in a similar fashion:

4. include/nuttx/nx/nxfonts.h. Add your new font as a possible system
default font:

#if defined(CONFIG_NXFONT_SANS23X27)
# define NXFONT_DEFAULT FONTID_SANS23X27
#elif defined(CONFIG_NXFONT_MYFONT)
# define NXFONT_DEFAULT FONTID_MYFONT
#endif

Then define the actual font ID. Make sure that the font ID value
is unique:

enum nx_fontid_e
{
FONTID_DEFAULT = 0 /* The default font */
#ifdef CONFIG_NXFONT_SANS23X27
, FONTID_SANS23X27 = 1 /* The 23x27 sans serif font */
#endif
#ifdef CONFIG_NXFONT_MYFONT
, FONTID_MYFONT = 2 /* My shiny, new font */
#endif
...

Now add the font to the NX build system. There are several files that
you have to modify to do this. Look how the build system uses the
font CONFIG_NXFONT_SANS23X27 for examples:

5. nuttx/graphics/Makefile. This file needs logic to auto-generate
a C source file from the header file that you generated with the
the bdf-converter program. Notice NXFONTS_FONTID=2; this must be
set to the same font ID value that you defined in the
include/nuttx/nx/nxfonts.h file.

genfontsources:
ifeq ($(CONFIG_NXFONT_SANS23X27),y)
@$(MAKE) -C nxfonts -f Makefile.sources NXFONTS_FONTID=1 EXTRAFLAGS=$(EXTRAFLAGS)
endif
ifeq ($(CONFIG_NXFONT_MYFONT),y)
@$(MAKE) -C nxfonts -f Makefile.sources NXFONTS_FONTID=2 EXTRAFLAGS=$(EXTRAFLAGS)
endif

6. nuttx/libnx/nxfonts/Make.defs. Set the make variable NXFSET_CSRCS.
NXFSET_CSRCS determines the name of the font C file to build when
NXFONTS_FONTID=2:

ifeq ($(CONFIG_NXFONT_SANS23X27),y)
NXFSET_CSRCS += nxfonts_bitmaps_sans23x27.c
endif
ifeq ($(CONFIG_NXFONT_MYFONT),y)
NXFSET_CSRCS += nxfonts_bitmaps_myfont.c
endif

7. nuttx/libnx/nxfonts/Makefile.sources. This is the Makefile used
in step 5 that will actually generate the font C file. So, given
your NXFONTS_FONTID=2, it needs to determine a prefix to use for
auto-generated variable and function names and (again) the name of
the auto-generated file to create (this must be the same name that
was used in nuttx/libnx/nxfonts/Make.defs):

ifeq ($(NXFONTS_FONTID),1)
NXFONTS_PREFIX := g_sans23x27_
GEN_CSRC = nxfonts_bitmaps_sans23x27.c
endif
ifeq ($(NXFONTS_FONTID),2)
NXFONTS_PREFIX := g_myfont_
GEN_CSRC = nxfonts_bitmaps_myfont.c
endif

8. graphics/libnx/nxfonts_bitmaps.c. This is the file that contains
the generic font structures. It is used as a "template" file by
nuttx/libnx/nxfonts/Makefile.sources to create your customized
font data set.

#if NXFONTS_FONTID == 1
# include "nxfonts_sans23x27.h"
#elif NXFONTS_FONTID == 2
# include "nxfonts_myfont.h"
#else
# error "No font ID specified"
#endif

Where nxfonts_myfont.h is the NuttX font file that we generated in
step 2 using the bdf-converter tool.

9. libnx/nxfonts/nxfonts_getfont.c. Finally, we need to extend the
logic that does the run-time font lookups so that can find our new
font. The lookup function is NXHANDLE nxf_getfonthandle(enum nx_fontid_e fontid).
The new font information needs to be added to data structures used by
that function:

#ifdef CONFIG_NXFONT_SANS23X27
extern const struct nx_fontpackage_s g_sans23x27_package;
#endif
#ifdef CONFIG_NXFONT_MYFONT
extern const struct nx_fontpackage_s g_myfont_package;
#endif

static FAR const struct nx_fontpackage_s *g_fontpackages[] =
{
#ifdef CONFIG_NXFONT_SANS23X27
&g_sans23x27_package,
#endif
#ifdef CONFIG_NXFONT_MYFONT
&g_myfont_package,
#endif
NULL
};

define.sh and define.bat
------------------------

Different compilers have different conventions for specifying pre-
processor definitions on the compiler command line. This bash
script allows the build system to create command line definitions
without concern for the particular compiler in use.

The define.bat script is a counterpart for use in the native Windows
build.

flash_writer.py
---------------

This flash writer is using the xmodem for firmware transfer on
boards based on cxd56 chip (Ex. Spresense). This tool depends on
the xmodem package (https://pypi.org/project/xmodem/).

for flashing the .spk image to the board please use:
tools/flash_writer.py -s -c /dev/ttyUSB0 -d -b 115200 -n nuttx.spk

ide_exporter.py
---------------

This Python script will help to create NuttX project in the IAR and
uVision IDEs. These are few simple the steps to export the IDE
workspaces.

1) Start the NuttX build from the Cygwin command line before trying to
create your project by running:

make V=1 |& tee build_log

This is necessary to certain auto-generated files and directories that
will be needed. This will provide the build log to construct the IDE
project also.

2) Export the IDE project base on that make log. The script usage:

usage: ide_exporter.py [-h] [-v] [-o OUT_DIR] [-d] build_log {iar,uvision_armcc,uvision_gcc} template_dir

positional arguments:
build_log Log file from make V=1
{iar,uvision_armcc,uvision_gcc}
The target IDE: iar, uvision_gcc, (uvision_armcc is experimental)
template_dir Directory that contains IDEs template projects

optional arguments:
-h, --help show this help message and exit
-v, --version show program's version number and exit
-o OUT_DIR, --output OUT_DIR
Output directory
-d, --dump Dump project structure tree

Example:
cd nuttx
make V=1 |& tee build_log

./tools/ide_exporter.py makelog_f2nsh_c iar ./boards////ide/template/iar -o ./boards////ide/nsh/iar

or

./tools/ide_exporter.py makelog_f2nsh_c uvision_gcc ./boards////ide/template/uvision_gcc/ -o ./boards////ide/nsh/uvision

3) Limitations:
- IAR supports C only. Iar C++ does not compatible with g++ so disable
C++ if you want to use IAR.
- uvision_armcc : nuttx asm (inline and .asm) can't be compiled with
armcc so do not use this option.
- uvision_gcc : uvision project that uses gcc. Need to specify path to
gnu toolchain.
In uVison menu, select:

Project/Manage/Project Items.../FolderExtension/Use GCC compiler/ PreFix, Folder

4) Template projects' constrains:
- mcu, core, link script shall be configured in template project
- Templates' name are fixed:
- template_nuttx.eww : IAR nuttx workspace template
- template_nuttx_lib.ewp : IAR nuttx library project template
- template_nuttx_main.ewp : IAR nuttx main project template
- template_nuttx.uvmpw : uVision workspace
- template_nuttx_lib.uvproj : uVision library project
- template_nuttx_main.uvproj : uVision main project
- iar:
- Library option shall be set to 'None' so that IAR could use nuttx
libc
- __ASSEMBLY__ symbol shall be defined in assembler
- uVision_gcc:
- There should be one fake .S file in projects that has been defined
__ASSEMBLY__ in assembler.
- In Option/CC tab : disable warning
- In Option/CC tab : select Compile thump code (or Misc control =
-mthumb)
- template_nuttx_lib.uvproj shall add 'Post build action' to copy .a
file to .\lib
- template_nuttx_main.uvproj Linker:
- Select 'Do not use Standard System Startup Files' and 'Do not
use Standard System Libraries'
- Do not select 'Use Math libraries'
- Misc control = --entry=__start

5) How to create template for other configurations:
1) uVision with gcc toolchain:
- Copy 3 uVision project files
- Select the MCU for main and lib project
- Correct the path to ld script if needed
2) iar:
- Check if the arch supports IAR (only armv7-m is support IAR
now)
- Select the MCU for main and lib project
- Add new ld script file for IAR

NOTE: Due to bit rot, the template files for the stm3220g-eval and for
the stm32f429-disco have been removed from the NuttX repository. For
reference, they can be found in the Obsoleted repository at
Obsoleted/stm32f429i_disco/ltcd/template and at
Obsoleted/stm3220g-eval/template.

incdir.sh, incdir.bat, and incdir.c
-----------------------------------

Different compilers have different conventions for specifying lists
of include file paths on the compiler command line. This incdir.sh
bash script allows the build system to create include file paths without
concern for the particular compiler in use.

The incdir.bat script is a counterpart for use in the native Windows
build. However, there is currently only one compiler supported in
that context: MinGW-GCC.

incdir.c is a higher performance version of incdir.sh, converted to C.

indent.sh
---------

This script can be used to indent .c and .h files in a manner similar
to the NuttX coding style. It doesn't do a really good job, however
(see below and the comments at the top of the indent.sh file).

USAGE:
tools/indent.sh [-d] [-p] -o
tools/indent.sh [-d] [-p]
tools/indent.sh [-d] -h

Where:
-
A single, unformatted input file
-
A list of unformatted input files that will be reformatted in place.
-o
Write the single, reformatted to .
will not be modified.
-d
Enable script debug
-p
Comments are pre-formatted. Do not reformat.
-h
Show this help message and exit

The conversions make by the indent.sh script differs from the NuttX coding
style in that:

1. The coding standard requires that the trailing */ of a multi-line
comment be on a separate line. By default, indent.sh will put the
final */ on the same line as the last comment text. If your C file
already has properly formatted comments then using the -p option will
eliminate that bad behavior
2. If your source file has highly formatted comments containing things
such as tables or lists, then use the -p option to preserve those
pre-formatted comments.
3. I usually align things vertically (like '=' in assignments),
4. indent.sh puts a bogus blank line at the top of the file,
5. I don't like the way it handles nested conditional compilation
intermixed with code. I prefer the preprocessor conditional tests
be all right justified in that case.
6. I also indent brackets differently on structures than does this script.
7. I normally use no spaces in casts. indent.sh adds spaces in casts like
"(FAR void *)&foo" becomes "(FAR void *) & foo".
8. When used with header files, the initial idempotence conditional test
causes all preprocessor directives to be indented in the file. So for
header files, you will need to substitute "^# " with "#" in the
converted header file.

You will manually need to check for the issues listed above after
performing the conversions. nxstyle.c provides a good test that will
catch most of the indent.sh screw-ups. Together, they do a pretty good
job of formatting.

See also nxstyle.c and uncrustify.cfg

kconfig.bat
-----------

Recent versions of NuttX support building NuttX from a native Windows
CMD.exe shell. But kconfig-frontends is a Linux tool and is not yet
available in the pure CMD.exe environment. At this point, there are
only a few options for the Windows user (see the top-level README.txt
file).

You can, with some effort, run the Cygwin kconfig-mconf tool directly
in the CMD.exe shell. In this case, you do not have to modify the
.config file, but there are other complexities: You need to
temporarily set the Cygwin directories in the PATH variable and
then run kconfig-mconf outside of the Make system.

kconfig.bat is a Windows batch file at tools/kconfig.bat that automates
these steps. It is used from the top-level NuttX directory like:

tools/kconfig menuconfig

NOTE: There is currently an issue with accessing DOS environment
variables from the Cygwin kconfig-mconf running in the CMD.exe shell.
The following change to the top-level Kconfig file seems to work around
these problems:

config APPSDIR
string
- option env="APPSDIR"
+ default "../apps"

link.sh, link.bat, copydir.sh, copydir.bat, unlink.sh, and unlink.bat
---------------------------------------------------------------------

Different file systems have different capabilities for symbolic links.
Some Windows file systems have no native support for symbolic links.
Cygwin running under Windows has special links built in that work with
all cygwin tools. However, they do not work when Windows native tools
are used with cygwin. In that case something different must be done.

If you are building under Linux or under cygwin with a cygwin tool
chain, then your Make.defs file may have definitions like the
following:

DIRLINK = $(TOPDIR)/tools/link.sh
DIRUNLINK = (TOPDIR)/tools/unlink.sh

The first definition is not always present because link.sh is the
default. link.sh is a bash script that performs a normal, Linux-style
symbolic link; unlink.sh is a do-it-all unlinking script.

But if you are building under cygwin using a Windows native toolchain
within a POSIX framework (such as Cygwin), then you will need something
like the following in you Make.defs file:

DIRLINK = $(TOPDIR)/tools/copydir.sh
DIRUNLINK = (TOPDIR)/tools/unlink.sh

copydir.sh will copy the whole directory instead of linking it.

Finally, if you are running in a pure native Windows environment with
a CMD.exe shell, then you will need something like this:

DIRLINK = $(TOPDIR)/tools/copydir.bat
DIRUNLINK = (TOPDIR)/tools/unlink.bat

Note that this will copy directories. link.bat might also be used in
this case. link.bat will attempt to create a symbolic link using the
NTFS mklink.exe command instead of copying files. That logic, however,
has not been verified as of this writing.

Makefile.host
-------------

This is the makefile that is used to make the mkconfig program from
the mkconfig.c C file, the cmpconfig program from cmpconfig.c C file,
the mkversion program from the mkconfig.c C file, or the mksyscall
program from the mksyscall.c file. Usage:

cd tools/
make -f Makefile.host

mkromfsimg.sh
-------------

This script may be used to automate the generation of a ROMFS file system
image. It accepts an rcS script "template" and generates an image that
may be mounted under /etc in the NuttX pseudo file system.

TIP: Edit the resulting header file and mark the generated data values
as 'const' so that they will be stored in FLASH.

mkdeps.c, cnvwindeps.c, mkwindeps.sh, and mknulldeps.sh
-------------------------------------------------------

NuttX uses the GCC compiler's capabilities to create Makefile dependencies.
The program mkdeps is used to run GCC in order to create the dependencies.
If a NuttX configuration uses the GCC toolchain, its Make.defs file (see
boards/README.txt) will include a line like:

MKDEP = $(TOPDIR)/tools/mkdeps[.exe] (See NOTE below)

If the NuttX configuration does not use a GCC compatible toolchain, then
it cannot use the dependencies and instead it uses mknulldeps.sh:

MKDEP = $(TOPDIR)/tools/mknulldeps.sh

The mknulldeps.sh is a stub script that does essentially nothing.

mkwindeps.sh is a version that creates dependencies using the Windows
native toolchain. That generates Windows native paths in the dependency
file. But the mkwindeps.sh uses cnvwindeps.c to convert the Windows
paths to POSIX paths. This adds some time to the Windows dependency
generation but is generally the best option available for that mixed
environment of Cygwin with a native Windows GCC toolchain.

mkdeps.c generates mkdeps (on Linux) or mkdeps.exe (on Windows).
However, this version is still under-development. It works well in
the all POSIX environment or in the all Windows environment but also
does not work well in mixed POSIX environment with a Windows toolchain.
In that case, there are still issues with the conversion of things like
'c:\Program Files' to 'c:program files' by bash. Those issues may,
eventually be solvable but for now continue to use mkwindeps.sh in
that mixed environment.


netusb.sh
---------

Helper script used to set up the CDC ECM Ethernet Over USB driver,
host routes, and IP Tables rules to support networking with a NuttX
system that has a CDC ECM Ethernet Over USB driver configured. Only
supported on Linux.

General usage:

$ ./tools/netusb.sh
Usage: tools/netusb.sh

This has been tested on the SAMA5D3-Xplained board; see
`boards/arm/sama5/sama5d3-xplained/README.txt` for more information on how
to configure the CDC ECM driver for that board.


README.txt
----------

This file!

refresh.sh
----------

[NOTE: This script with --silent is really obsolete. refresh with the
silent option really adds default values. However, as of 217-07-09,
defconfig files are retained in a compressed format, i.e., with default
values removed. So the --silent option will accomplish nothing.
Without --silent, you will have the opportunity over override the default
value from the command line and, in that case, the script may still have
some minimal value.]

This is a bash script that automatics refreshing of board default
configuration (defconfig) files. It does not do anything special
that you cannot do manually, but is useful for me when I have to
update dozens of configuration files.

Configuration files have to be updated because over time, the
configuration settings change: New configurations are added and
new dependencies are added. So an old configuration file may
not be usable anymore until it is refreshed.

Help is also available:

$ tools/refresh.sh --help
tools/refresh.sh is a tool for refreshing board configurations

USAGE: ./refresh.sh [options] /+

Where [options] include:
--debug
Enable script debug
--silent
Update board configuration without interaction
--defaults
Do not prompt for new default selections; accept all recommended default values
--help
Show this help message and exit

The board directory under nuttx/boards

The board configuration directory under nuttx/boards///

The steps to refresh the file taken by refresh.sh are:

1. Make tools/cmpconfig if it is not already built.
2. Copy the defconfig file to the top-level NuttX
directory as .config (being careful to save any previous
.config file that you might want to keep!).
3. Execute 'make oldconfig' to update the configuration.
'make oldconfig' will prompt you for each change in the
configuration that requires that you make some decision.
With the --silent option, the script will use 'make
oldefconfig' instead and you won't have to answer any
questions; the refresh will simply accept the default
value for any new configuration settings.
4. Then it runs tools/cmpconfig to show the real differences
between the configuration files. Configuration files are
complex and things can move around so a simple 'diff' between
two configuration files is often not useful. But tools/cmpconfig
will show only the meaningful differences between the two
configuration files.
4. It will edit the .config file to comment out the setting
of the CONFIG_APPS_DIR= setting. This setting should not
be in checked-in defconfig files because the actually must
be determined at the next time that the configuration is
installed.
5. Finally, the refreshed defconfig file is copied back in
place where it can be committed with the next set of
difference to the command line. If you select the --silent
option, this file copy will occur automatically. Otherwise,
refresh.sh will prompt you first to avoid overwriting the
defconfig file with changes that you may not want.

rmcr.c
------

Removes all white space from the end of lines. Whitespace here
includes space characters, TAB characters, horizontal and vertical
TABs, and carriage returns. Lines will be terminated with the
newline character only.

sethost.sh
----------

Saved configurations may run on Linux, Cygwin (32- or 64-bit), or other
platforms. The platform characteristics can be changed use 'make
menuconfig'. Sometimes this can be confusing due to the differences
between the platforms. Enter sethost.sh

sethost.sh is a simple script that changes a configuration to your
host platform. This can greatly simplify life if you use many different
configurations. For example, if you are running on Linux and you
configure like this:

$ tools/configure.sh board:configuration

The you can use the following command to both (1) make sure that the
configuration is up to date, AND (2) the configuration is set up
correctly for Linux:

$ tools/sethost.sh -l

Or, if you are on a Windows/Cygwin 64-bit platform:

$ tools/sethost.sh -c

Other options are available:

$ ./sethost.sh -h

USAGE: ./sethost.sh [-l|m|c|g|n] [make-opts]
./sethost.sh -h

Where:
-l|m|c|g|n selects Linux (l), macOS (m), Cygwin (c),
MSYS/MSYS2 (g) or Windows native (n). Default Linux
make-opts directly pass to make
-h will show this help test and terminate

simhostroute.sh
---------------

Helper script used to set up the tap driver, host routes,
and IP Tables rules to support networking with the
simulator under Linux. General usage:

$ tools/simhostroute.sh
Usage: tools/simhostroute.sh

See boards/sim/sim/sim/NETWORK-LINUX.txt for further information

simbridge.sh
------------

Helper script used to set up a bridge to support networking with the
simulator under Linux. General usage:

$ tools/simbridge.sh
Usage: tools/simbridge.sh

See boards/sim/sim/sim/NETWORK-LINUX.txt for further information

showsize.sh
-----------

Show the top 10 biggest memory hogs in code and data spaces. This
must be executed from the top-level NuttX directory like:

$ tools/showsize.sh
TOP 10 BIG DATA
...
TOP 10 BIG CODE
...

testbuild.sh
------------

This script automates building of a set of configurations. The intent is
simply to assure that the set of configurations build correctly. The -h
option shows the usage:

$ ./testbuild.sh -h

USAGE: ./testbuild.sh [-l|m|c|g|n] [-d] [-x] [-j ] [-a ] [-t ] [-p] [-G]
./testbuild.sh -h

Where:
-l|m|c|g|n selects Linux (l), macOS (m), Cygwin (c),
MSYS/MSYS2 (g) or Windows native (n). Default Linux
-d enables script debug output
-x exit on build failures
-j passed on to make. Default: No -j make option.
-a provides the relative path to the apps/ directory. Default ../apps
-t provides the absolute path to top nuttx/ directory.
Default $WD/../nuttx, where $WD is the parent directory of
the directory where this script is.
-p only print the list of configs without running any builds
-C Skip tree cleanness check.
-G Use "git clean -xfdq" instead of "make distclean" to clean the tree.
This option may speed up the builds. However, note that:
* This assumes that your trees are git based.
* This assumes that only nuttx and apps repos need to be cleaned.
* If the tree has files not managed by git, they will be removed
as well.
-h will show this help test and terminate
selects the list of configurations to test. No default

Your PATH variable must include the path to both the build tools and the
kconfig-frontends tools

These script needs two pieces of information.

a. A description of the platform that you are testing on. This description
is provided by the optional -l, -m, -c, -g and -n options.
b. A list of configurations to build. That list is provided by a test
list file. The final, non-optional parameter, ,
provides the path to that file.

The test list file is a sequence of build descriptions, one per line. One
build descriptions consists of two comma separated values. For example:

stm32f429i-disco:nsh,CONFIG_ARMV7M_TOOLCHAIN_GNU_EABIL
arduino-due:nsh,CONFIG_ARMV7M_TOOLCHAIN_GNU_EABIL
/arm,CONFIG_ARMV7M_TOOLCHAIN_GNU_EABIL
/risc-v,CONFIG_RV32IM_TOOLCHAIN_GNU_RVGL

The first value is the usual configuration description of the form
: or / and must correspond to a
configuration or folder in the nuttx/boards directory.

The second value is valid name for a toolchain configuration to use
when building the configuration. The set of valid toolchain
configuration names depends on the underlying architecture of the
configured board.

The prefix '-' can be used to skip a configuration:
-stm32f429i-disco/nsh

or skip a configuration on a specific host(e.g. Darwin):
-Darwin,sim:rpserver

uncrustify.cfg
--------------

This is a configuration script for the uncrustify code beautifier.
Uncrustify does well with forcing braces into "if" statements and
indenting per the NuttX C coding standard. It correctly does things
like placing all braces on separate lines at the proper indentation
level. It cannot handle certain requirements of the coding standard
such as

- FAR attributes in pointer declarations.
- The NuttX standard function header block comments.
- Naming violations such as use of CamelCase variable names,
lower case pre-processor definitions, etc.

Comment blocks, function headers, files headers, etc. must be formatted
manually.

Its handling of block comments is fragile. If the comment is perfect,
it leaves it alone, but if the block comment is deemed to need a fix
it starts erroneously indenting the continuation lines of the comment.

- uncrustify.cfg messed up the indent of most block comments.
cmt_sp_before_star_cont is applied inconsistently. I added

cmt_indent_multi = false # disable all multi-line comment changes

to the .cfg file to limit its damage to block comments.
- It is very strict at wrapping lines at column 78. Even when column 79
just contained the '/' of a closing "*/". That created many
bad continuation lines.
- It moved '{' that opened a struct to the line defining the struct.
nl_struct_brace = add (or force) seemed to be ignored.
- It also aligned variable names in declarations and '=' signs in
assignment statements in a seemingly arbitrary manner. Making changes
that were not necessary.

NOTE: uncrustify.cfg should *ONLY* be used with new files that have an
inconsistent coding style. uncrustify.cfg should get you in the ballpark,
but you should expect to review and hand-edit the files to assume 100%
compliance.

WARNING: *NEVER* use uncrustify.cfg for modifications to existing NuttX
files. It will probably corrupt the style in subtle ways!

This was last verified against uncrustify 0.66.1 by Bob Feretich.

About uncrustify: Uncrustify is a highly configurable, easily modifiable
source code beautifier. To learn more about uncrustify:

http://uncrustify.sourceforge.net/

Source code is available on GitHub:

https://github.com/uncrustify/uncrustify

Binary packages are available for Linux via command line installers.
Binaries for both Windows and Linux are available at:

https://sourceforge.net/projects/uncrustify/files/

See also indent.sh and nxstyle.c

zds
---

This directory contains build tools used only with the ZDS-II
platforms (z8, ez80, zNeo).

zipme.sh
--------

I use this script to create the nuttx-xx.yy.tar.gz tarballs for
release. It is handy because it also does the kind of clean up
that you need to do to make a clean code release.
It can also PGP sign the final tarballs and create their SHA512 hash.
Any VCS files or directories are excluded from the final tarballs.

$ ./tools/zipme.sh -h
USAGE="USAGE: ./tools/zipme.sh [-d|h|v|s] [-b [-e ] [-k ] []"
Examples:
./tools/zipme.sh -s 9.0.0
Create version 9.0.0 tarballs and sign them.
./tools/zipme.sh -s -k XXXXXX 9.0.0
Same as above but use the key-id XXXXXX to sign the tarballs
./tools/zipme.sh -e "*.swp tmp" 9.0.0
Create the tarballs but exclude any .swp file and the "tmp" directory.