Naming and Header File Conventions
- Common Microprocessor Interfaces. Any interface that is common to all microprocessors should be prefixed with - up_and prototyped in- include/nuttx/arch.h. The definitions in that header file provide the common interface between NuttX and the architecture-specific implementation in- arch/.- up_is supposed to stand for microprocessor; the- uis like the Greek letter micron: μ. So it would be- μPwhich is a common shortening of the word microprocessor. I don’t like that name very much. I wish I would have used a more obvious prefix like- arch_instead – then I would not have to answer this question so often.
- Microprocessor-Specific Interfaces. An interface which is unique to a certain microprocessor should be prefixed with the name of the microprocessor, for example - stm32_, and be prototyped in some header file in the- arch/directories.- There is also a - arch/<architecture>/include/<chip>/chip.hheader file that can be used to communicate other microprocessor-specific information between the board logic and even application logic. Application logic may, for example, need to know specific capabilities of the chip. Prototypes in that- chip.hheader file should follow the microprocessor-specific naming convention.
- Common Board Interfaces. Any interface that is common to all boards should be prefixed with - board_and should also be prototyped in- include/nuttx/board.h. These- board_definitions provide the interface between the board-level logic and the commaon and architecture-specific logic.
- Board-Specific Interfaces. Any interface which is unique to a board should be prefixed with the board name, for example - stm32f4discovery_. Sometimes the board name is too long so- stm32_would be okay too. These should be prototyped in- boards/<arch>/<chip>/<board>/src/<board>.hand should not be used outside of that directory since board-specific definitions have no meaning outside of the board directory.
- Scope of Inclusions. Header files are made accessible to internal OS logic and to applications through symbolic links and through include paths that are provided to the C/C++ compiler. Through these include paths, the NuttX build system also enforces modularity in the design. For example, one important design principle is architectural layering. In this case I am referring to the OS as layered into application interface, common internal OS logic, and lower level platform-specific layers. The platform-specific layers all reside in the either - arch/sub-directories or the- boards/subdirectories: The former sub-directories are reserved for microcontroller-specific logic and the latter for board-specific logic.- In the strict, layered NuttX architecture, the upper level OS services are always available to platform-specific logic. However, the opposite is not true: Common OS logic must never have any dependency on the lower level platform-specific code. The OS logic must be totally agnostic about its hardware environment. Similarly, microcontroller-specific logic was be completely ignorant of board-specific logic. - This strict layering is enforced in the NuttX build system by controlling the compiler include paths: Higher level code can never include header files from either of the platform-specific source directories; microcontroller-specific code can never include header files from the board-specific source directories. The board-specific directories are, then, at the bottom of the layered hierarchy. - An exception to these inclusion restrictions is the platform-specific include/. These are made available to higher level OS logic. The microcontroller-specific include directory will be linked at - include/arch/chipand, hence, can be included like- #include <arch/hardware/chip.h. Similarly, the board-specific include directory will be linked at- include/arch/boardand, hence, can be included like- #include <arch/board/board.h.- Keeping in the spirit of the layered architecture, these publicly visible header files must not export platform-specific definitions; Only platform-specific realizations of standardized declarations should be visible. Those standardized declarations should appear in common header files such as those provided by - include/nuttx/arch.hand- include/nuttx/board.h. Similarly, these publicly visible header file must not include files that reside in the inaccessible platform-specific source directories. For example, the board-specific- boards/<arch>/<chip>/<board>/include/board.hheader file must never include microcontroller-specific header files that reside in- arch/<arch>/src/<mcu>. That practice will cause inclusion failures when the publicly visible file is included in common logic outside of the platform-specific source directories.