e47a801fd1
git-svn-id: svn://svn.code.sf.net/p/nuttx/code/trunk@5479 42af7a65-404d-4744-a932-0658087f49c3
6487 lines
254 KiB
HTML
6487 lines
254 KiB
HTML
<html>
|
|
<head>
|
|
<title>NuttX Porting Guide</title>
|
|
<meta name="author" content="Gregory Nutt">
|
|
</head>
|
|
|
|
<body background="backgd.gif">
|
|
<hr><hr>
|
|
<table width ="100%">
|
|
<tr align="center" bgcolor="#e4e4e4">
|
|
<td>
|
|
<h1><big><font color="#3c34ec">
|
|
<i>NuttX RTOS Porting Guide</i>
|
|
</font></big></h1>
|
|
<p>Last Updated: January 4, 2012</p>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
<hr><hr>
|
|
|
|
<table width ="100%">
|
|
<tr bgcolor="#e4e4e4">
|
|
<td>
|
|
<h1>Table of Contents</h1>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
|
|
<ul>
|
|
<a href="#Introduction">1.0 Introduction</a><br>
|
|
<a href="#DirectoryStructure">2.0 Directory Structure</a>
|
|
<ul>
|
|
<a href="#DirStructDocumentation">2.1 Documentation</a></br>
|
|
<a href="#DirStructArch">2.2 arch/</a>
|
|
<ul>
|
|
<a href="#archdirectorystructure">2.2.1 Subdirectory Structure</a><br>
|
|
<a href="#summaryofarchfiles">2.2.2 Summary of Files</a><br>
|
|
<a href="#supportedarchitectures">2.2.3 Supported Architectures</a>
|
|
</ul>
|
|
<a href="#DirStructBinFmt">2.3 binfmt/</a><br>
|
|
<a href="#DirStructConfigs">2.4 configs/</a>
|
|
<ul>
|
|
<a href="#configsdirectorystructure">2.4.1 Subdirectory Structure</a><br>
|
|
<a href="#summaryofconfigfiles">2.4.2 Summary of Files</a>
|
|
<ul>
|
|
<a href="#boardlogic">2.4.2.1 Board Specific Logic</a><br>
|
|
<a href="#boardconfigsubdirs">2.4.2.2 Board Specific Configuration Sub-Directories</a>
|
|
</ul>
|
|
<a href="#supportedboards">2.4.3 Supported Boards</a>
|
|
</ul>
|
|
<a href="#DirStructDrivers">2.5 nuttx/drivers/</a><br>
|
|
<a href="#DirStructFs">2.6 nuttx/fs/</a><br>
|
|
<a href="#DirStructGraphics">2.7 nuttx/graphics/</a><br>
|
|
<a href="#DirStructInclude">2.8 nuttx/include/</a><br>
|
|
<a href="#DirStructLib">2.9 nuttx/libc/</a><br>
|
|
<a href="#DirStructLibXX">2.10 nuttx/libxx/</a><br>
|
|
<a href="#DirStructMm">2.11 nuttx/mm/</a><br>
|
|
<a href="#DirStructNet">2.12 nuttx/net</a><br>
|
|
<a href="#DirStructSched">2.13 nuttx/sched/</a><br>
|
|
<a href="#DirStructSyscall">2.14 nuttx/syscall/</a><br>
|
|
<a href="#DirStructTools">2.15 nuttx/tools/</a><br>
|
|
<a href="#topmakefile">2.16 nuttx/Makefile</a><br>
|
|
<a href="#DirStructNetUtils">2.17 apps/netutils</a><br>
|
|
<a href="#DirStructNshLib">2.18 apps/nshlib</a><br>
|
|
<a href="#DirStructExamples">2.19 apps/examples/</a>
|
|
</ul>
|
|
<a href="#configandbuild">3.0 Configuring and Building</a>
|
|
<ul>
|
|
<a href="#configuringnuttx">3.1 Configuring NuttX</a><br>
|
|
<a href="#buildingnuttx">3.2 Building NuttX</a>
|
|
</ul>
|
|
<a href="#ArchAPIs">4.0 Architecture APIs</a>
|
|
<ul>
|
|
<a href="#imports">4.1 APIs Exported by Architecture-Specific Logic to NuttX</a>
|
|
<ul>
|
|
<a href="#upinitialize">4.1.1 <code>up_initialize()</code></a><br>
|
|
<a href="#upidle">4.1.2 <code>up_idle()</code></a><br>
|
|
<a href="#upinitialstate">4.1.3 <code>up_initial_state()</code></a><br>
|
|
<a href="#upcreatestack">4.1.4 <code>up_create_stack()</code></a><br>
|
|
<a href="#upusestack">4.1.5 <code>up_use_stack()</code></a><br>
|
|
<a href="#upreleasestack">4.1.6 <code>up_release_stack()</code></a><br>
|
|
<a href="#upunblocktask">4.1.7 <code>up_unblock_task()</code></a><br>
|
|
<a href="#upblocktask">4.1.8 <code>up_block_task()</code></a><br>
|
|
<a href="#upreleasepending">4.1.9 <code>up_release_pending()</code></a><br>
|
|
<a href="#upreprioritizertr">4.1.10 <code>up_reprioritize_rtr()</code></a><br>
|
|
<a href="#_exit">4.1.11 <code>_exit()</code></a><br>
|
|
<a href="#upassert">4.1.12 <code>up_assert()</code></a><br>
|
|
<a href="#upschedulesigaction">4.1.13 <code>up_schedule_sigaction()</code></a><br>
|
|
<a href="#upallocateheap">4.1.14 <code>up_allocate_heap()</code></a><br>
|
|
<a href="#upinterruptcontext">4.1.15 <code>up_interrupt_context()</code></a><br>
|
|
<a href="#updisableirq">4.1.16 <code>up_disable_irq()</code></a><br>
|
|
<a href="#upenableirq">4.1.17 <code>up_enable_irq()</code></a><br>
|
|
<a href="#upprioritizeirq">4.1.18 <code>up_prioritize_irq()</code></a></br>
|
|
<a href="#upputc">4.1.19 <code>up_putc()</code></a></br>
|
|
<a href="#systemtime">4.1.20 System Time and Clock</a><br>
|
|
<a href="#addrenv">4.1.21 Address Environments</a>
|
|
</ul>
|
|
<a href="#exports">4.2 APIs Exported by NuttX to Architecture-Specific Logic</a>
|
|
<ul>
|
|
<a href="#osstart">4.2.1 <code>os_start()</code></a><br>
|
|
<a href="#listmgmt">4.2.2 OS List Management APIs</a><br>
|
|
<a href="#schedprocesstimer">4.2.3 <code>sched_process_timer()</code></a><br>
|
|
<a href="#irqdispatch">4.2.4 <code>irq_dispatch()</code></a>
|
|
</ul>
|
|
<a href="#demandpaging">4.3 On-Demand Paging</a><br>
|
|
<a href="#ledsupport">4.4 LED Support</a>
|
|
<ul>
|
|
<a href="#ledheaders">4.3.1 Header Files</a><br>
|
|
<a href="#leddefinitions">4.3.2 LED Definitions</a><br>
|
|
<a href="#ledapis">4.3.3 Common LED interfaces</a>
|
|
</ul>
|
|
</ul>
|
|
<a href="#NxFileSystem">5.0 NuttX File System</a><br>
|
|
<a href="#DeviceDrivers">6.0 NuttX Device Drivers</a>
|
|
<ul>
|
|
<a href="#chardrivers">6.1 Character Device Drivers</a><br>
|
|
<a href="#blockdrivers">6.2 Block Device Drivers</a><br>
|
|
<a href="#blockdrivers">6.3 Specialized Device Drivers</a>
|
|
<ul>
|
|
<a href="#ethdrivers">6.3.1 Ethernet Device Drivers</a><br>
|
|
<a href="#spidrivers">6.3.2 SPI Device Drivers</a><br>
|
|
<a href="#i2cdrivers">6.3.3 I2C Device Drivers</a><br>
|
|
<a href="#serialdrivers">6.3.4 Serial Device Drivers</a><br>
|
|
<a href="#fbdrivers">6.3.5 Frame Buffer Drivers</a><br>
|
|
<a href="#lcddrivers">6.3.6 LCD Drivers</a><br>
|
|
<a href="#mtddrivers">6.3.7 Memory Technology Device Drivers</a><br>
|
|
<a href="#sdiodrivers">6.3.8 SDIO Device Drivers</a><br>
|
|
<a href="#usbhostdrivers">6.3.9 USB Host-Side Drivers</a><br>
|
|
<a href="#usbdevdrivers">6.3.10 USB Device-Side Drivers</a><br>
|
|
<a href="#analogdrivers">6.3.11 Analog (ADC/DAC) Drivers</a><br>
|
|
<a href="#pwmdrivers">6.3.12 PWM Drivers</a><br>
|
|
<a href="#candrivers">6.3.13 CAN Drivers</a><br>
|
|
<a href="#quadencoder">6.3.14 Quadrature Encoder Drivers</a><br>
|
|
<a href="#wdogdriver">6.3.15 Watchdog Timer Drivers</a><br>
|
|
<a href="#kbddriver">6.3.16 Keyboard/Keypad Drivers</a><br>
|
|
</ul>
|
|
<a href="#pwrmgmt">6.4 Power Management</a>
|
|
<ul>
|
|
<a href="#pmoverview">6.4.1 Overview</a><br>
|
|
<a href="#pminterfaces">6.4.2 Interfaces</a><br>
|
|
<a href="#pmcallbacks">6.4.3 Callbacks</a>
|
|
</ul>
|
|
</ul>
|
|
<a href="#apndxconfigs">Appendix A: NuttX Configuration Settings</a><br>
|
|
<a href="#apndxtrademarks">Appendix B: Trademarks</a>
|
|
</ul>
|
|
|
|
<table width ="100%">
|
|
<tr bgcolor="#e4e4e4">
|
|
<td>
|
|
<h1>1.0 <a name="Introduction">Introduction</a></h1>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
|
|
<p><b>Overview</b>
|
|
This document provides and overview of the NuttX build and configuration
|
|
logic and provides hints for the incorporation of new processor/board architectures
|
|
into the build.
|
|
</p>
|
|
<p>
|
|
See also <code>arch/README.txt</code> and <code>configs/README.txt</code>.
|
|
</p>
|
|
|
|
<table width ="100%">
|
|
<tr bgcolor="#e4e4e4">
|
|
<td>
|
|
<h1>2.0 <a name="DirectoryStructure">Directory Structure</a></h1>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
|
|
<p>
|
|
<b>Directory Structure</b>.
|
|
The general directly layout for NuttX is very similar to the directory structure
|
|
of the Linux kernel -- at least at the most superficial layers.
|
|
At the top level is the main makefile and a series of sub-directories identified
|
|
below and discussed in the following paragraphs:
|
|
</p>
|
|
<ul><pre>
|
|
.
|
|
|- nuttx
|
|
| |-- <a href="#topmakefile">Makefile</a>
|
|
| |-- <a href="#DirStructDocumentation">Documentation</a>
|
|
| | `-- <i>(documentation files)</i>/
|
|
| |-- <a href="#DirStructArch">arch</a>/
|
|
| | |-- <i><arch-name></i>/
|
|
| | | |-- include/
|
|
| | | | |--<i><chip-name></i>/
|
|
| | | | | `-- <i>(chip-specific header files)</i>
|
|
| | | | |--<i><other-chips></i>/
|
|
| | | | `-- <i>(architecture-specific header files)</i>
|
|
| | | `-- src/
|
|
| | | |--<i><chip-name></i>/
|
|
| | | | `-- <i>(chip-specific source files)</i>
|
|
| | | |--<i><other-chips></i>/
|
|
| | | `-- <i>(architecture-specific source files)</i>
|
|
| | `-- <i><other-architecture directories></i>/
|
|
| |-- <a href="#DirStructBinFmt">binfmt</a>/
|
|
| | |-- Makefile
|
|
| | |-- <i>(binfmt-specific sub-directories)</i>/
|
|
| | | `-- <i>(binfmt-specific source files)</i>
|
|
| | `-- <i>(common binfmt source files)</i>
|
|
| |-- <a href="#DirStructConfigs">configs</a>/
|
|
| | |-- <i><board-name></i>/
|
|
| | | |-- include/
|
|
| | | | `-- <i>(other board-specific header files)</i>
|
|
| | | |-- src/
|
|
| | | | `-- <i>(board-specific source files)</i>
|
|
| | | |---<i><config-name></i>/
|
|
| | | | `-- <i>(board configuration-specific source files)</i>
|
|
| | | `---<i>(other configuration sub-directories for this board)</i>/
|
|
| | `-- <i><(other board directories)></i>/
|
|
| |-- <a href="#DirStructDrivers">drivers</a>/
|
|
| | |-- Makefile
|
|
| | |-- <i>(driver-specific sub-directories)/</i>
|
|
| | | `-- <i>(driver-specific source files)</i>
|
|
| | `-- <i>(common driver source files)</i>
|
|
| |-- <a href="#DirStructFs">fs</a>/
|
|
| | |-- Makefile
|
|
| | |-- <i>(file system-specific sub-directories)</i>/
|
|
| | | `-- <i>(file system-specific source files)</i>
|
|
| | `-- <i>(common file system source files)</i>
|
|
| |-- <a href="#DirStructGraphics">graphics</a>/
|
|
| | |-- Makefile
|
|
| | |-- <i>(feature-specific sub-directories)</i>/
|
|
| | | `-- <i>(feature-specific source files library source files)</i>
|
|
| | `-- <i>(common graphics-related source files)</i>
|
|
| |-- <a href="#DirStructInclude">include</a>/
|
|
| | |-- <i>(standard header files)</i>
|
|
| | |-- <i>(standard include sub-directories)</i>
|
|
| | | `-- <i>(more standard header files)</i>
|
|
| | |-- <i>(non-standard include sub-directories)</i>
|
|
| | `-- <i>(non-standard header files)</i>
|
|
| |-- <a href="#DirStructLib">libc</a>/
|
|
| | |-- Makefile
|
|
| | `-- <i>(libc source files)</i>
|
|
| |-- <a href="#DirStructLibXX">libxx</a>/
|
|
| | |-- Makefile
|
|
| | `-- <i>(libxx management source files)</i>
|
|
| |-- <a href="#DirStructMm">mm</a>/
|
|
| | |-- Makefile
|
|
| | `-- <i>(memory management source files)</i>
|
|
| |-- <a href="#DirStructNet">net</a>/
|
|
| | |-- Makefile
|
|
| | |-- uip/
|
|
| | | `-- <i>(uip source files)</i>
|
|
| | `-- <i>(BSD socket source files)</i>
|
|
| |-- <a href="#DirStructSched">sched</a>/
|
|
| | |-- Makefile
|
|
| | `-- <i>(sched source files)</i>
|
|
| |-- <a href="#DirStructSysCall">syscall</a>/
|
|
| | |-- Makefile
|
|
| | `-- <i>(syscall source files)</i>
|
|
| `-- <a href="#DirStructTools">tools</a>/
|
|
| `-- <i>(miscellaneous scripts and programs)</i>
|
|
`- apps
|
|
|-- <a href="#DirStructNetUtils">netutils</a>/
|
|
| |-- Makefile
|
|
| |-- <i>(network feature sub-directories)</i>/
|
|
| | `-- <i>(network feature source files)</i>
|
|
| `-- <i>(netutils common files)</i>
|
|
|-- <a href="#DirStructNshLib">nshlib</a>/
|
|
| |-- Makefile
|
|
| `-- <i>NuttShell (NSH) files</i>
|
|
|-- <i>(Board-specific applications)</i>/
|
|
| |-- Makefile
|
|
| |-- <i>(Board-specific application sub-directories)</i>/
|
|
| | `-- <i>(Board-specific application source files)</i>
|
|
| `-- <i>(Board-specific common files)</i>
|
|
`-- <a href="#DirStructExamples">examples</a>/
|
|
`-- <i>(example)</i>/
|
|
|-- Makefile
|
|
`-- <i>(example source files)</i>
|
|
</pre></ul>
|
|
|
|
<p>
|
|
<b>Configuration Files</b>.
|
|
The NuttX configuration consists of:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<i>Processor architecture specific files</i>.
|
|
These are the files contained in the <code>arch/</code><i><arch-name></i><code>/</code> directory
|
|
and are discussed in a paragraph <a href="#archdirectorystructure">below</a>.
|
|
</li>
|
|
<li>
|
|
<i>Chip/SoC specific files</i>.
|
|
Each processor processor architecture is embedded in chip or <i>System-on-a-Chip</i> (SoC) architecture.
|
|
The full chip architecture includes the processor architecture plus chip-specific interrupt logic,
|
|
clocking logic, general purpose I/O (GIO) logic, and specialized, internal peripherals (such as UARTs, USB, etc.).
|
|
<p>
|
|
These chip-specific files are contained within chip-specific sub-directories in the
|
|
<code>arch/</code><i><arch-name></i><code>/</code> directory and are selected via
|
|
the <code>CONFIG_ARCH_name</code> selection.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<i>Board specific configurations</i>.
|
|
In order to be usable, the chip must be contained in a board environment.
|
|
The board configuration defines additional properties of the board including such things as
|
|
peripheral LEDs, external peripherals (such as network, USB, etc.).
|
|
<p>
|
|
These board-specific configuration files can be found in the
|
|
<code>configs/</code><i><board-name></i><code>/</code> sub-directories and are discussed
|
|
in a paragraph <a href="#configsdirectorystructure">below</a>.
|
|
</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<h2>2.1 <a name="DirStructDocumentation">Documentation</a></h2>
|
|
|
|
<p>
|
|
General documentation for the NuttX OS resides in this directory.
|
|
</p>
|
|
|
|
<h2>2.2 <a name="DirStructArch">nuttx/arch</a></h2>
|
|
|
|
<h3><a name="archdirectorystructure">2.2.1 Subdirectory Structure</a></h3>
|
|
<p>
|
|
This directory contains several sub-directories, each containing
|
|
architecture-specific logic.
|
|
The task of porting NuttX to a new processor consists of
|
|
add a new subdirectory under <code>arch/</code> containing logic specific
|
|
to the new architecture.
|
|
The complete board port in is defined by the architecture-specific code in this
|
|
directory (plus the board-specific configurations in the <code>config/</code>
|
|
subdirectory).
|
|
Each architecture must provide a subdirectory, <i><arch-name></i>
|
|
under <code>arch/</code> with the following characteristics:
|
|
</p>
|
|
<ul><pre>
|
|
<i><arch-name></i>/
|
|
|-- include/
|
|
| |--<i><chip-name></i>/
|
|
| | `-- <i>(chip-specific header files)</i>
|
|
| |--<i><other-chips></i>/
|
|
| |-- arch.h
|
|
| |-- irq.h
|
|
| |-- types.h
|
|
| |-- limits.h
|
|
| `-- syscall.h
|
|
`-- src/
|
|
|--<i><chip-name></i>/
|
|
| `-- <i>(chip-specific source files)</i>
|
|
|--<i><other-chips></i>/
|
|
|-- Makefile
|
|
`-- <i>(architecture-specific source files)</i>
|
|
</pre></ul>
|
|
|
|
<h3><a name="summaryofarchfiles">2.2.2 Summary of Files</a></h3>
|
|
<ul>
|
|
<li>
|
|
<code>include/</code><i><chip-name></i><code>/</code>
|
|
This sub-directory contains chip-specific header files.
|
|
</li>
|
|
<li>
|
|
<code>include/arch.h</code>:
|
|
This is a hook for any architecture specific definitions that may
|
|
be needed by the system. It is included by <code>include/nuttx/arch.h</code>.
|
|
</li>
|
|
<li>
|
|
<code>include/types.h</code>:
|
|
This provides architecture/toolchain-specific definitions for
|
|
standard types. This file should <code>typedef</code>:
|
|
<ul><code>
|
|
_int8_t, _uint8_t, _int16_t, _uint16_t, _int32_t, _uint32_t_t
|
|
</code></ul>
|
|
<p>and if the architecture supports 24- or 64-bit integers</p>
|
|
<ul><code>
|
|
_int24_t, _uint24_t, int64_t, uint64_t
|
|
</code></ul>
|
|
<p>
|
|
NOTE that these type names have a leading underscore character. This
|
|
file will be included(indirectly) by include/stdint.h and typedef'ed to
|
|
the final name without the underscore character. This roundabout way of
|
|
doings things allows the stdint.h to be removed from the include/
|
|
directory in the event that the user prefers to use the definitions
|
|
provided by their toolchain header files
|
|
</p>
|
|
<p>
|
|
And finally
|
|
</p>
|
|
<ul><code>
|
|
irqstate_t
|
|
</code></ul>
|
|
<p>
|
|
Must be defined to the be the size required to hold the interrupt
|
|
enable/disable state.
|
|
</p>
|
|
<p>
|
|
This file will be included by include/sys/types.h and be made
|
|
available to all files.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<code>include/irq.h</code>:
|
|
This file needs to define some architecture specific functions (usually
|
|
inline if the compiler supports inlining) and some structures. These include:
|
|
<ul>
|
|
<li>
|
|
<code>struct xcptcontext</code>:
|
|
This structures represents the saved context of a thread.
|
|
</li>
|
|
<li>
|
|
<code>irqstate_t irqsave(void)</code>:
|
|
Used to disable all interrupts.
|
|
</li>
|
|
<li>
|
|
<code>void irqrestore(irqstate_t flags)</code>:
|
|
Used to restore interrupt enables to the same state as before <code>irqsave()</code> was called.
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
This file must also define <code>NR_IRQS</code>, the total number of IRQs supported
|
|
by the board.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<code>include/syscall.h</code>:
|
|
This file needs to define some architecture specific functions (usually
|
|
inline if the compiler supports inlining) to support software interrupts
|
|
or <i>syscall</i>s that can be used all from user-mode applications into
|
|
kernel-mode NuttX functions.
|
|
This directory must always be provided to prevent compilation errors.
|
|
However, it need only contain valid function declarations if the architecture
|
|
supports the <code>CONFIG_NUTTX_KERNEL</code> configuration.
|
|
<ul>
|
|
<li>
|
|
<code>uintptr_t sys_call0(unsigned int nbr)</code>:
|
|
<code>nbr</code> is one of the system call numbers that can be found in <code>include/sys/syscall.h</code>.
|
|
This function will perform a system call with no (additional) parameters.
|
|
</li>
|
|
<li>
|
|
<code>uintptr_t sys_call1(unsigned int nbr, uintptr_t parm1)</code>:
|
|
<code>nbr</code> is one of the system call numbers that can be found in <code>include/sys/syscall.h</code>.
|
|
This function will perform a system call with one (additional) parameter.
|
|
</li>
|
|
<li>
|
|
<code>uintptr_t sys_call2(unsigned int nbr, uintptr_t parm1, uintptr_t parm2)</code>:
|
|
<code>nbr</code> is one of the system call numbers that can be found in <code>include/sys/syscall.h</code>.
|
|
This function will perform a system call with two (additional) parameters.
|
|
</li>
|
|
<li>
|
|
<code>uintptr_t sys_call3(unsigned int nbr, uintptr_t parm1, uintptr_t parm2, uintptr_t parm3)</code>:
|
|
<code>nbr</code> is one of the system call numbers that can be found in <code>include/sys/syscall.h</code>.
|
|
This function will perform a system call with three (additional) parameters.
|
|
</li>
|
|
<li>
|
|
<code>uintptr_t sys_call4(unsigned int nbr, uintptr_t parm1, uintptr_t parm2, uintptr_t parm3, uintptr_t parm4)</code>:
|
|
<code>nbr</code> is one of the system call numbers that can be found in <code>include/sys/syscall.h</code>.
|
|
This function will perform a system call with four (additional) parameters.
|
|
</li>
|
|
<li>
|
|
<code>uintptr_t sys_call5(unsigned int nbr, uintptr_t parm1, uintptr_t parm2, uintptr_t parm3, uintptr_t parm4, uintptr_t parm5)</code>:
|
|
<code>nbr</code> is one of the system call numbers that can be found in <code>include/sys/syscall.h</code>.
|
|
This function will perform a system call with five (additional) parameters.
|
|
</li>
|
|
<li>
|
|
<code>uintptr_t sys_call6(unsigned int nbr, uintptr_t parm1, uintptr_t parm2, uintptr_t parm3, uintptr_t parm4, uintptr_t parm5, uintptr_t parm6)</code>:
|
|
<code>nbr</code> is one of the system call numbers that can be found in <code>include/sys/syscall.h</code>.
|
|
This function will perform a system call with six (additional) parameters.
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
This file must also define <code>NR_IRQS</code>, the total number of IRQs supported
|
|
by the board.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<code>src/</code><i><chip-name></i><code>/</code>
|
|
This sub-directory contains chip-specific source files.
|
|
</li>
|
|
<li>
|
|
<code>src/Makefile</code>:
|
|
This makefile will be executed to build the targets <code>src/libup.a</code> and
|
|
<code>src/up_head.o</code>. The <code>up_head.o</code> file holds the entry point into the system
|
|
(power-on reset entry point, for example). It will be used in
|
|
the final link with <code>libup.a</code> and other system archives to generate the
|
|
final executable.
|
|
</li>
|
|
<li>
|
|
<i>(architecture-specific source files)</i>.
|
|
The file <code>include/nuttx/arch.h</code> identifies all of the APIs that must
|
|
be provided by the architecture specific logic. (It also includes
|
|
<code>arch/</code><i><arch-name></i><code>/arch.h</code> as described above).
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="supportedarchitectures">2.2.3 Supported Architectures</a></h3>
|
|
<p>
|
|
<b>Architecture- and Chip-Specific Directories</b>.
|
|
All processor architecture-specific directories are maintained in sub-directories of
|
|
the <code>arch/</code> directory.
|
|
Different chips or SoC's may implement the same processor core.
|
|
Chip-specific logic can be found in sub-directories under the architecture
|
|
directory.
|
|
Current architecture/chip directories are summarized below:
|
|
</p>
|
|
<ul>
|
|
<li><code>arch/sim</code>:
|
|
A user-mode port of NuttX to the x86 Linux platform is available.
|
|
The purpose of this port is primarily to support OS feature development.
|
|
This port does not support interrupts or a real timer (and hence no
|
|
round robin scheduler) Otherwise, it is complete.
|
|
</li>
|
|
<p>NOTE: This target will not run on Cygwin probably for many reasons but
|
|
first off because it uses some of the same symbols as does cygwind.dll.
|
|
</p>
|
|
|
|
<li><code>arch/arm</code>:
|
|
This directory holds common ARM architectures. At present, this includes
|
|
the following subdirectories:
|
|
<ul>
|
|
<li><code>arch/arm/include</code> and <code>arch/arm/src/common</code>:
|
|
Common ARM logic.
|
|
</li>
|
|
|
|
<li><code>arch/arm/include/c5471</code> and <code>arch/arm/src/c5471</code>:
|
|
TI TMS320C5471 (also called TMS320DM180 or just C5471).
|
|
NuttX operates on the ARM7 of this dual core processor.
|
|
This port is complete, verified, and included in the NuttX release 0.1.1.
|
|
</li>
|
|
|
|
<li><code>arch/arm/include/dm320</code> and <code>arch/arm/src/dm320</code>:
|
|
TI TMS320DM320 (also called just DM320).
|
|
NuttX operates on the ARM9EJS of this dual core processor.
|
|
This port complete, verified, and included in the NuttX release 0.2.1.
|
|
</li>
|
|
|
|
<li><code>arch/arm/include/lpc214x</code> and <code>arch/arm/src/lpc214x</code>:
|
|
These directories provide support for NXP LPC214x family of
|
|
processors.
|
|
STATUS: This port boots and passes the OS test (apps/examples/ostest).
|
|
The port is complete and verified. As of NuttX 0.3.17, the port includes:
|
|
timer interrupts, serial console, USB driver, and SPI-based MMC/SD card
|
|
support. A verified NuttShell configuration is also available.
|
|
</li>
|
|
|
|
</ul>
|
|
</li>
|
|
|
|
<li><code>configs/mcu123-lpc214x</code>:
|
|
The mcu123.com lpc214x development board.
|
|
This is a work in progress.
|
|
</li>
|
|
|
|
<li><code>arch/m68322</code>
|
|
A work in progress.
|
|
</li>
|
|
|
|
<li><code>arch/8051</code>:
|
|
8051 Microcontroller. This port is not quite ready for prime time.
|
|
</li>
|
|
|
|
<li><code>arch/z16f</code>:
|
|
Zilog z16f Microcontroller.
|
|
This port uses the Zilog z16f2800100zcog Development Kit.
|
|
This port was released with nuttx-0.3.7.
|
|
</li>
|
|
|
|
<li><code>arch/z80</code>:
|
|
This directory holds 8-bit ZiLOG architectures. At present, this includes the
|
|
Zilog z80, ez80Acclaim! and z8Encore! Microcontrollers.
|
|
<ul>
|
|
<li><code>arch/z80/include</code> and <code>arch/z80/src/common</code>:
|
|
Common logic.
|
|
</li>
|
|
|
|
<li><code>arch/z80/include/z80</code> and <code>arch/z80/src/z80</code>:
|
|
The Z80 port was released in nuttx-0.3.6 has been verified using only a
|
|
z80 instruction simulator.
|
|
The set simulator can be found in the NuttX SVN at
|
|
http://svn.code.sf.net/p/nuttx/code/trunk/misc/sims/z80sim.
|
|
This port also uses the SDCC toolchain (http://sdcc.sourceforge.net/")
|
|
(verified with version 2.6.0 and 2.7.0).
|
|
</li>
|
|
|
|
<li><code>arch/z80/include/ez80</code> and <code>arch/z80/src/ez80</code>:
|
|
The ez80Acclaim! port uses the ZiLOG ez80f0910200kitg development kit, eZ80F091 part,
|
|
with the Zilog ZDS-II Windows command line tools.
|
|
The development environment is Cygwin under WinXP.
|
|
This is a work in progress. Verified ez80 support will be announced in a future NuttX release.
|
|
</li>
|
|
|
|
<li><code>arch/z80/include/z8</code> and <code>arch/z80/src/z8</code>:
|
|
The Z8Encore! port uses either the ZiLOG z8encore000zco development kit, Z8F6403 part,
|
|
or the z8f64200100kit development kit, Z8F6423 part with the Zilog ZDS-II Windows command line
|
|
tools. The development environment is Cygwin under WinXP.
|
|
The initial release, verified only on the ZDS-II ez8 simulator, was released in nuttx-0.3.9.
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
|
|
<p>
|
|
<b>Deprecated Architecture Directories</b>.
|
|
The following architecture directories are deprecated. They have been
|
|
replaced by the logic in <code>arm/arm</code> and will deleted when
|
|
<code>arch/arm</code> is fully verified.
|
|
</p>
|
|
<ul>
|
|
<li><code>arch/c5471</code>:
|
|
Replaced with <code>arch/arm/include/c5471</code> and
|
|
<code>arch/arm/src/c5471</code>.
|
|
</li>
|
|
|
|
<li><code>arch/dm320</code>:
|
|
Replaced with <code>arch/arm/include/dm320</code> and
|
|
<code>arch/arm/src/dm320</code>.
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
Other ports for the for the TI TMS320DM270 and for MIPS are in various states
|
|
of progress
|
|
</p>
|
|
|
|
<h2>2.3 <a name="DirStructBinFmt">nuttx/binfmt</a></h2>
|
|
|
|
<p>
|
|
The <code>binfmt/</code> subdirectory contains logic for loading binaries in the file
|
|
system into memory in a form that can be used to execute them.
|
|
</p>
|
|
|
|
<h2>2.4 <a name="DirStructConfigs">nuttx/configs</a></h2>
|
|
<p>
|
|
The <code>configs/</code> subdirectory contains configuration data for each board.
|
|
These board-specific configurations plus the architecture-specific configurations in
|
|
the <code>arch/</code> subdirectory complete define a customized port of NuttX.
|
|
</p>
|
|
|
|
<h3><a name="configsdirectorystructure">2.4.1 Subdirectory Structure</a></h3>
|
|
<p>
|
|
The configs directory contains board specific configuration files. Each board must
|
|
provide a subdirectory <board-name> under <code>configs/</code> with the following characteristics:
|
|
</p>
|
|
<ul><pre>
|
|
<i><board-name></i>
|
|
|-- Kconfig
|
|
|-- include/
|
|
| |-- board.h
|
|
| `-- <i>(board-specific header files)</i>
|
|
|-- src/
|
|
| |-- Makefile
|
|
| `-- <i>(board-specific source files)</i>
|
|
|-- <i><config1-dir></i>
|
|
| |-- Make.defs
|
|
| |-- defconfig
|
|
| |-- appconfig<sup>1</sup>
|
|
| `-- setenv.sh
|
|
|-- <i><config2-dir></i>
|
|
| |-- Make.defs
|
|
| |-- defconfig
|
|
| |-- appconfig<sup>1</sup>
|
|
| `-- setenv.sh
|
|
| ...
|
|
`-- <i>(other board-specific configuration sub-directories)</i>/
|
|
</pre>
|
|
<p><small>
|
|
<sup>1</sup>Optional
|
|
</small></p>
|
|
</ul>
|
|
|
|
<h3><a name="summaryofconfigfiles">2.4.2 Summary of Files</a></h3>
|
|
<h4><a name="boardlogic">2.4.2.1 Board Specific Logic</a></h4>
|
|
<ul>
|
|
<li>
|
|
<code>include/</code>:
|
|
This directory contains board specific header files.
|
|
This directory will be linked as <code>include/arch/board</code> at configuration time
|
|
and can be included via <code>#include <arch/board/header.h></code>.
|
|
These header file can only be included by files in <code>arch/</code><i><arch-name></i><code>/include/</code>
|
|
and <code>arch/</code><i><arch-name></i><code>/src/</code>.
|
|
</li>
|
|
<li>
|
|
<code>src/</code>:
|
|
This directory contains board specific drivers.
|
|
This directory will be linked as <config>arch/</code><i><arch-name></i><code>/src/board</code> at configuration
|
|
time and will be integrated into the build system.
|
|
</li>
|
|
<li>
|
|
<code>src/Makefile</code>:
|
|
This makefile will be invoked to build the board specific drivers.
|
|
It must support the following targets: <code>libext$(LIBEXT)</code>, <code>clean</code>, and <code>distclean</code>.
|
|
</li>
|
|
</ul>
|
|
<h4><a name="boardconfigsubdirs">2.4.2.2 Board Specific Configuration Sub-Directories</a></h4>
|
|
<p>
|
|
The <code>configs/</code><i><board-name></i><code>/</code> sub-directory holds all of the
|
|
files that are necessary to configure NuttX for the particular board.
|
|
A board may have various different configurations using the common source files.
|
|
Each board configuration is described by three files: <code>Make.defs</code>, <code>defconfig</code>, and <code>setenv.sh</code>.
|
|
Typically, each set of configuration files is retained in a separate configuration sub-directory
|
|
(<i><config1-dir></i>, <i><config2-dir></i>, .. in the above diagram).
|
|
|
|
The procedure for configuring NuttX is described <a href="#configuringnuttx">below</a>,
|
|
This paragraph will describe the contents of these configuration files.
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<code>Make.defs</code>: This makefile fragment provides architecture and
|
|
tool-specific build options. It will be included by all other
|
|
makefiles in the build (once it is installed). This make fragment
|
|
should define:
|
|
<ul>
|
|
<li>Tools: <code>CC</code>, <code>LD</code>, <code>AR</code>, <code>NM</code>, <code>OBJCOPY</code>, <code>OBJDUMP</code></li>
|
|
<li>Tool options: <code>CFLAGS</code>, <code>LDFLAGS</code></li>
|
|
</ul>
|
|
<p>
|
|
When this makefile fragment runs, it will be passed <code>TOPDIR</code> which
|
|
is the path to the root directory of the build. This makefile
|
|
fragment should include:
|
|
</p>
|
|
<ul>
|
|
<li><code>$(TOPDIR)/.config </code> : Nuttx configuration</li>
|
|
<li><code>$(TOPDIR)/tools/Config.mk</code> : Common definitions</li>
|
|
</ul>
|
|
<p>
|
|
Definitions in the <code>Make.defs</code> file probably depend on some of the
|
|
settings in the .<code>config</code> file. For example, the <code>CFLAGS</code> will most likely be
|
|
different if <code>CONFIG_DEBUG=y</code>.
|
|
</p>
|
|
<p>
|
|
The included <code>tools/Config.mk</code> file contains additional definitions that may
|
|
be overriden in the architecture-specific Make.defs file as necessary:
|
|
</p>
|
|
<ul>
|
|
<li><code>COMPILE</code>, <code>ASSEMBLE</code>, <code>ARCHIVE</code>, <code>CLEAN</code>, and <code>MKDEP</code> macros</li>
|
|
</ul>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<code>defconfig</code>: This is a configuration file similar to the Linux
|
|
configuration file. In contains variable/value pairs like:
|
|
</p>
|
|
<ul>
|
|
<li><code>CONFIG_VARIABLE</code>=value</li>
|
|
</ul>
|
|
<p>
|
|
This configuration file will be used at build time:
|
|
</p>
|
|
<p><ol>
|
|
<li>As a makefile fragment included in other makefiles, and</li>
|
|
<li>to generate <code>include/nuttx/config.h</code> which is included by
|
|
most C files in the system.</li>
|
|
</ol></p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<code>appconfig</code>: This is another configuration file that is specific to the
|
|
application. This file is copied into the application build directory
|
|
when NuttX is configured. See <code>../apps/README.txt</code> for further details.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<code>setenv.sh</code>: This is a script that you can include that will be installed at
|
|
the top level of the directory structure and can be sourced to set any
|
|
necessary environment variables.
|
|
You will most likely have to customize the default <code>setenv.sh</code> script in order
|
|
for it to work correctly in your environment.
|
|
</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="supportedboards">2.4.3 Supported Boards</a></h3>
|
|
<p>
|
|
All of the specific boards supported by NuttX are identified below.
|
|
These are the specific <i><board-name></i>'s that may be used to configure NuttX
|
|
as described <a href="#configuringnuttx">below</a>.
|
|
</p>
|
|
<ul>
|
|
<li><code>configs/avr32dev1</code>:
|
|
This is a port of NuttX to the Atmel AVR32DEV1 board. That board is
|
|
based on the Atmel AT32UC3B0256 MCU and uses a specially patched
|
|
version of the GNU toolchain: The patches provide support for the
|
|
AVR32 family. That patched GNU toolchain is available only from the
|
|
Atmel website. STATUS: This port is functional but very basic. There
|
|
are configurations for NSH and the OS test.
|
|
</li>
|
|
|
|
<li><code>configs/c5471evm</code>:
|
|
This is a port to the Spectrum Digital C5471 evaluation board. The
|
|
C5471 is a dual core processor from TI with an ARM7TDMI general purpose
|
|
processor and a c54 DSP. It is also known as TMS320DA180 or just DA180.
|
|
NuttX runs on the ARM core and is built with with a GNU arm-nuttx-elf toolchain
|
|
under Linux or Cygwin. This port is complete and verified.
|
|
</li>
|
|
|
|
<li><code>configs/demo9s12ne64</code>:
|
|
Feescale DMO9S12NE64 board based on the MC9S12NE64 hcs12 cpu. This
|
|
port uses the m9s12x GCC toolchain. STATUS: (Still) under development; it
|
|
is code complete but has not yet been verified.
|
|
</li>
|
|
|
|
<li><code>configs/ea3131</code>:
|
|
Embedded Artists EA3131 Development bard. This board is based on the
|
|
an NXP LPC3131 MCU. This OS is built with the arm-nuttx-elf toolchain.
|
|
STATUS: This port is complete and mature.
|
|
</li>
|
|
|
|
<li><code>configs/eagle100</code>:
|
|
Micromint Eagle-100 Development board. This board is based on the
|
|
an ARM Cortex-M3 MCU, the Luminary LM3S6918. This OS is built with the
|
|
arm-nuttx-elf toolchain. STATUS: This port is complete and mature.
|
|
</li>
|
|
|
|
<li><code>configs/ez80f0910200kitg</code>
|
|
ez80Acclaim! Microcontroller. This port use the Zilog ez80f0910200kitg
|
|
development kit, eZ80F091 part, and the Zilog ZDS-II Windows command line
|
|
tools. The development environment is Cygwin under WinXP.
|
|
</li>
|
|
|
|
<li><code>configs/ez80f910200zco</code>:
|
|
ez80Acclaim! Microcontroller. This port use the Zilog ez80f0910200zco
|
|
development kit, eZ80F091 part, and the Zilog ZDS-II Windows command line
|
|
tools. The development environment is Cygwin under WinXP.
|
|
</li>
|
|
|
|
<li><code>configs/lm3s6965-ek</code>:
|
|
Stellaris LM3S6965 Evaluation Kit. This board is based on the
|
|
an ARM Cortex-M3 MCU, the Luminary/TI LM3S6965. This OS is built with the
|
|
arm-nuttx-elf toolchain. STATUS: This port is complete and mature.
|
|
</li>
|
|
|
|
<li><code>configs/lm3s8962-ek</code>:
|
|
Stellaris LMS38962 Evaluation Kit. STATUS: contributed.
|
|
</li>
|
|
|
|
<li><code>configs/lpcxpresso-lpc1768</code>:
|
|
Embedded Artists base board with NXP LPCExpresso LPC1768. This board
|
|
is based on the NXP LPC1768. The Code Red toolchain is used by default.
|
|
STATUS: Under development.
|
|
</li>
|
|
|
|
<li><code>configs/m68322evb</code>:
|
|
This is a partial port for the venerable m68322evb board from Motorola.
|
|
This port was never completed and there are no plans to complete.
|
|
It will probably just be removed from the source tree at some point.
|
|
</li>
|
|
|
|
<li><code>configs/mbed</code>:
|
|
The configurations in this directory support the mbed board (http://mbed.org)
|
|
that features the NXP LPC1768 microcontroller. This OS is also built
|
|
with the arm-nuttx-elf toolchain. STATUS: Contributed.
|
|
</li>
|
|
|
|
<li><code>configs/mcu123-lpc214x</code>:
|
|
This port is for the NXP LPC2148 as provided on the mcu123.com
|
|
lpc214x development board.
|
|
This OS is also built with the arm-nuttx-elf toolchain* under Linux or Cygwin.
|
|
The port supports serial, timer0, spi, and usb.
|
|
</li>
|
|
|
|
<li><code>configs/mirtoo</code>:
|
|
This is the port to the DTX1-4000L "Mirtoo" module.
|
|
This module uses MicroChipPIC32MX250F128D.
|
|
See the <a href="http://www.dimitech.com/">Dimitech</a> website for further information.
|
|
</li>
|
|
|
|
<li><code>configs/mx1ads</code>:
|
|
This is a port to the Motorola MX1ADS development board. That board
|
|
is based on the Freescale i.MX1 processor. The i.MX1 is an ARM920T.
|
|
STATUS: This port is nearly code complete but was never fully
|
|
integrated due to tool-related issues.
|
|
</li>
|
|
|
|
<li><code>configs/ne64badge</code>:
|
|
Future Electronics Group NE64 /PoE Badge board based on the
|
|
MC9S12NE64 hcs12 cpu. This port uses the m9s12x GCC toolchain.
|
|
STATUS: Under development. The port is code-complete but has
|
|
not yet been fully tested.
|
|
</li>
|
|
|
|
<li><code>configs/ntosd-dm320</code>:
|
|
This port uses the Neuros OSD with a GNU arm-nuttx-elf toolchain* under Linux or Cygwin.
|
|
See <a href="http://wiki.neurostechnology.com/index.php/Developer_Welcome">Neuros Wiki</a>
|
|
for further information.
|
|
NuttX operates on the ARM9EJS of this dual core processor.
|
|
STATUS: This port is code complete, verified, and included in the
|
|
NuttX 0.2.1 release.
|
|
</li>
|
|
|
|
<li><code>configs/nucleus2g</code>:
|
|
This port uses the Nucleus 2G board (with Babel CAN board).
|
|
This board features an NXP LPC1768 processor.
|
|
See the <a href="http://www.2g-eng.com/">2G Engineering</a> website for more information about the Nucleus 2G.
|
|
</li>
|
|
|
|
<li><code>configs/olimex-lpc1766stk</code>:
|
|
This port uses the Olimex LPC1766-STK board and a GNU GCC toolchain under
|
|
Linux or Cygwin. STATUS: Complete and mature.
|
|
</li>
|
|
|
|
<li><code>configs/olimex-lpc2378</code>:
|
|
This port uses the Olimex-lpc2378 board and a GNU arm-nuttx-elf toolchain under
|
|
Linux or Cygwin. STATUS: ostest and NSH configurations available.
|
|
</li>
|
|
|
|
<li><code>configs/olimex-strp711</code>:
|
|
This port uses the Olimex STR-P711 board arm-nuttx-elf toolchain* under Linux or Cygwin.
|
|
See the <a href="http://www.olimex.com/dev/str-p711.html">Olimex</a> web site
|
|
for further information.
|
|
STATUS: Configurations for the basic OS test and NSH are complete and verified.
|
|
</li>
|
|
|
|
<li><code>configs/pcblogic-pic32mx</code>:
|
|
This is the port of NuttX to the PIC32MX board from PCB Logic Design Co.
|
|
This board features the MicroChip PIC32MX460F512L.
|
|
The board is a very simple -- little more than a carrier for the PIC32
|
|
MCU plus voltage regulation, debug interface, and an OTG connector.
|
|
STATUS: Code complete but testing has been stalled due to tool related problems
|
|
(PICkit 2 does not work with the PIC32).
|
|
</li>
|
|
|
|
<li><code>configs/pjrc-8051</code>:
|
|
8051 Microcontroller. This port uses the PJRC 87C52 development system
|
|
and the <a href="http://sdcc.sourceforge.net/">SDCC</a> toolchain under Linux or Cygwin.
|
|
This port is not quite ready for prime time.
|
|
</li>
|
|
|
|
<li><code>configs/qemu-i486</code>:
|
|
Port of NuttX to QEMU in i486 mode. This port will also run on real i486
|
|
hardwared (Google the Bifferboard).
|
|
</li>
|
|
|
|
<li><code>configs/rgmp</code>:
|
|
RGMP stands for RTOS and GPOS on Multi-Processor. RGMP is a project for
|
|
running GPOS and RTOS simultaneously on multi-processor platforms. You can
|
|
port your favorite RTOS to RGMP together with an unmodified Linux to form a
|
|
hybrid operating system. This makes your application able to use both RTOS
|
|
and GPOS features.
|
|
See the <a href="http://rgmp.sourceforge.net/wiki/index.php/Main_Page">RGMP Wiki</a> for further information about RGMP.
|
|
</li>
|
|
|
|
<li><code>configs/sam3u-ek</code>:
|
|
The port of NuttX to the Atmel SAM3U-EK development board.
|
|
</li>
|
|
|
|
<li><code>configs/skp16c26</code>:
|
|
Renesas M16C processor on the Renesas SKP16C26 StarterKit. This port
|
|
uses the GNU m32c toolchain. STATUS: The port is complete but untested
|
|
due to issues with compiler internal errors.
|
|
</li>
|
|
|
|
<li><code>configs/stm3210e-eval</code>:
|
|
STMicro STM3210E-EVAL development board based on the STMicro STM32F103ZET6
|
|
microcontroller (ARM Cortex-M3). This port uses the GNU Cortex-M3
|
|
toolchain.
|
|
</li>
|
|
|
|
<li><code>configs/sim</code>:
|
|
A user-mode port of NuttX to the x86 Linux platform is available.
|
|
The purpose of this port is primarily to support OS feature development.
|
|
This port does not support interrupts or a real timer (and hence no
|
|
round robin scheduler) Otherwise, it is complete.
|
|
</li>
|
|
|
|
<li><code>configs/us7032evb1</code>:
|
|
This is a port of the Hitachi SH-1 on the Hitachi SH-1/US7032EVB1 board.
|
|
STATUS: This port is available as of release 0.3.18 of NuttX. The port is basically
|
|
complete and many examples run correctly. However, there are remaining instabilities
|
|
that make the port un-usable. The nature of these is not understood; the behavior is
|
|
that certain SH-1 instructions stop working as advertised. This could be a silicon
|
|
problem, some pipeline issue that is not handled properly by the gcc 3.4.5 toolchain
|
|
(which has very limited SH-1 support to begin with), or perhaps with the CMON debugger.
|
|
At any rate, I have exhausted all of the energy that I am willing to put into this cool
|
|
old processor for the time being.
|
|
</li>
|
|
|
|
<li><code>configs/vsn</code>:
|
|
ISOTEL NetClamps VSN V1.2 ready2go sensor network platform based on the
|
|
STMicro STM32F103RET6. Contributed by Uros Platise.
|
|
See the <a href="http://isotel.eu/NetClamps/">Isotel</a> web site for further information
|
|
about the NetClamps board.
|
|
</li>
|
|
|
|
<li><code>configs/xtrs</code>:
|
|
TRS80 Model 3. This port uses a vintage computer based on the Z80.
|
|
An emulator for this computer is available to run TRS80 programs on a
|
|
Linux platform (http://www.tim-mann.org/xtrs.html).
|
|
</li>
|
|
|
|
<li><code>configs/z16f2800100zcog</code>
|
|
z16f Microcontroller.
|
|
This port use the Zilog z16f2800100zcog development kit and the
|
|
Zilog ZDS-II Windows command line tools.
|
|
The development environment is Cygwin under WinXP.
|
|
</li>
|
|
|
|
<li><code>configs/z80sim</code>:
|
|
z80 Microcontroller. This port uses a Z80 instruction set simulator.
|
|
That simulator can be found in the NuttX SVN
|
|
<a href="http://svn.code.sf.net/p/nuttx/code/trunk/misc/sims/z80sim">here</a>.
|
|
This port also the <a href="http://sdcc.sourceforge.net/">SDCC</a> toolchain
|
|
under Linux or Cygwin(verified with version 2.6.0).
|
|
</li>
|
|
|
|
<li><code>configs/z8encore000zco</code>
|
|
z8Encore! Microcontroller. This port use the Zilog z8encore000zco
|
|
development kit, Z8F6403 part, and the Zilog ZDS-II Windows command line
|
|
tools. The development environment is Cygwin under WinXP.
|
|
</li>
|
|
|
|
<li><code>configs/z8encore000zco</code>
|
|
z8Encore! Microcontroller. This port use the Zilog z8f64200100kit
|
|
development kit, Z8F6423 part, and the Zilog ZDS-II Windows command line
|
|
tools. The development environment is Cygwin under WinXP.
|
|
</li>
|
|
|
|
<li><code>configs/z8f64200100kit</code>:
|
|
z8Encore! Microcontroller. This port use the Zilog z8f64200100kit
|
|
development kit, Z8F6423 part, and the Zilog ZDS-II Windows command line
|
|
tools. The development environment is Cygwin under WinXP.
|
|
</li>
|
|
</ul>
|
|
|
|
<p><small><blockquote>
|
|
* A customized version of the <a href="http://www.buildroot.org">buildroot</a>
|
|
is available to build these toolchains under Linux or Cygwin.
|
|
</blockquote></small></p>
|
|
|
|
<h2>2.5 <a name="DirStructDrivers">nuttx/drivers</a></h2>
|
|
|
|
<p>
|
|
This directory holds architecture-independent device drivers.
|
|
</p>
|
|
<ul><pre>
|
|
drivers/
|
|
|-- Kconfig
|
|
|-- Makefile
|
|
|-- analog/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(Common ADC and DAC driver source files)</i>
|
|
|-- bch/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(bch driver source files)</i>
|
|
|-- input/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(Common touchscreen and keypad driver source files)</i>
|
|
|-- lcd/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(Common LCD driver source files)</i>
|
|
|-- mmcsd/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(Common MMC/SD card driver source files)</i>
|
|
|-- mtd/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(Common memory technology device driver source files)</i>
|
|
|-- net/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(Common network driver source files)</i>
|
|
|-- sensors/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(Common sensor driver source files)</i>
|
|
|-- serial/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(Files for the Calypso SERCOMM driver)</i>
|
|
|-- serial/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(Common front-end character drivers for chip-specific UARTs)</i>
|
|
|-- usbdev/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(Common USB device driver source files)</i>
|
|
|-- usbhost/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(Common USB host driver source files)</i>
|
|
|-- wirelss/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(Common wireless driver source files)</i>
|
|
`-- <i>(Various common driver source files)</i>
|
|
</pre></ul>
|
|
|
|
<h2>2.6 <a name="DirStructFs">nuttx/fs</a></h2>
|
|
|
|
<p>
|
|
This directory contains the NuttX file system.
|
|
This file system is described <a href="#NxFileSystem">below</a>.
|
|
</p>
|
|
<ul><pre>
|
|
fs/
|
|
|-- Kconfig
|
|
|-- Makefile
|
|
|-- fat/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(FAT file system source files)</i>
|
|
|-- mmap/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(RAM-based file mapping source files)</i>
|
|
|-- nfs/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(NFS client file system source files)</i>
|
|
|-- nxffs/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(NuttX Flash File System (NXFFS) source files)</i>
|
|
|-- romfs/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(ROMFS file system source files)</i>
|
|
`-- <i>(common file system source files)</i>
|
|
</pre></ul>
|
|
|
|
<h2>2.7 <a name="DirStructGraphics">nuttx/graphics</a></h2>
|
|
|
|
<p>
|
|
This directory contains files for graphics/video support under NuttX.
|
|
</p>
|
|
<ul><pre>
|
|
graphics/
|
|
|-- Kconfig
|
|
|-- Makefile
|
|
|-- nxbe/
|
|
| |-- Make.defs
|
|
| `-- <i>(NuttX graphics back-end (NXBE) source files)</i>
|
|
|-- nxfont/
|
|
| |-- Make.defs
|
|
| `-- <i>(NuttX graphics font-related (NXFONT) source files)</i>
|
|
|-- nxglib/
|
|
| |-- Make.defs
|
|
| `-- <i>(NuttX graphics library (NXGL) source files)</i>
|
|
|-- nxmu/
|
|
| |-- Make.defs
|
|
| `-- <i>(NuttX graphics multi-user (NXMU) server source files)</i>
|
|
|-- nxsu/
|
|
| |-- Make.defs
|
|
| `-- <i>(NuttX graphics single-user (NXSU) source files)</i>
|
|
`-- <i>(common file system source files)</i>
|
|
</pre></ul>
|
|
|
|
<h2>2.8 <a name="DirStructInclude">nuttx/include</a></h2>
|
|
<p>
|
|
This directory holds NuttX header files.
|
|
Standard header files file retained in can be included in the <i>normal</i> fashion:
|
|
</p>
|
|
<ul>
|
|
<code>include <stdio.h></code><br>
|
|
<code>include <sys/types.h></code><br>
|
|
etc.
|
|
</ul>
|
|
<p>
|
|
Directory structure:
|
|
</p>
|
|
<ul><pre>
|
|
include/
|
|
|-- <i>(standard header files)</i>
|
|
|-- arpa/
|
|
| `-- <i>(Standard header files)</i>
|
|
|-- cxx/
|
|
| `-- <i>(C++ standard header files)</i>
|
|
|-- netinet/
|
|
| `-- <i>(Standard header files)</i>
|
|
|-- nuttx/
|
|
| |-net/
|
|
| | `-- uip/
|
|
| | `-- <i>(uIP specific header files)</i>
|
|
| `-- <i>(NuttX specific header files)</i>
|
|
`- sys/
|
|
`-- <i>(More standard header files)</i>
|
|
</per></ul>
|
|
|
|
<h2>2.9 <a name="DirStructLib">nuttx/libc</a></h2>
|
|
<p>
|
|
This directory holds a collection of standard libc-like functions with custom
|
|
interfaces into NuttX.
|
|
</p>
|
|
<p>
|
|
Normally the logic in this file builds to a single library (<code>libc.a</code>).
|
|
However, if NuttX is built as a separately compiled kernel (with <code>CONFIG_NUTTX_KERNEL=y</code>), then the contents of this directory are built as two libraries:
|
|
One for use by user programs (<code>libuc.a</code>) and one for use only within the <kernel> space (<code>libkc.a</code>).
|
|
</p>
|
|
<p>
|
|
These user/kernel space libraries (along with the sycalls of <a href="#DirStructSyscall"><code>nuttx/syscall</code></a>) are needed to support the two differing protection domains.
|
|
</p>
|
|
<p>
|
|
Directory structure:
|
|
</p>
|
|
<ul><pre>
|
|
libc/
|
|
|-- libgen/
|
|
| `-- <i>(Implementation of functions from libgen.h)</i>
|
|
|-- math/
|
|
| `-- <i>(Implementation of functions from fixedmath.h)</i>
|
|
|-- misc/
|
|
| `-- <i>(Implementation of miscellaneous library functions)</i>
|
|
|-- mqueue/
|
|
| `-- <i>(Implementation of some functions from mqueue.h)</i>
|
|
|-- net/
|
|
| `-- <i>(Implementation of network-related library functions)</i>
|
|
|-- queue/
|
|
| `-- <i>(Implementation of functions from queue.h)</i>
|
|
|-- sched/
|
|
| `-- <i>(Implementation of some functions from sched.h)</i>
|
|
|-- semaphore/
|
|
| `-- <i>(Implementation of some functions from semaphore.h)</i>
|
|
|-- signal/
|
|
| `-- <i>(Implementation of some functions from signal.h)</i>
|
|
|-- stdio/
|
|
| `-- <i>(Implementation of functions from stdio.h)</i>
|
|
|-- stdlib/
|
|
| `-- <i>(Implementation of functions from stdlib.h)</i>
|
|
|-- string/
|
|
| `-- <i>(Implementation of functions from string.h)</i>
|
|
|-- time/
|
|
| `-- <i>(Implementation of some functions from time.h)</i>
|
|
`-- unistd/
|
|
`-- <i>(Implementation of some functions from unistd.h)</i>
|
|
</per></ul>
|
|
|
|
<h2>2.10 <a name="DirStructLibXX">nuttx/libxx</a></h2>
|
|
<p>
|
|
This directory holds a tiny, minimal standard std C++ that can be used to
|
|
build some, simple C++ applications in NuttX.
|
|
</p>
|
|
|
|
<h2>2.11 <a name="DirStructMm">nuttx/mm</a></h2>
|
|
<p>
|
|
This is the NuttX memory manager.
|
|
</p>
|
|
|
|
<h2>2.12 <a name="DirStructNet">nuttx/net</a></h2>
|
|
<p>
|
|
This directory contains the implementation of the NuttX internal socket APIs.
|
|
The subdirectory, <code>uip</code> contains the uIP port.
|
|
</P>
|
|
|
|
<h2>2.13 <a name="DirStructSched">nuttx/sched</a></h2>
|
|
<p>
|
|
The files forming core of the NuttX RTOS reside here.
|
|
</p>
|
|
|
|
<h2>2.14 <a name="DirStructSyscall">nuttx/syscall</a></h2>
|
|
<p>
|
|
If NuttX is built as a separately compiled kernel (with <code>CONFIG_NUTTX_KERNEL=y</code>),
|
|
then the contents of this directory are built.
|
|
This directory holds a syscall interface that can be used for communication
|
|
between user-mode applications and the kernel-mode RTOS.
|
|
</p>
|
|
|
|
<h2>2.15 <a name="DirStructTools">nuttx/tools</a></h2>
|
|
<p>
|
|
This directory holds a collection of tools and scripts to simplify
|
|
configuring, building and maintaining NuttX.
|
|
</p>
|
|
<ul><pre>
|
|
tools/
|
|
|-- Makefile.host
|
|
|-- Makefile.export
|
|
|-- README.txt
|
|
|-- configure.sh / configure.bat
|
|
|-- cfgparser.c
|
|
|-- cfgparser.h
|
|
|-- copydir.sh / copydir.bat
|
|
|-- define.sh / define.bat
|
|
|-- incdir.sh / indir.bat
|
|
|-- indent.sh
|
|
|-- link.sh / link.bat
|
|
|-- mkconfig.c
|
|
|-- mkdeps.sh / mkdeps.bat
|
|
|-- mkexport.sh
|
|
|-- mkimage.sh
|
|
|-- mknulldeps.sh
|
|
|-- mkromfsimg.sh
|
|
|-- mksyscall.c
|
|
|-- mkversion.c
|
|
|-- unlink.sh / unlink.bat
|
|
|-- version.sh
|
|
`-- zipme.sh
|
|
</pre></ul>
|
|
|
|
<p>
|
|
Refer to the README file in the <code>tools</code> directory for more information about the individual files.
|
|
Some of these tools are discussed below as well in the discussion of <a href="#configandbuild">configuring and building</a> NuttX.
|
|
</p>
|
|
|
|
<h2>2.16 <a name="topmakefile">nuttx/Makefile</a></h2>
|
|
<p>
|
|
The top-level <code>Makefile</code> in the <code>${TOPDIR}</code> directory contains all of the top-level control
|
|
logic to build NuttX.
|
|
Use of this <code>Makefile</code> to build NuttX is described <a href="#buildingnuttx">below</a>.
|
|
</p>
|
|
|
|
<h2>2.17 <a name="DirStructNetUtils">apps/netutils</a></h2>
|
|
<p>
|
|
This directory contains most of the network applications.
|
|
Some of these are original with NuttX (like tftpc and dhcpd) and others were leveraged from the uIP-1.0 apps directory.
|
|
As the uIP apps/README says, these applications "are not all heavily tested."
|
|
</p>
|
|
<ul><pre>
|
|
netutils/
|
|
|-- Kconfig
|
|
|-- Makefile
|
|
|-- dhcdp/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(DHCP client source files)</i>
|
|
|-- dhcpd/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(DHCP server source files)</i>
|
|
|-- ftpc/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(FTP client source files)</i>
|
|
|-- ftpd/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(FTP server source files)</i>
|
|
|-- resolv/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(resolv source files)</i>
|
|
|-- resolv/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(resolv source files)</i>
|
|
|-- smtp/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(smtp source files)</i>
|
|
|-- telnetd/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(Telnet client source files)</i>
|
|
|-- tftpc/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(TFTP client source files)</i>
|
|
|-- thttpd/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(thttpd HTTP server source files)</i>
|
|
|-- uiplib/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(uiplib source files)</i>
|
|
|-- weblclient/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(webclient source files)</i>
|
|
|-- webserver/
|
|
| |-- Kconfig
|
|
| |-- Make.defs
|
|
| `-- <i>(uIP webserver source files)</i>
|
|
`-- <i>(netutils common files)</i>
|
|
</pre></ul>
|
|
|
|
<h2>2.18 <a name="DirStructNshLib">apps/nshlib</a></h2>
|
|
<p>
|
|
This directory contains for the core of the NuttShell (NSH) application.
|
|
</p>
|
|
|
|
<h2>2.19 <a name="DirStructExamples">apps/examples</a></h2>
|
|
<p>
|
|
Example and test programs to build against.
|
|
</p>
|
|
|
|
<table width ="100%">
|
|
<tr bgcolor="#e4e4e4">
|
|
<td>
|
|
<h1>3.0 <a name="configandbuild">Configuring and Building</a></h1>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
|
|
<h2><a name="configuringnuttx">3.1 Configuring NuttX</a></h2>
|
|
<p>
|
|
<b>Manual Configuration</b>.
|
|
Configuring NuttX requires only copying the
|
|
<a href="#boardconfigsubdirs">board-specific configuration files</a> into the top level directory which appears in the make files as the make variable, <code>${TOPDIR}</code>.
|
|
This could be done manually as follows:
|
|
</p>
|
|
<ul>
|
|
<li>Copy <code>configs/</code><i><board-name></i><code>/[</code><i><config-dir></i><code>/]Make.defs</code> to <code>${TOPDIR}/Make.defs</code>,<li>
|
|
<li>Copy <code>configs/</code><i><board-name></i><code>/[</code><i><config-dir></i><code>/]setenv.sh</code> to <code>${TOPDIR}/setenv.sh</code>, and</li>
|
|
<li>Copy <code>configs/</code><i><board-name></i><code>/[</code><i><config-dir></i><code>/]defconfig</code> to <code>${TOPDIR}/.config</code></li>
|
|
</ul>
|
|
|
|
<p>
|
|
And if <code>configs/</code><i><board-name></i><code>/[</code><i><config-dir></i><code>/appconfig</code> exists in the board configuration directory:
|
|
</p>
|
|
<ul>
|
|
<li>Copy <code>configs/</code><i><board-name></i><code>/[</code><i><config-dir></i><code>/appconfig</code> to <app-dir><code>/.config</code></li>
|
|
<li><code>echo "APPS_LOC=\"<app-dir>\"" >> "${TOPDIR}/.config"</code></li>
|
|
</ul>
|
|
|
|
</p>
|
|
<p>
|
|
Where <i><board-name></i> is the name of one of the sub-directories of the
|
|
NuttX <a href="#DirStructConfigs"><code>configs/</code></a> directory.
|
|
This sub-directory name corresponds to one of the supported boards
|
|
identified <a href="#supportedboards">above</a>.
|
|
<config-dir> is the optional, specific configuration directory for the board.
|
|
And <app-dir> is the location of the optonal application directory.
|
|
</p>
|
|
<p>
|
|
<b>Automated Configuration</b>.
|
|
There is a script that automates these steps. The following steps will
|
|
accomplish the same configuration:
|
|
</p>
|
|
<ul><pre>
|
|
cd tools
|
|
./configure.sh <i><board-name></i>[/<i><config-dir></i>]
|
|
</pre></ul>
|
|
|
|
<p>
|
|
There is an alternative Windows batch file, <code>configure.bat</code>, that can be used insteach of <code>configure.sh</code> in the windows native enironment like:
|
|
</p>
|
|
<ul><pre>
|
|
cd tools
|
|
configure.bat <i><board-name></i>[\<i><config-dir></i>]
|
|
</pre></ul>
|
|
<p>
|
|
See <code>tools/README.txt</code> for more information about these scripts.
|
|
</p>
|
|
|
|
<p>
|
|
If <code>configs/</code><i><board-name></i><code>/[</code><i><config-dir></i>]<code>/appconfig</code>
|
|
exists and your application directory is not in the standard loction (<config>../apps</config>),
|
|
then you should also specify the location of the application directory on the command line like:
|
|
</p>
|
|
<ul><pre>
|
|
cd tools
|
|
./configure.sh -a <app-dir> <i><board-name></i>[/<i><config-dir></i>]
|
|
</pre></ul>
|
|
|
|
<p>
|
|
<b>Version Files</b>.
|
|
The NuttX build expects to find a version file located in the top-level NuttX build directory.
|
|
That version file is called <code>.version</code>.
|
|
The correct version file is installed in each versioned NuttX released.
|
|
However, if you are working from an SVN snapshot, then there will be no version file.
|
|
If there is no version file, the top-level <code>Makefile</code> will create a dummy <code>.version</code> file on the first make.
|
|
This dummy version file will contain all zeroes for version information.
|
|
If that is not what you want, they you should run the <code>version.sh</code> script to create a better <code>.version</code> file.
|
|
</p>
|
|
|
|
<p>
|
|
You can get help information from the <code>version.sh</code> script using the <code>-h</code> option.
|
|
For example:
|
|
</p>
|
|
<ul><pre>
|
|
$ tools/version.sh -h
|
|
tools/version.sh is a tool for generation of proper version files for the NuttX build
|
|
|
|
USAGE: tools/version.sh [-d|-h] [-b build] -v <major.minor> <outfile-path>
|
|
|
|
Where:
|
|
-d
|
|
Enable script debug
|
|
-h
|
|
show this help message and exit
|
|
-v <major.minor>
|
|
The NuttX version number expressed a major and minor number separated
|
|
by a period
|
|
<outfile-path>
|
|
The full path to the version file to be created
|
|
</pre></ul>
|
|
|
|
<p>
|
|
As an example, the following command will generate a version file for version 6.1 using the current SVN revision number:
|
|
</p>
|
|
<ul><pre>
|
|
tools/version.h -v 6.1 .version
|
|
</pre></ul>
|
|
|
|
<p>
|
|
The <code>.version</code> file is also used during the build process to create a C header file at <code>include/nuttx/version.h</code> that contains the same version information.
|
|
That version file may be used by your C applications for, as an example, reporting version information.
|
|
</p>
|
|
|
|
<p>
|
|
<b>Additional Configuration Steps</b>.
|
|
The remainder of configuration steps will be performed by <a href="#topmakefile"><code>${TOPDIR}/Makefile</code></a>
|
|
the first time the system is built as described below.
|
|
</p>
|
|
|
|
<h2><a name="buildingnuttx">3.2 Building NuttX</a></h2>
|
|
<p>
|
|
<b>Building NuttX</b>.
|
|
Once NuttX has been configured as described <a href="#configuringnuttx">above</a>, it may be built as follows:
|
|
</p>
|
|
<ul><pre>
|
|
cd ${TOPDIR}
|
|
source ./setenv.sh
|
|
make
|
|
</pre></ul>
|
|
<p>
|
|
The <code>${TOPDIR}</code> directory holds:
|
|
</p>
|
|
<ul>
|
|
<li>The top level <a href="#topmakefile"><code>Makefile</code></a> that controls the NuttX build.
|
|
</ul>
|
|
<p>
|
|
That directory also holds:
|
|
</p>
|
|
<ul>
|
|
<li>The makefile fragment <a href="#boardconfigsubdirs"><code>.config</code></a> that describes the current configuration.</li>
|
|
<li>The makefile fragment <a href="#boardconfigsubdirs"><code>Make.defs</code></a> that provides customized build targets, and</li>
|
|
<li>The shell script <a href="#boardconfigsubdirs"><code>setenv.sh</code></a> that sets up the configuration environment for the build.</li>
|
|
</ul>
|
|
<p>
|
|
The <a href="#boardconfigsubdirs"><code>setenv.sh</code></a> contains Linux/Cygwin environmental settings that are needed for the build.
|
|
The specific environmental definitions are unique for each board but should include, as a minimum, updates to the <code>PATH</code> variable to include the full path to the architecture-specific toolchain identified in <a href="#boardconfigsubdirs"><code>Make.defs</code></a>.
|
|
The <a href="#boardconfigsubdirs"><code>setenv.sh</code></a> only needs to be source'ed at the beginning of a session.
|
|
The system can be re-made subsequently by just typing <code>make</code>.
|
|
</p>
|
|
<p>
|
|
<b>First Time Make.</b>
|
|
Additional configuration actions will be taken the first time that system is built.
|
|
These additional steps include:
|
|
</p>
|
|
<ul>
|
|
<li>Auto-generating the file <code>include/nuttx/config.h</code> using the <code>${TOPDIR}/.config</code> file.</li>
|
|
<li>Auto-generating the file <code>${TOPDIR}/.version</code> with version 0.0 if one does not exist.</li>
|
|
<li>Auto-generating the file <code>include/nuttx/version.h</code> using the <code>${TOPDIR}/.version</code> file.</li>
|
|
<li>Creating a link to <code>${TOPDIR}/arch/</code><i><arch-name></i><code>/include</code> at <code>${TOPDIR}/include/arch</code>.</li>
|
|
<li>Creating a link to <code>${TOPDIR}/configs/</code><i><board-name></i><code>/include</code> at <code>${TOPDIR}/include/arch/board</code>.</li>
|
|
<li>Creating a link to <code>${TOPDIR}/configs/</code><i><board-name></i><code>/src</code> at <code>${TOPDIR}/arch/</code><i><arch-name></i><code>/src/board</code></li>
|
|
<li>Creating a link to <code>${APPDIR}/include</code> at <code>${TOPDIR}/include/apps</code></li>
|
|
<li>Creating make dependencies.
|
|
</ul>
|
|
|
|
<table width ="100%">
|
|
<tr bgcolor="#e4e4e4">
|
|
<td>
|
|
<h1>4.0 <a name="ArchAPIs">Architecture APIs</a></h1>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
|
|
<p>
|
|
The file <code>include/nuttx/arch.h</code> identifies by prototype all of the APIs that must
|
|
be provided by the architecture specific logic.
|
|
The internal OS APIs that architecture-specific logic must
|
|
interface with also also identified in <code>include/nuttx/arch.h</code> or in
|
|
other header files.
|
|
</p>
|
|
|
|
<h2><a name="imports">4.1 APIs Exported by Architecture-Specific Logic to NuttX</a></h2>
|
|
<h3><a name="upinitialize">4.1.1 <code>up_initialize()</code></a></h3>
|
|
|
|
<p><b>Prototype</b>: <code>void up_initialize(void);</code></p>
|
|
|
|
<p><b>Description</b>.
|
|
<code>up_initialize()</code> will be called once during OS
|
|
initialization after the basic OS services have been
|
|
initialized. The architecture specific details of
|
|
initializing the OS will be handled here. Such things as
|
|
setting up interrupt service routines, starting the
|
|
clock, and registering <a href="#DeviceDrivers">device drivers</a> are some of the
|
|
things that are different for each processor and hardware
|
|
platform.
|
|
</p>
|
|
<p>
|
|
<code>up_initialize()</code> is called after the OS initialized but
|
|
before the init process has been started and before the
|
|
libraries have been initialized. OS services and driver
|
|
services are available.
|
|
</p>
|
|
|
|
<h3><a name="upidle">4.1.2 <code>up_idle()</code></a></h3>
|
|
<p><b>Prototype</b>: <code>void up_idle(void);</code></p>
|
|
|
|
<p><b>Description</b>.
|
|
<code>up_idle()</code> is the logic that will be executed
|
|
when their is no other ready-to-run task. This is processor
|
|
idle time and will continue until some interrupt occurs to
|
|
cause a context switch from the idle task.
|
|
</p>
|
|
<p>
|
|
Processing in this state may be processor-specific. e.g.,
|
|
this is where power management operations might be performed.
|
|
</p>
|
|
|
|
<h3><a name="upinitialstate">4.1.3 <code>up_initial_state()</code></a></h3>
|
|
<p><b>Prototype</b>: <code>void up_initial_state(FAR _TCB *tcb);</code></p>
|
|
|
|
<p><b>Description</b>.
|
|
A new thread is being started and a new TCB has been created.
|
|
This function is called to initialize the processor specific portions of the new TCB.
|
|
</p>
|
|
<p>
|
|
This function must setup the initial architecture registers and/or stack so that execution
|
|
will begin at tcb->start on the next context switch.
|
|
</p>
|
|
<p>
|
|
This function may also need to set up processor registers so that the new thread executes
|
|
with the correct privileges.
|
|
If <code>CONFIG_NUTTX_KERNEL</code> has been selected in the NuttX configuration,
|
|
then special initialization may need to be performed depending on the task type specified
|
|
in the TCB's flags field:
|
|
Kernel threads will require kernel-mode privileges;
|
|
User tasks and pthreads should have only user-mode privileges.
|
|
If <code>CONFIG_NUTTX_KERNEL</code> has <i>not</i> been selected,
|
|
then all threads should have kernel-mode privileges.
|
|
</p>
|
|
|
|
<h3><a name="upcreatestack">4.1.4 <code>up_create_stack()</code></a></h3>
|
|
<p><b>Prototype</b>: <code>STATUS up_create_stack(FAR _TCB *tcb, size_t stack_size);</code></p>
|
|
|
|
<p><b>Description</b>.
|
|
Allocate a stack for a new thread and setup
|
|
up stack-related information in the TCB.
|
|
</p>
|
|
<p>
|
|
The following TCB fields must be initialized:
|
|
</p>
|
|
<ul>
|
|
<li><code>adj_stack_size</code>: Stack size after adjustment for hardware,
|
|
processor, etc. This value is retained only for debug
|
|
purposes.</li>
|
|
<li><code>stack_alloc_ptr</code>: Pointer to allocated stack</li>
|
|
<li><code>adj_stack_ptr</code>: Adjusted <code>stack_alloc_ptr</code> for HW. The
|
|
initial value of the stack pointer.
|
|
</ul>
|
|
<p>
|
|
This API is <i>NOT</i> required if <code>CONFIG_CUSTOM_STACK</code>
|
|
is defined.
|
|
</p>
|
|
|
|
<p><b>Input Parameters</b>:</p>
|
|
<ul>
|
|
<li>
|
|
<code>tcb</code>: The TCB of new task.
|
|
</li>
|
|
<li>
|
|
<code>stack_size</code>: The requested stack size. At least this much
|
|
must be allocated.
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="upusestack">4.1.5 <code>up_use_stack()</code></a></h3>
|
|
<p><b>Prototype</b>:
|
|
<code>STATUS up_use_stack(FAR _TCB *tcb, FAR void *stack, size_t stack_size);</code>
|
|
</p>
|
|
|
|
<p><b>Description</b>.
|
|
Setup up stack-related information in the TCB
|
|
using pre-allocated stack memory.
|
|
</p>
|
|
<p>
|
|
The following TCB fields must be initialized:
|
|
</p>
|
|
<ul>
|
|
<li><code>adj_stack_size</code>: Stack size after adjustment for hardware,
|
|
processor, etc. This value is retained only for debug
|
|
purposes.</li>
|
|
<li><code>stack_alloc_ptr</code>: Pointer to allocated stack</li>
|
|
<li><code>adj_stack_ptr</code>: Adjusted <code>stack_alloc_ptr</code> for HW. The
|
|
initial value of the stack pointer.
|
|
</ul>
|
|
<p>
|
|
This API is <i>NOT</i> required if <code>CONFIG_CUSTOM_STACK</code>
|
|
is defined.
|
|
</p>
|
|
|
|
<p><b>Input Parameters:</b></p>
|
|
<ul>
|
|
<li>
|
|
<code>tcb</code>: The TCB of new task.
|
|
</li>
|
|
<li>
|
|
<code>stack_size</code>: The allocated stack size.
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="upreleasestack">4.1.6 <code>up_release_stack()</code></a></h3>
|
|
<p><b>Prototype</b>: <code>void up_release_stack(FAR _TCB *dtcb);</code></p>
|
|
|
|
<p><b>Description</b>.
|
|
A task has been stopped. Free all stack
|
|
related resources retained int the defunct TCB.
|
|
</p>
|
|
<p>
|
|
This API is <i>NOT</i> required if <code>CONFIG_CUSTOM_STACK</code>
|
|
is defined.
|
|
</p>
|
|
|
|
<h3><a name="upunblocktask">4.1.7 <code>up_unblock_task()</code></a></h3>
|
|
<p><b>Prototype</b>: <code>void up_unblock_task(FAR _TCB *tcb);</code></p>
|
|
|
|
<p><b>Description</b>.
|
|
A task is currently in an inactive task list
|
|
but has been prepped to execute. Move the TCB to the
|
|
ready-to-run list, restore its context, and start execution.
|
|
</p>
|
|
<p>
|
|
This function is called only from the NuttX scheduling
|
|
logic. Interrupts will always be disabled when this
|
|
function is called.
|
|
</p>
|
|
|
|
<p><b>Input Parameters</b>:
|
|
<ul>
|
|
<li><code>tcb</code>: Refers to the tcb to be unblocked. This tcb is
|
|
in one of the waiting tasks lists. It must be moved to
|
|
the ready-to-run list and, if it is the highest priority
|
|
ready to run tasks, executed.
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="upblocktask">4.1.8 <code>up_block_task()</code></a></h3>
|
|
<p><b>Prototype</b>: <code>void up_block_task(FAR _TCB *tcb, tstate_t task_state);</code></p>
|
|
|
|
<p><b>Description</b>.
|
|
The currently executing task at the head of
|
|
the ready to run list must be stopped. Save its context
|
|
and move it to the inactive list specified by task_state.
|
|
|
|
This function is called only from the NuttX scheduling
|
|
logic. Interrupts will always be disabled when this
|
|
function is called.
|
|
|
|
<p><b>Input Parameters:</b></p>
|
|
<ul>
|
|
<li><code>tcb</code>: Refers to a task in the ready-to-run list (normally
|
|
the task at the head of the list). It most be
|
|
stopped, its context saved and moved into one of the
|
|
waiting task lists. It it was the task at the head
|
|
of the ready-to-run list, then a context to the new
|
|
ready to run task must be performed.
|
|
</li>
|
|
<li><code>task_state</code>: Specifies which waiting task list should be
|
|
hold the blocked task TCB.
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="upreleasepending">4.1.9 <code>up_release_pending()</code></a></h3>
|
|
<p><b>Prototype</b>: <code>void up_release_pending(void);</code></p>
|
|
|
|
<p><b>Description</b>.
|
|
When tasks become ready-to-run but cannot run because pre-emption
|
|
is disabled, they are placed into a pending task list.
|
|
This function releases and makes ready-to-run all of the tasks that have
|
|
collected in the pending task list. This can cause a
|
|
context switch if a new task is placed at the head of
|
|
the ready to run list.
|
|
</p>
|
|
<p>
|
|
This function is called only from the NuttX scheduling logic when
|
|
pre-emption is re-enabled. Interrupts will always be disabled when this
|
|
function is called.
|
|
</p>
|
|
|
|
<h3><a name="upreprioritizertr">4.1.10 <code>up_reprioritize_rtr()</code></a></h3>
|
|
<p><b>Prototype</b>: <code>void up_reprioritize_rtr(FAR _TCB *tcb, uint8_t priority);</code></p>
|
|
|
|
<p><b>Description</b>.
|
|
Called when the priority of a running or
|
|
ready-to-run task changes and the reprioritization will
|
|
cause a context switch. Two cases:
|
|
</p>
|
|
<ol>
|
|
<li>
|
|
The priority of the currently running task drops and the next
|
|
task in the ready to run list has priority.
|
|
</li>
|
|
<li>
|
|
An idle, ready to run task's priority has been raised above the
|
|
the priority of the current, running task and it now has the
|
|
priority.
|
|
</li>
|
|
</ol>
|
|
<p>
|
|
This function is called only from the NuttX scheduling
|
|
logic. Interrupts will always be disabled when this
|
|
function is called.
|
|
</p>
|
|
|
|
<p><b>Input Parameters:</b></p>
|
|
<ul>
|
|
<li>
|
|
<code>tcb</code>: The TCB of the task that has been reprioritized
|
|
</li>
|
|
<li>
|
|
<code>priority</code>: The new task priority
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="_exit">4.1.11 <code>_exit()</code></a></h3>
|
|
<p><b>Prototype</b>: <code>void _exit(int status) noreturn_function;</code></p>
|
|
|
|
<p><b>Description</b>.
|
|
This function causes the currently executing task to cease
|
|
to exist. This is a special case of task_delete().
|
|
</p>
|
|
<p>
|
|
Unlike other UP APIs, this function may be called
|
|
directly from user programs in various states. The
|
|
implementation of this function should disable interrupts
|
|
before performing scheduling operations.
|
|
</p>
|
|
|
|
<h3><a name="upassert">4.1.12 <code>up_assert()</code></a></h3>
|
|
<p><b>Prototype</b>:<br>
|
|
<code>void up_assert(FAR const uint8_t *filename, int linenum);</code></br>
|
|
<code>void up_assert_code(FAR const uint8_t *filename, int linenum, int error_code);</code></br>
|
|
</p>
|
|
|
|
<p><b>Description</b>.
|
|
Assertions may be handled in an architecture-specific
|
|
way.
|
|
</p>
|
|
|
|
<h3><a name="upschedulesigaction">4.1.13 <code>up_schedule_sigaction()</code></a></h3>
|
|
<p><b>Prototype</b>:
|
|
<code>void up_schedule_sigaction(FAR _TCB *tcb, sig_deliver_t sigdeliver);</code>
|
|
</p>
|
|
|
|
<p><b>Description</b>.
|
|
This function is called by the OS when one or more
|
|
signal handling actions have been queued for execution.
|
|
The architecture specific code must configure things so
|
|
that the 'sigdeliver' callback is executed on the thread
|
|
specified by 'tcb' as soon as possible.
|
|
</p>
|
|
<p>
|
|
This function may be called from interrupt handling logic.
|
|
</p>
|
|
<p>
|
|
This operation should not cause the task to be unblocked
|
|
nor should it cause any immediate execution of sigdeliver.
|
|
Typically, a few cases need to be considered:
|
|
</p>
|
|
<ol>
|
|
<li>
|
|
This function may be called from an interrupt handler
|
|
During interrupt processing, all xcptcontext structures
|
|
should be valid for all tasks. That structure should
|
|
be modified to invoke sigdeliver() either on return
|
|
from (this) interrupt or on some subsequent context
|
|
switch to the recipient task.
|
|
</li>
|
|
<li>
|
|
If not in an interrupt handler and the tcb is NOT
|
|
the currently executing task, then again just modify
|
|
the saved xcptcontext structure for the recipient
|
|
task so it will invoke sigdeliver when that task is
|
|
later resumed.
|
|
</li>
|
|
<li>
|
|
If not in an interrupt handler and the tcb IS the
|
|
currently executing task -- just call the signal
|
|
handler now.
|
|
</li>
|
|
</ol>
|
|
<p>
|
|
This API is <i>NOT</i> required if <code>CONFIG_DISABLE_SIGNALS</code>
|
|
is defined.
|
|
</p>
|
|
|
|
<h3><a name="upallocateheap">4.1.14 <code>up_allocate_heap()</code></a></h3>
|
|
<p><b>Prototype</b>: <code>void up_allocate_heap(FAR void **heap_start, size_t *heap_size);</code></p>
|
|
|
|
<p><b>Description</b>.
|
|
The heap may be statically allocated by
|
|
defining CONFIG_HEAP_BASE and CONFIG_HEAP_SIZE. If these
|
|
are not defined, then this function will be called to
|
|
dynamically set aside the heap region.
|
|
</p>
|
|
<p>
|
|
This API is <i>NOT</i> required if <code>CONFIG_HEAP_BASE</code>
|
|
is defined.
|
|
</p>
|
|
|
|
<h3><a name="upinterruptcontext">4.1.15 <code>up_interrupt_context()</code></a></h3>
|
|
<p><b>Prototype</b>: <code>bool up_interrupt_context(void)</code></p>
|
|
|
|
<p><b>Description</b>.
|
|
Return true if we are currently executing in the interrupt handler context.
|
|
</p>
|
|
|
|
<h3><a name="updisableirq">4.1.16 <code>up_disable_irq()</code></a></h3>
|
|
<p><b>Prototype</b>:</p>
|
|
<ul><pre>
|
|
#ifndef CONFIG_ARCH_NOINTC
|
|
void up_disable_irq(int irq);
|
|
#endif
|
|
</pre></ul>
|
|
|
|
<p><b>Description</b>.
|
|
Disable the IRQ specified by 'irq'
|
|
On many architectures, there are three levels of interrupt enabling: (1)
|
|
at the global level, (2) at the level of the interrupt controller,
|
|
and (3) at the device level. In order to receive interrupts, they
|
|
must be enabled at all three levels.
|
|
</p>
|
|
<p>
|
|
This function implements enabling of the device specified by 'irq'
|
|
at the interrupt controller level if supported by the architecture
|
|
(irqsave() supports the global level, the device level is hardware
|
|
specific).
|
|
<p>
|
|
If the architecture does not support <code>up_disable_irq</code>,
|
|
<code>CONFIG_ARCH_NOINTC</code> should be defined in the NuttX configuration file.
|
|
Since this API cannot be supported on all architectures, it should be
|
|
avoided in common implementations where possible.
|
|
</p>
|
|
|
|
<h3><a name="upenableirq">4.1.17 <code>up_enable_irq()</code></a></h3>
|
|
<p><b>Prototype</b>:</p>
|
|
<ul><pre>
|
|
#ifndef CONFIG_ARCH_NOINTC
|
|
void up_enable_irq(int irq);
|
|
#endif
|
|
</pre></ul>
|
|
|
|
<p><b>Description</b>.
|
|
This function implements disabling of the device specified by 'irq'
|
|
at the interrupt controller level if supported by the architecture
|
|
(irqrestore() supports the global level, the device level is hardware
|
|
specific).
|
|
</p>
|
|
<p>
|
|
If the architecture does not support <code>up_disable_irq</code>,
|
|
<code>CONFIG_ARCH_NOINTC</code> should be defined in the NuttX configuration file.
|
|
Since this API cannot be supported on all architectures, it should be
|
|
avoided in common implementations where possible.
|
|
</p>
|
|
|
|
<h3><a name="upprioritizeirq">4.1.18 <code>up_prioritize_irq()</code></a></h3>
|
|
<p><b>Prototype</b>:</p>
|
|
<ul><pre>
|
|
#ifdef CONFIG_ARCH_IRQPRIO
|
|
void up_enable_irq(int irq);
|
|
#endif
|
|
</pre></ul>
|
|
<p><b>Description</b>.
|
|
Set the priority of an IRQ.
|
|
</p>
|
|
<p>
|
|
If the architecture supports <code>up_enable_irq</code>,
|
|
<code>CONFIG_ARCH_IRQPRIO</code> should be defined in the NuttX configuration file.
|
|
Since this API cannot be supported on all architectures, it should be
|
|
avoided in common implementations where possible.
|
|
</p>
|
|
|
|
<h3><a name="upputc">4.1.19 <code>up_putc()</code></a></h3>
|
|
|
|
<p><b>Prototype</b>: <code>int up_putc(int ch);</code></p>
|
|
<p><b>Description</b>.
|
|
This is a debug interface exported by the architecture-specific logic.
|
|
Output one character on the console
|
|
</p>
|
|
|
|
<h3><a name="systemtime">4.1.20 System Time and Clock</a></h3>
|
|
|
|
<h4>4.1.20.1 Basic System Timer</h4>
|
|
|
|
<p><b>System Timer</b>
|
|
In most implementations, system time is provided by a timer interrupt.
|
|
That timer interrupt runs at rate determined by <code>CONFIG_MSEC_PER_TICKS</code> (default 10 or 100Hz).
|
|
The timer generates an interrupt each <code>CONFIG_MSEC_PER_TICKS</code> milliseconds and increments a counter called <code>g_system_timer</code>.
|
|
<code>g_system_timer</code> then provides a time-base for calculating <i>up-time</i> and elapsed time intervals in units of <code>CONFIG_MSEC_PER_TICKS</code>.
|
|
The range of <code>g_system_timer</code> is, by default, 32-bits.
|
|
However, if the MCU supports type <code>long long</code> and <code>CONFIG_SYSTEM_TIME16</code> is selected,
|
|
a 64-bit system timer will be supported instead.
|
|
</p>
|
|
<p><b>System Timer Accuracy</b>
|
|
On many system, the exact timer interval specified by <code>CONFIG_MSEC_PER_TICKS</code> cannot be achieved due to limitations in frequencies or in dividers.
|
|
As a result, the time interval specified by <code>CONFIG_MSEC_PER_TICKS</code> may only be approximate and there may be small errors in the apparent <i>up-time</i> time.
|
|
These small errors, however, will accumulate over time and after a long period of time may have an unacceptably large error in the apparent <i>up-time</i> of the MCU.
|
|
</p>
|
|
If the timer tick period generated by the hardware is not exactly <code>CONFIG_MSEC_PER_TICKS</code> <i>and</i> if there you require accurate up-time for the MCU, then there are measures that you can take:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
Perhaps you can adjust <code>CONFIG_MSEC_PER_TICKS</code> to a different value so that an exactly <code>CONFIG_MSEC_PER_TICKS</code> can be accomplished.
|
|
</li>
|
|
<li>
|
|
Or you can use a technique known as <i>Delta-Sigma Modulation</i>. (Suggested by Uros Platise). Consider the example below.
|
|
</li>
|
|
</ul>
|
|
|
|
<p><b>Delta-Sigma Modulation Example</b>.
|
|
Consider this case: The system timer is a count-up timer driven at 32.768KHz.
|
|
There are dividers that can be used, but a divider of one yields the highest accuracy.
|
|
This counter counts up until the count equals a match value, then a timer interrupt is generated.
|
|
The desire frequency is 100Hz (<code>CONFIG_MSEC_PER_TICKS</code> is 10).
|
|
</p>
|
|
<p>
|
|
This exact frequency of 100Hz cannot be obtained in this case.
|
|
In order to obtain that exact frequency a match value of 327.68 would have to be provided.
|
|
The closest integer value is 328 but the ideal match value is between 327 and 328.
|
|
The closest value, 328, would yield an actual timer frequency of 99.9Hz!
|
|
That will may cause significant timing errors in certain usages.
|
|
</p>
|
|
<p>
|
|
Use of Delta-Sigma Modulation can eliminate this error in the long run.
|
|
Consider this example implementation:
|
|
</p>
|
|
<ol>
|
|
<li>
|
|
Initially an accumulator is zero an the match value is programmed to 328:
|
|
<ul><pre>
|
|
accumulator = 0;
|
|
match = 328;
|
|
</pre></ul>
|
|
</li>
|
|
<li>
|
|
On each timer interrupt, accumulator is updated with difference that, in this reflects, 100* the error in interval that just passed.
|
|
So on the first timer interrupt, the accumulator would be updated like:
|
|
<ul><pre>
|
|
if (match == 328)
|
|
{
|
|
accumulator += 32; // 100*(328 - 327.68)
|
|
}
|
|
else
|
|
{
|
|
accumulator -= 68; // (100*(327 - 327.68)
|
|
}
|
|
</pre></ul>
|
|
</li>
|
|
<li>
|
|
And on that same timer interrupt a new match value would be programmed:
|
|
<ul><pre>
|
|
if (accumulator < 0)
|
|
{
|
|
match = 328;
|
|
}
|
|
else
|
|
{
|
|
match = 327;
|
|
}
|
|
</pre></ul>
|
|
</ol>
|
|
<p>
|
|
In this way, the timer interval is controlled from interrupt-to-interrupt to produce an average frequency of exactly 100Hz.
|
|
</p>
|
|
|
|
<h4>4.1.20.1 Hardware</h4>
|
|
<p>
|
|
To enable hardware module use the following configuration options:
|
|
<p>
|
|
<ul><dl>
|
|
<dt><code>CONFIG_RTC</code>
|
|
<dd>Enables general support for a hardware RTC.
|
|
Specific architectures may require other specific settings.
|
|
<dt><code>CONFIG_RTC_DATETIME</code>
|
|
<dd>There are two general types of RTC: (1) A simple battery backed counter that keeps the time when power
|
|
is down, and (2) A full date / time RTC the provides the date and time information, often in BCD format.
|
|
If <code>CONFIG_RTC_DATETIME</code> is selected, it specifies this second kind of RTC.
|
|
In this case, the RTC is used to "seed"" the normal NuttX timer and the NuttX system timer
|
|
provides for higher resoution time.
|
|
<dt><code>CONFIG_RTC_HIRES</code>
|
|
<dd>If <code>CONFIG_RTC_DATETIME</code> not selected, then the simple, battery backed counter is used.
|
|
There are two different implementations of such simple counters based on the time resolution of the counter:
|
|
The typical RTC keeps time to resolution of 1 second, usually supporting a 32-bit <code>time_t</code> value.
|
|
In this case, the RTC is used to "seed" the normal NuttX timer and the NuttX timer provides for higher resoution time.
|
|
If <code>CONFIG_RTC_HIRES</code> is enabled in the NuttX configuration, then the RTC provides higher resolution time and completely replaces the system timer for purpose of date and time.
|
|
<dt><code>CONFIG_RTC_FREQUENCY</code>
|
|
<dd>If <code>CONFIG_RTC_HIRES</code> is defined, then the frequency of the high resolution RTC must be provided.
|
|
If <code>CONFIG_RTC_HIRES</code> is not defined, <code>CONFIG_RTC_FREQUENCY</code> is assumed to be one.
|
|
<dt><code>CONFIG_RTC_ALARM</code>
|
|
<dd>Enable if the RTC hardware supports setting of an alarm.
|
|
A callback function will be executed when the alarm goes off
|
|
</dl></ul>
|
|
<p>
|
|
which requires the following base functions to read and set time:
|
|
</p>
|
|
<ul>
|
|
<li><code>up_rtcinitialize()</code>.
|
|
Initialize the hardware RTC per the selected configuration.
|
|
This function is called once during the OS initialization sequence
|
|
</li>
|
|
<li><code>up_rtc_time()</code>.
|
|
Get the current time in seconds. This is similar to the standard <code>time()</code> function.
|
|
This interface is only required if the low-resolution RTC/counter hardware implementation selected.
|
|
It is only used by the RTOS during intialization to set up the system time when <code>CONFIG_RTC</code> is set
|
|
but neither <code>CONFIG_RTC_HIRES</code> nor <code>CONFIG_RTC_DATETIME</code> are set.
|
|
</li>
|
|
<li><code>up_rtc_gettime()</code>.
|
|
Get the current time from the high resolution RTC clock/counter.
|
|
This interface is only supported by the hight-resolution RTC/counter hardware implementation.
|
|
It is used to replace the system timer (<code>g_system_tick</code>).
|
|
</li>
|
|
<li><code>up_rtc_settime()</code>.
|
|
Set the RTC to the provided time.
|
|
All RTC implementations must be able to set their time based on a standard timespec.
|
|
</li>
|
|
<li><code>up_rtc_setalarm()</code>.
|
|
Set up an alarm.
|
|
</li>
|
|
</ul>
|
|
|
|
<h4>4.1.20.2 System Tick and Time</h4>
|
|
<p>
|
|
The system tick is represented by::
|
|
</p>
|
|
<ul>
|
|
<li><code>g_system_timer</code></li>
|
|
</ul>
|
|
<p>
|
|
Running at rate of system base timer, used for time-slicing, and so forth.
|
|
</p>
|
|
<p>
|
|
If hardware RTC is present (<code>CONFIG_RTC</code>) and and high-resolution timing
|
|
is enabled (<code>CONFIG_RTC_HIRES</code>), then after successful
|
|
initiliazation variables are overriden by calls to <code>up_rtc_gettime()</code> which is
|
|
running continously even in power-down modes.
|
|
</p>
|
|
<p>
|
|
In the case of <code>CONFIG_RTC_HIRES</code> is set the <code>g_system_timer</code>
|
|
keeps counting at rate of a system timer, which however, is disabled in power-down mode.
|
|
By comparing this time and RTC (actual time) one may determine the actual system active time.
|
|
To retrieve that variable use:
|
|
</p>
|
|
|
|
<h3><a name="addrenv">4.1.21 Address Environments</a></h3>
|
|
|
|
<p>
|
|
CPUs that support memory management units (MMUs) may provide <i>address environments</i> within which tasks and their child threads execute.
|
|
The configuration indicates the CPUs ability to support address environments by setting the configuration varabile <code>CONFIG_ADDRENV=y</code>.
|
|
These address environments are created only when tasks are created via <code>exec()</code> or <code>exec_module()</code> (see <code>include/nuttx/binfmt/binfmt.h</code>).
|
|
</p>
|
|
<p>
|
|
When <code>CONFIG_ADDRENV=y</code> is set in the board configuration, the CPU-specific logic must provide a set of interfaces as defined in the header file <code>include/nuttx/arch.h</code>.
|
|
These interfaces are listed below and described in detail in the following paragraphs.
|
|
</p>
|
|
<p>
|
|
The CPU-specific logic must provide two categories in interfaces:
|
|
</p>
|
|
<ol>
|
|
<li>
|
|
<p>
|
|
<b>Binary Loader Support</b>.
|
|
These are low-level interfaces used in <code>binfmt/</code> to instantiate tasks with address environments.
|
|
These interfaces all operate on type <code>task_addrenv_t</code> which is an abstract representation of a asks's address environment and must be defined in arch/arch.h if <code>CONFIG_ADDRENV</code> is defined.
|
|
These low-level interfaces include:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<a href="#up_addrenv_create">4.1.21.1 <code>up_addrenv_create()</code></a>:
|
|
Create an address environment.
|
|
</li>
|
|
<li>
|
|
<a href="#up_addrenv_vaddr">4.1.21.2 <code>up_addrenv_vaddr()</code></a>:
|
|
Returns the virtual base address of the address environment.
|
|
</li>
|
|
<li>
|
|
<a href="#up_addrenv_select">4.1.21.3 <code>up_addrenv_select()</code></a>:
|
|
Instantiate an address environment.
|
|
</li>
|
|
<li>
|
|
<a href="#up_addrenv_restore">4.1.21.4 <code>up_addrenv_restore()</code></a>:
|
|
Restore an address environment.
|
|
</li>
|
|
<li>
|
|
<a href="#up_addrenv_destroy">4.1.21.5 <code>up_addrenv_destroy()</code></a>:
|
|
Destroy an address environment.
|
|
</li>
|
|
<li>
|
|
<a href="#up_addrenv_assign">4.1.21.6 <code>up_addrenv_assign()</code></a>:
|
|
Assign an address environment to a TCB.
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Tasking Support</b>.
|
|
Other interfaces must be provided to support higher-level interfaces used by the NuttX tasking logic.
|
|
These interfaces are* used by the functions in <code>sched/</code> and all operate on the TCB which as been assigned an address environment by <code>up_addrenv_assign()</code>.
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<a href="#up_addrenv_share">4.1.21.7 <code>up_addrenv_share()</code></a>:
|
|
Clone the address environment assigned to one TCB to another.
|
|
This operation is done when a pthread is created that share's the same address environment.
|
|
</li>
|
|
<li>
|
|
<a href="#up_addrenv_release">4.1.21.8 <code>up_addrenv_release()</code></a>:
|
|
Release the TCB's reference to an address environment when a task/thread exits.
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
</ol>
|
|
|
|
|
|
<h4><a name="up_addrenv_create">4.1.21.1 <code>up_addrenv_create()</code></a></h4>
|
|
<p><b>Prototype</b>:</p>
|
|
<ul>
|
|
<code>int up_addrenv_create(size_t envsize, FAR task_addrenv_t *addrenv);</code>
|
|
</ul>
|
|
<p><b>Description</b>:</p>
|
|
<ul>
|
|
This function is called from the binary loader logic when a new task is created in order to instantiate an address environment for the task.
|
|
<code>up_addrenv_create()</code> is essentially the allocator of the physical memory for the new task.
|
|
</ul>
|
|
<p><b>Input Parameters</b>:</p>
|
|
<ul>
|
|
<li><code>envsize</code>: The size (in bytes) of the address environment needed by the task.</li>
|
|
<li><code>addrenv</code>: The location to return the representation of the task address environment.</li>
|
|
</ul>
|
|
<p><b>Returned Value</b>:</p>
|
|
<ul>
|
|
Zero (<code>OK</code>) on success; a negated <code>errno</code> value on failure.
|
|
</ul>
|
|
|
|
<h4><a name="up_addrenv_vaddr">4.1.21.2 <code>up_addrenv_vaddr()</code></a></h4>
|
|
<p><b>Prototype</b>:<p>
|
|
<ul>
|
|
<code>int up_addrenv_vaddr(FAR task_addrenv_t addrenv, FAR void **vaddr);</code>
|
|
</ul>
|
|
<p><b>Description</b>:</p>
|
|
<ul>
|
|
Return the virtual address associated with the newly create address environment.
|
|
This function is used by the binary loaders in order get an address that can be used to initialize the new task.
|
|
</ul>
|
|
<p><b>Input Parameters</b>:</p>
|
|
<ul>
|
|
<li><code>addrenv</code>: The representation of the task address environment previously returned by up_addrenv_create.</li>
|
|
<li><code>vaddr</code>: The location to return the virtual address.</li>
|
|
</ul>
|
|
<p><b>Returned Value</b>:</p>
|
|
<ul>
|
|
Zero (<code>OK</code>) on success; a negated <code>errno</code> value on failure.
|
|
</ul>
|
|
|
|
<h4><a name="up_addrenv_select">4.1.21.3 <code>up_addrenv_select()</code></a></h4>
|
|
<p><b>Prototype</b>:<p>
|
|
<ul>
|
|
<code>int up_addrenv_select(task_addrenv_t addrenv, hw_addrenv_t *oldenv);</code>
|
|
</ul>
|
|
<p><b>Description</b>:</p>
|
|
<ul>
|
|
After an address environment has been established for a task (via <code>up_addrenv_create())</code>, this function may be called to to instantiate that address environment in the virtual address space.
|
|
This might be necessary, for example, to load the code for the task from a file or to access address environment private data.
|
|
</ul>
|
|
<p><b>Input Parameters</b>:</p>
|
|
<ul>
|
|
<li><code>addrenv</code>: The representation of the task address environment previously returned by up_addrenv_create.</li>
|
|
<li><code>oldenv</code>:
|
|
The address environment that was in place before <code>up_addrenv_select()</code> was called.
|
|
This may be used with <code>up_addrenv_restore()</code> to restore the original address environment that was in place before <code>up_addrenv_select()</code> was called.
|
|
Note that this may be a task agnostic, hardware representation that is different from <code>task_addrenv_t</code>.
|
|
</li>
|
|
</ul>
|
|
<p><b>Returned Value</b>:</p>
|
|
<ul>
|
|
Zero (<code>OK</code>) on success; a negated <code>errno</code> value on failure.
|
|
</ul>
|
|
|
|
<h4><a name="up_addrenv_restore">4.1.21.4 <code>up_addrenv_restore()</code></a></h4>
|
|
<p><b>Prototype</b>:<p>
|
|
<ul>
|
|
<code>int up_addrenv_restore(hw_addrenv_t oldenv);</code>
|
|
</ul>
|
|
<p><b>Description</b>:</p>
|
|
<ul>
|
|
After an address environment has been temporarilty instantiated by <code>up_addrenv_select</code>,
|
|
this function may be called to to restore the original address environment.
|
|
</ul>
|
|
<p><b>Input Parameters</b>:</p>
|
|
<ul>
|
|
<li><code>oldenv</code>: The hardware representation of the address environment previously returned by <code>up_addrenv_select()</code>.</li>
|
|
</ul>
|
|
<p><b>Returned Value</b>:</p>
|
|
<ul>
|
|
Zero (<code>OK</code>) on success; a negated <code>errno</code> value on failure.
|
|
</ul>
|
|
|
|
<h4><a name="up_addrenv_destroy">4.1.21.5 <code>up_addrenv_destroy()</code></a></h4>
|
|
<p><b>Prototype</b>:<p>
|
|
<ul>
|
|
<code>int up_addrenv_destroy(task_addrenv_t addrenv);</code>
|
|
</ul>
|
|
<p><b>Description</b>:</p>
|
|
<ul>
|
|
Called from the binary loader loader during error handling to destroy the address environment previously created by <code>up_addrenv_create()</code>.
|
|
</ul>
|
|
<p><b>Input Parameters</b>:</p>
|
|
<ul>
|
|
<li><code>addrenv</code>: The representation of the task address environment previously returned by up_addrenv_create.</li>
|
|
</ul>
|
|
<p><b>Returned Value</b>:</p>
|
|
<ul>
|
|
Zero (<code>OK</code>) on success; a negated <code>errno</code> value on failure.
|
|
</ul>
|
|
|
|
<h4><a name="up_addrenv_assign">4.1.21.6 <code>up_addrenv_assign()</code></a></h4>
|
|
<p><b>Prototype</b>:<p>
|
|
<ul>
|
|
<code>int up_addrenv_assign(task_addrenv_t addrenv, FAR _TCB *tcb);</code>
|
|
</ul>
|
|
<p><b>Description</b>:</p>
|
|
<ul>
|
|
Assign an address environment to a TCB.
|
|
</ul>
|
|
<p><b>Input Parameters</b>:</p>
|
|
<ul>
|
|
<li><code>addrenv</code>: The representation of the task address environment previously returned by up_addrenv_create.</li>
|
|
<li><code>tcb</code>: The TCB of the task to receive the address environment.</li>
|
|
</ul>
|
|
<p><b>Returned Value</b>:</p>
|
|
<ul>
|
|
Zero (<code>OK</code>) on success; a negated <code>errno</code> value on failure.
|
|
</ul>
|
|
|
|
<h4><a name="up_addrenv_share">4.1.21.7 <code>up_addrenv_share()</code></a></h4>
|
|
<p><b>Prototype</b>:<p>
|
|
<ul>
|
|
<code>int up_addrenv_share(FAR const _TCB *ptcb, FAR _TCB *ctcb);</code>
|
|
</ul>
|
|
<p><b>Description</b>:</p>
|
|
<ul>
|
|
This function is called from the core scheduler logic when a thread is created that needs to share the address ennvironment of its parent task.
|
|
In this case, the parent's address environment needs to be "cloned" for the child thread.
|
|
</ul>
|
|
<p><b>Input Parameters</b>:</p>
|
|
<ul>
|
|
<li><code>ptcb</code>: The TCB of the parent task that has the address environment.</li>
|
|
<li><code>ctcb</code>: The TCB of the child thread needing the address environment.</li>
|
|
</ul>
|
|
<p><b>Returned Value</b>:</p>
|
|
<ul>
|
|
Zero (<code>OK</code>) on success; a negated <code>errno</code> value on failure.
|
|
</ul>
|
|
|
|
<h4><a name="up_addrenv_release">4.1.21.8 <code>up_addrenv_release()</code></a></h4>
|
|
<p><b>Prototype</b>:<p>
|
|
<ul>
|
|
<code>int up_addrenv_release(FAR _TCB *tcb);</code>
|
|
</ul>
|
|
<p><b>Description</b>:</p>
|
|
<ul>
|
|
This function is called when a task or thread exits in order to release its reference to an address environment.
|
|
When there are no furtherreferences to an address environment, that address environment should
|
|
be destroyed.
|
|
</ul>
|
|
<p><b>Input Parameters</b>:</p>
|
|
<ul>
|
|
<li><code>tcb</code>: The TCB of the task or thread whose the address environment will be released.</li>
|
|
</ul>
|
|
<p><b>Returned Value</b>:</p>
|
|
<ul>
|
|
Zero (<code>OK</code>) on success; a negated <code>errno</code> value on failure.
|
|
</ul>
|
|
|
|
<h2><a name="exports">4.2 APIs Exported by NuttX to Architecture-Specific Logic</a></h2>
|
|
<p>
|
|
These are standard interfaces that are exported by the OS
|
|
for use by the architecture specific logic.
|
|
</p>
|
|
|
|
<h3><a name="osstart">4.2.1 <code>os_start()</code></a></h3>
|
|
<p>
|
|
<b><i>To be provided</i></b>
|
|
</p>
|
|
|
|
<h3><a name="listmgmt">4.2.2 OS List Management APIs</a></h3></h3>
|
|
<p>
|
|
<b><i>To be provided</i></b>
|
|
</p>
|
|
|
|
<h3><a name="schedprocesstimer">4.2.3 <code>sched_process_timer()</code></a></h3>
|
|
<p><b>Prototype</b>: <code>void sched_process_timer(void);</code></p>
|
|
|
|
<p><b>Description</b>.
|
|
This function handles system timer events.
|
|
The timer interrupt logic itself is implemented in the
|
|
architecture specific code, but must call the following OS
|
|
function periodically -- the calling interval must be
|
|
<code>MSEC_PER_TICK</code>.
|
|
</p>
|
|
|
|
<h3><a name="irqdispatch">4.2.4 <code>irq_dispatch()</code></a></h3>
|
|
<p><b>Prototype</b>: <code>void irq_dispatch(int irq, FAR void *context);</code></p>
|
|
|
|
<p><b>Description</b>.
|
|
This function must be called from the architecture-
|
|
specific logic in order to display an interrupt to
|
|
the appropriate, registered handling logic.
|
|
</p>
|
|
|
|
<h2><a name="demandpaging">4.3 On-Demand Paging</a></h2>
|
|
|
|
<p>
|
|
The NuttX On-Demand Paging feature permits embedded MCUs with some limited RAM space to execute large programs from some non-random access media.
|
|
If the platform meets certiain requirements, then NuttX can provide on-demand paging:
|
|
It can copy .text from the large program in non-volatile media into RAM as needed to execute a huge program from the small RAM.
|
|
Design and porting issues for this feature are discussed in a sepate document.
|
|
Please see the <a href="NuttXDemandPaging.html">NuttX Demand Paging</a> design document for further information.
|
|
</p>
|
|
|
|
<h2><a name="ledsupport">4.4 LED Support</a></h2>
|
|
|
|
<p>
|
|
A board architecture may or may not have LEDs.
|
|
If the board does have LEDs, then most architectures provide similar LED support that is enabled when <code>CONFIG_ARCH_LEDS</code>
|
|
is selected in the NuttX configuration file.
|
|
This LED support is part of architecture-specific logic and is not managed by the core NuttX logic.
|
|
However, the support provided by each architecture is sufficiently similar that it can be documented here.
|
|
</p>
|
|
|
|
<h3><a name="ledheaders">4.3.1 Header Files</a></h3>
|
|
|
|
<p>
|
|
LED-related definitions are provided in two header files:
|
|
<ul>
|
|
<li>
|
|
LED definitions are provided for each board in the <code>board.h</code> that resides
|
|
in the <code><i><board-name></i>/include/board.h</code> file (which is also
|
|
linked to <code>include/arch/board/board.h</code> when the RTOS is configured).
|
|
Those definitions are discussed <a href="#leddefinitions">below</a>.
|
|
</li>
|
|
<li>
|
|
The board-specific logic provides unique instances of the LED interfaces.
|
|
This is because the implementation of LED support may be very different
|
|
on different boards.
|
|
Prototypes for these board-specific implementations are, however, provided
|
|
in architecture-common header files.
|
|
That header file is usually at <code><i><arch-name></i>/src/common/up_internal.h</code>,
|
|
but could be at other locations in particular architectures.
|
|
These prototypes are discussed <a href="#ledapis">below</a>.
|
|
</li>
|
|
</ul>
|
|
</p>
|
|
|
|
<h3><a name="leddefinitions">4.3.2 LED Definitions</a></h3>
|
|
|
|
<p>
|
|
The implementation of LED support is very specific to a board architecture.
|
|
Some boards have several LEDS, others have only one or two.
|
|
Some have none.
|
|
Others LED matrices and show alphanumeric data, etc.
|
|
The NuttX logic does not refer to specific LEDS, rather, it refers to an event to be shown on the LEDS
|
|
in whatever manner is appropriate for the board;
|
|
the way that this event is presented depends upon the hardware available on the board.
|
|
</p>
|
|
<p>
|
|
The model used by NuttX is that the board can show 8 events defined as follows in <code><i><board-name></i>/include/board.h</code>:
|
|
</p>
|
|
<ul><pre>
|
|
#define LED_STARTED ??
|
|
#define LED_HEAPALLOCATE ??
|
|
#define LED_IRQSENABLED ??
|
|
#define LED_STACKCREATED ??
|
|
#define LED_INIRQ ??
|
|
#define LED_SIGNAL ??
|
|
#define LED_ASSERTION ??
|
|
#define LED_PANIC ??
|
|
</pre></ul>
|
|
<p>
|
|
The specific value assigned to each pre-processor variable can be whatever makes the implementation easiest for the board logic.
|
|
The <i>meaning</i> associated with each definition is as follows:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<code>LED_STARTED</code> is the value that describes the setting of the LEDs when the LED logic is first initialized.
|
|
This LED value is set but never cleared.
|
|
</li>
|
|
<li>
|
|
<code>LED_HEAPALLOCATE</code> indicates that the NuttX heap has been configured.
|
|
This is an important place in the boot sequence because if the memory is configured wrong, it will probably crash leaving this LED setting.
|
|
This LED value is set but never cleared.
|
|
</li>
|
|
<li>
|
|
<code>LED_IRQSENABLED</code> indicates that interrupts have been enabled.
|
|
Again, during bring-up (or if there are hardware problems), it is very likely that the system may crash just when interrupts are enabled, leaving this setting on the LEDs.
|
|
This LED value is set but never cleared.
|
|
</li>
|
|
<li>
|
|
<code>LED_STACKCREATED</code> is set each time a new stack is created.
|
|
If set, it means that the system attempted to start at least one new thread.
|
|
This LED value is set but never cleared.
|
|
</li>
|
|
<li>
|
|
<code>LED_INIRQ</code> is set and cleared on entry and exit from each interrupt.
|
|
If interrupts are working okay, this LED will have a dull glow.
|
|
</li>
|
|
<li>
|
|
<code>LED_SIGNAL</code> is set and cleared on entry and exit from a signal handler.
|
|
Signal handlers are tricky so this is especially useful during bring-up or a new architecture.
|
|
</li>
|
|
<li>
|
|
<code>LED_ASSERTION</code> is set if an assertion occurs.
|
|
</li>
|
|
<li>
|
|
<code>LED_PANIC</code> will blink at around 1Hz if the system panics and hangs.
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="ledapis">4.3.3 Common LED interfaces</a></h3>
|
|
|
|
<p>
|
|
The <code><i><arch-name></i>/src/common/up_internal.h</code> probably has definitions
|
|
like:
|
|
</p>
|
|
<ul><pre>
|
|
/* Defined in board/up_leds.c */
|
|
|
|
#ifdef CONFIG_ARCH_LEDS
|
|
extern void up_ledinit(void);
|
|
extern void up_ledon(int led);
|
|
extern void up_ledoff(int led);
|
|
#else
|
|
# define up_ledinit()
|
|
# define up_ledon(led)
|
|
# define up_ledoff(led)
|
|
#endif
|
|
</pre></ul>
|
|
<p>
|
|
Where:
|
|
<p>
|
|
<ul>
|
|
<li>
|
|
<code>void up_ledinit(void)</code> is called early in power-up initialization to initialize the LED hardware.
|
|
</li>
|
|
<li>
|
|
<code>up_ledon(int led)</code> is called to instantiate the LED presentation of the event.
|
|
The <code>led</code> argument is one of the definitions provided in <code><i><board-name></i>/include/board.h</code>.
|
|
</li>
|
|
<li>
|
|
<code>up_ledoff(int led</code>is called to terminate the LED presentation of the event.
|
|
The <code>led</code> argument is one of the definitions provided in <code><i><board-name></i>/include/board.h</code>.
|
|
Note that only <code>LED_INIRQ</code>, <code>LED_SIGNAL</code>, <code>LED_ASSERTION</code>, and <code>LED_PANIC</code>
|
|
indications are terminated.
|
|
</li>
|
|
</ul>
|
|
|
|
<table width ="100%">
|
|
<tr bgcolor="#e4e4e4">
|
|
<td>
|
|
<h1><a name="NxFileSystem">5.0 NuttX File System</a></h1>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
|
|
<p><b>Overview</b>.
|
|
NuttX includes an optional, scalable file system.
|
|
This file-system may be omitted altogether; NuttX does not depend on the presence
|
|
of any file system.
|
|
</p>
|
|
|
|
<p><b>Pseudo Root File System</b>.
|
|
Or, a simple <i>in-memory</i>, <i>pseudo</i> file system can be enabled.
|
|
This simple file system can be enabled setting the CONFIG_NFILE_DESCRIPTORS
|
|
option to a non-zero value (see <a href="#apndxconfigs">Appendix A</a>).
|
|
This is an <i>in-memory</i> file system because it does not require any
|
|
storage medium or block driver support.
|
|
Rather, file system contents are generated on-the-fly as referenced via
|
|
standard file system operations (open, close, read, write, etc.).
|
|
In this sense, the file system is <i>pseudo</i> file system (in the
|
|
same sense that the Linux <code>/proc</code> file system is also
|
|
referred to as a pseudo file system).
|
|
</p>
|
|
|
|
<p>
|
|
Any user supplied data or logic can be accessed via the pseudo-file system.
|
|
Built in support is provided for character and block <a href="#DeviceDrivers">drivers</a> in the
|
|
<code>/dev</code> pseudo file system directory.
|
|
</p>
|
|
|
|
<p><b>Mounted File Systems</b>
|
|
The simple in-memory file system can be extended my mounting block
|
|
devices that provide access to true file systems backed up via some
|
|
mass storage device.
|
|
NuttX supports the standard <code>mount()</code> command that allows
|
|
a block driver to be bound to a mountpoint within the pseudo file system
|
|
and to a file system.
|
|
At present, NuttX supports the standard VFAT and ROMFS file systems,
|
|
a special, wear-leveling NuttX FLASH File System (NXFFS),
|
|
as well as a Network File System client (NFS version 3, UDP).
|
|
</p>
|
|
|
|
<p><b>Comparison to Linux</b>
|
|
From a programming perspective, the NuttX file system appears very similar
|
|
to a Linux file system.
|
|
However, there is a fundamental difference:
|
|
The NuttX root file system is a pseudo file system and true file systems may be
|
|
mounted in the pseudo file system.
|
|
In the typical Linux installation by comparison, the Linux root file system
|
|
is a true file system and pseudo file systems may be mounted in the true,
|
|
root file system.
|
|
The approach selected by NuttX is intended to support greater scalability
|
|
from the very tiny platform to the moderate platform.
|
|
</p>
|
|
|
|
<table width ="100%">
|
|
<tr bgcolor="#e4e4e4">
|
|
<td>
|
|
<h1><a name="DeviceDrivers">6.0 NuttX Device Drivers</a></h1>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
|
|
<p>
|
|
NuttX supports a variety of device drivers including:
|
|
<ul>
|
|
<li><i>Character</i> Device Drivers,</li>
|
|
<li><i>Block</i> Device Drivers, and</li>
|
|
<li>Other <i>Specialized</i> Drivers.</li>
|
|
</ul>
|
|
These different device driver types are discussed in the following paragraphs.
|
|
Note: device driver support requires that the <i>in-memory</i>, <i>pseudo</i> file system
|
|
is enabled by setting the CONFIG_NFILE_DESCRIPTORS in the NuttX configuration file to a
|
|
non-zero value.
|
|
</p>
|
|
|
|
<h2><a name="chardrivers">6.1 Character Device Drivers</a></h2>
|
|
|
|
<p>
|
|
Character device drivers have these properties:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<p>
|
|
<b><code>include/nuttx/fs/fs.h</code></b>.
|
|
All structures and APIs needed to work with character drivers are provided in this header file.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>struct file_operations</code></b>.
|
|
Each character device driver must implement an instance of <code>struct file_operations</code>.
|
|
That structure defines a call table with the following methods:
|
|
<ul>
|
|
<p><code>int open(FAR struct file *filp);</code><br>
|
|
<code>int close(FAR struct file *filp);</code><br>
|
|
<code>ssize_t read(FAR struct file *filp, FAR char *buffer, size_t buflen);</code><br>
|
|
<code>ssize_t write(FAR struct file *filp, FAR const char *buffer, size_t buflen);</code><br>
|
|
<code>off_t seek(FAR struct file *filp, off_t offset, int whence);</code><br>
|
|
<code>int ioctl(FAR struct file *filp, int cmd, unsigned long arg);</code><br>
|
|
<code>int poll(FAR struct file *filp, struct pollfd *fds, bool setup);</code></p>
|
|
</ul>
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>int register_driver(const char *path, const struct file_operations *fops, mode_t mode, void *priv);</code></b>.
|
|
Each character driver registers itself by calling <code>register_driver()</code>, passing it the
|
|
<code>path</code> where it will appear in the <a href="#NxFileSystem">pseudo-file-system</a> and it's
|
|
initialized instance of <code>struct file_operations</code>.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>User Access</b>.
|
|
After it has been registered, the character driver can be accessed by user code using the standard
|
|
<a href="NuttxUserGuide.html#driveroperations">driver operations</a> including
|
|
<code>open()</code>, <code>close()</code>, <code>read()</code>, <code>write()</code>, etc.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Examples</b>:
|
|
<code>drivers/dev_null.c</code>, <code>drivers/fifo.c</code>, <code>drivers/serial.c</code>, etc.
|
|
</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<h2><a name="blockdrivers">6.2 Block Device Drivers</a></h2>
|
|
|
|
<p>
|
|
Block device drivers have these properties:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<p>
|
|
<b><code>include/nuttx/fs/fs.h</code></b>.
|
|
All structures and APIs needed to work with block drivers are provided in this header file.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>struct block_operations</code></b>.
|
|
Each block device driver must implement an instance of <code>struct block_operations</code>.
|
|
That structure defines a call table with the following methods:
|
|
<ul>
|
|
<p><code>int open(FAR struct inode *inode);</code><br>
|
|
<code>int close(FAR struct inode *inode);</code><br>
|
|
<code>ssize_t read(FAR struct inode *inode, FAR unsigned char *buffer, size_t start_sector, unsigned int nsectors);</code><br>
|
|
<code>ssize_t write(FAR struct inode *inode, FAR const unsigned char *buffer, size_t start_sector, unsigned int nsectors);</code><br>
|
|
<code>int geometry(FAR struct inode *inode, FAR struct geometry *geometry);</code><br>
|
|
<code>int ioctl(FAR struct inode *inode, int cmd, unsigned long arg);</code></p>
|
|
</ul>
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>int register_blockdriver(const char *path, const struct block_operations *bops, mode_t mode, void *priv);</code></b>.
|
|
Each block driver registers itself by calling <code>register_blockdriver()</code>, passing it the
|
|
<code>path</code> where it will appear in the <a href="#NxFileSystem">pseudo-file-system</a> and it's
|
|
initialized instance of <code>struct block_operations</code>.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>User Access</b>.
|
|
Users do not normally access block drivers directly, rather, they access block drivers
|
|
indirectly through the <code>mount()</code> API.
|
|
The <code>mount()</code> API binds a block driver instance with a file system and with a mountpoint.
|
|
Then the user may use the block driver to access the file system on the underlying media.
|
|
<i>Example</i>: See the <code>cmd_mount()</code> implementation in <code>apps/nshlib/nsh_fscmds.c</code>.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Accessing a Character Driver as a Block Device</b>.
|
|
See the loop device at <code>drivers/loop.c</code>.
|
|
<i>Example</i>: See the <code>cmd_losetup()</code> implementation in <code>apps/nshlib/nsh_fscmds.c</code>.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Accessing a Block Driver as Character Device</b>.
|
|
See the Block-to-Character (BCH) conversion logic in <code>drivers/bch/</code>.
|
|
<i>Example</i>: See the <code>cmd_dd()</code> implementation in <code>apps/nshlib/nsh_ddcmd.c</code>.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Examples</b>.
|
|
<code>drivers/loop.c</code>, <code>drivers/mmcsd/mmcsd_spi.c</code>, <code>drivers/ramdisk.c</code>, etc.
|
|
</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<h2><a name="blockdrivers">6.3 Specialized Device Drivers</a></h2>
|
|
|
|
<h3><a name="ethdrivers">6.3.1 Ethernet Device Drivers</a></h3>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>
|
|
<b><code>include/nuttx/net/uip/uip-arch.h</code></b>.
|
|
All structures and APIs needed to work with Ethernet drivers are provided in this header file.
|
|
The structure <code>struct uip_driver_s</code> defines the interface and is passed to uIP via
|
|
<code>netdev_register()</code>.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>int netdev_register(FAR struct uip_driver_s *dev);</code></b>.
|
|
Each Ethernet driver registers itself by calling <code>netdev_register()</code>.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Examples</b>:
|
|
<code>drivers/net/dm90x0.c</code>, <code>arch/drivers/arm/src/c5471/c5471_ethernet.c</code>, <code>arch/z80/src/ez80/ez80_emac.c</code>, etc.
|
|
</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="spidrivers">6.3.2 SPI Device Drivers</a></h3>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>
|
|
<b><code>include/nuttx/spi.h</code></b>.
|
|
All structures and APIs needed to work with SPI drivers are provided in this header file.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>struct spi_ops_s</code></b>.
|
|
Each SPI device driver must implement an instance of <code>struct spi_ops_s</code>.
|
|
That structure defines a call table with the following methods:
|
|
<ul>
|
|
<p><code>void lock(FAR struct spi_dev_s *dev);</code></p>
|
|
<p><code>void select(FAR struct spi_dev_s *dev, enum spi_dev_e devid, bool selected);</code><br>
|
|
<code>uint32_t setfrequency(FAR struct spi_dev_s *dev, uint32_t frequency);</code><br>
|
|
<code>void setmode(FAR struct spi_dev_s *dev, enum spi_mode_e mode);</code><br>
|
|
<code>void setbits(FAR struct spi_dev_s *dev, int nbits);</code><br>
|
|
<code>uint8_t status(FAR struct spi_dev_s *dev, enum spi_dev_e devid);</code><br>
|
|
<code>uint16_t send(FAR struct spi_dev_s *dev, uint16_t wd);</code><br>
|
|
<code>void exchange(FAR struct spi_dev_s *dev, FAR const void *txbuffer, FAR void *rxbuffer, size_t nwords);</code><br>
|
|
<p><code>int registercallback(FAR struct spi_dev_s *dev, mediachange_t callback, void *arg);</code></p>
|
|
</ul>
|
|
</p>
|
|
<li>
|
|
<p>
|
|
<b>Binding SPI Drivers</b>.
|
|
SPI drivers are not normally directly accessed by user code, but are usually bound to another,
|
|
higher level device driver.
|
|
See for example, <code>int mmcsd_spislotinitialize(int minor, int slotno, FAR struct spi_dev_s *spi)</code> in <code>drivers/mmcsd/mmcsd_spi.c</code>.
|
|
In general, the binding sequence is:
|
|
</p>
|
|
<p>
|
|
<ol>
|
|
<li>Get an instance of <code>struct spi_dev_s</code> from the hardware-specific SPI device driver, and </li>
|
|
<li>Provide that instance to the initialization method of the higher level device driver.</li>
|
|
</ol>
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Examples</b>:
|
|
<code>drivers/loop.c</code>, <code>drivers/mmcsd/mmcsd_spi.c</code>, <code>drivers/ramdisk.c</code>, etc.
|
|
</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="i2cdrivers">6.3.3 I2C Device Drivers</a></h3>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>
|
|
<b><code>include/nuttx/i2c/i2c.h</code></b>.
|
|
All structures and APIs needed to work with I2C drivers are provided in this header file.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>struct i2c_ops_s</code></b>.
|
|
Each I2C device driver must implement an instance of <code>struct i2c_ops_s</code>.
|
|
That structure defines a call table with the following methods:
|
|
<ul>
|
|
<p><code>uint32_t setfrequency(FAR struct i2c_dev_s *dev, uint32_t frequency);</code><br>
|
|
<code>int setaddress(FAR struct i2c_dev_s *dev, int addr, int nbits);</code><br>
|
|
<code>int write(FAR struct i2c_dev_s *dev, const uint8_t *buffer, int buflen);</code><br>
|
|
<code>int read(FAR struct i2c_dev_s *dev, uint8_t *buffer, int buflen);</code></p>
|
|
</p>
|
|
</ul>
|
|
<li>
|
|
<p>
|
|
<b>Binding I2C Drivers</b>.
|
|
I2C drivers are not normally directly accessed by user code, but are usually bound to another,
|
|
higher level device driver.
|
|
In general, the binding sequence is:
|
|
</p>
|
|
<p>
|
|
<ol>
|
|
<li>Get an instance of <code>struct i2c_dev_s</code> from the hardware-specific I2C device driver, and </li>
|
|
<li>Provide that instance to the initialization method of the higher level device driver.</li>
|
|
</ol>
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Examples</b>:
|
|
<code>arch/z80/src/ez80/ez80_i2c.c</code>, <code>arch/z80/src/z8/z8_i2c.c</code>, etc.
|
|
</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="serialdrivers">6.3.4 Serial Device Drivers</a></h3>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>
|
|
<b><code>include/nuttx/serial/serial.h</code></b>.
|
|
All structures and APIs needed to work with serial drivers are provided in this header file.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>struct uart_ops_s</code></b>.
|
|
Each serial device driver must implement an instance of <code>struct uart_ops_s</code>.
|
|
That structure defines a call table with the following methods:
|
|
<ul>
|
|
<p><code>int setup(FAR struct uart_dev_s *dev);</code><br>
|
|
<code>void shutdown(FAR struct uart_dev_s *dev);</code><br>
|
|
<code>int attach(FAR struct uart_dev_s *dev);</code><br>
|
|
<code>void detach(FAR struct uart_dev_s *dev);</code><br>
|
|
<code>int ioctl(FAR struct file *filep, int cmd, unsigned long arg);</code><br>
|
|
<code>int receive(FAR struct uart_dev_s *dev, unsigned int *status);</code><br>
|
|
<code>void rxint(FAR struct uart_dev_s *dev, bool enable);</code><br>
|
|
<code>bool rxavailable(FAR struct uart_dev_s *dev);</code><br>
|
|
<code>void send(FAR struct uart_dev_s *dev, int ch);</code><br>
|
|
<code>void txint(FAR struct uart_dev_s *dev, bool enable);</code><br>
|
|
<code>bool txready(FAR struct uart_dev_s *dev);</code><br>
|
|
<code>bool txempty(FAR struct uart_dev_s *dev);</code></p>
|
|
</ul>
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>int uart_register(FAR const char *path, FAR uart_dev_t *dev);</code></b>.
|
|
A serial driver may register itself by calling <code>uart_register()</code>, passing it the
|
|
<code>path</code> where it will appear in the <a href="#NxFileSystem">pseudo-file-system</a> and it's
|
|
initialized instance of <code>struct uart_ops_s</code>.
|
|
By convention, serial device drivers are registered at paths like <code>/dev/ttyS0</code>, <code>/dev/ttyS1</code>, etc.
|
|
See the <code>uart_register()</code> implementation in <code>drivers/serial.c</code>.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>User Access</b>.
|
|
Serial drivers are, ultimately, normal <a href="#chardrivers">character drivers</a> and are accessed as other character drivers.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Examples</b>:
|
|
<code>arch/arm/src/chip/lm3s_serial.c</code>, <code>arch/arm/src/lpc214x/lpc214x_serial.c</code>, <code>arch/z16/src/z16f/z16f_serial.c</code>, etc.
|
|
</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="fbdrivers">6.3.5 Frame Buffer Drivers</a></h3>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>
|
|
<b><code>include/nuttx/fb.h</code></b>.
|
|
All structures and APIs needed to work with frame buffer drivers are provided in this header file.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>struct fb_vtable_s</code></b>.
|
|
Each frame buffer device driver must implement an instance of <code>struct fb_vtable_s</code>.
|
|
That structure defines a call table with the following methods:
|
|
</p>
|
|
<p>
|
|
Get information about the video controller configuration and the configuration of each color plane.
|
|
</p>
|
|
<ul>
|
|
<p><code>int (*getvideoinfo)(FAR struct fb_vtable_s *vtable, FAR struct fb_videoinfo_s *vinfo);</code><br>
|
|
<code>int (*getplaneinfo)(FAR struct fb_vtable_s *vtable, int planeno, FAR struct fb_planeinfo_s *pinfo);</code></p>
|
|
</ul>
|
|
<p>
|
|
The following are provided only if the video hardware supports RGB color mapping:
|
|
</p>
|
|
<ul>
|
|
<p><code>int (*getcmap)(FAR struct fb_vtable_s *vtable, FAR struct fb_cmap_s *cmap);</code><br>
|
|
<code>int (*putcmap)(FAR struct fb_vtable_s *vtable, FAR const struct fb_cmap_s *cmap);</code></p>
|
|
</ul>
|
|
<p>
|
|
The following are provided only if the video hardware supports a hardware cursor:
|
|
</p>
|
|
<ul>
|
|
<p><code>int (*getcursor)(FAR struct fb_vtable_s *vtable, FAR struct fb_cursorattrib_s *attrib);</code><br>
|
|
<code>int (*setcursor)(FAR struct fb_vtable_s *vtable, FAR struct fb_setcursor_s *settings);</code></p>
|
|
</ul>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Binding Frame Buffer Drivers</b>.
|
|
Frame buffer drivers are not normally directly accessed by user code, but are usually bound to another,
|
|
higher level device driver.
|
|
In general, the binding sequence is:
|
|
</p>
|
|
<p>
|
|
<ol>
|
|
<li>Get an instance of <code>struct fb_vtable_s</code> from the hardware-specific frame buffer device driver, and </li>
|
|
<li>Provide that instance to the initialization method of the higher level device driver.</li>
|
|
</ol>
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Examples</b>:
|
|
<code>arch/sim/src/up_framebuffer.c</code>.
|
|
See also the usage of the frame buffer driver in the <code>graphics/</code> directory.
|
|
</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="lcddrivers">6.3.6 LCD Drivers</a></h3>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>
|
|
<b><code>include/nuttx/lcd/lcd.h</code></b>.
|
|
Structures and APIs needed to work with LCD drivers are provided in this header file.
|
|
This header file also depends on some of the same definitions used for the frame buffer driver as privided in <code>include/nuttx/fb.h</code>.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>struct lcd_dev_s</code></b>.
|
|
Each LCD device driver must implement an instance of <code>struct lcd_dev_s</code>.
|
|
That structure defines a call table with the following methods:
|
|
</p>
|
|
<p>
|
|
Get information about the LCD video controller configuration and the configuration of each LCD color plane.
|
|
</p>
|
|
<ul>
|
|
<p>
|
|
<code>int (*getvideoinfo)(FAR struct lcd_dev_s *dev, FAR struct fb_videoinfo_s *vinfo);</code><br>
|
|
<code>int (*getplaneinfo)(FAR struct lcd_dev_s *dev, unsigned int planeno, FAR struct lcd_planeinfo_s *pinfo);</code>
|
|
</p>
|
|
</ul>
|
|
<p>
|
|
The following are provided only if the video hardware supports RGB color mapping:
|
|
</p>
|
|
<ul>
|
|
<p>
|
|
<code>int (*getcmap)(FAR struct lcd_dev_s *dev, FAR struct fb_cmap_s *cmap);</code><br>
|
|
<code>int (*putcmap)(FAR struct lcd_dev_s *dev, FAR const struct fb_cmap_s *cmap);</code>
|
|
</p>
|
|
</ul>
|
|
<p>
|
|
The following are provided only if the video hardware supports a hardware cursor:
|
|
</p>
|
|
<ul>
|
|
<p>
|
|
<code>int (*getcursor)(FAR struct lcd_dev_s *dev, FAR struct fb_cursorattrib_s *attrib);</code><br>
|
|
<code>int (*setcursor)(FAR struct lcd_dev_s *dev, FAR struct fb_setcursor_s *settings)</code>
|
|
</p>
|
|
</ul>
|
|
<p>
|
|
Get the LCD panel power status (0: full off - <code>CONFIG_LCD_MAXPOWER</code>: full on).
|
|
On backlit LCDs, this setting may correspond to the backlight setting.
|
|
</p>
|
|
<ul>
|
|
<p>
|
|
<code>int (*getpower)(struct lcd_dev_s *dev);</code>
|
|
</p>
|
|
</ul>
|
|
<p>
|
|
Enable/disable LCD panel power (0: full off - <code>CONFIG_LCD_MAXPOWER</code>: full on).
|
|
On backlit LCDs, this setting may correspond to the backlight setting.
|
|
</p>
|
|
<ul>
|
|
<p>
|
|
<code>int (*setpower)(struct lcd_dev_s *dev, int power);</code>
|
|
</p>
|
|
</ul>
|
|
<p>
|
|
Get the current contrast setting (0-CONFIG_LCD_MAXCONTRAST) */
|
|
</p>
|
|
<ul>
|
|
<p>
|
|
<code>int (*getcontrast)(struct lcd_dev_s *dev);</code>
|
|
</p>
|
|
</ul>
|
|
<p>
|
|
Set LCD panel contrast (0-CONFIG_LCD_MAXCONTRAST)
|
|
</p>
|
|
<ul>
|
|
<p>
|
|
<code>int (*setcontrast)(struct lcd_dev_s *dev, unsigned int contrast);</code>
|
|
</p>
|
|
</ul>
|
|
</p>
|
|
<li>
|
|
<p>
|
|
<b>Binding LCD Drivers</b>.
|
|
LCD drivers are not normally directly accessed by user code, but are usually bound to another,
|
|
higher level device driver.
|
|
In general, the binding sequence is:
|
|
</p>
|
|
<p>
|
|
<ol>
|
|
<li>Get an instance of <code>struct lcd_dev_s</code> from the hardware-specific LCD device driver, and </li>
|
|
<li>Provide that instance to the initialization method of the higher level device driver.</li>
|
|
</ol>
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Examples</b>:
|
|
<code>drivers/lcd/nokia6100.c</code>, <code>drivers/lcd/p14201.c</code>, <code>configs/sam3u-ek/src/up_lcd.c.</code>
|
|
See also the usage of the LCD driver in the <code>graphics/</code> directory.
|
|
</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="mtddrivers">6.3.7 Memory Technology Device Drivers</a></h3>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>
|
|
<b><code>include/nuttx/mtd.h</code></b>.
|
|
All structures and APIs needed to work with MTD drivers are provided in this header file.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>struct mtd_dev_s</code></b>.
|
|
Each MTD device driver must implement an instance of <code>struct mtd_dev_s</code>.
|
|
That structure defines a call table with the following methods:
|
|
</p>
|
|
<p>
|
|
Erase the specified erase blocks (units are erase blocks):
|
|
</p>
|
|
<ul>
|
|
<p><code>int (*erase)(FAR struct mtd_dev_s *dev, off_t startblock, size_t nblocks);</code></p>
|
|
</ul>
|
|
<p>
|
|
Read/write from the specified read/write blocks:
|
|
</p>
|
|
<ul>
|
|
<p><code>ssize_t (*bread)(FAR struct mtd_dev_s *dev, off_t startblock, size_t nblocks, FAR uint8_t *buffer);</code><br>
|
|
<code>ssize_t (*bwrite)(FAR struct mtd_dev_s *dev, off_t startblock, size_t nblocks, FAR const uint8_t *buffer);</code></p>
|
|
</ul>
|
|
<p>
|
|
Some devices may support byte oriented reads (optional).
|
|
Most MTD devices are inherently block oriented so byte-oriented writing is not supported.
|
|
It is recommended that low-level drivers not support read() if it requires buffering.
|
|
</p>
|
|
<ul>
|
|
<p><code>ssize_t (*read)(FAR struct mtd_dev_s *dev, off_t offset, size_t nbytes, FAR uint8_t *buffer);</code></p>
|
|
</ul>
|
|
<p>
|
|
Support other, less frequently used commands:
|
|
</p>
|
|
<ul>
|
|
<li><code>MTDIOC_GEOMETRY</code>: Get MTD geometry</li>
|
|
<li><code>MTDIOC_XIPBASE:</code>: Convert block to physical address for eXecute-In-Place</li>
|
|
<li><code>MTDIOC_BULKERASE</code>: Erase the entire device</li>
|
|
</ul>
|
|
<p>
|
|
is provided via a sinble <code>ioctl</code> method (see <code>include/nuttx/fs/ioctl.h</code>):
|
|
</p>
|
|
<ul>
|
|
<p><code>int (*ioctl)(FAR struct mtd_dev_s *dev, int cmd, unsigned long arg);</code></p>
|
|
</ul>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Binding MTD Drivers</b>.
|
|
MTD drivers are not normally directly accessed by user code, but are usually bound to another,
|
|
higher level device driver.
|
|
In general, the binding sequence is:
|
|
</p>
|
|
<p>
|
|
<ol>
|
|
<li>Get an instance of <code>struct mtd_dev_s</code> from the hardware-specific MTD device driver, and </li>
|
|
<li>Provide that instance to the initialization method of the higher level device driver.</li>
|
|
</ol>
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Examples</b>:
|
|
<code>drivers/mtd/m25px.c</code> and <code>drivers/mtd/ftl.c</code>
|
|
</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="sdiodrivers">6.3.8 SDIO Device Drivers</a></h3>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>
|
|
<b><code>include/nuttx/sdio.h</code></b>.
|
|
All structures and APIs needed to work with SDIO drivers are provided in this header file.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>struct sdio_dev_s</code></b>.
|
|
Each SDIOI device driver must implement an instance of <code>struct sdio_dev_s</code>.
|
|
That structure defines a call table with the following methods:
|
|
</p>
|
|
<p>
|
|
Mutual exclusion:
|
|
</p>
|
|
<ul>
|
|
<p>
|
|
<code>#ifdef CONFIG_SDIO_MUXBUS</code><br>
|
|
<code> int (*lock)(FAR struct sdio_dev_s *dev, bool lock);</code><br>
|
|
<code>#endif</code>
|
|
</p>
|
|
</ul>
|
|
<p>
|
|
Initialization/setup:
|
|
</p>
|
|
<ul>
|
|
<p><code>void (*reset)(FAR struct sdio_dev_s *dev);</code><br>
|
|
<code>uint8_t (*status)(FAR struct sdio_dev_s *dev);</code><br>
|
|
<code>void (*widebus)(FAR struct sdio_dev_s *dev, bool enable);</code><br>
|
|
<code>void (*clock)(FAR struct sdio_dev_s *dev, enum sdio_clock_e rate);</code><br>
|
|
<code>int (*attach)(FAR struct sdio_dev_s *dev);</code><br>
|
|
</ul>
|
|
<p>
|
|
Command/Status/Data Transfer:
|
|
</p>
|
|
<ul>
|
|
<p><code>int (*sendcmd)(FAR struct sdio_dev_s *dev, uint32_t cmd, uint32_t arg);</code><br>
|
|
<code>int (*recvsetup)(FAR struct sdio_dev_s *dev, FAR uint8_t *buffer, size_t nbytes);</code><br>
|
|
<code>int (*sendsetup)(FAR struct sdio_dev_s *dev, FAR const uint8_t *buffer, size_t nbytes);</code><br>
|
|
<code>int (*cancel)(FAR struct sdio_dev_s *dev);</code><br>
|
|
<code>int (*waitresponse)(FAR struct sdio_dev_s *dev, uint32_t cmd);</code><br>
|
|
<code>int (*recvR1)(FAR struct sdio_dev_s *dev, uint32_t cmd, uint32_t *R1);</code><br>
|
|
<code>int (*recvR2)(FAR struct sdio_dev_s *dev, uint32_t cmd, uint32_t R2[4]);</code><br>
|
|
<code>int (*recvR3)(FAR struct sdio_dev_s *dev, uint32_t cmd, uint32_t *R3);</code><br>
|
|
<code>int (*recvR4)(FAR struct sdio_dev_s *dev, uint32_t cmd, uint32_t *R4);</code><br>
|
|
<code>int (*recvR5)(FAR struct sdio_dev_s *dev, uint32_t cmd, uint32_t *R5);</code><br>
|
|
<code>int (*recvR6)(FAR struct sdio_dev_s *dev, uint32_t cmd, uint32_t *R6);</code><br>
|
|
<code>int (*recvR7)(FAR struct sdio_dev_s *dev, uint32_t cmd, uint32_t *R7);</code></p>
|
|
</ul>
|
|
<p>
|
|
Event/Callback support:
|
|
</p>
|
|
<ul>
|
|
<p><code>void (*waitenable)(FAR struct sdio_dev_s *dev, sdio_eventset_t eventset);</code><br>
|
|
<code>sdio_eventset_t (*eventwait)(FAR struct sdio_dev_s *dev, uint32_t timeout);</code><br>
|
|
<code>void (*callbackenable)(FAR struct sdio_dev_s *dev, sdio_eventset_t eventset);</code><br>
|
|
<code>int (*registercallback)(FAR struct sdio_dev_s *dev, worker_t callback, void *arg);</code></p>
|
|
</ul>
|
|
<p>
|
|
DMA support:
|
|
</p>
|
|
<ul>
|
|
<p><code>bool (*dmasupported)(FAR struct sdio_dev_s *dev);</code><br>
|
|
<code>int (*dmarecvsetup)(FAR struct sdio_dev_s *dev, FAR uint8_t *buffer, size_t buflen);</code><br>
|
|
<code>int (*dmasendsetup)(FAR struct sdio_dev_s *dev, FAR const uint8_t *buffer, size_t buflen);</code></p>
|
|
</ul>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Binding SDIO Drivers</b>.
|
|
SDIO drivers are not normally directly accessed by user code, but are usually bound to another,
|
|
higher level device driver.
|
|
In general, the binding sequence is:
|
|
</p>
|
|
<p>
|
|
<ol>
|
|
<li>Get an instance of <code>struct sdio_dev_s</code> from the hardware-specific SDIO device driver, and </li>
|
|
<li>Provide that instance to the initialization method of the higher level device driver.</li>
|
|
</ol>
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Examples</b>:
|
|
<code>arch/arm/src/stm32/stm32_sdio.c</code> and <code>drivers/mmcsd/mmcsd_sdio.c</code>
|
|
</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="usbhostdrivers">6.3.9 USB Host-Side Drivers</a></h3>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>
|
|
<b><code>include/nuttx/usb/usbhost.h</code></b>.
|
|
All structures and APIs needed to work with USB host-side drivers are provided in this header file.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>struct usbhost_driver_s</code></b>.
|
|
Each USB host controller driver must implement an instance of <code>struct usbhost_driver_s</code>.
|
|
This structure is defined in <code>include/nuttx/usb/usbhost.h</code>.
|
|
</p>
|
|
<p>
|
|
<b>Examples</b>:
|
|
<code>arch/arm/src/lpc17xx/lpc17_usbhost.c</code>.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>struct usbhost_class_s</code></b>.
|
|
Each USB host class driver must implement an instance of <code>struct usbhost_class_s</code>.
|
|
This structure is also defined in <code>include/nuttx/usb/usbhost.h</code>.
|
|
</p>
|
|
<p>
|
|
<b>Examples</b>:
|
|
<code>drivers/usbhost/usbhost_storage.c</code>
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>USB Host Class Driver Registry</b>.
|
|
The NuttX USB host infrastructure includes a <i>registry</i>.
|
|
During its initialization, each USB host class driver must call the interface, <code>usbhost_registerclass()</code>
|
|
in order add its interface to the registery.
|
|
Later, when a USB device is connected, the USB host controller will look up the USB host class driver that is needed to support the connected device in this registry.
|
|
</p>
|
|
<p>
|
|
<b>Examples</b>:
|
|
<code>drivers/usbhost/usbhost_registry.c</code>, <code>drivers/usbhost/usbhost_registerclass.c</code>, and <code>drivers/usbhost/usbhost_findclass.c</code>,
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Detection and Enumeration of Connected Devices</b>.
|
|
Each USB host device controller supports two methods that are used to detect and enumeration newly connected devices
|
|
(and also detect disconnected devices):
|
|
</p>
|
|
<p>
|
|
<ul>
|
|
<li>
|
|
<p>
|
|
<code>int (*wait)(FAR struct usbhost_driver_s *drvr, bool connected);</code>
|
|
</p>
|
|
<p>
|
|
Wait for a device to be connected or disconnected.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<code>int (*enumerate)(FAR struct usbhost_driver_s *drvr);</code>
|
|
</p>
|
|
<p>
|
|
Enumerate the connected device.
|
|
As part of this enumeration process, the driver will
|
|
(1) get the device's configuration descriptor,
|
|
(2) extract the class ID info from the configuration descriptor,
|
|
(3) call <code>usbhost_findclass(</code>) to find the class that supports this device,
|
|
(4) call the <code>create()</code> method on the <code>struct usbhost_registry_s interface</code> to get a class instance, and
|
|
finally (5) call the <code>connect()</code> method of the <code>struct usbhost_class_s</code> interface.
|
|
After that, the class is in charge of the sequence of operations.
|
|
</p>
|
|
</ul>
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Binding USB Host-Side Drivers</b>.
|
|
USB host-side controller drivers are not normally directly accessed by user code,
|
|
but are usually bound to another, higher level USB host class driver.
|
|
The class driver exports the standard NuttX device interface so that the connected USB device can be accessed just as with other, similar, on-board devices.
|
|
For example, the USB host mass storage class driver (<code>drivers/usbhost/usbhost_storage.c</code>) will register a standard, NuttX block driver interface (like <code>/dev/sda</code>)
|
|
that can be used to mount a file system just as with any other other block driver instance.
|
|
In general, the binding sequence is:
|
|
</p>
|
|
<p>
|
|
<ol>
|
|
<li>
|
|
<p>
|
|
Each USB host class driver includes an intialization entry point that is called from the
|
|
application at initialization time.
|
|
This driver calls <code>usbhost_registerclass()</code> during this initialization in order to makes itself available in the event the the device that it supports is connected.
|
|
</p>
|
|
<p>
|
|
<b>Examples</b>:
|
|
The function <code>usbhost_storageinit()</code> in the file <code>drivers/usbhost/usbhost_storage.c</code>
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
Each application must include a <i>waiter</i> thread thread that (1) calls the USB host controller driver's <code>wait()</code> to detect the connection of a device, and then
|
|
(2) call the USB host controller driver's <code>enumerate</code> method to bind the registered USB host class driver to the USB host controller driver.
|
|
</p>
|
|
<p>
|
|
<b>Examples</b>:
|
|
The function <code>nsh_waiter()</code> in the file <code>configs/nucleus2g/src/up_nsh.c</code> and
|
|
the function <code>nsh_waiter()</code> in the file <code>configs/olimex-lpc1766stk/src/up_nsh.c</code>.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
As part of its operation during the binding operation, the USB host class driver will register an instances of a standard NuttX driver under the <code>/dev</code> directory.
|
|
To repeat the above example, the USB host mass storage class driver (<code>drivers/usbhost/usbhost_storage.c</code>) will register a standard, NuttX block driver interface (like <code>/dev/sda</code>)
|
|
that can be used to mount a file system just as with any other other block driver instance.
|
|
</p>
|
|
<p>
|
|
<b>Examples</b>:
|
|
See the call to <code>register_blockdriver()</code> in the function <code>usbhost_initvolume()</code> in the file <code>drivers/usbhost/usbhost_storage.c</code>.
|
|
</p>
|
|
</li>
|
|
</ol>
|
|
</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="usbdevdrivers">6.3.10 USB Device-Side Drivers</a></h3>
|
|
|
|
<ul>
|
|
<li>
|
|
<p>
|
|
<b><code>include/nuttx/usb/usbdev.h</code></b>.
|
|
All structures and APIs needed to work with USB device-side drivers are provided in this header file.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>include/nuttx/usb/usbdev_trace.h</code></b>.
|
|
Declarations needed to work the the NuttX USB device driver trace capability.
|
|
That USB trace capability is detailed in <a href="UsbTrace.html">separate document</a>.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>struct usbdev_s</code></b>.
|
|
Each USB device controller driver must implement an instance of <code>struct usbdev_s</code>.
|
|
This structure is defined in <code>include/nuttx/usb/usbdev.h</code>.
|
|
</p>
|
|
<p>
|
|
<b>Examples</b>:
|
|
<code>arch/arm/src/dm320/dm320_usbdev.c</code>, <code>arch/arm/src/lpc17xx/lpc17_usbdev.c</code>,
|
|
<code>arch/arm/src/lpc214x/lpc214x_usbdev.c</code>, <code>arch/arm/src/lpc313x/lpc313x_usbdev.c</code>, and
|
|
<code>arch/arm/src/stm32/stm32_usbdev.c</code>.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>struct usbdevclass_driver_s</code></b>.
|
|
Each USB device class driver must implement an instance of <code>struct usbdevclass_driver_s</code>.
|
|
This structure is also defined in <code>include/nuttx/usb/usbdev.h</code>.
|
|
</p>
|
|
<p>
|
|
<b>Examples</b>:
|
|
<code>drivers/usbdev/pl2303.c</code> and <code>drivers/usbdev/usbmsc.c</code>
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Binding USB Device-Side Drivers</b>.
|
|
USB device-side controller drivers are not normally directly accessed by user code,
|
|
but are usually bound to another, higher level USB device class driver.
|
|
The class driver is then configured to export the USB device functionality.
|
|
In general, the binding sequence is:
|
|
</p>
|
|
<p>
|
|
<ol>
|
|
<li>
|
|
<p>
|
|
Each USB device class driver includes an intialization entry point that is called from the
|
|
application at initialization time.
|
|
</p>
|
|
<p>
|
|
<b>Examples</b>:
|
|
The function <code>usbdev_serialinitialize()</code> in the file <code>drivers/usbdev/pl2303.c</code> and
|
|
the function <code></code> in the file <code>drivers/usbdev/usbmsc.c</code>
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
These initialization functions called the driver API, <code>usbdev_register()</code>.
|
|
This driver function will <i>bind</i> the USB class driver to the USB device controller driver,
|
|
completing the initialization.
|
|
</p>
|
|
</li>
|
|
</ol>
|
|
</p>
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="analogdrivers">6.3.11 Analog (ADC/DAC) Drivers</a></h3>
|
|
<p>
|
|
The NuttX PWM driver is split into two parts:
|
|
</p>
|
|
<ol>
|
|
<li>
|
|
An "upper half", generic driver that provides the comman PWM interface to application level code, and
|
|
</li>
|
|
<li>
|
|
A "lower half", platform-specific driver that implements the low-level timer controls to implement the PWM functionality.
|
|
</li>
|
|
</ol>
|
|
<ul>
|
|
<li>
|
|
General header files for the NuttX analog drivers reside in <code>include/nuttx/analog/</code>.
|
|
These header files includes both the application level interface to the analog driver as well as the interface between the "upper half" and "lower half" drivers.
|
|
</li>
|
|
<li>
|
|
Common analog logic and share-able analog drivers reside in the <code>drivers/analog/</code>.
|
|
</li>
|
|
<li>
|
|
Platform-specific drivers reside in <code>arch/</code><i><architecture></i><code>/src/</code><i><chip></i> directory for the specific processor <i><architecture></i> and for the specific <i><chip></i> analog peripheral devices.
|
|
</li>
|
|
</ul>
|
|
|
|
<h4><a name="adcdrivers">6.3.11.1 ADC Drivers</a></h4>
|
|
<ul>
|
|
<li>
|
|
<code>include/nuttx/analog/adc.h</code>.
|
|
All structures and APIs needed to work with ADC drivers are provided in this header file.
|
|
This header file includes:
|
|
<ol>
|
|
<li>
|
|
Structures and interface descriptions needed to develop a low-level,
|
|
architecture-specific, ADC driver.
|
|
</li>
|
|
<li>
|
|
To register the ADC driver with a common ADC character driver.
|
|
</li>
|
|
<li>
|
|
Interfaces needed for interfacing user programs with the common ADC character driver.
|
|
</li>
|
|
</ol>
|
|
</li>
|
|
<li>
|
|
<code>drivers/analog/adc.c</code>.
|
|
The implementation of the common ADC character driver.
|
|
</li>
|
|
</ul>
|
|
|
|
<h4><a name="dacdrivers">6.3.11.2 DAC Drivers</a></h4>
|
|
<ul>
|
|
<li>
|
|
<code>include/nuttx/analog/dac.h</code>.
|
|
All structures and APIs needed to work with DAC drivers are provided in this header file.
|
|
This header file includes:
|
|
<ol>
|
|
<li>
|
|
Structures and interface descriptions needed to develop a low-level,
|
|
architecture-specific, DAC driver.
|
|
</li>
|
|
<li>
|
|
To register the DAC driver with a common DAC character driver.
|
|
</li>
|
|
<li>
|
|
Interfaces needed for interfacing user programs with the common DAC character driver.
|
|
</li>
|
|
</ol>
|
|
</li>
|
|
<li>
|
|
<code>drivers/analog/dac.c</code>.
|
|
The implementation of the common DAC character driver.
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="pwmdrivers">6.3.12 PWM Drivers</a></h3>
|
|
<p>
|
|
For the purposes of this driver, a PWM device is any device that generates periodic output pulses of controlled frequency and pulse width.
|
|
Such a device might be used, for example, to perform pulse-width modulated output or frequency/pulse-count modulated output
|
|
(such as might be needed to control a stepper motor).
|
|
</p>
|
|
<p>
|
|
The NuttX PWM driver is split into two parts:
|
|
</p>
|
|
<ol>
|
|
<li>
|
|
An "upper half", generic driver that provides the comman PWM interface to application level code, and
|
|
</li>
|
|
<li>
|
|
A "lower half", platform-specific driver that implements the low-level timer controls to implement the PWM functionality.
|
|
</li>
|
|
</ol>
|
|
<p>
|
|
Files supporting PWM can be found in the following locations:
|
|
</p>
|
|
<ul>
|
|
<li><b>Interface Definition</b>.
|
|
The header file for the NuttX PWM driver reside at <code>include/nuttx/pwm.h</code>.
|
|
This header file includes both the application level interface to the PWM driver as well as the interface between the "upper half" and "lower half" drivers.
|
|
The PWM module uses a standard character driver framework.
|
|
However, since the PWM driver is a devices control interface and not a data transfer interface,
|
|
the majority of the functionality available to the application is implemented in driver ioctl calls.
|
|
</li>
|
|
<li><b>"Upper Half" Driver</b>.
|
|
The generic, "upper half" PWM driver resides at <code>drivers/pwm.c</code>.
|
|
</li>
|
|
<li><b>"Lower Half" Drivers</b>.
|
|
Platform-specific PWM drivers reside in <code>arch/</code><i><architecture></i><code>/src/</code><i><chip></i> directory for the specific processor <i><architecture></i> and for the specific <i><chip></i> PWM peripheral devices.
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="candrivers">6.3.13 CAN Drivers</a></h3>
|
|
<p>
|
|
NuttX supports only a very low-level CAN driver.
|
|
This driver supports only the data exchange and does not include any high-level CAN protocol.
|
|
The NuttX CAN driver is split into two parts:
|
|
</p>
|
|
<ol>
|
|
<li>
|
|
An "upper half", generic driver that provides the comman CAN interface to application level code, and
|
|
</li>
|
|
<li>
|
|
A "lower half", platform-specific driver that implements the low-level timer controls to implement the CAN functionality.
|
|
</li>
|
|
</ol>
|
|
<p>
|
|
Files supporting CAN can be found in the following locations:
|
|
</p>
|
|
<ul>
|
|
<li><b>Interface Definition</b>.
|
|
The header file for the NuttX CAN driver reside at <code>include/nuttx/can.h</code>.
|
|
This header file includes both the application level interface to the CAN driver as well as the interface between the "upper half" and "lower half" drivers.
|
|
The CAN module uses a standard character driver framework.
|
|
</li>
|
|
<li><b>"Upper Half" Driver</b>.
|
|
The generic, "upper half" CAN driver resides at <code>drivers/can.c</code>.
|
|
</li>
|
|
<li><b>"Lower Half" Drivers</b>.
|
|
Platform-specific CAN drivers reside in <code>arch/</code><i><architecture></i><code>/src/</code><i><chip></i> directory for the specific processor <i><architecture></i> and for the specific <i><chip></i> CAN peripheral devices.
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="quadencoder">6.3.14 Quadrature Encoder Drivers</a></h3>
|
|
<p>
|
|
NuttX supports a low-level, two-part Quadrature Encoder driver.
|
|
</p>
|
|
<ol>
|
|
<li>
|
|
An "upper half", generic driver that provides the comman Quadrature Encoder interface to application level code, and
|
|
</li>
|
|
<li>
|
|
A "lower half", platform-specific driver that implements the low-level timer controls to implement the Quadrature Encoder functionality.
|
|
</li>
|
|
</ol>
|
|
<p>
|
|
Files supporting the Quadrature Encoder can be found in the following locations:
|
|
</p>
|
|
<ul>
|
|
<li><b>Interface Definition</b>.
|
|
The header file for the NuttX Quadrature Encoder driver reside at <code>include/nuttx/sensors/qencoder.h</code>.
|
|
This header file includes both the application level interface to the Quadrature Encoder driver as well as the interface between the "upper half" and "lower half" drivers.
|
|
The Quadrature Encoder module uses a standard character driver framework.
|
|
</li>
|
|
<li><b>"Upper Half" Driver</b>.
|
|
The generic, "upper half" Quadrature Encoder driver resides at <code>drivers/sensors/qencoder.c</code>.
|
|
</li>
|
|
<li><b>"Lower Half" Drivers</b>.
|
|
Platform-specific Quadrature Encoder drivers reside in <code>arch/</code><i><architecture></i><code>/src/</code><i><chip></i> directory for the specific processor <i><architecture></i> and for the specific <i><chip></i> Quadrature Encoder peripheral devices.
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="wdogdriver">6.3.15 Watchdog Timer Drivers</a></h3>
|
|
<p>
|
|
NuttX supports a low-level, two-part watchdog timer driver.
|
|
</p>
|
|
<ol>
|
|
<li>
|
|
An "upper half", generic driver that provides the comman watchdog timer interface to application level code, and
|
|
</li>
|
|
<li>
|
|
A "lower half", platform-specific driver that implements the low-level timer controls to implement the watchdog timer functionality.
|
|
</li>
|
|
</ol>
|
|
<p>
|
|
Files supporting the watchdog timer can be found in the following locations:
|
|
</p>
|
|
<ul>
|
|
<li><b>Interface Definition</b>.
|
|
The header file for the NuttX watchdog timer driver reside at <code>include/nuttx/watchdog.h</code>.
|
|
This header file includes both the application level interface to the watchdog timer driver as well as the interface between the "upper half" and "lower half" drivers.
|
|
The watchdog timer driver uses a standard character driver framework.
|
|
</li>
|
|
<li><b>"Upper Half" Driver</b>.
|
|
The generic, "upper half" watchdog timer driver resides at <code>drivers/watchdog.c</code>.
|
|
</li>
|
|
<li><b>"Lower Half" Drivers</b>.
|
|
Platform-specific watchdog timer drivers reside in <code>arch/</code><i><architecture></i><code>/src/</code><i><chip></i> directory for the specific processor <i><architecture></i> and for the specific <i><chip></i> watchdog timer peripheral devices.
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="kbddriver">6.3.16 Keyboard/Keypad Drivers</a></h3>
|
|
<p>
|
|
<b>Keypads vs. Keyboards</b>
|
|
Keyboards and keypads are really the same devices for NuttX.
|
|
A keypad is thought of as simply a keyboard with fewer keys.
|
|
</p>
|
|
<p>
|
|
<b>Special Commands</b>.
|
|
In NuttX, a keyboard/keypad driver is simply a character driver that may have an (optional) encoding/decoding layer on the data returned by the character driver.
|
|
A keyboard may return simple text data (alphabetic, numeric, and punctuaction) or control characters (enter, control-C, etc.) when a key is pressed.
|
|
We can think about this the "normal" keyboard data stream.
|
|
However, in addition, most keyboards support actions that cannot be represented as text or control data.
|
|
Such actions include things like cursor controls (home, up arrow, page down, etc.), editing functions (insert, delete, etc.), volume controls, (mute, volume up, etc.) and other special functions.
|
|
In this case, some special encoding may be required to multiplex the normal text data and special command key press data streams.
|
|
</p>
|
|
<p>
|
|
<b>Key Press and Release Events</b>
|
|
Sometimes the time that a key is released is needed by applications as well.
|
|
Thus, in addition to normal and special key press events, it may also be necessary to encode normal and special key release events.
|
|
</p>
|
|
<p>
|
|
<b>Encoding/Decoding</b> Layer</b>.
|
|
An optional encoding/decoding layer can be used with the basic character driver to encode the keyboard events into the text data stream.
|
|
The function interfaces that comprise that encoding/decoding layer are defined in the header file <code>include/nuttx/input/kbd_code.h</code>.
|
|
These functions provide an matched set of (a) driver encoding interfaces, and (b) application decoding interfaces.
|
|
</p>
|
|
<ol>
|
|
<li>
|
|
<p>
|
|
<b>Driver Encoding Interfaces</b>.
|
|
These are interfaces used by the keyboard/keypad driver to encode keyboard events and data.
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<p>
|
|
<b><code>kbd_press()</code></b>
|
|
</p>
|
|
<p><b>Function Prototype:</b></p>
|
|
<ul><pre>
|
|
#include <nuttx/streams.h>
|
|
#include <nuttx/input/kbd_codec.h>
|
|
void kbd_press(int ch, FAR struct lib_outstream_s *stream);
|
|
</pre></ul>
|
|
<p><b>Description:</b></p>
|
|
<ul>
|
|
Indicates a normal key press event.
|
|
Put one byte of normal keyboard data into the output stream.
|
|
</ul>
|
|
<p><b>Input Pameters:</b></p>
|
|
<ul>
|
|
<li>
|
|
<code>ch</code>: The character to be added to the output stream.
|
|
</li>
|
|
<li>
|
|
<code>stream</code>: An instance of <code>lib_outstream_s</code> to perform the actual low-level put operation.
|
|
</li>
|
|
</ul>
|
|
<p><b>Returned Value:</b></p>
|
|
<ul>
|
|
None.
|
|
</ul>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>kbd_release()</code></b>
|
|
</p>
|
|
<p><b>Function Prototype:</b></p>
|
|
<ul><pre>
|
|
#include <nuttx/streams.h>
|
|
#include <nuttx/input/kbd_codec.h>
|
|
void kbd_release(uint8_t ch, FAR struct lib_outstream_s *stream);
|
|
</pre></ul>
|
|
<p><b>Description:</b></p>
|
|
<ul>
|
|
Encode the release of a normal key.
|
|
</ul>
|
|
<p><b>Input Pameters:</b></p>
|
|
<ul>
|
|
<li>
|
|
<code>ch</code>: The character associated with the key that was releared.
|
|
</li>
|
|
<li>
|
|
<code>stream</code>: An instance of <code>lib_outstream_s</code> to perform the actual low-level put operation.
|
|
</li>
|
|
</ul>
|
|
<p><b>Returned Value:</b></p>
|
|
<ul>
|
|
None.
|
|
</ul>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>kbd_specpress()</code></b>
|
|
</p>
|
|
<p><b>Function Prototype:</b></p>
|
|
<ul><pre>
|
|
#include <nuttx/streams.h>
|
|
#include <nuttx/input/kbd_codec.h>
|
|
void kbd_specpress(enum kbd_keycode_e keycode, FAR struct lib_outstream_s *stream);
|
|
</pre></ul>
|
|
<p><b>Description:</b></p>
|
|
<ul>
|
|
Denotes a special key press event.
|
|
Put one special keyboard command into the output stream.
|
|
</ul>
|
|
<p><b>Input Pameters:</b></p>
|
|
<ul>
|
|
<li>
|
|
<code>keycode</code>: The command to be added to the output stream.
|
|
The enumeration <code>enum kbd_keycode_e keycode</code> identifies all commands known to the system.
|
|
</li>
|
|
<li>
|
|
<code>stream</code>: An instance of <code>lib_outstream_s</code> to perform the actual low-level put operation.
|
|
</li>
|
|
</ul>
|
|
<p><b>Returned Value:</b></p>
|
|
<ul>
|
|
None.
|
|
</ul>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b><code>kbd_specrel()</code></b>
|
|
</p>
|
|
<p><b>Function Prototype:</b></p>
|
|
<ul><pre>
|
|
#include <nuttx/streams.h>
|
|
#include <nuttx/input/kbd_codec.h>
|
|
void kbd_specrel(enum kbd_keycode_e keycode, FAR struct lib_outstream_s *stream);
|
|
</pre></ul>
|
|
<p><b>Description:</b></p>
|
|
<ul>
|
|
Denotes a special key release event.
|
|
Put one special keyboard command into the output stream.
|
|
</ul>
|
|
<p><b>Input Pameters:</b></p>
|
|
<ul>
|
|
<li>
|
|
<code>keycode</code>: The command to be added to the output stream.
|
|
The enumeration <code>enum kbd_keycode_e keycode</code> identifies all commands known to the system.
|
|
</li>
|
|
<li>
|
|
<code>stream</code>: An instance of <code>lib_outstream_s</code> to perform the actual low-level put operation.
|
|
</li>
|
|
</ul>
|
|
<p><b>Returned Value:</b></p>
|
|
<ul>
|
|
None.
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
<b>Application Decoding Interfaces</b>.
|
|
These are user interfaces to decode the values returned by the keyboard/keypad driver.
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<p>
|
|
<b><code>kbd_decode()</code></b>
|
|
</p>
|
|
<p><b>Function Prototype:</b></p>
|
|
<ul><pre>
|
|
#include <nuttx/streams.h>
|
|
#include <nuttx/input/kbd_codec.h>
|
|
int kbd_decode(FAR struct lib_instream_s *stream, FAR struct kbd_getstate_s *state, FAR uint8_t *pch);
|
|
</pre></ul>
|
|
<p><b>Description:</b></p>
|
|
<ul>
|
|
Get one byte of data or special command from the driver provided input buffer.
|
|
</ul>
|
|
<p><b>Input Pameters:</b></p>
|
|
<ul>
|
|
<li>
|
|
<code>stream</code>: An instance of <code>lib_instream_s</code> to perform the actual low-level get operation.
|
|
</li>
|
|
<li>
|
|
<code>pch</code>: The location to save the returned value.
|
|
This may be either a normal, character code or a special command (i.e., a value from <code>enum kbd_getstate_s</code>.
|
|
</li>
|
|
<li>
|
|
<code>state</code>: A user provided buffer to support parsing.
|
|
This structure should be cleared the first time that <code>kbd_decode()</code> is called.
|
|
</li>
|
|
</ul>
|
|
<p><b>Returned Value:</b></p>
|
|
<ul>
|
|
<li>
|
|
<b><code>KBD_PRESS</code> (0)</b>:
|
|
Indicates the successful receipt of normal, keyboard data.
|
|
This corresponds to a keypress event.
|
|
The returned value in <code>pch</code> is a simple byte of text or control data.
|
|
</li>
|
|
<li>
|
|
<b><code>KBD_RELEASE</code> (1)</b>:
|
|
Indicates a key release event.
|
|
The returned value in <code>pch</code> is the byte of text or control data corresponding to the released key.
|
|
</li>
|
|
<li>
|
|
<b><code>KBD_SPECPRESS</code> (2)</b>:
|
|
Indicates the successful receipt of a special keyboard command.
|
|
The returned value in <code>pch</code> is a value from <code>enum kbd_getstate_s</code>.
|
|
</li>
|
|
<li>
|
|
<b><code>KBD_SPECREL</code> (3)</b>:
|
|
Indicates a special command key release event.
|
|
The returned value in <code>pch</code> is a value from <code>enum kbd_getstate_s</code>.
|
|
</li>
|
|
<li>
|
|
<b><code>KBD_ERROR</code> (<code>EOF</code>)</b>:
|
|
An error has getting the next character (reported by the <code>stream</code>).
|
|
Normally indicates the end of file.
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
</ol>
|
|
<p>
|
|
<b>I/O Streams</b>.
|
|
Notice the use of the abstract I/O streams in these interfaces.
|
|
These stream interfaces are defined in <code>include/nuttx/streams.h</code>.
|
|
</p>
|
|
|
|
<h2><a name="pwrmgmt">6.4 Power Management</a></h2>
|
|
|
|
<h3><a name="pmoverview">6.4.1 Overview</a></h3>
|
|
<p>
|
|
NuttX supports a simple power managment (PM) sub-system. This sub-system:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<p>
|
|
Monitors driver activity, and
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
Provides hooks to place drivers (and the whole system) into reduce power
|
|
modes of operation.
|
|
</p>
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
<center><img src="pm.png"></center>
|
|
</p>
|
|
<p>
|
|
The PM sub-system integrates the MCU idle loop with a collection of device drivers to support:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<p>
|
|
Reports of relevant driver or other system activity.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
Registration and callback mechanism to interface with individual device drivers.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
IDLE time polling of overall driver activity.
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<p>
|
|
Coordinated, global, system-wide transitions to lower power usage states.
|
|
</p>
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
Various "sleep" and low power consumption states have various names and are sometimes used in conflicting ways.
|
|
In the NuttX PM logic, we will use the following terminology:
|
|
</p>
|
|
<dl>
|
|
<dt><code>NORMAL</code>
|
|
<dd>The normal, full power operating mode.
|
|
<dt><code>IDLE</code>
|
|
<dd>This is still basically normal operational mode, the system is,
|
|
however, <code>IDLE</code> and some simple simple steps to reduce power
|
|
consumption provided that they do not interfere with normal
|
|
Operation. Simply dimming the a backlight might be an example
|
|
somethat that would be done when the system is idle.
|
|
<dt><code>STANDBY</code>
|
|
<dd>Standby is a lower power consumption mode that may involve more
|
|
extensive power management steps such has disabling clocking or
|
|
setting the processor into reduced power consumption modes. In
|
|
this state, the system should still be able to resume normal
|
|
activity almost immediately.
|
|
<dt><code>SLEEP</code>
|
|
<dd>The lowest power consumption mode. The most drastic power
|
|
reduction measures possible should be taken in this state. It
|
|
may require some time to get back to normal operation from
|
|
<code>SLEEP</code> (some MCUs may even require going through reset).
|
|
</dl>
|
|
<p>
|
|
These various states are represented with type <code>enum pm_state_e</code> in <code>include/nuttx/power/pm.h</code>.
|
|
</p>
|
|
|
|
<h3><a name="pminterfaces">6.4.2 Interfaces</a></h3>
|
|
<p>
|
|
All PM interfaces are declared in the file <code>include/nuttx/power/pm.h</code>.
|
|
</p>
|
|
|
|
<h4><a name="pminitialize">6.4.2.1 <code>pm_initialize()</code></a></h4>
|
|
<p><b>Function Prototype:</b></p>
|
|
<ul><pre>
|
|
#include <nuttx/power/pm.h>
|
|
void pm_initialize(void);
|
|
</pre></ul>
|
|
<p><b>Description:</b>
|
|
This function is called by MCU-specific one-time at power on reset in order to initialize the power management capabilities.
|
|
This function must be called <i>very</i> early in the intialization sequence <i>before</i> any other device drivers are initialize (since they may attempt to register with the power management subsystem).
|
|
</p>
|
|
<p><b>Input Parameters:</b>
|
|
None
|
|
</p>
|
|
<p><b>Returned Value:</b>
|
|
None
|
|
</p>
|
|
|
|
<h4><a name="pmregister">6.4.2.2 <code>pm_register()</code></a></h4>
|
|
<p><b>Function Prototype:</b></p>
|
|
<ul><pre>
|
|
#include <nuttx/power/pm.h>
|
|
int pm_register(FAR struct pm_callback_s *callbacks);
|
|
</pre></ul>
|
|
<p><b>Description:</b>
|
|
This function is called by a device driver in order to register to receive power management event callbacks.
|
|
Refer to the <a href="#pmcallbacks">PM Callback</a> section for more details.
|
|
</p>
|
|
<p><b>Input Parameters:</b>
|
|
<dl>
|
|
<dt><code>callbacks</code>
|
|
<dd>An instance of <code>struct pm_callback_s</code> providing the driver callback functions.
|
|
</dl>
|
|
</p>
|
|
<p><b>Returned Value:</b>
|
|
Zero (<code>OK</code>) on success; otherwise a negater <code>errno</code> value is returned.
|
|
</p>
|
|
|
|
<h4><a name="pmactivity">6.4.2.3 <code>pm_activity()</code></a></h4>
|
|
<p><b>Function Prototype:</b></p>
|
|
<ul><pre>
|
|
#include <nuttx/power/pm.h>
|
|
void pm_activity(int priority);
|
|
</pre></ul>
|
|
<p><b>Description:</b>
|
|
This function is called by a device driver to indicate that it is performing meaningful activities (non-idle).
|
|
This increment an activty count and/or will restart a idle timer and prevent entering reduced power states.
|
|
</p>
|
|
<p><b>Input Parameters:</b>
|
|
<dl>
|
|
<dt><code>priority</code>
|
|
<dd>
|
|
Activity priority, range 0-9.
|
|
Larger values correspond to higher priorities.
|
|
Higher priority activity can prevent the system from entering reduced power states for a longer period of time.
|
|
As an example, a button press might be higher priority activity because it means that the user is actively interacting with the device.
|
|
</dl>
|
|
</p>
|
|
<p><b>Returned Value:</b>
|
|
None
|
|
</p>
|
|
<p><b>Assumptions:</b>
|
|
This function may be called from an interrupt handler (this is the ONLY PM function that may be called from an interrupt handler!).
|
|
</p>
|
|
|
|
<h4><a name="pmcheckstate">6.4.2.4 <code>pm_checkstate()</code></a></h4>
|
|
<p><b>Function Prototype:</b></p>
|
|
<ul><pre>
|
|
#include <nuttx/power/pm.h>
|
|
enum pm_state_e pm_checkstate(void);
|
|
</pre></ul>
|
|
<p><b>Description:</b>
|
|
This function is called from the MCU-specific IDLE loop to monitor the the power management conditions.
|
|
This function returns the "recommended" power management state based on the PM configuration and activity reported in the last sampling periods.
|
|
The power management state is not automatically changed, however.
|
|
The IDLE loop must call <code>pm_changestate()</code> in order to make the state change.
|
|
</p>
|
|
<p>
|
|
These two steps are separated because the plaform-specific IDLE loop may have additional situational information that is not available to the the PM sub-system.
|
|
For example, the IDLE loop may know that the battery charge level is very low and may force lower power states even if there is activity.
|
|
</p>
|
|
<p>
|
|
NOTE: That these two steps are separated in time and, hence, the IDLE loop could be suspended for a long period of time between calling <code>pm_checkstate()</code> and <code>pm_changestate()</code>.
|
|
The IDLE loop may need to make these calls atomic by either disabling interrupts until the state change is completed.
|
|
</p>
|
|
<p><b>Input Parameters:</b>
|
|
None
|
|
</p>
|
|
<p><b>Returned Value:</b>
|
|
The recommended power management state.
|
|
</p>
|
|
|
|
<h4><a name="pmchangestate">6.4.2.5 <code>pm_changestate()</code></a></h4>
|
|
<p><b>Function Prototype:</b></p>
|
|
<ul><pre>
|
|
#include <nuttx/power/pm.h>
|
|
int pm_changestate(enum pm_state_e newstate);
|
|
</pre></ul>
|
|
<p><b>Description:</b>
|
|
This function is used by platform-specific power management logic.
|
|
It will announce the power management power management state change to all drivers that have registered for power management event callbacks.
|
|
</p>
|
|
<p><b>Input Parameters:</b>
|
|
<dl>
|
|
<dt><code>newstate</code>
|
|
<dd>Identifies the new PM state
|
|
</dl>
|
|
</p>
|
|
<p><b>Returned Value:</b>
|
|
0 (<code>OK</code>) means that the callback function for all registered drivers returned <code>OK</code> (meaning that they accept the state change).
|
|
Non-zero means that one of the drivers refused the state change.
|
|
In this case, the system will revert to the preceding state.
|
|
</p>
|
|
<p><b>Assumptions:</b>
|
|
It is assumed that interrupts are disabled when this function is called.
|
|
This function is probably called from the IDLE loop... the lowest priority task in the system.
|
|
Changing driver power management states may result in renewed system activity and, as a result, can
|
|
suspend the IDLE thread before it completes the entire state change unless interrupts are disabled throughout the state change.
|
|
</p>
|
|
|
|
<h3><a name="pmcallbacks">6.4.3 Callbacks</a></h3>
|
|
<p>
|
|
The <code>struct pm_callback_s</code> includes the pointers to the driver callback functions.
|
|
This structure is defined <code>include/nuttx/power/pm.h</code>.
|
|
These callback functions can be used to provide power management information to the driver.
|
|
</p>
|
|
|
|
<h4><a name="pmprepare">6.4.3.1 <code>prepare()</code></a></h4>
|
|
<p><b>Function Prototype:</b></p>
|
|
<ul><pre>
|
|
int (*prepare)(FAR struct pm_callback_s *cb, enum pm_state_e pmstate);
|
|
</pre></ul>
|
|
<p><b>Description:</b>
|
|
Request the driver to prepare for a new power state.
|
|
This is a warning that the system is about to enter into a new power state.
|
|
The driver should begin whatever operations that may be required to enter power state.
|
|
The driver may abort the state change mode by returning a non-zero value from the callback function.
|
|
</p>
|
|
<p><b>Input Parameters:</b>
|
|
<dl>
|
|
<dt><code>cb</code>
|
|
<dd>Returned to the driver.
|
|
The driver version of the callback strucure may include additional, driver-specific state data at the end of the structure.
|
|
<dt><code>pmstate</code>
|
|
<dd>Identifies the new PM state
|
|
</dl>
|
|
</p>
|
|
<p><b>Returned Value:</b>
|
|
Zero (<code>OK</code>) means the event was successfully processed and that the driver is prepared for the PM state change.
|
|
Non-zero means that the driver is not prepared to perform the tasks needed achieve this power setting and will cause the state change to be aborted.
|
|
NOTE: The <code>prepare()</code> method will also be called when reverting from lower back to higher power consumption modes (say because another driver refused a lower power state change).
|
|
Drivers are not permitted to return non-zero values when reverting back to higher power
|
|
consumption modes!
|
|
</p>
|
|
|
|
<h4><a name="pmnotify">6.4.3.1 <code>notify()</code></a></h4>
|
|
<p><b>Function Prototype:</b></p>
|
|
<ul><pre>
|
|
#include <nuttx/power/pm.h>
|
|
void (*notify)(FAR struct pm_callback_s *cb, enum pm_state_e pmstate);
|
|
</pre></ul>
|
|
<p><b>Description:</b>
|
|
Notify the driver of new power state.
|
|
This callback is called after all drivers have had the opportunity to prepare for the new power state.
|
|
</p>
|
|
<p><b>Input Parameters:</b>
|
|
<dl>
|
|
<dt><code>cb</code>
|
|
<dd>Returned to the driver.
|
|
The driver version of the callback strucure may include additional, driver-specific state data at the end of the structure.
|
|
<dt><code>pmstate</code>
|
|
<dd>Identifies the new PM state
|
|
</dl>
|
|
</p>
|
|
<p><b>Returned Value:</b>
|
|
None.
|
|
The driver already agreed to transition to the low power consumption state when when it returned <code>OK</code> to the <code>prepare()</code> call.
|
|
</p>
|
|
|
|
<table width ="100%">
|
|
<tr bgcolor="#e4e4e4">
|
|
<td>
|
|
<h1><a name="apndxconfigs">Appendix A: NuttX Configuration Settings</a></h1>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
|
|
<p>
|
|
The following variables are recognized by the build (you may
|
|
also include architecture-specific settings).
|
|
</p>
|
|
|
|
<h2>Architecture selection</h2>
|
|
<p>
|
|
The following configuration items select the architecture, chip, and
|
|
board configuration for the build.
|
|
</p>
|
|
<ul>
|
|
<li><code>CONFIG_ARCH</code>:
|
|
Identifies the arch subdirectory</li>
|
|
<li><code>CONFIG_ARCH_name</code>:
|
|
For use in C code</li>
|
|
<li><code>CONFIG_ARCH_CHIP</code>:
|
|
Identifies the arch/*/chip subdirectory</li>
|
|
<li><code>CONFIG_ARCH_CHIP_name</code>:
|
|
For use in C code</li>
|
|
<li><code>CONFIG_ARCH_BOARD</code>:
|
|
Identifies the configs subdirectory and hence, the board that supports
|
|
the particular chip or SoC.</li>
|
|
<li><code>CONFIG_ARCH_BOARD_name</code>:
|
|
For use in C code</li>
|
|
<li><code>CONFIG_ENDIAN_BIG</code>:
|
|
Define if big endian (default is little endian).</li>
|
|
<li><code>CONFIG_ARCH_NOINTC</code>:
|
|
Define if the architecture does not support an interrupt controller
|
|
or otherwise cannot support APIs like up_enable_irq() and up_disable_irq().</li>
|
|
<li><code>CONFIG_ARCH_VECNOTIRQ</code>:
|
|
Usually the interrupt vector number provided to interfaces like <code>irq_attach()</code>
|
|
and <code>irq_detach</code> are the same as IRQ numbers that are provied to IRQ
|
|
management functions like <code>up_enable_irq()</code> and <code>up_disable_irq()</code>.
|
|
But that is not true for all interrupt controller implementations. For example, the
|
|
PIC32MX interrupt controller manages interrupt sources that have a many-to-one
|
|
relationship to interrupt vectors.
|
|
In such cases, <code>CONFIG_ARCH_VECNOTIRQ</code> must defined so that the OS logic
|
|
will know not to assume it can use a vector number to enable or disable interrupts.
|
|
<li><code>CONFIG_ARCH_IRQPRIO</code>:
|
|
Define if the architecture supports prioritization of interrupts and the
|
|
up_prioritize_irq() API.</li>
|
|
<li><code>CONFIG_ADDRENV</code>:
|
|
The CPU supports an MMU and CPU port supports provision of address
|
|
environments for tasks (making the, perhaps, processes).
|
|
In this case, the CPU-specific logic must provide a set of address environment interfaces as defined in the <a href="#addrenv">Address Environments</a> paragraph.
|
|
</li>
|
|
</ul>
|
|
|
|
<p>
|
|
Some architectures require a description of the RAM configuration:
|
|
</p>
|
|
<ul>
|
|
<li><code>CONFIG_DRAM_SIZE</code>:
|
|
Describes the installed DRAM.</li>
|
|
<li><code>CONFIG_DRAM_START</code>:
|
|
The start address of DRAM (physical)</li>
|
|
<li><code>CONFIG_DRAM_VSTART</code>:
|
|
The start address of DRAM (virtual)</li>
|
|
</ul>
|
|
|
|
<h2>Build Options</h2>
|
|
<p>
|
|
General build options:
|
|
</p>
|
|
<ul>
|
|
<li><code>CONFIG_RRLOAD_BINARY</code>:
|
|
Make the rrload binary format used with BSPs from <a href="www.ridgerun.com">ridgerun.com</a>
|
|
using the <code>tools/mkimage.sh</code> script.
|
|
</li>
|
|
<li><code>CONFIG_INTELHEX_BINARY</code>:
|
|
Make the Intel HEX binary format used with many different loaders using the GNU objcopy program
|
|
This option should not be selected if you are not using the GNU toolchain.
|
|
</li>
|
|
<li><code>CONFIG_MOTOROLA_SREC</code>:
|
|
Make the Motorola S-Record binary format used with many different loaders using the GNU objcopy program
|
|
Should not be selected if you are not using the GNU toolchain.
|
|
</li>
|
|
<li><code>CONFIG_RAW_BINARY</code>:
|
|
Make a raw binary format file used with many different loaders using the GNU objcopy program.
|
|
This option should not be selected if you are not using the GNU toolchain.
|
|
</li>
|
|
<li><code>CONFIG_HAVE_CXX</code>:
|
|
Toolchain supports C++ and <code>CXX</code>, <code>CXXFLAGS</code>, and <code>COMPILEXX</code>
|
|
have been defined in the configurations <code>Make.defs</code> file.
|
|
</li>
|
|
<li><code>CONFIG_HAVE_CXXINITIALIZE</code>:
|
|
The platform-specific logic includes support for initialization of static C++ instances for this architecture and for the selected toolchain (via <code>up_cxxinitialize()</code>).
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
Building application code:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<p>
|
|
<code>CONFIG_APPS_DIR</code>: Identifies the directory that builds the application to link with NuttX.
|
|
This symbol must be assigned to the path of the application build directory <i>relative</i> to the NuttX top build directory.
|
|
If the application resides in the top-level <code>../apps/</code> directory, it is not necessary to define <code>CONFIG_APPS_DIR</code>.
|
|
If you have an application directory and the NuttX directory each in separate directories such as this:
|
|
<ul><pre>
|
|
build
|
|
|-nuttx
|
|
| |
|
|
| `- Makefile
|
|
`-application
|
|
|
|
|
`- Makefile
|
|
</pre></ul>
|
|
Then you would set <code>CONFIG_APPS_DIR=../application</code>.
|
|
The default value of <code>CONFIG_APPS_DIR</code> is <code>../apps/</code>.
|
|
</p>
|
|
<p>
|
|
The application direction must contain <code>Makefile</code> and this make file must support the following targets:
|
|
<ul>
|
|
<li>
|
|
<code>libapps$(LIBEXT)</code> (usually <code>libapps.a</code>).
|
|
<code>libapps.a</code> is a static library ( an archive) that contains all of application object files.
|
|
</li>
|
|
<li>
|
|
<code>clean</code>.
|
|
Do whatever is appropriate to clean the application directories for a fresh build.
|
|
</li>
|
|
<li>
|
|
<code>distclean</code>.
|
|
Clean everthing -- auto-generated files, symbolic links etc. -- so that the directory contents are the same as the contents in your configuration management system.
|
|
This is only done when you change the NuttX configuration.
|
|
</li>
|
|
<li>
|
|
<code>context</code>.
|
|
Perform one-time configuration-related setup.
|
|
This might includes such things as creating auto-generated files or symbolic links for directory configurations.
|
|
</li>
|
|
<li>
|
|
<code>depend</code>.
|
|
Make or update the application build dependencies.
|
|
</li>
|
|
</ul>
|
|
</p>
|
|
<p>
|
|
When this application is invoked it will receive the setting <code>TOPDIR</code> like:
|
|
<ul>
|
|
<code>$(MAKE) -C $(CONFIG_APPS_DIR) TOPDIR="$(TOPDIR)"</code> <target>
|
|
</ul>
|
|
</p>
|
|
<p>
|
|
<code>TOPDIR</code> is the full path to the NuttX directory.
|
|
It can be used, for example, to include makefile fragments (e.g., <code>.config</code> or <code>Make.defs</code>) or to set up include file paths.
|
|
</p>
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
Two-pass Build Options.
|
|
If the 2 pass build option is selected, then these options configure the make system build a extra link object.
|
|
This link object is assumed to be an incremental (relative) link object, but could be a static library (archive)
|
|
(some modification to this Makefile would be required if CONFIG_PASS1_TARGET generates an archive).
|
|
Pass 1 1ncremental (relative) link objects should be put into the processor-specific source directory
|
|
where other link objects will be created - ff the pass1 obect is an archive, it could go anywhere.
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_BUILD_2PASS</code>:
|
|
Enables the two pass build options.
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
When the two pass build option is enabled, the following also apply:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<p>
|
|
<code>CONFIG_PASS1_TARGET</code>: The name of the first pass build target.
|
|
</p>
|
|
</li>
|
|
<li><code>CONFIG_PASS1_BUILDIR</code>:
|
|
<p>
|
|
The path, relative to the top NuttX build directory to directory that contains the Makefile to build the first pass object.
|
|
The Makefile must support the following targets:
|
|
</p>
|
|
<p>
|
|
<ul>
|
|
<li>The special target <code>CONFIG_PASS1_TARGET</code> (if defined), and</li>
|
|
<li>The usual depend, clean, and distclean targets.</li>
|
|
</ul>
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PASS1_OBJECT</code>: May be used to include an extra, pass1 object into the final link.
|
|
This would probably be the object generated from the <code>CONFIG_PASS1_TARGET</code>.
|
|
It may be available at link time in the <code>arch/<architecture>/src</code> directory.
|
|
</li>
|
|
</ul>
|
|
|
|
<h2>Debug Options</h2>
|
|
<p>
|
|
General Debug setup options are provided to (1) enable and control debug console output, (2) to build NuttX for use with a debugger, and (3) to enable specific debug features:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_DEBUG</code>: enables built-in debug options.
|
|
This includes more extensive parameter checking, debug assertions, and other debug logic.
|
|
This option is also necessary (but not sufficient) to enable debug console output;
|
|
Debug console output must also be enabled on a subsystem-by-subsystem basis as described below.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_DEBUG_VERBOSE</code>: If debug console output is enabled, the option enables more verbose debug output.
|
|
Ignored if <code>CONFIG_DEBUG</code> is not defined.
|
|
If only <code>CONFIG_DEBUG</code> then the only output will be errors, warnings, and critical information.
|
|
If <code>CONFIG_DEBUG_VERBOSE</code> is defined in addition, then general debug comments will also be included in the console output.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_DEBUG_ENABLE</code>: Support an interface to enable or disable debug output.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_DEBUG_SYMBOLS</code>: build without optimization and with debug symbols (needed for use with a debugger).
|
|
This option has nothing to do with debug output.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_DEBUG_STACK</code>: a few ports include logic to monitor stack usage.
|
|
If the NuttX port supports this option, it would be enabled with this option.
|
|
This option also requires <code>CONFIG_DEBUG</code> to enable general debug features.
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
If debug features are enabled with <code>CONFIG_DEBUG</code> (and possibly <code>CONFIG_DEBUG_VERBOSE</code>), then debug console output can also be enabled on a subsystem-by-subsystem basis.
|
|
Below are debug subsystems that are generally available on all platforms:
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_DEBUG_SCHED</code>: enable OS debug output (disabled by default)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_DEBUG_MM</code>: enable memory management debug output (disabled by default)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_DEBUG_NET</code>: enable network debug output (disabled by default)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_DEBUG_USB</code>: enable USB debug output (disabled by default)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_DEBUG_FS</code>: enable file system debug output (disabled by default)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_DEBUG_LIB</code>: enable C library debug output (disabled by default)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_DEBUG_BINFMT</code>: enable binary loader debug output (disabled by default)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_DEBUG_GRAPHICS</code>: enable NX graphics debug output (disabled by default)
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
The following debug options may also be used with certain ports that support these features:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_DEBUG_DMA</code>: enable DMA controller debug output (disabled by default)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_DEBUG_GPIO</code>: enable detail GPIO usage debug output (disabled by default)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_DEBUG_PAGING</code>: enable on-demand paging debug output (disabled by default)
|
|
</li>
|
|
</ul>
|
|
|
|
<h2>Memory Management</h2>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_MM_REGIONS</code>: If the architecture includes multiple
|
|
regions of memory to allocate from, this specifies the
|
|
number of memory regions that the memory manager must
|
|
handle and enables the API mm_addregion(start, end);
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_MM_SMALL</code>: Each memory allocation has a small allocation
|
|
overhead. The size of that overhead is normally determined by
|
|
the "width" of the address support by the MCU. MCUs that support
|
|
16-bit addressability have smaller overhead than devices that
|
|
support 32-bit addressability. However, there are many MCUs
|
|
that support 32-bit addressability <i>but</i> have internal SRAM
|
|
of size less than or equal to 64K. In this case, CONFIG_MM_SMALL
|
|
can be defined so that those MCUs will also benefit from the
|
|
smaller, 16-bit-based allocation overhead.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_HEAP2_BASE</code> and <code>CONFIG_HEAP2_SIZE</code>:
|
|
Some architectures use these settings to specify the size of
|
|
a second heap region.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_GRAN</code>:
|
|
Enable granual allocator support. Allocations will be aligned to the
|
|
granule size; allocations will be in units of the granule size.
|
|
Larger granules will give better performance and less overhead but
|
|
more losses of memory due to alignment and quantization waste.
|
|
NOTE: The current implementation also restricts the maximum
|
|
allocation size to 32 granaules. That restriction could be
|
|
eliminated with some additional coding effort.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_GRAN_SINGLE</code>:
|
|
Select if there is only one instance of the granule allocator (i.e.,
|
|
gran_initialize will be called only once. In this case, (1) there
|
|
are a few optimizations that can can be done and (2) the GRAN_HANDLE
|
|
is not needed.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_GRAN_INTR</code>:
|
|
Normally mutual exclusive access to granule allocator data is assured using a semaphore.
|
|
If this option is set then, instead, mutual exclusion logic will disable interrupts.
|
|
While this options is more invasive to system performance, it will also support use of the
|
|
granule allocator from interrupt level logic.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_DEBUG_GRAM</code>:
|
|
Just like <code>CONFIG_DEBUG_MM</code>, but only generates ouput from the gran
|
|
allocation logic.
|
|
</li>
|
|
</ul>
|
|
|
|
<h2>General OS setup</h2>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_ARCH_LOWPUTC</code>: architecture supports low-level, boot
|
|
time console output
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NUTTX_KERNEL</code>:
|
|
With most MCUs, NuttX is built as a flat, single executable image
|
|
containing the NuttX RTOS along with all application code.
|
|
The RTOS code and the application run in the same address space and at the same kernel-mode privileges.
|
|
If this option is selected, NuttX will be built separately as a monolithic, kernel-mode module and the applications
|
|
can be added as a separately built, user-mode module.
|
|
In this a system call layer will be built to support the user- to kernel-mode interface to the RTOS.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_MSEC_PER_TICK</code>: The default system timer is 100Hz
|
|
or <code>MSEC_PER_TICK</code>=10. This setting may be defined to inform NuttX
|
|
that the processor hardware is providing system timer interrupts at some interrupt
|
|
interval other than 10 msec.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_RR_INTERVAL</code>: The round robin time slice will be set
|
|
this number of milliseconds; Round robin scheduling can
|
|
be disabled by setting this value to zero.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SCHED_INSTRUMENTATION</code>: enables instrumentation in
|
|
scheduler to monitor system performance
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_TASK_NAME_SIZE</code>: Specifies that maximum size of a
|
|
task name to save in the TCB. Useful if scheduler
|
|
instrumentation is selected. Set to zero to disable.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SYSTEM_TIME16</code>:
|
|
The range of system time is, by default, 32-bits.
|
|
However, if the MCU supports type <code>long long</code> and <code>CONFIG_SYSTEM_TIME16</code> is selected,
|
|
a 64-bit system timer will be supported instead.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_START_YEAR</code>, <code>CONFIG_START_MONTH</code>, <code>CONFIG_START_DAY</code> -
|
|
Used to initialize the internal time logic.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_GREGORIAN_TIME</code>: Enables Gregorian time conversions.
|
|
You would only need this if you are concerned about accurate time conversions in
|
|
the recent past or in the distant future.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_JULIAN_TIME</code>: Enables Julian time conversions.
|
|
You would only need this if you are concerned about accurate time conversion in the distand past.
|
|
You must also define <code>CONFIG_GREGORIAN_TIME</code> in order to use Julian time.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_DEV_CONSOLE</code>: Set if architecture-specific logic provides <code>/dev/console</code>.
|
|
Enables <code>stdout</code>, <code>stderr</code>, and <code>stdin</code>.
|
|
This implies the "normal" serial driver provides the console unless another console device is specified
|
|
(See <code>CONFIG_DEV_LOWCONSOLE</code>).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_MUTEX_TYPES</code>: Set to enable support for recursive and
|
|
errorcheck mutexes. Enables <code>pthread_mutexattr_settype()</code>.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PRIORITY_INHERITANCE</code>: Set to enable support for
|
|
priority inheritance on mutexes and semaphores.
|
|
Priority inheritance is a strategy of addressing
|
|
<a href="NuttxUserGuide.html#priorityinversion"><i>priority inversion</i></a>.
|
|
Details of the NuttX implementation of priority inheritance is
|
|
discussed <a href="NuttxUserGuide.html#priorityinheritance">elsewhere</a>.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SEM_PREALLOCHOLDERS</code>: This setting is only used
|
|
if priority inheritance is enabled.
|
|
It defines the maximum number of different threads (minus one) that
|
|
can take counts on a semaphore with priority inheritance support.
|
|
This may be set to zero if priority inheritance is disabled OR if you
|
|
are only using semaphores as mutexes (only one holder) OR if no more
|
|
than two threads participate using a counting semaphore.
|
|
If defined, then this should be a relatively large number because this
|
|
is the total number of counts on the total number of semaphores (like
|
|
64 or 100).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SEM_NNESTPRIO</code>: If priority inheritance is enabled,
|
|
then this setting is the maximum number of higher priority threads (minus
|
|
1) than can be waiting for another thread to release a count on a semaphore.
|
|
This value may be set to zero if no more than one thread is expected to
|
|
wait for a semaphore.
|
|
If defined, then this should be a relatively small number because this the
|
|
number of maximumum of waiters on one semaphore (like 4 or 8).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_FDCLONE_DISABLE</code>: Disable cloning of all file descriptors
|
|
by task_create() when a new task is started.
|
|
If set, all files/drivers will appear to be closed in the new task.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_FDCLONE_STDIO</code>: Disable cloning of all but the first
|
|
three file descriptors (stdin, stdout, stderr) by task_create()
|
|
when a new task is started.
|
|
If set, all files/drivers will appear to be closed in the new task except
|
|
for stdin, stdout, and stderr.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SDCLONE_DISABLE</code>: Disable cloning of all socket
|
|
desciptors by task_create() when a new task is started.
|
|
If set, all sockets will appear to be closed in the new task.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SCHED_WORKQUEUE</code>: Create a dedicated "worker" thread to
|
|
handle delayed processing from interrupt handlers. This feature
|
|
is required for some drivers but, if there are not complaints,
|
|
can be safely disabled. The worker thread also performs
|
|
garbage collection -- completing any delayed memory deallocations
|
|
from interrupt handlers. If the worker thread is disabled,
|
|
then that clean will be performed by the IDLE thread instead
|
|
(which runs at the lowest of priority and may not be appropriate
|
|
if memory reclamation is of high priority). If CONFIG_SCHED_WORKQUEUE
|
|
is enabled, then the following options can also be used:
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SCHED_WORKPRIORITY</code>: The execution priority of the worker
|
|
thread. Default: 50
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SCHED_WORKPERIOD</code>: How often the worker thread checks for
|
|
work in units of microseconds. Default: 50*1000 (50 MS).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SCHED_WORKSTACKSIZE</code>: The stack size allocated for the worker
|
|
thread. Default: CONFIG_IDLETHREAD_STACKSIZE.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SIG_SIGWORK</code>: The signal number that will be used to wake-up
|
|
the worker thread. Default: 4
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SCHED_LPWORK</code>: If CONFIG_SCHED_WORKQUEUE</code> is defined, then a single work queue is created by default.
|
|
If <code>CONFIG_SCHED_LPWORK</code> is also defined then an additional, lower-priority work queue will also be created.
|
|
This lower priority work queue is better suited for more extended processing (such as file system clean-up operations)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SCHED_LPWORKPRIORITY</code>: The execution priority of the lower priority worker thread. Default: 50
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SCHED_LPWORKPERIOD</code>: How often the lower priority worker thread checks for work in units of microseconds. Default: 50*1000 (50 MS).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SCHED_LPWORKSTACKSIZE - The stack size allocated for the lower priority worker thread. Default: CONFIG_IDLETHREAD_STACKSIZE.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SCHED_WAITPID</code>: Enables the <a href="NuttxUserGuide.html#waitpid"><code>waitpid()</code><a> API
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SCHED_ATEXIT</code>: Enables the <a href="NuttxUserGuide.html#atexit">atexit()</code><a> API
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SCHED_ATEXIT_MAX</code>: By default if <code>CONFIG_SCHED_ATEXIT</code> is selected, only a single <code>atexit()</code> function is supported.
|
|
That number can be increased by defined this setting to the number that you require.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SCHED_ONEXIT</code>: Enables the <a href="NuttxUserGuide.html#onexit">on_exit()</code><a> API
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SCHED_ONEXIT_MAX</code>: By default if <code>CONFIG_SCHED_ONEXIT</code> is selected, only a single <code>on_exit()</code> function is supported.
|
|
That number can be increased by defined this setting to the number that you require.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USER_ENTRYPOINT</code>: The name of the entry point for user
|
|
applications.
|
|
For the example applications this is of the form <code>app_main</code>
|
|
where <code>app</code> is the application name.
|
|
If not defined, <code>CONFIG_USER_ENTRYPOINT</code> defaults to
|
|
<code>user_start</code>.
|
|
</li>
|
|
</ul>
|
|
|
|
<p>
|
|
Binary Loaders:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_BINFMT_DISABLE</code>: By default, support for loadable binary formats is built.
|
|
This logic may be suppressed be defining this setting.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_BINFMT_EXEPATH</code>: Use the contents of the <code>PATH</code> environment variable to locate executable files. Default: n
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PATH_INITIAL</code>: The initial value of the <code>PATH</code> variable. This is the colon-separated list of absolute paths. E.g., <code>"/bin:/usr/bin:/sbin"</code>
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_BINFMT_CONSTRUCTORS</code>: Build in support for C++ constructors in loaded modules.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SYMTAB_ORDEREDBYNAME</code>: Symbol tables are order by name (rather than value).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFLAT</code>: Enable support for the NXFLAT binary format.
|
|
This format will support execution of NuttX binaries located
|
|
in a ROMFS file system (see <code>apps/examples/nxflat</code>).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_ELF</code>: Enable support for the ELF binary format.
|
|
This format will support execution of ELF binaries copied from a file system and relocated into RAM (see <code>apps/examples/elf</code>).
|
|
</li>
|
|
<p>
|
|
If <code>CONFIG_ELF</code> is selected, then these additional options are available:
|
|
</p>
|
|
<li>
|
|
<code>CONFIG_ELF_ALIGN_LOG2</code>: Align all sections to this Log2 value: 0->1, 1->2, 2->4, etc.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_ELF_STACKSIZE</code>: This is the default stack size that will will be used when starting ELF binaries.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_ELF_BUFFERSIZE</code>: This is an I/O buffer that is used to access the ELF file. Variable length items will need to be read (such as symbol names).
|
|
This is really just this initial size of the buffer; it will be reallocated as necessary to hold large symbol names).
|
|
Default: 128
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_ELF_BUFFERINCR</code>: This is an I/O buffer that is used to access the ELF file. Variable length items will need to be read (such as symbol names).
|
|
This value specifies the size increment to use each time the buffer is reallocated.
|
|
Default: 32
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_ELF_DUMPBUFFER</code>: Dump various ELF buffers for debug purposes.
|
|
This option requires <code>CONFIG_DEBUG</code> and <code>CONFIG_DEBUG_VERBOSE</code>.
|
|
</li>
|
|
</ul>
|
|
|
|
<p>
|
|
System Logging:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_SYSLOG</code>: Enables general system logging support.
|
|
</li>
|
|
<code>CONFIG_SYSLOG_DEVPATH</code>: The full path to the system logging device.
|
|
Default <code>"/dev/ramlog"</code> (RAMLOG) or <code>"dev/ttyS1;</code> (CHARDEV).
|
|
<p>
|
|
At present, there are two system loggins devices available.
|
|
If <code>CONFIG_SYSLOG</code> is selected, then these options are also available.
|
|
</p>
|
|
<p>
|
|
First, any a generic character device that may be used as the SYSLOG.
|
|
</p>
|
|
<li>
|
|
<code>CONFIG_SYSLOG_CHAR</code>:
|
|
Enable the generic character device for the SYSLOG.
|
|
A disadvantage of using the generic character device for the SYSLOG is that it cannot handle debug output generated from interrupt level handlers.
|
|
NOTE: No more than one SYSLOG device should be configured.
|
|
<p>
|
|
Alternatively, a circular buffer in RAM can be used as the SYSLOGing device.
|
|
The contents of this RAM buffer can be dumped using the NSH dmesg command.
|
|
</p>
|
|
<li>
|
|
<code>CONFIG_RAMLOG</code>: Enables the RAM logging feature
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_RAMLOG_CONSOLE</code>: Use the RAM logging device as a system console.
|
|
If this feature is enabled (along with <code>CONFIG_DEV_CONSOLE</code>), then all
|
|
console output will be re-directed to a circular buffer in RAM. This
|
|
is useful, for example, if the only console is a Telnet console. Then
|
|
in that case, console output from non-Telnet threads will go to the
|
|
circular buffer and can be viewed using the NSH 'dmesg' command.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_RAMLOG_SYSLOG</code>:
|
|
Use the RAM logging device for the syslogging interface.
|
|
If this feature is enabled (along with <code>CONFIG_SYSLOG</code>), then all debug output (only) will be re-directed to the circular buffer in RAM.
|
|
This RAM log can be view from NSH using the <code>dmesg</code> command.
|
|
NOTE: Unlike the limited, generic character driver SYSLOG device, the RAMLOG <i>can</i> be used to generate debug output from interrupt level handlers.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_RAMLOG_NPOLLWAITERS</code>: The number of threads than can be waiting
|
|
for this driver on poll(). Default: 4
|
|
</li>
|
|
<p>
|
|
If <code>CONFIG_RAMLOG_CONSOLE</code> or <code>CONFIG_RAMLOG_SYSLOG</code> is selected, then the
|
|
following may also be provided:
|
|
</p>
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_RAMLOG_CONSOLE_BUFSIZE</code>: Size of the console RAM log. Default: 1024
|
|
</li>
|
|
</ul>
|
|
|
|
<p>
|
|
Kernel build options:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_NUTTX_KERNEL</code>: Builds NuttX as a separately compiled kernel.
|
|
</li>
|
|
<code>CONFIG_SYS_RESERVED</code>: Reserved system call values for use by architecture-specific logic.
|
|
</li>
|
|
</ul>
|
|
|
|
<p>
|
|
OS setup related to on-demand paging:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_PAGING</code>: If set =y in your configation file, this setting will
|
|
enable the on-demand paging feature as described in
|
|
<a href="http://www.nuttx.org/Documentation/NuttXDemandPaging.html">NuttXDemandPaging.html</a>.
|
|
</li>
|
|
</ul>
|
|
|
|
<p>
|
|
If CONFIG_PAGING is selected, then you will probabaly need <code>CONFIG_BUILD_2PASS</code> to correctly position
|
|
the code and the following configuration options also apply:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_PAGING_PAGESIZE</code>:
|
|
The size of one managed page.
|
|
This must be a value supported by the processor's memory management unit.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_NLOCKED</code>:
|
|
This is the number of locked pages in the memory map.
|
|
The locked address region will then be from <code>CONFIG_DRAM_VSTART</code> through
|
|
(<code>CONFIG_DRAM_VSTART</code> + <code>CONFIG_PAGING_PAGESIZE</code>*<code>CONFIG_PAGING_NLOCKED</code>)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_LOCKED_PBASE</code> and <code>CONFIG_PAGING_LOCKED_VBASE</code>:
|
|
These may be defined to determine the base address of the locked page regions.
|
|
If neither are defined, the logic will be set the bases to <code>CONFIG_DRAM_START</code>
|
|
and <code>CONFIG_DRAM_VSTART</code> (i.e., it assumes that the base address of the locked
|
|
region is at the beginning of RAM).
|
|
<b>NOTE</b>:
|
|
In some architectures, it may be necessary to take some memory from the beginning
|
|
of this region for vectors or for a page table.
|
|
In such cases, <code>CONFIG_PAGING_LOCKED_P/VBASE</code> should take that into consideration
|
|
to prevent overlapping the locked memory region and the system data at the beginning of SRAM.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_NPPAGED</code>:
|
|
This is the number of physical pages available to support the paged text region.
|
|
This paged region begins at
|
|
(<code>CONFIG_PAGING_LOCKED_PBASE</code> + <code>CONFIG_PAGING_PAGESIZE</code>*<code>CONFIG_PAGING_NPPAGED</code>)
|
|
and continues until
|
|
(<code>CONFIG_PAGING_LOCKED_PBASE</code> + <code>CONFIG_PAGING_PAGESIZE</code>*(<code>CONFIG_PAGING_NLOCKED</code> +
|
|
<code>CONFIG_PAGING_NPPAGED</code>)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_NVPAGED</code>:
|
|
This actual size of the paged text region (in pages).
|
|
This is also the number of virtual pages required to support the entire paged region.
|
|
The on-demand paging feature is intended to support only the case where the virtual paged text
|
|
area is much larger the available physical pages.
|
|
Otherwise, why would you enable on-demand paging?
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_NDATA</code>:
|
|
This is the number of data pages in the memory map.
|
|
The data region will extend to the end of RAM unless overridden by a setting in the configuration file.
|
|
<b>NOTE</b>:
|
|
In some architectures, it may be necessary to take some memory from the end of RAM for page tables
|
|
or other system usage.
|
|
The configuration settings and linker directives must be cognizant of that:
|
|
<code>CONFIG_PAGING_NDATA</code> should be defined to prevent the data region from extending all the way to the end of memory.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_DEFPRIO</code>:
|
|
The default, minimum priority of the page fill worker thread.
|
|
The priority of the page fill work thread will be boosted boosted dynmically so that it matches the
|
|
priority of the task on behalf of which it peforms the fill.
|
|
This defines the minimum priority that will be used. Default: 50.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_STACKSIZE</code>:
|
|
Defines the size of the allocated stack for the page fill worker thread. Default: 1024.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_BLOCKINGFILL</code>:
|
|
The architecture specific <code>up_fillpage()</code> function may be blocking or non-blocking.
|
|
If defined, this setting indicates that the <code>up_fillpage()</code> implementation will block until the
|
|
transfer is completed. Default: Undefined (non-blocking).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_WORKPERIOD</code>:
|
|
The page fill worker thread will wake periodically even if there is no mapping to do.
|
|
This selection controls that wake-up period (in microseconds).
|
|
This wake-up a failsafe that will handle any cases where a single is lost (that would
|
|
really be a bug and shouldn't happen!)
|
|
and also supports timeouts for case of non-blocking, asynchronous fills (see <code>CONFIG_PAGING_TIMEOUT_TICKS</code>).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_TIMEOUT_TICKS</code>:
|
|
If defined, the implementation will monitor the (asynchronous) page fill logic.
|
|
If the fill takes longer than this number if microseconds, then a fatal error will be declared.
|
|
Default: No timeouts monitored.
|
|
</li>
|
|
<p>
|
|
Some architecture-specific settings.
|
|
Defaults are architecture specific.
|
|
If you don't know what you are doing, it is best to leave these undefined and try the system defaults:
|
|
</p>
|
|
<li>
|
|
<code>CONFIG_PAGING_VECPPAGE</code>:
|
|
This the physical address of the page in memory to be mapped to the vector address.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_VECL2PADDR</code>:
|
|
This is the physical address of the L2 page table entry to use for the vector mapping.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_VECL2VADDR</code>:
|
|
This is the virtual address of the L2 page table entry to use for the vector mapping.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_BINPATH</code>:
|
|
If <code>CONFIG_PAGING_BINPATH</code> is defined, then it is the full path to a file on a mounted file system that contains a binary image of the NuttX executable.
|
|
Pages will be filled by reading from offsets into this file that correspond to virtual fault addresses.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_MOUNTPT</code>:
|
|
If <code>CONFIG_PAGING_BINPATH</code> is defined, additional options may be provided to control the initialization of underlying devices.
|
|
<code>CONFIG_PAGING_MOUNTPT</code> identifies the mountpoint to be used if a device is mounted.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_MINOR</code>:
|
|
Some mount operations require a "minor" number to identify the specific device instance.
|
|
Default: 0
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_SDSLOT</code>:
|
|
If <code>CONFIG_PAGING_BINPATH</code> is defined, additional options may be provided to control the initialization of underlying devices.
|
|
<code>CONFIG_PAGING_SDSLOT</code> identifies the slot number of the SD device to initialize.
|
|
This must be undefined if SD is not being used.
|
|
This should be defined to be zero for the typical device that has only a single slot (See <code>CONFIG_MMCSD_NSLOTS</code>).
|
|
If defined, <code>CONFIG_PAGING_SDSLOT</code> will instruct certain board-specific logic to initialize the media in this SD slot.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_M25PX</code>:
|
|
Use the m25px.c FLASH driver.
|
|
If this is selected, then the MTD interface to the M25Px device will be used to support paging.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_AT45DB</code>:
|
|
Use the at45db.c FLASH driver.
|
|
If this is selected, then the MTD interface to the Atmel AT45DB device will be used to support paging.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_BINOFFSET</code>:
|
|
If CONFIG_PAGING_M25PX or CONFIG_PAGING_AT45DB is defined then CONFIG_PAGING_BINOFFSET will be used to specify the offset in bytes into the FLASH device where the NuttX binary image is located.
|
|
Default: 0
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PAGING_SPIPORT</code>:
|
|
If CONFIG_PAGING_M25PX or CONFIG_PAGING_AT45DB is defined and the device has multiple SPI busses (ports), then this configuration should be set to indicate which SPI port the device is connected.
|
|
Default: 0
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
The following can be used to disable categories of APIs supported
|
|
by the OS. If the compiler supports weak functions, then it
|
|
should not be necessary to disable functions unless you want to
|
|
restrict usage of those APIs.
|
|
</p>
|
|
<p>
|
|
There are certain dependency relationships in these features.
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<code>mq_notify()</code> logic depends on signals to awaken tasks
|
|
waiting for queues to become full or empty.
|
|
</li>
|
|
<li>
|
|
<code>pthread_condtimedwait()</code> depends on signals to wake
|
|
up waiting tasks.
|
|
</li>
|
|
</ul>
|
|
|
|
<ul>
|
|
<code>CONFIG_DISABLE_CLOCK</code>, <code>CONFI_DISABLE_POSIX_TIMERS</code>,
|
|
<code>CONFIG_DISABLE_PTHREAD</code>, <code>CONFIG_DISABLE_SIGNALS</code>,
|
|
<code>CONFIG_DISABLE_MQUEUE</code>, <code>CONFIG_DISABLE_MOUNTPOUNT</code>
|
|
</ul>
|
|
|
|
<h2>Miscellaneous libc settings</h2>
|
|
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_NOPRINTF_FIELDWIDTH</code>: <code>sprintf</code>-related logic is a
|
|
little smaller if we do not support fieldwidthes
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_LIBC_FLOATINGPOINT</code>: By default, floating point
|
|
support in <code>printf</code>, <code>sscanf</code>, etc. is disabled.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_LIBC_STRERROR</code>:
|
|
<code>strerror()</code> is useful because it decodes <code>errno</code> values into a human readable strings.
|
|
But it can also require a lot of memory to store the strings.
|
|
If this option is selected, <code>strerror()</code> will still exist in the build but it will not decode error values.
|
|
This option should be used by other logic to decide if it should use <code>strerror()</code> or not.
|
|
For example, the NSH application will not use <code>strerror()</code> if this option is not selected;
|
|
<code>perror(</code>) will not use strerror() is this option is not selected (see also <code>CONFIG_NSH_STRERROR</code>).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_LIBC_STRERROR_SHORT</code>:
|
|
If this option is selected, then <code>strerror()</code> will use a shortened string when it decodes the error.
|
|
Specifically, <code>strerror()</code> is simply use the string that is the common name for the error.
|
|
For example, the <code>errno</code> value of 2 will produce the string "No such file or directory" if <code>CONFIG_LIBC_STRERROR_SHORT</code> is not defined but the string "ENOENT" if <code>CONFIG_LIBC_STRERROR_SHORT</code> is defined.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_LIBC_PERROR_STDOUT</code>:
|
|
POSIX requires that <code>perror()</code> provide its output on <code>stderr</code>.
|
|
This option may be defined, however, to provide <code>perror()</code> output that is serialized with other <code>stdout</code> messages.
|
|
</li>
|
|
</ul>
|
|
|
|
<h2>Allow for architecture optimized implementations</h2>
|
|
|
|
<ul>
|
|
<li>
|
|
The architecture can provide optimized versions of the following to improve system performance.
|
|
</li>
|
|
<ul><p>
|
|
<code>CONFIG_ARCH_MEMCPY</code>, <code>CONFIG_ARCH_MEMCMP</code>, <code>CONFIG_ARCH_MEMMOVE</code>,
|
|
<code>CONFIG_ARCH_MEMSET</code>, <code>CONFIG_ARCH_STRCMP</code>, <code>CONFIG_ARCH_STRCPY</code>,
|
|
<code>CONFIG_ARCH_STRNCPY</code>, <code>CONFIG_ARCH_STRLEN</code>, <code>CONFIG_ARCH_STRNLEN</code>,
|
|
<code>CONFIG_ARCH_BZERO</code>
|
|
</p></ul>
|
|
|
|
<p><li>
|
|
If <code>CONFIG_ARCH_MEMCPY</code> is <b>not</b> selected, then you make also select Daniel
|
|
Vik's optimized implementation of <code>memcpy()</code>:
|
|
</p>
|
|
<ul><li>
|
|
<code>CONFIG_MEMCPY_VIK</code>:
|
|
Select this option to use the optimized <code>memcpy()</code> function by Daniel Vik.
|
|
Select this option for improved performance at the expense of increased size.
|
|
See licensing information in the top-level <code>COPYING</code> file.
|
|
Default: <code>n</code>.
|
|
</li></ul>
|
|
|
|
<p>
|
|
And if <code>CONFIG_MEMCPY_VIK</code> is selected, the following tuning options are available:
|
|
</p>
|
|
<ul><li>
|
|
<code>CONFIG_MEMCPY_PRE_INC_PTRS</code>:
|
|
Use pre-increment of pointers.
|
|
Default is post increment of pointers.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_MEMCPY_INDEXED_COPY</code>
|
|
Copying data using array indexing.
|
|
Using this option, disables the <code>CONFIG_MEMCPY_PRE_INC_PTRS</code> option.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_MEMCPY_64BIT</code>:
|
|
Compiles <code>memcpy()</code> for 64 bit architectures
|
|
</li></ul>
|
|
|
|
<p><li>
|
|
If <code>CONFIG_ARCH_MEMSET</code> is <b>not</b> selected, then the following option is also available:
|
|
</p>
|
|
<ul><li>
|
|
<code>CONFIG_MEMSET_OPTSPEED</code>:
|
|
Select this option to use a version of <code>memset()</code> optimized for speed.
|
|
Default: <code>memset()</code> is optimized for size.
|
|
</li></ul>
|
|
|
|
<p>
|
|
And if <code>CONFIG_MEMSET_OPTSPEED</code> is selected, the following tuning option is available:
|
|
</p>
|
|
<ul><li>
|
|
<code>CONFIG_MEMSET_64BIT</code>:
|
|
Compiles <code>memset()</code> for 64 bit architectures
|
|
</li></ul>
|
|
|
|
<li>
|
|
<p>
|
|
The architecture may provide custom versions of certain standard header files:
|
|
</p>
|
|
<ul>
|
|
<li><b><code>CONFIG_ARCH_STDBOOL_H</code></b>.
|
|
<p>
|
|
The <code>stdbool.h</code> header file can be found at <code>nuttx/include/stdbool.h</code>.
|
|
However, that header includes logic to redirect the inclusion of an architecture specific header file like:
|
|
</p>
|
|
<ul><pre>
|
|
#ifdef CONFIG_ARCH_STDBOOL_H
|
|
# include <arch/stdbool.h>
|
|
#else
|
|
...
|
|
#endif
|
|
</pre></ul>
|
|
<p>
|
|
Recall that that include path, <code>include/arch</code>, is a symbolic link and will refer to a version of <code>stdbool.h</code> at <code>nuttx/arch/<architecture>/include/stdbool.h</code>.
|
|
</p>
|
|
</li>
|
|
<li><b><code>CONFIG_ARCH_STDINT_H</code></b>.
|
|
<p>
|
|
Similar logic exists for the <code>stdint.h</code> header file can also be found at <code>nuttx/include/stdint.h</code>.
|
|
<ul><pre>
|
|
#ifdef CONFIG_ARCH_STDBOOL_H
|
|
# include <arch/stdinit.h>
|
|
#else
|
|
...
|
|
#endif
|
|
</pre></ul>
|
|
</p>
|
|
</li>
|
|
<li><b><code>CONFIG_ARCH_MATH_H</code></b>.
|
|
<p>
|
|
There is also a re-directing version of <code>math.h</code> in the source tree. However, it resides out-of-the-way at <code>include/nuttx/math.h</code> because it conflicts too often with the system <code>math.h</code>.
|
|
If <code>CONFIG_ARCH_MATH_H=y</code> is defined, however, the top-level makefile will copy the redirecting <code>math.h</code> header file from <code>include/nuttx/math.h</code> to <code>include/math.h</code>.
|
|
<code>math.h</code> will then include the architecture-specific version of <code>math.h</code> that you must provide at <code>nuttx/arch/<architecture>/include/math.h</code>.
|
|
</p>
|
|
<ul><pre>
|
|
#ifdef CONFIG_ARCH_MATH_H
|
|
# include <arch/math.h>
|
|
#endif
|
|
</pre></ul>
|
|
<p>
|
|
So for the architectures that define <code>CONFIG_ARCH_MATH_H=y</code>, <code>include/math.h</code> will be the redirecting <code>math.h</code> header file; for the architectures that don't select <code>CONFIG_ARCH_MATH_H</code>, the redirecting <code>math.h</code> header file will stay out-of-the-way in <code>include/nuttx/</code>.
|
|
</p>
|
|
</li>
|
|
<li><b><code>CONFIG_ARCH_FLOAT_H</code></b>.
|
|
<p>
|
|
If you enable the generic, built-in math library, then that math library will expect your toolchain to provide the standard <code>float.h</code> header file.
|
|
The <code>float.h</code> header file defines the properties of your floating point implementation.
|
|
It would always be best to use your toolchain's <code>float.h</code> header file but if none is avaiable, a default <code>float.h</code> header file will provided if this option is selected.
|
|
However, there is no assurance that the settings in this float.h are actually correct for your platform!
|
|
</p>
|
|
</li>
|
|
<li><b><code>CONFIG_ARCH_STDARG_H</code></b>.
|
|
<p>
|
|
There is also a redirecting version of <code>stdarg.h</code> in the source tree as well.
|
|
It also resides out-of-the-way at <code>include/nuttx/stdarg.h</code>.
|
|
This is because you should normally use your toolchain's <code>stdarg.h</code> file.
|
|
But sometimes, your toolchain's <code>stdarg.h</code> file may have other header file dependencies and so may not be usable in the NuttX build environment.
|
|
In those cases, you may have to create a architecture-specific <code>stdarg.h</code> header file at <code>nuttx/arch/<architecture>/include/stdarg.h</code>
|
|
</p>
|
|
<p>
|
|
If <code>CONFIG_ARCH_STDARG_H=y</code> is defined, the top-level makefile will copy the re-directing <code>stdarg.h</code> header file from <code>include/nuttx/stdarg.h</code> to <code>include/stdarg.h</code>.
|
|
So for the architectures that cannot use their toolchain's <code>stdarg.h</code> file, they can use this alternative by defining <code>CONFIG_ARCH_STDARG_H=y</code> and providing.
|
|
If <code>CONFIG_ARCH_STDARG_H</code>, is not defined, then the <code>stdarg.h</code> header file will stay out-of-the-way in <code>include/nuttx/.</code>
|
|
</p>
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
|
|
<li>
|
|
<p><code>CONFIG_ARCH_ROMGETC</code>:
|
|
There are cases where string data cannot be cannot be accessed by simply de-referencing a string pointer.
|
|
As examples:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
In Harvard architectures, data accesses and instruction accesses occur on different busses, perhaps concurrently.
|
|
All data accesses are performed on the data bus unless special machine instructions are used to read data from the instruction address space.
|
|
Also, in the typical MCU, the available SRAM data memory is much smaller that the non-volatile FLASH instruction memory.
|
|
So if the application requires many constant strings, the only practical solution may be to store those constant strings in FLASH memory where they can only be accessed using architecture-specific machine instructions.
|
|
</li>
|
|
<li>
|
|
A similar case is where strings are retained in "external" memory such as EEPROM or serial FLASH.
|
|
This case is similar only in that again special operations are required to obtain the string data;
|
|
it cannot be accessed directly from a string pointer.
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
If <code>CONFIG_ARCH_ROMGETC</code> is defined, then the architecture-specific logic must export the function <code>up_romgetc()</code>.
|
|
<code>up_romgetc()</code> will simply read one byte of data from the instruction space.
|
|
</p>
|
|
<p>
|
|
If <code>CONFIG_ARCH_ROMGETC</code>, certain C stdio functions are effected:
|
|
(1) All format strings in <code>printf</code>, <code>fprintf</code>, <code>sprintf</code>, etc. are assumed to lie in FLASH
|
|
(string arguments for <code>%s</code> are still assumed to reside in SRAM).
|
|
And (2), the string argument to <code>puts</code> and <code>fputs</code> is assumed to reside in FLASH.
|
|
Clearly, these assumptions may have to modified for the particular needs of your environment.
|
|
There is no "one-size-fits-all" solution for this problem.
|
|
</p>
|
|
</ul>
|
|
|
|
<h2>Sizes of configurable things (0 disables)</h2>
|
|
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_MAX_TASKS</code>: The maximum number of simultaneously
|
|
active tasks. This value must be a power of two.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NPTHREAD_KEYS</code>: The number of items of thread-
|
|
specific data that can be retained
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NFILE_DESCRIPTORS</code>: The maximum number of file
|
|
descriptors (one for each open)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NFILE_STREAMS</code>: The maximum number of streams that
|
|
can be fopen'ed
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NAME_MAX</code>: Maximum number of bytes in a filename (not including terminating null).
|
|
Default: 32
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PATH_MAX</code>: Maximum number of bytes in a pathname, including the terminating null character.
|
|
Default: <code>MIN(256,(4*CONFIG_NAME_MAX+1))</code>
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_STDIO_BUFFER_SIZE</code>: Size of the buffer to allocate
|
|
on fopen. (Only if CONFIG_NFILE_STREAMS > 0)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_STDIO_LINEBUFFER</code>:
|
|
If standard C buffered I/O is enabled (<code>CONFIG_STDIO_BUFFER_SIZE</code> > 0),
|
|
then this option may be added to force automatic, line-oriented flushing the output buffer
|
|
for <code>putc()</code>, <code>fputc()</code>, <code>putchar()</code>, <code>puts()</code>, <code>fputs()</code>,
|
|
<code>printf()</code>, <code>fprintf()</code>, and <code>vfprintf()</code>.
|
|
When a newline character is encountered in the output string, the output buffer will be flushed.
|
|
This (slightly) increases the NuttX footprint but supports the kind of behavior that people expect for <code>printf()</code>.
|
|
<li>
|
|
<code>CONFIG_NUNGET_CHARS</code>: Number of characters that can be
|
|
buffered by ungetc() (Only if CONFIG_NFILE_STREAMS > 0)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PREALLOC_MQ_MSGS</code>: The number of pre-allocated message
|
|
structures. The system manages a pool of preallocated
|
|
message structures to minimize dynamic allocations
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_MQ_MAXMSGSIZE</code>: Message structures are allocated with
|
|
a fixed payload size given by this setting (does not include
|
|
other message structure overhead.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PREALLOC_WDOGS</code>: The number of pre-allocated watchdog
|
|
structures. The system manages a pool of preallocated
|
|
watchdog structures to minimize dynamic allocations
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PREALLOC_IGMPGROUPS</code>: Pre-allocated IGMP groups are used
|
|
Only if needed from interrupt level group created (by the IGMP server).
|
|
Default: 4
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_DEV_PIPE_SIZE</code>: Size, in bytes, of the buffer to allocated
|
|
for pipe and FIFO support (default is 1024).
|
|
</li>
|
|
</ul>
|
|
|
|
<h2>File Systems</h2>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_FS_FAT</code>: Enable FAT file system support.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_FAT_LCNAMES</code>: Enable use of the NT-style upper/lower case 8.3 file name support.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_FAT_LFN</code>: Enable FAT long file names.
|
|
NOTE: Microsoft claims patents on FAT long file name technology.
|
|
Please read the disclaimer in the top-level COPYING file and only enable this feature if you understand these issues.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_FAT_MAXFNAME</code>: If <code>CONFIG_FAT_LFN</code> is defined, then the default, maximum long file name is 255 bytes.
|
|
This can eat up a lot of memory (especially stack space).
|
|
If you are willing to live with some non-standard, short long file names, then define this value.
|
|
A good choice would be the same value as selected for CONFIG_NAME_MAX which will limit the visibility of longer file names anyway.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_FS_FATTIME</code>: Support FAT date and time.
|
|
NOTE: There is not much sense in supporting FAT date and time unless you have a hardware RTC
|
|
or other way to get the time and date.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_FS_NXFFS</code>: Enable NuttX FLASH file system (NXFF) support.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFFS_ERASEDSTATE</code>: The erased state of FLASH.
|
|
This must have one of the values of <code>0xff</code> or <code>0x00</code>.
|
|
Default: <code>0xff</code>.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFFS_PACKTHRESHOLD</code>: When packing flash file data,
|
|
don't both with file chunks smaller than this number of data bytes.
|
|
Default: 32.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFFS_MAXNAMLEN</code>: The maximum size of an NXFFS file name.
|
|
Default: 255.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFFS_PACKTHRESHOLD</code>: When packing flash file data,
|
|
don't both with file chunks smaller than this number of data bytes.
|
|
Default: 32.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFFS_TAILTHRESHOLD</code>: clean-up can either mean
|
|
packing files together toward the end of the file or, if file are
|
|
deleted at the end of the file, clean up can simply mean erasing
|
|
the end of FLASH memory so that it can be re-used again. However,
|
|
doing this can also harm the life of the FLASH part because it can
|
|
mean that the tail end of the FLASH is re-used too often. This
|
|
threshold determines if/when it is worth erased the tail end of FLASH
|
|
and making it available for re-use (and possible over-wear).
|
|
Default: 8192.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_FS_ROMFS</code>: Enable ROMFS file system support
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NFS</code>: Enable Network File System (NFS) client file system support.
|
|
Provided support is version 3 using UDP.
|
|
In addition to common prerequisites for mount-able file systems in general,
|
|
this option requires UDP networking support;
|
|
this would include <code>CONFIG_NET</code> and <code>CONFIG_NET_UDP</code> at a minimum.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_FS_RAMMAP</code>: For file systems that do not support
|
|
XIP, this option will enable a limited form of memory mapping that is
|
|
implemented by copying whole files into memory.
|
|
</li>
|
|
</ul>
|
|
|
|
<h2>Device Drivers</h2>
|
|
<h3>RTC</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_RTC</code>:
|
|
Enables general support for a hardware RTC.
|
|
Specific architectures may require other specific settings.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_RTC_DATETIME</code>:
|
|
There are two general types of RTC: (1) A simple battery backed counter that keeps the time when power
|
|
is down, and (2) A full date / time RTC the provides the date and time information, often in BCD format.
|
|
If <code>CONFIG_RTC_DATETIME</code> is selected, it specifies this second kind of RTC.
|
|
In this case, the RTC is used to "seed"" the normal NuttX timer and the NuttX system timer
|
|
provides for higher resoution time.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_RTC_HIRES</code>:
|
|
If <code>CONFIG_RTC_DATETIME</code> not selected, then the simple, battery backed counter is used.
|
|
There are two different implementations of such simple counters based on the time resolution of the counter:
|
|
The typical RTC keeps time to resolution of 1 second, usually supporting a 32-bit <code>time_t</code> value.
|
|
In this case, the RTC is used to "seed" the normal NuttX timer and the NuttX timer provides for higher resoution time.
|
|
If <code>CONFIG_RTC_HIRES</code> is enabled in the NuttX configuration, then the RTC provides higher resolution time and completely replaces the system timer for purpose of date and time.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_RTC_FREQUENCY</code>:
|
|
If <code>CONFIG_RTC_HIRES</code> is defined, then the frequency of the high resolution RTC must be provided.
|
|
If <code>CONFIG_RTC_HIRES</code> is not defined, <code>CONFIG_RTC_FREQUENCY</code> is assumed to be one.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_RTC_ALARM</code>:
|
|
Enable if the RTC hardware supports setting of an alarm.
|
|
A callback function will be executed when the alarm goes off
|
|
</li>
|
|
</ul>
|
|
|
|
<h3>CAN driver</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_CAN</code>: Enables CAN support
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CAN_FIFOSIZE</code>: The size of the circular buffer of CAN messages. Default: 8
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CAN_NPENDINGRTR</code>: The size of the list of pending RTR requests. Default: 4
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CAN_LOOPBACK</code>: A CAN driver may or may not support a loopback mode for testing.
|
|
If the driver does support loopback mode, the setting will enable it.
|
|
(If the driver does not, this setting will have no effect).
|
|
</li>
|
|
</ul>
|
|
|
|
<h3>SPI driver</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_SPI_OWNBUS</code>: Set if there is only one active device
|
|
on the SPI bus. No locking or SPI configuration will be performed.
|
|
It is not necessary for clients to lock, re-configure, etc..
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SPI_EXCHANGE</code>: Driver supports a single exchange method
|
|
(vs a recvblock() and sndblock ()methods)
|
|
</li>
|
|
</ul>
|
|
|
|
<h3>SPI-based MMC/SD driver</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_MMCSD_NSLOTS</code>: Number of MMC/SD slots supported by the driver. Default is one.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_MMCSD_READONLY</code>: Provide read-only access. Default is Read/Write
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_MMCSD_SPICLOCK</code>: Maximum SPI clock to drive MMC/SD card. Default is 20MHz.
|
|
</li>
|
|
</ul>
|
|
|
|
<h3>SDIO/SDHC driver</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_SDIO_DMA</code>: SDIO driver supports DMA
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SDIO_MUXBUS</code>: Set this SDIO interface if the SDIO interface
|
|
or hardware resources are shared with other drivers.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SDIO_WIDTH_D1_ONLY</code>: Select 1-bit transfer mode. Default:
|
|
4-bit transfer mode.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_MMCSD_MULTIBLOCK_DISABLE</code>: Use only the single block transfer method.
|
|
This setting is used to work around buggy SDIO drivers that cannot handle
|
|
multiple block transfers.
|
|
</li>
|
|
</ul>
|
|
|
|
<h3>SDIO-based MMC/SD driver</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_FS_READAHEAD</code>: Enable read-ahead buffering
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_FS_WRITEBUFFER</code>: Enable write buffering
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SDIO_DMA</code>: SDIO driver supports DMA
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_MMCSD_MMCSUPPORT</code>: Enable support for MMC cards
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_MMCSD_HAVECARDDETECT</code>: SDIO driver card detection is 100% accurate
|
|
</li>
|
|
</ul>
|
|
|
|
<h3>RiT P14201 OLED driver</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_LCD_P14201</code>: Enable P14201 support
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_P14201_SPIMODE</code>: Controls the SPI mode
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_P14201_FREQUENCY</code>: Define to use a different bus frequency
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_P14201_NINTERFACES</code>:
|
|
Specifies the number of physical P14201 devices that will be supported.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_P14201_FRAMEBUFFER</code>:
|
|
If defined, accesses will be performed using an in-memory copy of the OLEDs GDDRAM.
|
|
This cost of this buffer is 128 * 96 / 2 = 6K.
|
|
If this is defined, then the driver will be fully functional.
|
|
If not, then it will have the following limitations:
|
|
<ul>
|
|
<li>Reading graphics memory cannot be supported, and</li>
|
|
<li>All pixel writes must be aligned to byte boundaries.</li>
|
|
</ul>
|
|
The latter limitation effectively reduces the 128x96 disply to 64x96.
|
|
</li>
|
|
</ul>
|
|
|
|
<h3>Nokia 6100 Configuration Settings:</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_NOKIA6100_SPIMODE</code>: Controls the SPI mode,
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NOKIA6100_FREQUENCY</code>: Define to use a different bus frequency.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NOKIA6100_NINTERFACES</code>:Specifies the number of physical Nokia
|
|
6100 devices that will be supported.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NOKIA6100_BPP</code>: Device supports 8, 12, and 16 bits per pixel.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NOKIA6100_S1D15G10</code>: Selects the Epson S1D15G10 display controller
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NOKIA6100_PCF8833</code>: Selects the Phillips PCF8833 display controller
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NOKIA6100_BLINIT</code>: Initial backlight setting
|
|
</li>
|
|
<p>
|
|
The following may need to be tuned for your hardware:
|
|
</p>
|
|
<li>
|
|
<code>CONFIG_NOKIA6100_INVERT</code>: Display inversion, 0 or 1, Default: 1
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NOKIA6100_MY</code>: Display row direction, 0 or 1, Default: 0
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NOKIA6100_MX</code>: Display column direction, 0 or 1, Default: 1
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NOKIA6100_V</code>: Display address direction, 0 or 1, Default: 0
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NOKIA6100_ML</code>: Display scan direction, 0 or 1, Default: 0
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NOKIA6100_RGBORD</code>: Display RGB order, 0 or 1, Default: 0
|
|
</li>
|
|
<p>
|
|
Required LCD driver settings:
|
|
</p>
|
|
<li>
|
|
<code>CONFIG_LCD_NOKIA6100</code>: Enable Nokia 6100 support
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_LCD_MAXCONTRAST</code>: Must be 63 with the Epson controller and 127 with
|
|
the Phillips controller.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_LCD_MAXPOWER</code>:Maximum value of backlight setting. The backlight
|
|
control is managed outside of the 6100 driver so this value has no
|
|
meaning to the driver. Board-specific logic may place restrictions on
|
|
this value.
|
|
</li>
|
|
</ul>
|
|
|
|
<h3>Input Devices</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_INPUT</code>:
|
|
Enables general support for input devices
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_INPUT_TSC2007</code>:
|
|
If CONFIG_INPUT is selected, then this setting will enable building
|
|
of the TI TSC2007 touchscreen driver.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_TSC2007_MULTIPLE</code>:
|
|
Normally only a single TI TSC2007 touchscreen is used. But if
|
|
there are multiple TSC2007 touchscreens, this setting will enable
|
|
multiple touchscreens with the same driver.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_INPUT_STMPE811</code>:
|
|
Enables support for the STMPE811 driver (Needs <code>CONFIG_INPUT</code>)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_STMPE811_SPI</code>:
|
|
Enables support for the SPI interface (not currenly supported)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_STMPE811_I2C</code>:
|
|
Enables support for the I2C interface
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_STMPE811_MULTIPLE </code>:
|
|
Can be defined to support multiple STMPE811 devices on board.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_STMPE811_ACTIVELOW</code>:
|
|
Interrupt is generated by an active low signal (or falling edge).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_STMPE811_EDGE</code>:
|
|
Interrupt is generated on an edge (vs. on the active level)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_STMPE811_NPOLLWAITERS</code>:
|
|
Maximum number of threads that can be waiting on poll() (ignored if
|
|
<code>CONFIG_DISABLE_POLL</code> is set).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_STMPE811_TSC_DISABLE</code>:
|
|
Disable driver touchscreen functionality.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_STMPE811_ADC_DISABLE</code>:
|
|
Disable driver ADC functionality.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_STMPE811_GPIO_DISABLE</code>:
|
|
Disable driver GPIO functionlaity.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_STMPE811_GPIOINT_DISABLE</code>:
|
|
Disable driver GPIO interrupt functionality (ignored if GPIO
|
|
functionality is disabled).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_STMPE811_SWAPXY</code>:
|
|
Reverse the meaning of X and Y to handle different LCD orientations.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_STMPE811_TEMP_DISABLE</code>:
|
|
Disable driver temperature sensor functionality.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_STMPE811_REGDEBUG</code>:
|
|
Enabled very low register-level debug output. Requires <code>CONFIG_DEBUG</code>.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_STMPE811_THRESHX</code> and <code>CONFIG_STMPE811_THRESHY</code>:
|
|
STMPE811 touchscreen data comes in a a very high rate. New touch positions
|
|
will only be reported when the X or Y data changes by these thresholds.
|
|
This trades reduces data rate for some loss in dragging accuracy. The
|
|
STMPE811 is configure for 12-bit values so the raw ranges are 0-4095. So
|
|
for example, if your display is 320x240, then THRESHX=13 and THRESHY=17
|
|
would correspond to one pixel. Default: 12
|
|
</li>
|
|
</ul>
|
|
|
|
<h3>Analog Devices</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_DAC</code>:
|
|
Enables general support for Digital-to-Analog conversion devices.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_ADC</code>:
|
|
Enables general support for Analog-to-Digital conversion devices.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_ADC_ADS125X</code>:
|
|
Adds support for the TI ADS 125x ADC.
|
|
</li>
|
|
</ul>
|
|
|
|
<h3>ENC28J60 Ethernet Driver Configuration Settings</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_ENC28J60</code>: Enabled ENC28J60 support
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_ENC28J60_SPIMODE</code>: Controls the SPI mode
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_ENC28J60_FREQUENCY</code>: Define to use a different bus frequency
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_ENC28J60_NINTERFACES</code>:
|
|
Specifies the number of physical ENC28J60 devices that will be supported.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_ENC28J60_STATS</code>: Collect network statistics
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_ENC28J60_HALFDUPPLEX</code>: Default is full duplex
|
|
</li>
|
|
</ul>
|
|
|
|
<h2>Network Support</h2>
|
|
<h3>TCP/IP and UDP support via uIP</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_NET</code>: Enable or disable all network features
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_SLIP</code>: Selects the Serial Line Internet Protocol (SLIP) data link layer.
|
|
(This selection is discussed further <a href="#slipdriver">below</a>).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_NOINTS</code>: <code>CONFIG_NET_NOINT</code> indicates that uIP not called from the interrupt level.
|
|
If <code>CONFIG_NET_NOINTS</code> is defined, critical sections will be managed with semaphores;
|
|
Otherwise, it assumed that uIP will be called from interrupt level handling and critical sections will be managed by enabling and disabling interrupts.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_MULTIBUFFER</code>: Traditionally, uIP has used a single buffer for all incoming and outgoing traffic.
|
|
If this configuration is selected, then the driver can manage multiple I/O buffers and can, for example, be filling one input buffer while sending another output buffer.
|
|
Or, as another example, the driver may support queuing of concurrent input/ouput and output transfers for better performance.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_IPv6</code>: Build in support for IPv6
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NSOCKET_DESCRIPTORS</code>: Maximum number of socket descriptors per task/thread.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_NACTIVESOCKETS</code>: Maximum number of concurrent socket operations (recv, send, etc.).
|
|
Default: <code>CONFIG_NET_TCP_CONNS</code>+<code>CONFIG_NET_UDP_CONNS</code>.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_SOCKOPTS</code>: Enable or disable support for socket options.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_BUFSIZE</code>: uIP buffer size
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_TCP</code>: TCP support on or off
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_TCP_CONNS</code>: Maximum number of TCP connections (all tasks).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_TCPBACKLOG</code>:
|
|
Incoming connections pend in a backlog until <code>accept()</code> is called.
|
|
The size of the backlog is selected when <code>listen()</code> is called.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_TCP_READAHEAD_BUFSIZE</code>: Size of TCP read-ahead buffers
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_NTCP_READAHEAD_BUFFERS</code>: Number of TCP read-ahead buffers (may be zero to disable TCP/IP read-ahead buffering)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_TCP_RECVDELAY</code>: Delay (in deciseconds) after a TCP/IP packet is received.
|
|
This delay may allow catching of additional packets when TCP/IP read-ahead is disabled.
|
|
Default: 0
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_MAX_LISTENPORTS</code>: Maximum number of listening TCP ports (all tasks).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_TCPURGDATA</code>: Determines if support for TCP urgent data
|
|
notification should be compiled in. Urgent data (out-of-band data)
|
|
is a rarely used TCP feature that is very seldom would be required.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_UDP</code>: UDP support on or off
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_UDP_CHECKSUMS</code>: UDP checksums on or off
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_UDP_CONNS</code>: The maximum amount of concurrent UDP connections
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_ICMP</code>: Enable minimal ICMP support. Includes built-in support
|
|
for sending replies to received ECHO (ping) requests.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_ICMP_PING</code>: Provide interfaces to support application level
|
|
support for sending ECHO (ping) requests and associating ECHO replies.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_IGMP</code>: Enable IGMPv2 client support.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PREALLOC_IGMPGROUPS</code>: Pre-allocated IGMP groups are used
|
|
Only if needed from interrupt level group created (by the IGMP server).
|
|
Default: 4
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_PINGADDRCONF</code>: Use "ping" packet for setting IP address
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_STATISTICS</code>: uIP statistics on or off
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_RECEIVE_WINDOW</code>: The size of the advertised receiver's window
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_ARPTAB_SIZE</code>: The size of the ARP table
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_ARP_IPIN</code>: Harvest IP/MAC address mappings for the ARP table from incoming IP packets.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_BROADCAST</code>: Incoming UDP broadcast support
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_MULTICAST</code>: Outgoing multi-cast address support
|
|
</li>
|
|
</ul>
|
|
|
|
<h3><a name="slipdriver">SLIP</a></h3>
|
|
<p>
|
|
The NuttX SLIP driver supports point-to-point IP communications over a serial port.
|
|
The default data link layer for uIP is Ethernet.
|
|
If <code>CONFIG_NET_SLIP</code> is defined in the NuttX configuration file, then SLIP will be supported.
|
|
The basic differences between the SLIP and Ethernet configurations is that when SLIP is selected:
|
|
<ul>
|
|
<li>The link level header (that comes before the IP header) is omitted.</li>
|
|
<li>All MAC address processing is suppressed.</li>
|
|
<li>ARP is disabled.</li>
|
|
</ul>
|
|
If <code>CONFIG_NET_SLIP</code> is not selected, then Ethernet will be used
|
|
(there is no need to define anything special in the configuration file to use Ethernet -- it is the default).
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_NET_SLIP</code>: Enables building of the SLIP driver.
|
|
SLIP requires at least one IP protocols selected and the following additional network settings: <code>CONFIG_NET_NOINTS</code> and <code>CONFIG_NET_MULTIBUFFER</code>.
|
|
<code>CONFIG_NET_BUFSIZE</code> <i>must</i> be set to 296.
|
|
Other optional configuration settings that affect the SLIP driver: <code>CONFIG_NET_STATISTICS</code>.
|
|
Default: Ethernet.
|
|
</li>
|
|
<p>
|
|
If SLIP is selected, then the following SLIP options are available:
|
|
</p>
|
|
<li>
|
|
<code>CONFIG_CLIP_NINTERFACES</code>: Selects the number of physical SLIP interfaces to support. Default: 1
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SLIP_STACKSIZE</code>: Select the stack size of the SLIP RX and TX tasks. Default: 2048
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_SLIP_DEFPRIO</code>: The priority of the SLIP RX and TX tasks. Default: 128
|
|
</li>
|
|
</li>
|
|
</ul>
|
|
|
|
<h3>UIP Network Utilities</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_NET_DHCP_LIGHT</code>: Reduces size of DHCP
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_RESOLV_ENTRIES</code>: Number of resolver entries
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NET_RESOLV_MAXRESPONSE</code>:
|
|
This setting determines the maximum size of response message that can be received by the DNS resolver.
|
|
The default is 96 but may need to be larger on enterprise networks (perhaps 176).
|
|
</li>
|
|
</ul>
|
|
|
|
<h3>THTTPD</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_THTTPD_PORT</code>: THTTPD Server port number
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_IPADDR</code>: Server IP address (no host name)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_SERVER_ADDRESS</code>: SERVER_ADDRESS: response
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_SERVER_SOFTWARE</code>: SERVER_SOFTWARE: response
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_PATH</code>: Server working directory. Default: <code>/mnt/www</code>.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_CGI_PATH</code>: Path to CGI executables. Default: <code>/mnt/www/cgi-bin</code>.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_CGI_PATTERN</code>: Only CGI programs whose expanded paths
|
|
match this pattern will be executed. In fact, if this value is not defined
|
|
then no CGI logic will be built. Default: <code>/mnt/www/cgi-bin/*</code>.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_CGI_PRIORITY</code>: Provides the priority of CGI child tasks
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_CGI_STACKSIZE</code>: Provides the initial stack size of
|
|
CGI child task (will be overridden by the stack size in the NXFLAT
|
|
header)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_CGI_BYTECOUNT</code>: Byte output limit for CGI tasks.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_CGI_TIMELIMIT</code>: How many seconds to allow CGI programs
|
|
to run before killing them.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_CHARSET</code>: The default character set name to use with
|
|
text MIME types.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_IOBUFFERSIZE</code>:
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_INDEX_NAMES</code>: A list of index filenames to check. The
|
|
files are searched for in this order.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_AUTH_FILE</code>: The file to use for authentication. If this is
|
|
defined then thttpd checks for this file in the local directory
|
|
before every fetch. If the file exists then authentication is done,
|
|
otherwise the fetch proceeds as usual. If you leave this undefined
|
|
then thttpd will not implement authentication at all and will not
|
|
check for auth files, which saves a bit of CPU time. A typical
|
|
value is ".htpasswd&quout;
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_LISTEN_BACKLOG</code>: The listen() backlog queue length.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_LINGER_MSEC</code>: How many milliseconds to leave a connection
|
|
open while doing a lingering close.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_OCCASIONAL_MSEC</code>: How often to run the occasional
|
|
cleanup job.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_IDLE_READ_LIMIT_SEC</code>: How many seconds to allow for
|
|
reading the initial request on a new connection.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_IDLE_SEND_LIMIT_SEC</code>: How many seconds before an
|
|
idle connection gets closed.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_TILDE_MAP1 and CONFIG_THTTPD_TILDE_MAP2</code>: Tilde mapping.
|
|
Many URLs use ~username to indicate a user's home directory. thttpd
|
|
provides two options for mapping this construct to an actual filename.
|
|
<ol>
|
|
<li>
|
|
Map ~username to <prefix>/username. This is the recommended choice.
|
|
Each user gets a subdirectory in the main web tree, and the tilde
|
|
construct points there. The prefix could be something like "users",
|
|
or it could be empty.
|
|
</li>
|
|
<li>
|
|
Map ~username to <user's homedir>/<postfix>. The postfix would be
|
|
the name of a subdirectory off of the user's actual home dir,
|
|
something like "public_html".
|
|
</li>
|
|
</ol>
|
|
You can also leave both options undefined, and thttpd will not do
|
|
anything special about tildes. Enabling both options is an error.
|
|
Typical values, if they're defined, are "users" for
|
|
CONFIG_THTTPD_TILDE_MAP1 and "public_html" forCONFIG_THTTPD_TILDE_MAP2.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_GENERATE_INDICES</code>:
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_THTTPD_URLPATTERN</code>: If defined, then it will be used to match
|
|
and verify referrers.
|
|
</li>
|
|
</ul>
|
|
|
|
<h3>FTP Server</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_FTPD_VENDORID</code>: The vendor name to use in FTP communications. Default: "NuttX"
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_FTPD_SERVERID</code>: The server name to use in FTP communications. Default: "NuttX FTP Server"
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_FTPD_CMDBUFFERSIZE</code>: The maximum size of one command. Default: 128 bytes.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_FTPD_DATABUFFERSIZE</code>: The size of the I/O buffer for data transfers. Default: 512 bytes.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_FTPD_WORKERSTACKSIZE</code>: The stacksize to allocate for each FTP daemon worker thread. Default: 2048 bytes.
|
|
</li>
|
|
</ul>
|
|
<p>
|
|
Other required FTPD configuration settings: Of course TCP networking support is required. But here are a couple that are less obvious:
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_DISABLE_PTHREAD=n</code>: pthread support is required
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_DISABLE_POLL=n</code>: poll() support is required
|
|
</li>
|
|
</ul>
|
|
|
|
<h2>USB Device-Side Support</h2>
|
|
<h3>USB Device Controller Driver</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_USBDEV</code>: Enables USB device support
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBDEV_COMPOSITE</code>: Enables USB composite device support
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBDEV_ISOCHRONOUS</code>: Build in extra support for isochronous endpoints
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBDEV_DUALSPEED</code>: Hardware handles high and full speed operation (USB 2.0)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBDEV_SELFPOWERED</code>: Will cause USB features to indicate that the device is self-powered
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBDEV_MAXPOWER</code>: Maximum power consumption in mA
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBDEV_TRACE</code>: Enables USB tracing for debug
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBDEV_TRACE_NRECORDS</code>: Number of trace entries to remember
|
|
</li>
|
|
</ul>
|
|
|
|
<h3>USB Serial Device Class Driver (Prolific PL2303 Emulation)</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_PL2303</code>: Enable compilation of the USB serial driver
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PL2303_EPINTIN</code>: The logical 7-bit address of a hardware endpoint that supports interrupt IN operation
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PL2303_EPBULKOUT</code>: The logical 7-bit address of a hardware endpoint that supports bulk OUT operation
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PL2303_EPBULKIN</code>: The logical 7-bit address of a hardware endpoint that supports bulk IN operation
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PL2303_NWRREQS</code> and <code>CONFIG_PL2303_NRDREQS</code>: The number of write/read requests that can be in flight
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PL2303_VENDORID</code> and <code>CONFIG_PL2303_VENDORSTR</code>: The vendor ID code/string
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PL2303_PRODUCTID</code> and <code>CONFIG_PL2303_PRODUCTSTR</code>: The product ID code/string
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PL2303_RXBUFSIZE</code> and <code>CONFIG_PL2303_TXBUFSIZE</code>: Size of the serial receive/transmit buffers
|
|
</li>
|
|
</ul>
|
|
|
|
<h3>USB serial device class driver (Standard CDC ACM class)</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_CDCACM</code>: Enable compilation of the USB serial driver
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CDCACM_COMPOSITE</code>:
|
|
Configure the CDC serial driver as part of a composite driver
|
|
(only if <code>CONFIG_USBDEV_COMPOSITE</code> is also defined)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CDCACM_IFNOBASE</code>:
|
|
If the CDC driver is part of a composite device, then this may need to
|
|
be defined to offset the CDC/ACM interface numbers so that they are
|
|
unique and contiguous. When used with the Mass Storage driver, the
|
|
correct value for this offset is zero.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CDCACM_STRBASE</code>:
|
|
If the CDC driver is part of a composite device, then this may need to
|
|
be defined to offset the CDC/ACM string numbers so that they are
|
|
unique and contiguous. When used with the Mass Storage driver, the
|
|
correct value for this offset is four (this value actuallly only needs
|
|
to be defined if names are provided for the Notification interface,
|
|
<code>CONFIG_CDCACM_NOTIFSTR</code>, or the data interface, <code>CONFIG_CDCACM_DATAIFSTR</code>).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CDCACM_EP0MAXPACKET</code>: Endpoint 0 max packet size. Default 64.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CDCACM_EPINTIN</code>: The logical 7-bit address of a hardware endpoint that supports
|
|
interrupt IN operation. Default 2.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CDCACM_EPINTIN_FSSIZE</code>: Max package size for the interrupt IN endpoint if full speed mode. Default 64.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CDCACM_EPINTIN_HSSIZE</code>: Max package size for the interrupt IN endpoint if high speed mode. Default 64.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CDCACM_EPBULKOUT</code>: The logical 7-bit address of a hardware endpoint that supports
|
|
bulk OUT operation.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CDCACM_EPBULKOUT_FSSIZE</code>: Max package size for the bulk OUT endpoint if full speed mode. Default 64.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CDCACM_EPBULKOUT_HSSIZE</code>: Max package size for the bulk OUT endpoint if high speed mode. Default 512.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CDCACM_EPBULKIN</code>: The logical 7-bit address of a hardware endpoint that supports
|
|
bulk IN operation
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CDCACM_EPBULKIN_FSSIZE</code>: Max package size for the bulk IN endpoint if full speed mode. Default 64.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CDCACM_EPBULKIN_HSSIZE</code>: Max package size for the bulk IN endpoint if high speed mode. Default 512.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CDCACM_NWRREQS</code> and <code>CONFIG_CDCACM_NRDREQS</code>: The number of write/read requests that can be in flight.
|
|
<code>CONFIG_CDCACM_NWRREQS</code> includes write requests used for both the interrupt and bulk IN endpoints.
|
|
Default 4.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CDCACM_VENDORID</code> and <code>CONFIG_CDCACM_VENDORSTR</code>: The vendor ID code/string. Default 0x0525 and "NuttX,"
|
|
0x0525 is the Netchip vendor and should not be used in any products.
|
|
This default VID was selected for compatibility with the Linux CDC ACM default VID.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CDCACM_PRODUCTID</code> and <code>CONFIG_CDCACM_PRODUCTSTR</code>: The product ID code/string. Default 0xa4a7 and "CDC/ACM Serial"
|
|
0xa4a7 was selected for compatibility with the Linux CDC ACM default PID.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CDCACM_RXBUFSIZE</code> and <code>CONFIG_CDCACM_TXBUFSIZE</code>: Size of the serial receive/transmit buffers. Default 256.
|
|
</ul>
|
|
|
|
<h3>USB Storage Device Configuration</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_USBMSC</code>:
|
|
Enable compilation of the USB storage driver
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBMSC_COMPOSITE</code>:
|
|
Configure the mass storage driver as part of a composite driver
|
|
(only if <code>CONFIG_USBDEV_COMPOSITE</code> is also defined)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBMSC_IFNOBASE</code>:
|
|
If the CDC driver is part of a composite device, then this may need to
|
|
be defined to offset the mass storage interface number so that it is
|
|
unique and contiguous. When used with the CDC/ACM driver, the
|
|
correct value for this offset is two (because of the two CDC/ACM
|
|
interfaces that will precede it).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBMSC_STRBASE</code>:
|
|
If the CDC driver is part of a composite device, then this may need to
|
|
be defined to offset the mass storage string numbers so that they are
|
|
unique and contiguous. When used with the CDC/ACM driver, the
|
|
correct value for this offset is four (or perhaps 5 or 6, depending
|
|
on if <code>CONFIG_CDCACM_NOTIFSTR</code> or <code>CONFIG_CDCACM_DATAIFSTR</code> are defined).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBMSC_EP0MAXPACKET</code>:
|
|
Max packet size for endpoint 0
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBMSCEPBULKOUT</code> and <code>CONFIG_USBMSC_EPBULKIN</code>:
|
|
The logical 7-bit address of a hardware endpoints that support bulk OUT and IN operations
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBMSC_NWRREQS</code> and <code>CONFIG_USBMSC_NRDREQS</code>:
|
|
The number of write/read requests that can be in flight
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBMSC_BULKINREQLEN</code> and <code>CONFIG_USBMSC_BULKOUTREQLEN</code>:
|
|
The size of the buffer in each write/read request.
|
|
This value needs to be at least as large as the endpoint maxpacket and
|
|
ideally as large as a block device sector.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBMSC_VENDORID</code> and <code>CONFIG_USBMSC_VENDORSTR</code>:
|
|
The vendor ID code/string
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBMSC_PRODUCTID</code> and <code>CONFIG_USBMSC_PRODUCTSTR</code>:
|
|
The product ID code/string
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBMSC_REMOVABLE</code>:
|
|
Select if the media is removable
|
|
</li>
|
|
</ul>
|
|
|
|
<h3>USB Composite Device Configuration</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_USBDEV_COMPOSITE</code>:
|
|
Enables USB composite device support
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_CDCACM_COMPOSITE</code>:
|
|
Configure the CDC serial driver as part of a composite driver
|
|
(only if CONFIG_USBDEV_COMPOSITE is also defined)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_UBMSC_COMPOSITE</code>:
|
|
Configure the mass storage driver as part of a composite driver
|
|
(only if CONFIG_USBDEV_COMPOSITE is also defined)
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_COMPOSITE_IAD</code>:
|
|
If one of the members of the composite has multiple interfaces
|
|
(such as CDC/ACM), then an Interface Association Descriptor (IAD)
|
|
will be necessary. Default: IAD will be used automatically if
|
|
needed. It should not be necessary to set this.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_COMPOSITE_EP0MAXPACKET</code>:
|
|
Max packet size for endpoint 0
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_COMPOSITE_VENDORID</code> and <code>CONFIG_COMPOSITE_VENDORSTR</code>:
|
|
The vendor ID code/string
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_COMPOSITE_PRODUCTID</code> and <code>CONFIG_COMPOSITE_PRODUCTSTR</code>:
|
|
The product ID code/string
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_COMPOSITE_SERIALSTR</code>:
|
|
Device serial number string
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_COMPOSITE_CONFIGSTR</code>:
|
|
Configuration string
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_COMPOSITE_VERSIONNO</code>:
|
|
Interface version number.
|
|
</li>
|
|
</ul>
|
|
|
|
<h2>USB Host-Side Support</h2>
|
|
<h3>USB Host Controller Driver</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_USBHOST</code>: Enables USB host support
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBHOST_NPREALLOC</code>: Number of pre-allocated class instances
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBHOST_BULK_DISABLE</code>: On some architectures, selecting this setting will reduce driver size by disabling bulk endpoint support
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBHOST_INT_DISABLE</code>: On some architectures, selecting this setting will reduce driver size by disabling interrupt endpoint support
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USBHOST_ISOC_DISABLE</code>: On some architectures, selecting this setting will reduce driver size by disabling isochronous endpoint support
|
|
</li>
|
|
</ul>
|
|
<h3>USB Host HID Class Driver</h3>
|
|
<p>
|
|
Requires <code>CONFIG_USBHOST=y</code>, <code>CONFIG_USBHOST_INT_DISABLE=n</code>, <code>CONFIG_NFILE_DESCRIPTORS > 0</code>,
|
|
<code>CONFIG_SCHED_WORKQUEUE=y</code>, and <code>CONFIG_DISABLE_SIGNALS=n</code>.
|
|
</p>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_HIDKBD_POLLUSEC</code>: Device poll rate in microseconds. Default: 100 milliseconds.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_HIDKBD_DEFPRIO</code>: Priority of the polling thread. Default: 50.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_HIDKBD_STACKSIZE</code>: Stack size for polling thread. Default: 1024
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_HIDKBD_BUFSIZE</code>: Scancode buffer size. Default: 64.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_HIDKBD_NPOLLWAITERS</code>: If the poll() method is enabled, this defines the maximum number of threads that can be waiting for keyboard events. Default: 2.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_HIDKBD_RAWSCANCODES</code>: If set to <code>y</code> no conversion will be made on the raw keyboard scan codes. Default: ASCII conversion.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_HIDKBD_ALLSCANCODES</code>: If set to <code>y</code> all 231 possible scancodes will be converted to something. Default: 104 key US keyboard.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_HIDKBD_NODEBOUNCE</code>: If set to <code>y</code> normal debouncing is disabled. Default: Debounce/No repeat keys.
|
|
</li>
|
|
</ul>
|
|
<h3>USB Host HID Mass Storage Class Driver</h3>
|
|
<p>
|
|
Requires <code>CONFIG_USBHOST=y</code>, <code>CONFIG_USBHOST_BULK_DISABLE=n</code>, <code>CONFIG_NFILE_DESCRIPTORS > 0</code>,
|
|
and <code>CONFIG_SCHED_WORKQUEUE=y</code>.
|
|
</p>
|
|
|
|
<h2>Graphics related configuration settings</h3>
|
|
<li>
|
|
<code>CONFIG_NX</code>:
|
|
Enables overall support for graphics library and NX
|
|
</li>
|
|
</ul>
|
|
|
|
<h3>NX configuration setting</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_NX_MULTIUSER</code>:
|
|
Configures NX in multi-user mode.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NX_NPLANES</code>:
|
|
Some YUV color formats requires support for multiple planes,
|
|
one for each color component. Unless you have such special
|
|
hardware, this value should be undefined or set to 1.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NX_WRITEONLY</code>:
|
|
Define if the underlying graphics device does not support read operations.
|
|
Automatically defined if <code>CONFIG_NX_LCDDRIVER</code> and <code>CONFIG_LCD_NOGETRUN</code>
|
|
are defined.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NX_DISABLE_1BPP</code>, <code>CONFIG_NX_DISABLE_2BPP</code>,
|
|
<code>CONFIG_NX_DISABLE_4BPP</code>, <code>CONFIG_NX_DISABLE_8BPP</code>
|
|
<code>CONFIG_NX_DISABLE_16BPP</code>, <code>CONFIG_NX_DISABLE_24BPP</code>, and
|
|
<code>CONFIG_NX_DISABLE_32BPP</code>:
|
|
NX supports a variety of pixel depths. You can save some
|
|
memory by disabling support for unused color depths.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NX_PACKEDMSFIRST</code>:
|
|
If a pixel depth of less than 8-bits is used, then NX needs
|
|
to know if the pixels pack from the MS to LS or from LS to MS
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NX_LCDDRIVER</code>:
|
|
By default, NX builds to use a framebuffer driver (see <code>include/nuttx/fb.h</code>).
|
|
If this option is defined, NX will build to use an LCD driver (see <code>include/nuttx/lcd/lcd.h</code>).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_LCD_MAXPOWER</code>:
|
|
The full-on power setting for an LCD device.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_LCD_MAXCONTRAST</code>:
|
|
The maximum contrast value for an LCD device.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_LCD_LANDSCAPE</code>, <code>CONFIG_LCD_PORTRAIT</code>,
|
|
<code>CONFIG_LCD_RLANDSCAPE</code>, and <code>CONFIG_LCD_RPORTRAIT</code>:
|
|
Some LCD drivers may support these options to present the display in
|
|
landscape, portrait, reverse landscape, or reverse portrait orientations.
|
|
Check the <code>README.txt</code> file in each board configuration directory to
|
|
see if any of these are supported by the board LCD logic.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_LCD_NOGETRUN</code>:
|
|
NX components need to know if it can read from the LCD or not.
|
|
If reading from the LCD is supported, then NxConsole can do more efficient scrolling.
|
|
Default: Supported
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NX_MOUSE</code>:
|
|
Build in support for mouse input.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NX_KBD</code>:
|
|
Build in support of keypad/keyboard input.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXTK_BORDERWIDTH</code>:
|
|
Specifies with with of the border (in pixels) used with
|
|
framed windows. The default is 4.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXTK_BORDERCOLOR1</code> and <code>CONFIG_NXTK_BORDERCOLOR2</code>:
|
|
Specify the colors of the border used with framed windows.
|
|
<code>CONFIG_NXTK_BORDERCOLOR2</code> is the shadow side color and so
|
|
is normally darker. The default is medium and dark grey,
|
|
respectively
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXTK_AUTORAISE</code>:
|
|
If set, a window will be raised to the top if the mouse position
|
|
is over a visible portion of the window. Default: A mouse
|
|
button must be clicked over a visible portion of the window.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFONTS_CHARBITS</code>:
|
|
The number of bits in the character set. Current options are
|
|
only 7 and 8. The default is 7.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFONT_SANS17X22</code>:
|
|
This option enables support for a tiny, 17x22 san serif font
|
|
(font <code>ID FONTID_SANS17X22</code> == 14).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFONT_SANS20X26</code>:
|
|
This option enables support for a tiny, 20x26 san serif font
|
|
(font <code>ID FONTID_SANS20X26</code> == 15).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFONT_SANS23X27</code>:
|
|
This option enables support for a tiny, 23x27 san serif font
|
|
(font <code>ID FONTID_SANS23X27</code> == 1).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFONT_SANS22X29</code>:
|
|
This option enables support for a small, 22x29 san serif font
|
|
(font <code>ID FONTID_SANS22X29</code> == 2).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFONT_SANS28X37</code>:
|
|
This option enables support for a medium, 28x37 san serif font
|
|
(font <code>ID FONTID_SANS28X37</code> == 3).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFONT_SANS39X48</code>:
|
|
This option enables support for a large, 39x48 san serif font
|
|
(font <code>ID FONTID_SANS39X48</code> == 4).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFONT_SANS17X23B</code>:
|
|
This option enables support for a tiny, 17x23 san serif bold font
|
|
(font <code>ID FONTID_SANS17X23B</code> == 16).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFONT_SANS20X27B</code>:
|
|
This option enables support for a tiny, 20x27 san serif bold font
|
|
(font <code>ID FONTID_SANS20X27B</code> == 17).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFONT_SANS22X29B</code>:
|
|
This option enables support for a small, 22x29 san serif bold font
|
|
(font ID <code>FONTID_SANS22X29B</code> == 5).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFONT_SANS28X37B</code>:
|
|
This option enables support for a medium, 28x37 san serif bold font
|
|
(font ID <code>FONTID_SANS28X37B</code> == 6).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFONT_SANS40X49B</code>:
|
|
This option enables support for a large, 40x49 san serif bold font
|
|
(font ID <code>FONTID_SANS40X49B</code> == 7).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFONT_SERIF22X29</code>:
|
|
This option enables support for a small, 22x29 font (with serifs)
|
|
(font ID <code>FONTID_SERIF22X29</code> == 8).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFONT_SERIF29X37</code>:
|
|
This option enables support for a medium, 29x37 font (with serifs)
|
|
(font ID <code>FONTID_SERIF29X37</code> == 9).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFONT_SERIF38X48</code>:
|
|
This option enables support for a large, 38x48 font (with serifs)
|
|
(font ID <code>FONTID_SERIF38X48</code> == 10).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFONT_SERIF22X28B</code>:
|
|
This option enables support for a small, 27x38 bold font (with serifs)
|
|
(font ID <code>FONTID_SERIF22X28B</code> == 11).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFONT_SERIF27X38B</code>:
|
|
This option enables support for a medium, 27x38 bold font (with serifs)
|
|
(font ID <code>FONTID_SERIF27X38B</code> == 12).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NXFONT_SERIF38X49B</code>:
|
|
This option enables support for a large, 38x49 bold font (with serifs)
|
|
(font ID <code>FONTID_SERIF38X49B</code> == 13).
|
|
</li>
|
|
</ul>
|
|
|
|
<h3>NX Multi-user only options</h3>
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_NX_BLOCKING</code>
|
|
Open the client message queues in blocking mode. In this case,
|
|
<code>nx_eventhandler()</code> will not return until a message is received and processed.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_NX_MXSERVERMSGS</code> and <code>CONFIG_NX_MXCLIENTMSGS</code>
|
|
Specifies the maximum number of messages that can fit in
|
|
the message queues. No additional resources are allocated, but
|
|
this can be set to prevent flooding of the client or server with
|
|
too many messages (<code>CONFIG_PREALLOC_MQ_MSGS</code> controls how many
|
|
messages are pre-allocated).
|
|
</li>
|
|
</ul>
|
|
|
|
<h2>Stack and heap information</h2>
|
|
|
|
<ul>
|
|
<li>
|
|
<code>CONFIG_BOOT_RUNFROMFLASH</code>: Some configurations support XIP
|
|
operation from FLASH but must copy initialized .data sections to RAM.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_BOOT_COPYTORAM</code>: Some configurations boot in FLASH
|
|
but copy themselves entirely into RAM for better performance.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_BOOT_RAMFUNCS</code>: Other configurations may copy just
|
|
some functions into RAM, either for better performance or for errata workarounds.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_STACK_ALIGNMENT</code>: Set if the your application has specific
|
|
stack alignment requirements (may not be supported in all architectures).
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_IDLETHREAD_STACKSIZE</code>: The size of the initial stack.
|
|
This is the thread that (1) performs the initial boot of the system up
|
|
to the point where <code>CONFIG_USER_ENTRYPOINT</code>() is spawned,
|
|
and (2) there after is the IDLE thread that executes only when there
|
|
is no other thread ready to run.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_USERMAIN_STACKSIZE</code>: The size of the stack to allocate
|
|
for the main user thread that begins at the <code>CONFIG_USER_ENTRYPOINT</code>()
|
|
entry point.
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PTHREAD_STACK_MIN</code>: Minimum pthread stack size
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_PTHREAD_STACK_DEFAULT</code>: Default pthread stack size
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_HEAP_BASE</code>: The beginning of the heap
|
|
</li>
|
|
<li>
|
|
<code>CONFIG_HEAP_SIZE</code>: The size of the heap
|
|
</li>
|
|
</ul>
|
|
|
|
<table width ="100%">
|
|
<tr bgcolor="#e4e4e4">
|
|
<td>
|
|
<h1><a name="apndxtrademarks">Appendix B: Trademarks</a></h1>
|
|
</td>
|
|
</tr>
|
|
</table>
|
|
|
|
<li>ARM, ARM7 ARM7TDMI, ARM9, ARM920T, ARM926EJS, Cortex-M3 are trademarks of Advanced RISC Machines, Limited.</li>
|
|
<li>Cygwin is a trademark of Red Hat, Incorporated.</li>
|
|
<li>Linux is a registered trademark of Linus Torvalds.</li>
|
|
<li>Eagle-100 is a trademark of <a href=" http://www.micromint.com/">Micromint USA, LLC</a>.
|
|
<li>LPC2148 is a trademark of NXP Semiconductors.</li>
|
|
<li>TI is a trade name of Texas Instruments Incorporated.</li>
|
|
<li>UNIX is a registered trademark of The Open Group.</li>
|
|
<li>VxWorks is a registered trademark of Wind River Systems, Incorporated.</li>
|
|
<li>ZDS, ZNEO, Z16F, Z80, and Zilog are a registered trademark of Zilog, Inc.</li>
|
|
|
|
<p>
|
|
NOTE: NuttX is <i>not</i> licensed to use the POSIX trademark. NuttX uses the POSIX
|
|
standard as a development guideline only.
|
|
</p>
|
|
|
|
</body>
|
|
</html>
|
|
|
|
|