mirror of
https://github.com/apache/nuttx.git
synced 2025-01-13 02:48:37 +08:00
953f46426e
to NuttX.
112 lines
4 KiB
Markdown
112 lines
4 KiB
Markdown
# The Inviolable Principles of NuttX
|
||
|
||
These are properties of NuttX that we can be certain of for all time:
|
||
|
||
## Definition
|
||
|
||
*in·vi·o·la·ble*
|
||
/inˈvīələbəl/
|
||
|
||
adjective
|
||
adjective: inviolable
|
||
|
||
never to be broken, infringed, or dishonored.
|
||
|
||
"an inviolable rule of chastity"
|
||
|
||
synonyms: inalienable, absolute, untouchable, unalterable,
|
||
unchallengeable, unbreakable, impregnable; sacrosanct,
|
||
sacred, holy, hallowed; rare intemerate
|
||
|
||
"the inviolable right to life"
|
||
|
||
Source: Oxford Dictionary of the English Language
|
||
|
||
## Strict POSIX compliance
|
||
|
||
- Strict conformance to the portable standard OS interface as defined at
|
||
OpenGroup.org.
|
||
- A deeply embedded system requires some special support. Special
|
||
support must be minimized.
|
||
- The portable interface must never be compromised only for the sake of
|
||
expediency.
|
||
- Expediency or even improved performance are not justifications for
|
||
violation of the strict POSIX interface.
|
||
|
||
## Modular Architecture
|
||
|
||
- The internal modular architecture of the OS must be maintained.
|
||
- This means formalizing and documenting all internal interfaces (in the
|
||
porting guide), minimal use of global variables at the interface, and
|
||
only well defined functional interfaces.
|
||
|
||
## Clear, Consistent, Standardized Coding Style
|
||
|
||
- Strict conformance to the NuttX coding style. No "revolutionary"
|
||
changes to the coding standard (but perhaps some "evolutionary"
|
||
changes).
|
||
- Personal or organizational preference is not a justification for a
|
||
coding style change.
|
||
- Nothing can come into NuttX that does not follow the coding standard.
|
||
- Expediency is not a justification for violating the coding standard.
|
||
|
||
The NuttX coding standard can be found here:
|
||
https://nuttx.apache.org/docs/latest/contributing/coding_style.html
|
||
|
||
## Open and Unencumbered License
|
||
|
||
- Currently BSD 3-clause or compatible: BSD 3-clause with constraints,
|
||
BSD 3 and 4 clause, MIT, public domain.
|
||
- Other unencumbered licenses such as Apache may be considered.
|
||
NuttX will never be licensed under a restrictive, "Copyleft" license.
|
||
|
||
## All Users Matter
|
||
|
||
- All support must apply equally to all supported platforms. At present
|
||
this includes Linux, Windows MSYS, Windows Cygwin, Windows Ubuntu,
|
||
Windows native, macOS, Solaris, and FreeBSD. No tool/environment
|
||
solutions will be considered that limit the usage of NuttX on any of
|
||
the supported platforms.
|
||
- Inclusive rather than exclusive.
|
||
- Hobbyists are valued users of the OS including retro computing hobbyists
|
||
and DIY “Maker” hobbyists.
|
||
- Supported toolchains: GCC, Clang, SDCC, ZiLOG ZDS-II (c89), IAR.
|
||
Others?
|
||
- No changes to build system should limit use of NuttX by any user.
|
||
- Simplifying things for one user does not justify excluding another user.
|
||
- We should seek to expand the NuttX user base, not to limit it for
|
||
reasons of preference or priority.
|
||
- We must resist the pull to make NuttX into a Linux-only, GCC-only, and
|
||
ARM-only solution.
|
||
|
||
## NuttX Branding
|
||
|
||
- The official name of authentic NuttX will always be "NuttX".
|
||
- This name is trademarked and may not be used by other OSs or forks of
|
||
NuttX.
|
||
|
||
## The Enemies
|
||
|
||
### No Short Cuts
|
||
|
||
- Doing things the easy way instead of the correct way.
|
||
- Reducing effort at the expense of Quality, Portability, or
|
||
Consistency.
|
||
- Focus on the values of the organization, not the values of the Open
|
||
Source project. Need to support both.
|
||
- It takes work to support the Inviolables. There are no shortcuts.
|
||
|
||
### Sometimes Code Duplication is OK
|
||
|
||
- Sometimes is better to duplicate some logic than to introduce coupling.
|
||
|
||
### Keep the Big Picture
|
||
|
||
- Too much focus on solving the problem in hand, loss of the Big Picture.
|
||
- Insufficient understanding of the architectural principles.
|
||
|
||
### Conform to Standards
|
||
|
||
- Changing things only to suit a personal or organizational preference.
|
||
- Inflexibility, Inability to adapt.
|
||
- Not Invented Here (NIH) syndrome.
|