w8jcik opened a new issue #2206:
URL: https://github.com/apache/incubator-nuttx/issues/2206
## Setup
With following directory structure
```
/base
/nuttx (incubator-nuttx)
/apps (incubator-nuttx-app)
/board (empty folder)
```
```
cd base/nuttx ; ./configure.sh hymini-stm32v:nsh2
```
Bulids and runs.
Then I try to use `CONFIG_ARCH_BOARD_CUSTOM` functionality, with
`hymini-stm32v:nsh2`, by making a copy of it and trying to build NuttX. This
particular board is just an example.
## First attempt
Copied content of
https://github.com/apache/incubator-nuttx/tree/master/boards/arm/stm32/hymini-stm32v
into `/board`.
Using `make menuconfig` selected
```
CONFIG_ARCH_BOARD_CUSTOM=y
CONFIG_ARCH_BOARD_CUSTOM_NAME=custom-board # description says it is not
relevant
CONFIG_ARCH_BOARD_CUSTOM_DIR=../../board
CONFIG_ARCH_BOARD_CUSTOM_DIR_RELPATH=y
```
Issues at this step:
1) If I specify `CONFIG_ARCH_BOARD_CUSTOM_DIR` wrongly, it is not possible
to run `make menuconfig` anymore.
2) If I specify correctly, it is not building.
## Second attempt
I guess `tools/configure.sh` should be used for this somehow
```
tools/configure.sh -h # doesn't give any related help
USAGE: tools/configure.sh [-E] [-e] [-l|m|c|g|n] [L] [-a <app-dir>]
<board-name>:<config-name> [make-opts]
Where:
-E enforces distclean if already configured.
-e performs distclean if configuration changed.
-l selects the Linux (l) host environment.
-m selects the macOS (m) host environment.
-c selects the Windows host and Cygwin (c) environment.
-g selects the Windows host and MinGW/MSYS environment.
-n selects the Windows host and Windows native (n) environment.
Default: Use host setup in the defconfig file
Default Windows: Cygwin
-L Lists all available configurations.
-a <app-dir> is the path to the apps/ directory, relative to the nuttx
directory
<board-name> is the name of the board in the boards directory
configs/<config-name> is the name of the board configuration sub-directory
make-opts directly pass to make
tools/configure.sh ../../board # refuses
File Make.defs could not be found
tools/configure.sh ../../board:nsh2 # refuses
Directory for ../../board:nsh2 does not exist.
tools/configure.sh ../../board/configs/nsh2 # this works, but it is not
consistent with normal usage of this command and absent from help or
documentation
```
It builds, but it just configures `hymini-stm32v:nsh2` as far as I can tell.
So I am changing `/board/configs/nsh2/defconfig`
```diff
-CONFIG_ARCH_BOARD="hymini-stm32v"
-CONFIG_ARCH_BOARD_HYMINI_STM32V=y
+CONFIG_ARCH_BOARD_CUSTOM=y
+CONFIG_ARCH_BOARD_CUSTOM_NAME=custom-board
+CONFIG_ARCH_BOARD_CUSTOM_DIR=../../board
+CONFIG_ARCH_BOARD_CUSTOM_DIR_RELPATH=y
```
It is not building afterwards.
```
make distclean
tools/configure.sh ../../board/configs/nsh2
```
```
make[2]: Nothing to be done for 'clean_context'.
make[2]: Leaving directory '/home/user/dev/project/base/nuttx/arch/arm/src'
make[1]: Leaving directory '/home/user/dev/project/base/nuttx/tools'
make[1]: Leaving directory '/home/user/dev/project/base/nuttx'
Create version.h
LN: include/arch to arch/arm/include
LN: arch/arm/src/board to /home/user/dev/project/base/nuttx//src
LN: arch/arm/src/chip to arch/arm/src/stm32
LN: /home/user/dev/project/base/nuttx/drivers/platform to
/home/user/dev/project/base/nuttx/drivers/dummy
No directory at /home/user/dev/project/base/nuttx//src
make: *** [tools/Makefile.unix:293: arch/arm/src/board] Error 1
```
## Conclusion
This functionality is difficult to use.
Receipe for doing this is missing from documentation.
I am not sure what I am missing, analysed Makefiles a bit and searched
through different mailing lists of NuttX with some solutions present there, but
it doesn't help me solve this. It would be great if it would be easier.
Reading this doesn't help
-
https://nuttx.apache.org/docs/latest/quickstart/organization.html#boardsdirectorystructure
- https://cwiki.apache.org/confluence/display/NUTTX/Platform+Directories
----------------------------------------------------------------
This is an automated message from the Apache Git Service.
To respond to the message, please log on to GitHub and use the
URL above to go to the specific comment.
For queries about this service, please contact Infrastructure at:
[email protected]